これは Delphi Advent Calendar 2017 の 13 日目の記事です。
また、これは以前 EDN に投稿した記事のリライトです。
実行環境は 10.2 Tokyo Release 1, Nexus 5, Android 5.1.1 で確認してます。
Delphi/C++Builder にはアプリ内の文字列を翻訳するための TLang コンポーネントが用意されています。
ただし、これはあくまでアプリ内の文字列の翻訳だけで、デバイス上に表示されるパッケージ名 (アプリ名) の翻訳までは行ないません。
Android 上でのローカライズに関しては Android Developers のリファレンスのルールに従って
- ロケールフォルダを作成する
- 文字列ファイルを作成する
事と、Delphi/C++Builder 側での
- プロジェクトオプションの書き換え
- 配置情報に文字列ファイルを含める
が必要です。
##はじめにやること
- Delphi/C++Builder でクロスプラットフォームアプリケーションを作る
- フォルダを作って、そのフォルダ以下にプロジェクト等を保存しておくと作業がやりやすい
- 作ったアプリケーションは Android プラットホームを選択して、少なくとも1回はビルドしておく ( 後の工程で自動生成されたファイルを使うため )
##ロケールフォルダを作成する
プロジェクト等を保存しているフォルダに values, values-fr (ロケール:フランス) フォルダを作成します。
( ロケール:日本なら values-ja というフォルダを作成 )
ちなみに values は、翻訳文字列が用意されていない場合に表示されるものを指定するところです。
##文字列ファイルを作成する
翻訳文字列を定義する strings.xml を作成します。
この際注意しなければならないのは「改行コード」です。
XML の改行コードは LF しか使用できません。Windows の改行コード(CR LF) で作成してしまうと、デバイスに配置する際にエラーが発生してしまいます。
チェックのために、まずはエディタの表示オプションを設定します。
IDE のメニューから [ツール|オプション] を選び、エディタ設定のソースオプションで XML に関する設定で「改行の表示」のチェックボックスにチェックをつけておきます。
Delphi/C++Builder のエディタで xml ファイルを開いたときの改行が
なら LF なので OK
ビルドしたときに自動的に作成された \Android\Debug(またはRelease) フォルダ以下にある splash_image_def.xml ファイルを strings.xml という名前で、各ロケールフォルダ以下にコピーして修正すると改行コードが正しい状態で作成できます。
values フォルダ以下の strings.xml ファイルを次のように記載します。
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">L10Base</string>
</resources>
values-fr フォルダ以下の strings.xml ファイルは
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">L10FR</string>
</resources>
values-ja フォルダ以下の strings.xml ファイルは
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">L10JR</string>
</resources>
とそれぞれ記述します (日本語用のは JA とすべきところが JR にしてしまった....)
なお、string name で設定する文字列リソース名を、ここでは分かりやすいように「app_name」としています。後のステップで出てくるリソース名と同じで、かつ、予約語に被らなければ OK です。
##プロジェクトオプションの書き換え
文字列ファイルに設定した文字列がアプリ名に反映されるように、プロジェクトオプションを修正します。
IDE のメニューから [プロジェクト|オプション] を選び、アプリケーションの「バージョン情報」を選択します。
Android プラットフォームで、label キーの値を $(ModduleName) から @string/app_name に変更します。
##配置情報に文字列ファイルを含める
アプリをデバイスに配置する際の構成に文字列ファイルを含めます。
IDE のメニューから [プロジェクト|配置] を選び、配置マネージャを表示します。
Android プラットフォームで、values, value-xx のリモートパスを .\assets\internal から res\values, res\values-xx\ に書き換えます。
以下のスクリーンショットを参考にすると分かりやすいと思います。
これで準備完了!お疲れ様でした!
##実際どうなるかというと
###言語 : 日本語
(values-ja フォルダ以下の strings.xml ファイル内で指定した L10JR が表示される)
###言語 : フランス語
(values-fr フォルダ以下の strings.xml ファイル内で指定した L10FR が表示される)
###言語 : 英語
(ロケールフォルダが無いので、values フォルダ以下の strings.xml ファイル内で指定した L10Base が表示される)