チュートリアル : サテライト アセンブリからのリソースの読み込み
このチュートリアルでは、WPF Designer for Visual Studio を使用してサテライト アセンブリからリソース文字列を読み込む方法を説明します。 これによって、WPF アプリケーションのローカライズが容易になります。
このチュートリアルでは次のタスクを行います。
プロジェクトを作成する。
サテライト アセンブリを有効にする。
リソース文字列を作成し、これにアクセスする。
ここでは、サテライト アセンブリから文字列を取得する簡単なアプリケーションを作成します。
注意
実際に画面に表示されるダイアログ ボックスとメニュー コマンドは、アクティブな設定またはエディションによっては、ヘルプの説明と異なる場合があります。 設定を変更するには、[ツール] メニューの [設定のインポートとエクスポート] をクリックします。 詳細については、「設定の操作」を参照してください。
必須コンポーネント
このチュートリアルを実行するには、次のコンポーネントが必要です。
- Visual Studio 2010.
プロジェクトの作成
最初にアプリケーションのプロジェクトを作成します。
プロジェクトを作成するには
Visual Basic または Visual C# で ResourceTest という名前の新しい WPF アプリケーション プロジェクトを作成します。 詳細については、「方法 : 新しい WPF アプリケーション プロジェクトを作成する」を参照してください。
WPF デザイナーで MainWindow.xaml が開きます。
ツールボックスからデザイン サーフェイスに Button コントロールをドラッグします。
このボタンをダブルクリックして、このボタン コントロールの Click イベント ハンドラーを作成します。
サテライト アセンブリの有効化
AssemblyInfo ファイルおよびプロジェクト ファイルに小さな変更を行うことによって、サテライト アセンブリを有効にします。
サテライト アセンブリを有効にするには
コード エディターで AssemblyInfo.cs または AssemblyInfo.vb を開きます。 ソリューション エクスプローラーでこれらのファイルを表示するには、[すべてのファイルを表示] をクリックする必要がある場合もあります。
次の行のコメントを解除します。
//[assembly: NeutralResourcesLanguage("en-US", UltimateResourceFallbackLocation.Satellite)]
'<Assembly: NeutralResourcesLanguage("en-US", UltimateResourceFallbackLocation.Satellite)>
ソリューションを保存します。
ソリューション エクスプローラーで、ResourceTest プロジェクトを右クリックし、[プロジェクトのアンロード] をクリックします。
Visual Studio で ResourceTest プロジェクトがアンロードされます。
ソリューション エクスプローラーで、ResourceTest プロジェクトを右クリックし、[ResourceTest.csproj の編集] または [ResourceTest.vbproj の編集] をクリックします。
XML エディターでプロジェクト ファイルが開きます。
次の XML を、他の <PropertyGroup> 要素と同じレベルに挿入します。
<PropertyGroup> <UICulture>en-US</UICulture> </PropertyGroup>
ファイルを保存して閉じます。
ソリューション エクスプローラーで、ResourceTest プロジェクトを右クリックし、[プロジェクトの再読み込み] をクリックします。
ソリューション エクスプローラーで、既定の RESX ファイルの名前を Resources.resx から Resources.en-US.resx に変更します。
[プロパティ] ウィンドウで、リソース ファイルの [カスタム ツール] の値を削除します。
サテライト アセンブリ内のリソース文字列の作成
ここで、リソース ファイル内に文字列を作成します。
サテライト アセンブリ内のリソース文字列を作成するには
ソリューション エクスプローラーで、Resources.en-US.resx をダブルクリックします。
リソース デザイナーで Resources.en-US.resx が開きます。
既定の文字列の名前を String1 から helloWorldString に変更します。
helloWorldString の値を Hello world に変更します。
変更を保存し、リソース エディターを終了します。
リソース文字列へのアクセス
ResourceManager クラスを使用して、サテライト アセンブリ内の文字列にアクセスします。
リソース文字列にアクセスするには
コード エディターで MainWindow.xaml.cs または MainWindow.xaml.vb を開きます。
MainWindow.xaml.cs または MainWindow.xaml.vb の先頭に次のコードを挿入します。
using System.Reflection; using System.Resources;
Imports System.Reflection Imports System.Resources
button1_Click イベント ハンドラー内に次のコードを挿入します。
ResourceManager rm = new ResourceManager( "ResourceTest.Properties.Resources", Assembly.GetExecutingAssembly()); MessageBox.Show(rm.GetString("helloWorldString"));
Dim rm As New ResourceManager( _ "ResourceTest.Resources", _ Assembly.GetExecutingAssembly()) MessageBox.Show(rm.GetString("helloWorldString"))
F5 キーを押してアプリケーションをビルドし、実行します。
ボタンをクリックして、サテライト リソースから読み込まれた文字列値を確認します。
Debug/en-US フォルダーを開き、ResourceTest.resources.dll という名前のサテライト アセンブリを確認します。