![]() |
Модераторы: LSD, AntonSaburov |
![]() ![]() ![]() |
|
LSD |
|
||||||||||
![]() Leprechaun Software Developer ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 15718 Регистрация: 24.3.2004 Где: Dublin Репутация: 210 Всего: 538 |
Локализация приложений.
Локализация - переработка существующего программного продукта с целью использования его в странах с другим языком. Локализацию включает в себя адаптацию пользовательского интерфейса: система ввода-вывода текста (например ввод текста справо-налево, поддержка соответсвующей раскладки клавиатуры), расположение управляющих элементов (например кнопки в диалогах ориентированны в соответсвии с направлением ввода текста), перевод текстовых сообщений системы. В данной статье рассматривается проблемы перевода текстовых сообщений. Один из основных для локализации классов, это java.util.Locale. Этот класс описывает текущую локаль, локаль - это описание текущего региона, языка и других особенностей. Класс Locale предназначен только для идентификации локали, никаких данных для локализации он не содержит. Самый главный параметр это используемый язык, второй по значимости параметр это страна, и третий параметр это вариант. Вариант не имеет какого-то определенного смысла и предназначен для указания некой дополнительной информации, не описываемой первыми двумя параметрами, например диалекта. Как правило вариант не используется. Из всех параметров обязательным является только язык. Параметр страна является опциональным и предназначен для указания страны пользователя. Язык описывается двухбуквенным кодом ISO 639, код записывается в нижнем регистре. Страна обозначается двухбуквенным кодом ISO-3166, код записывается в верхнем регистре. Получить список языков и стран можно с помощью Locale.getISOLanguages() и Locale.getISOCountries() соответсвенно. Хотя никаких ограничений на вариант не накладывается, для варианта лучше придерживаться правил формирования идентификаторов в Java, иначе некоторые механизмы могут не работать или работать неправильно. Задача: создать локаль для описания русского языка на Украине:
Локаль по умолчанию устанавливается исходя из установок ОС, получить ее можно Locale.getDefault(). Переопределить локаль по умолчанию можно из кода Locale.setDefault(locale), из командной строки запуска: -Duser.language=ru -Duser.country=RU. Для преобразования чисел, дат и сообщений в строковое представление служал форматтеры (см. java.text.Format), они все поддерживают конструкторы с указанием локали, чтобы форматировать в соответсвии с текущей локалью. Эти классы можно использовать без доработки, они полностью локализованы. Единствеено но, может потребоваться написание своего ResourceBundle для поддержки "экзотического" языка или диалекта. Основная нагрузка по локализации приложений ложится на класс ResourceBundle. Данный класс умеет загружать ресурсы для указанной локали. Для загрузки ресурсов используется ResourceBundle.getBundle(<name>, <locale>, <classLoader>), где:
Задача: загрузить ResourceBundle и отобразить локализованное сообщение об ошибке.
Ресурсы загружаемые ResourceBundle могут хранится либо в текстовых файлах, организованных наподобие properties, либо в виде классов унаследованных от ListResourceBundle (именно отсюда идет требование к именам ресурсов). Ресурсы реализованные в виде наследников ListResourceBundle быстрее загружаются, позволяют хранить не только строки но любые объекты, но для локализации приложения нужен исходный код классов и компилятор. В то время как ResourceBundle реализованные в виде файлов properties могут быть локализованы в любом текстовом редакторе (может понадобится утилита native2ascii). Загрузка ресурсов происходит следующим образом: формируются потенциальные имена для ResourceBundle:
Задача: реализовать приложение с поддержкой русского и английского языков, в качестве умолчального выбрать английский Приложение:
Умольчальный ResourceBundle (он же английский)
ResourceBundle для русского языка
P.S. Как обычно замечания и предложения приветствуются ![]() Если кто переведет текст на еще какой нибудь язык, я покажу как создавать ResourceBundle в виде properties. -------------------- Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it. |
||||||||||
|
|||||||||||
carper |
|
|||
Бывалый ![]() Профиль Группа: Участник Сообщений: 227 Регистрация: 2.3.2005 Репутация: 1 Всего: 8 |
LSD
Во-первых, большое спасибо за статью. Во-вторых, не совсем понятно как свой ResourceBundle может помочь с экзотическими форматами, скажем, даты. Мне казалось, что в таких случаях надо создавать свой форматтер? Да, что касается файлов properties. Что-то их необходимость, с учетом их 7-и значной кодировки и извращений при добавлении символов других языков, представляется более чем сомнительной. Тем более, что не вижу какие препятствия и сложности могут возникнуть у переводчика при правке наследника ListResourceBundle? Его дело перевести, а вызов javac ..., особенно с учетом того, что переводить не глядя на получившийся результат нельзя, т.е. все равно переводчику придется устанавливать JAVA, ну не понятно как можно не откомпилировать один класс? В крайнем случае скройте эту часть работы от переводчика. ![]() |
|||
|
||||
LSD |
|
||||
![]() Leprechaun Software Developer ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 15718 Регистрация: 24.3.2004 Где: Dublin Репутация: 210 Всего: 538 |
Я говорил не о формате даты, а о языке. Например хочешь ты писать дату на латыни.
Вообщем да, например Sun полностью перешла на ListResourceBundle. -------------------- Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it. |
||||
|
|||||
carper |
|
|||
Бывалый ![]() Профиль Группа: Участник Сообщений: 227 Регистрация: 2.3.2005 Репутация: 1 Всего: 8 |
LSD
Ну, тогда, только остается еще раз поблагодарить за понятную и полезную статью, думаю, что она и так вполне полноценна и без описания properties. Да, почему-то на форумах SUN постоянно тусуется народ с одной и той же проблемой, а именно, у SUN как-то странно описано понятие базового имени класса-наследника ListResourceBundle и многие пытаются задавать base name не указывая имя пакета. Может стоит как-то это акцентировать? И еще, мне кажется использование ResourceBundle, благодаря возможности использовать объекты, дает довольно интересную (хотя и не полностью заменяет) альтернативу таким вещам как Enum для хранения стандартных настроек. Или это не целесообразно, все же нет такого контроля? |
|||
|
||||
LSD |
|
|||
![]() Leprechaun Software Developer ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 15718 Регистрация: 24.3.2004 Где: Dublin Репутация: 210 Всего: 538 |
Enum это скорее альтернатива public static final константам. Хранить объекты можно, только надо учитывать, что сколько локалей поддерживается столько объектов может быть порождено. Т.е. если у тебя одна картинка на все языки то класть ее в ResourceBundle не разумно, а вот если ты ее можешь менянять в зависимости от языка, то тогда вполне. -------------------- Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it. |
|||
|
||||
PashaOvechkin |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 394 Регистрация: 1.4.2007 Где: Riga, Latvia Репутация: 2 Всего: 4 |
Хорошая статья!
![]() Но веселей становится когда нужно сменить язык в ран тайме. |
|||
|
||||
w1nd |
|
|||
![]() Вертилятор ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1077 Регистрация: 22.3.2006 Где: Москва Репутация: 20 Всего: 54 |
Всё равно файлы properties удобнее. Я сам долгое время пользовался ListResourceBundle, но отсутствие необходимости перекомпиляции (и - главное - пересборки) дорогого стоит, так что теперь у меня только .properties. И нельзя упереться в ограничение на размер .class-файла. -------------------- ![]() ![]() |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Java" | |
|
Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Java: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |