今回はSwiftUIのText等を使った際の Localization の方法を説明します。
とは言ってもUIKitとほとんど変わりません。
1- プロジェクトにLocalizationを追加
まずはプロジェクトに必要な言語の追加をします。
プロジェクトのLocalizationの項目にある”+”ボタンを押すと言語の一覧が表示されます。必要な言語を選択して追加しましょう。今回は日本語を追加します。
data:image/s3,"s3://crabby-images/758aa/758aa39dd6a1fba4cc1c8b0e62bce2e2950c5b7b" alt=""
data:image/s3,"s3://crabby-images/1616e/1616ec62f3626de40684041e31df26d0cddfcb12" alt=""
2- Localizable.strings ファイルの作成
Localizable.stringファイルを作りましょう。
Xcodeの「New Flie… 」からStringsファイルを選択し、 Localizable.stringsというファイル名で保存します。
data:image/s3,"s3://crabby-images/bda06/bda066bde0588797f6c6211bea1f8f9c297f2646" alt=""
data:image/s3,"s3://crabby-images/292c7/292c71c5f526643cd10b5ea8637f5b75ee3944fc" alt=""
作成されたLocalizable.stringsを選択した状態で、Xcode右側のFile Inspectorの”Localize…”を押します。
data:image/s3,"s3://crabby-images/1083d/1083d46c3dbc9429451dbe9f8ccf9ca3e615ab8b" alt=""
そして追加したい言語を選択します。
data:image/s3,"s3://crabby-images/6bef3/6bef354df881895821f9fce00bb00d28cc7d45ad" alt=""
あとは以下のようにテキストを記述していくだけです。
"hello" = "こんにちは";
言語を追加したい場合は、Localizable.stringを表示し、右側のLocalizationから追加した言語にチェックを入れてください。
data:image/s3,"s3://crabby-images/ae0f2/ae0f25d254fb71fd5098d40b8547804e512c9709" alt=""
するとこのように言語ごとのstringファイルが作成されます。
data:image/s3,"s3://crabby-images/75735/757355d2f6c5fe4647f4d9315fc079f9bddb538c" alt=""
3- ローカライズされたテキストを表示
SwiftUIにおいて文字列指定されたテキストは、ローカライズキーとして扱われます。つまり特別なことをしなくてもローカライズされて表示されます。以下のようなレイアウトを言語設定が日本語の端末で表示すると、
struct ContentView: View {
var body: some View {
VStack {
Text("hello")
.padding()
}
}
}
data:image/s3,"s3://crabby-images/bd059/bd059f19c2290642b23a1353b424c9435c015293" alt=""
このようにローカライズされたテキストが表示されます。
質問、間違っている点などありましたらコメントください。
コメント