Compartilhar via


Demonstra Passo a passo: Localização de um aplicativo híbrido

This walkthrough shows you how to localize WPF elements in a Windows Forms-based hybrid application.

Tarefas ilustradas nesta explicação passo a passo incluem:

  • Creating the Windows Forms host project.

  • Adding localizable content.

  • Enabling localization.

  • Assigning resource identifiers.

  • Using the LocBaml tool to produce a satellite assembly.

For a complete code listing of the tasks illustrated in this walkthrough, see Localizando um exemplo de aplicativo híbrido.

When you are finished, you will have a localized hybrid application.

Observação As caixas de diálogo e comandos de menu você vê podem diferir daqueles descritos na ajuda dependendo de suas configurações ativas ou versão. Para alterar as configurações, escolher Importar e exportar configurações on the Ferramentas menu. Para obter mais informações, consulte Configurações do Visual Studio.

Pré-requisitos

Para completar este passo a passo, são necessários os seguintes componentes:

  • Visual Studio 2008.

Creating the Windows Forms Host Project

The first step is to create the Windows Forms application project and add a WPF element with content that you will localize.

To create the host project

  1. Create a WPF Application project named LocalizingWpfInWf. Para obter mais informações, consulte Como: Criar um projeto de aplicativo do Windows.

  2. Add a WPF UserControl element called SimpleControl to the project.

  3. Use the ElementHost control to place a SimpleControl element on the form. Para obter mais informações, consulte Demonstra Passo a passo: Hospedagem de um controle Windows Presentation Foundation composto do Windows Forms.

Adding Localizable Content

Next, you will add a Windows Forms label control and set the WPF element's content to a localizable string.

To add localizable content

  1. In Solution Explorer, double-click SimpleControl.xaml to open it in the WPF Designer.

  2. Set the content of the Button control using the following code.

  3. In Solution Explorer, double-click Form1 to open it in the Windows Forms Designer.

  4. Open the Toolbox and double-click Label to add a label control to the form. Set the value of its Text property to "Hello".

  5. Pressione F5 para criar e executar o aplicativo.

    Both the SimpleControl element and the label control display the text "Hello".

Enabling Localization

The Windows Forms Designer provides settings for enabling localization in a satellite assembly.

To enable localization

  1. In Solution Explorer, double-click Form1.cs to open it in the Windows Forms Designer.

  2. In the Properties window, set the value of the form's Localizable property to true.

  3. In the Properties window, set the value of the Language property to Spanish (Spain).

  4. In the Windows Forms Designer, select the label control.

  5. In the Properties window, set the value of the Text property to "Hola".

    A new resource file named Form1.es-ES.resx is added to the project.

  6. In Solution Explorer, right-click Form1.cs and click View Code to open it in the Code Editor.

  7. Copy the following code into the Form1 constructor, preceding the call to InitializeComponent.

  8. In Solution Explorer, right-click LocalizingWpfInWf and click Unload Project.

    The project name is labeled (unavailable).

  9. Right-click LocalizingWpfInWf, and click Edit LocalizingWpfInWf.csproj.

    The project file opens in the Code Editor.

  10. Copy the following line into the first PropertyGroup in the project file.

    <UICulture>en-US</UICulture> 
    
  11. Save the project file and close it.

  12. In Solution Explorer, right-click LocalizingWpfInWf and click Reload Project.

Assigning Resource Identifiers

You can map your localizable content to resource assemblies by using resource identifiers. The MsBuild.exe application automatically assigns resource identifiers when you specify the updateuid option.

To assign resource identifiers

  1. From the Start Menu, open the Visual Studio Command Prompt.

  2. Use the following command to assign resource identifiers to your localizable content.

    msbuild /t:updateuid LocalizingWpfInWf.csproj
    
  3. In Solution Explorer, double-click SimpleControl.xaml to open it in the Code Editor. You will see that the msbuild command has added the Uid attribute to all the elements. This facilitates localization through the assignment of resource identifiers.

  4. Press F6 to build the solution.

Using LocBaml to Produce a Satellite Assembly

Your localized content is stored in a resource-only satellite assembly. Use the command-line tool LocBaml.exe to produce a localized assembly for your WPF content.

To produce a satellite assembly

  1. Copy LocBaml.exe to your project's obj\Debug folder. Para obter mais informações, consulte Como: Localizar um Aplicativo.

  2. In the Command Prompt window, use the following command to extract resource strings into a temporary file.

    LocBaml /parse LocalizingWpfInWf.g.en-US.resources /out:temp.csv
    
  3. Open the temp.csv file with Visual Studio or another text editor. Replace the string "Hello" with its Spanish translation, "Hola".

  4. Save the temp.csv file.

  5. Use the following command to generate the localized resource file.

    LocBaml /generate /trans:temp.csv LocalizingWpfInWf.g.en-US.resources /out:. /cul:es-ES
    

    The LocalizingWpfInWf.g.es-ES.resources file is created in the obj\Debug folder.

  6. Use the following command to build the localized satellite assembly.

    Al.exe /out:LocalizingWpfInWf.resources.dll /culture:es-ES /embed:LocalizingWpfInWf.Form1.es-ES.resources /embed:LocalizingWpfInWf.g.es-ES.resources
    

    The LocalizingWpfInWf.resources.dll file is created in the obj\Debug folder.

  7. Copy the LocalizingWpfInWf.resources.dll file to the project's bin\Debug\es-ES folder. Replace the existing file.

  8. Run LocalizingWpfInWf.exe, which is located in your project's bin\Debug folder. Do not rebuild the application or the satellite assembly will be overwritten.

    The application shows the localized strings instead of the English strings.

Consulte também

Tarefas

Demonstra Passo a passo: Localizando Windows Forms

Conceitos

Como: Localizar um Aplicativo

Referência

ElementHost

WindowsFormsHost

Outros recursos

WPF Designer

Tópicos de "Como Fazer" migração e interoperabilidade