Udostępnij za pośrednictwem


StronglyTypedResourceBuilder Klasa

Definicja

Zapewnia obsługę silnie typiowanych zasobów. Klasa ta nie może być dziedziczona.

public ref class StronglyTypedResourceBuilder abstract sealed
public static class StronglyTypedResourceBuilder
type StronglyTypedResourceBuilder = class
Public Class StronglyTypedResourceBuilder
Dziedziczenie
StronglyTypedResourceBuilder

Przykłady

Poniższy przykład generuje klasę o nazwie DemoResources napisanej w języku C# lub Visual Basic (w zależności od kodu źródłowego przykładu). Ta klasa znajduje się w DemoApp przestrzeni nazw i ma właściwości zwracające mapę bitową logo i nazwę aplikacji. Przykład wywołuje metodę w celu utworzenia CreateResourceFile niezbędnego pliku resw i wymaga znalezienia pliku mapy bitowej o nazwie Logo.bmp w bieżącym katalogu przykładu. Przykładowy kod używa następującego pliku zasobu o nazwie demo.resx:

using Microsoft.CSharp;
using System;
using System.CodeDom;
using System.CodeDom.Compiler;
using System.Drawing;
using System.IO;
using System.Resources;
using System.Resources.Tools;

public class Example
{
   public static void Main()
   {
      CreateResXFile();
      
      StreamWriter sw = new StreamWriter(@".\DemoResources.cs");
      string[] errors = null;
      CSharpCodeProvider provider = new CSharpCodeProvider();
      CodeCompileUnit code = StronglyTypedResourceBuilder.Create("Demo.resx", "DemoResources", 
                                                                 "DemoApp", provider, 
                                                                 false, out errors);    
      if (errors.Length > 0)
         foreach (var error in errors)
            Console.WriteLine(error); 

      provider.GenerateCodeFromCompileUnit(code, sw, new CodeGeneratorOptions());                                         
      sw.Close();
   }

   private static void CreateResXFile()
   {
      Bitmap logo = new Bitmap(@".\Logo.bmp");

      ResXResourceWriter rw = new ResXResourceWriter(@".\Demo.resx");
      rw.AddResource("Logo", logo); 
      rw.AddResource("AppTitle", "Demo Application");
      rw.Generate();
      rw.Close();
   }
}
Imports System.CodeDom
Imports System.CodeDom.Compiler
Imports System.Drawing
Imports System.IO
Imports System.Resources
Imports System.Resources.Tools

Module Example
   Public Sub Main()
      CreateResXFile()
      
      Dim sw As New StreamWriter(".\DemoResources.vb")
      Dim errors() As String = Nothing
      Dim provider As New VBCodeProvider()
      Dim code As CodeCompileUnit = StronglyTypedResourceBuilder.Create("Demo.resx", "DemoResources", 
                                                                        "DemoApp", provider, 
                                                                        false, errors)    
      If errors.Length > 0 Then
         For Each [error] In errors
            Console.WriteLine([error]) 
         Next
      End If
      provider.GenerateCodeFromCompileUnit(code, sw, New CodeGeneratorOptions())                                         
      sw.Close()
   End Sub
   
   Private Sub CreateResXFile()
      Dim logo As New Bitmap(".\Logo.bmp")

      Dim rw As New ResXResourceWriter(".\Demo.resx")
      rw.AddResource("Logo", logo) 
      rw.AddResource("AppTitle", "Demo Application")
      rw.Generate()
      rw.Close()
   End Sub
End Module

Kod aplikacji może następnie użyć klasy w następujący sposób:

this.Text = DemoApp.DemoResources.AppTitle;
System.Drawing.Bitmap bmp = DemoApp.DemoResources.Logo;
Me.Text = DemoApp.DemoResources.AppTitle
Dim bmp As System.Drawing.Bitmap = DemoApp.DemoResources.Logo

Uwagi

Zazwyczaj zasoby oddzielają kod od zawartości w aplikacji. Tworzenie i korzystanie z tych zasobów ułatwia opracowywanie aplikacji lokalizowalnych. W .NET Framework zasoby są zwykle używane przy użyciu ResourceManager klasy, która zawiera metody zapewniające dostęp do zasobów specyficznych dla kultury w czasie wykonywania. Aby uzyskać więcej informacji na temat tworzenia i używania zasobów, zobacz Zasoby w aplikacjach klasycznych.

Silnie typizowane obsługa zasobów to funkcja czasu kompilacji, która hermetyzuje dostęp do zasobów, tworząc klasy zawierające zestaw statycznych właściwości tylko do odczytu (get). Zapewnia to alternatywny sposób korzystania z zasobów zamiast wywoływania ResourceManager.GetString metod i ResourceManager.GetObject .

Podstawową funkcją obsługi silnie typizowanego zasobu jest StronglyTypedResourceBuilder klasa (a także /str opcja wiersza polecenia w Resgen.exe (generator plików zasobów)). Dane wyjściowe Create metody to klasa, która zawiera silnie typizowane właściwości zgodne z zasobami, do których odwołuje się parametr wejściowy. Ta klasa zapewnia dostęp tylko do odczytu do zasobów, które są dostępne w przetworzonym pliku.

Metody

Create(IDictionary, String, String, CodeDomProvider, Boolean, String[])

Generuje plik klasy, który zawiera silnie typizowane właściwości zgodne z zasobami, do których odwołuje się określona kolekcja.

Create(IDictionary, String, String, String, CodeDomProvider, Boolean, String[])

Generuje plik klasy, który zawiera silnie typizowane właściwości zgodne z zasobami, do których odwołuje się określona kolekcja.

Create(String, String, String, CodeDomProvider, Boolean, String[])

Generuje plik klasy, który zawiera silnie typizowane właściwości zgodne z zasobami w określonym pliku resx.

Create(String, String, String, String, CodeDomProvider, Boolean, String[])

Generuje plik klasy, który zawiera silnie typizowane właściwości zgodne z zasobami w określonym pliku resx.

VerifyResourceName(String, CodeDomProvider)

Generuje prawidłowy ciąg zasobu na podstawie określonego ciągu wejściowego i dostawcy kodu.

Dotyczy