Thread.CurrentUICulture Tulajdonság
Definíció
Fontos
Egyes információk olyan, kiadás előtti termékekre vonatkoznak, amelyek a kiadásig még jelentősen módosulhatnak. A Microsoft nem vállal kifejezett vagy törvényi garanciát az itt megjelenő információért.
Lekéri vagy beállítja a Resource Manager által használt jelenlegi kultúrát, hogy futásidőben kultúrkultúra-specifikus erőforrásokat keressen.
public:
property System::Globalization::CultureInfo ^ CurrentUICulture { System::Globalization::CultureInfo ^ get(); void set(System::Globalization::CultureInfo ^ value); };
public System.Globalization.CultureInfo CurrentUICulture { get; set; }
member this.CurrentUICulture : System.Globalization.CultureInfo with get, set
Public Property CurrentUICulture As CultureInfo
Tulajdonság értéke
Az aktuális kultúrát jelképező objektum.
Kivételek
A tulajdonság értéke .null
A tulajdonság olyan kulturális névre van beállítva, amely nem használható erőforrásfájl megkeresésére. Az erőforrásfájlnevek csak betűket, számokat, kötőjeleket vagy aláhúzásjeleket tartalmazhatnak.
.NET Core és .NET 5+ csak: Nem támogatott egy szál kultúrájának olvasása vagy írása egy másik szálról.
Példák
Az alábbi példa azt határozza meg, hogy az aktuális szál felhasználói felületi kultúrájának nyelve francia-e. Ha nem, akkor az aktuális szál felhasználói felületi kultúráját angolra állítja (Egyesült Államok).
using System;
using System.Globalization;
using System.Threading;
public class Example
{
public static void Main()
{
// Change the current culture if the language is not French.
CultureInfo current = Thread.CurrentThread.CurrentUICulture;
if (current.TwoLetterISOLanguageName != "fr") {
CultureInfo newCulture = CultureInfo.CreateSpecificCulture("en-US");
Thread.CurrentThread.CurrentUICulture = newCulture;
// Make current UI culture consistent with current culture.
Thread.CurrentThread.CurrentCulture = newCulture;
}
Console.WriteLine("The current UI culture is {0} [{1}]",
Thread.CurrentThread.CurrentUICulture.NativeName,
Thread.CurrentThread.CurrentUICulture.Name);
Console.WriteLine("The current culture is {0} [{1}]",
Thread.CurrentThread.CurrentUICulture.NativeName,
Thread.CurrentThread.CurrentUICulture.Name);
}
}
// The example displays the following output:
// The current UI culture is English (United States) [en-US]
// The current culture is English (United States) [en-US]
open System.Globalization
open System.Threading
// Change the current culture if the language is not French.
let current = Thread.CurrentThread.CurrentUICulture
if current.TwoLetterISOLanguageName <> "fr" then
let newCulture = CultureInfo.CreateSpecificCulture "en-US"
Thread.CurrentThread.CurrentUICulture <- newCulture
// Make current UI culture consistent with current culture.
Thread.CurrentThread.CurrentCulture <- newCulture
printfn
$"The current UI culture is {Thread.CurrentThread.CurrentUICulture.NativeName} [{Thread.CurrentThread.CurrentUICulture.Name}]"
printfn
$"The current culture is {Thread.CurrentThread.CurrentUICulture.NativeName} [{Thread.CurrentThread.CurrentUICulture.Name}]"
// The example displays the following output:
// The current UI culture is English (United States) [en-US]
// The current culture is English (United States) [en-US]
Imports System.Globalization
Imports System.Threading
Module Example
Public Sub Main()
' Change the current culture if the language is not French.
Dim current As CultureInfo = Thread.CurrentThread.CurrentUICulture
If current.TwoLetterISOLanguageName <> "fr" Then
Dim newCulture As CultureInfo = CultureInfo.CreateSpecificCulture("en-US")
Thread.CurrentThread.CurrentUICulture = newCulture
' Make current UI culture consistent with current culture.
Thread.CurrentThread.CurrentCulture = newCulture
End If
Console.WriteLine("The current UI culture is {0} [{1}]",
Thread.CurrentThread.CurrentUICulture.NativeName,
Thread.CurrentThread.CurrentUICulture.Name)
Console.WriteLine("The current culture is {0} [{1}]",
Thread.CurrentThread.CurrentUICulture.NativeName,
Thread.CurrentThread.CurrentUICulture.Name)
End Sub
End Module
' The example displays output like the following:
' The current UI culture is English (United States) [en-US]
' The current culture is English (United States) [en-US]
Az alábbi kódpéldában a Windows Forms felhasználói felülete megjeleníthető a Vezérlőpult beállított kultúrában. További kódra van szükség.
using System;
using System.Threading;
using System.Windows.Forms;
class UICulture : Form
{
public UICulture()
{
// Set the user interface to display in the
// same culture as that set in Control Panel.
Thread.CurrentThread.CurrentUICulture =
Thread.CurrentThread.CurrentCulture;
// Add additional code.
}
static void Main()
{
Application.Run(new UICulture());
}
}
open System.Threading
open System.Windows.Forms
type UICulture() =
inherit Form()
do
// Set the user interface to display in the
// same culture as that set in Control Panel.
Thread.CurrentThread.CurrentUICulture <- Thread.CurrentThread.CurrentCulture
// Add additional code.
new UICulture() |> Application.Run
Imports System.Threading
Imports System.Windows.Forms
Public Class UICulture : Inherits Form
Sub New()
' Set the user interface to display in the
' same culture as that set in Control Panel.
Thread.CurrentThread.CurrentUICulture = _
Thread.CurrentThread.CurrentCulture
' Add additional code.
End Sub
Shared Sub Main()
Application.Run(New UICulture())
End Sub
End Class
Megjegyzések
A felhasználói felületi kultúra meghatározza azokat az erőforrásokat, amelyekre az alkalmazásnak szüksége van a felhasználói bemenet és a kimenet támogatásához, és alapértelmezés szerint ugyanaz, mint az operációs rendszer kultúrája. Az osztályban megismerheti a CultureInfo kultúraneveket és -azonosítókat, az invariáns, a semleges és az adott kultúrák közötti különbségeket, valamint azt, hogy a kulturális információk hogyan befolyásolják a szálakat és az alkalmazástartományokat. A tulajdonságból CultureInfo.CurrentUICulture megtudhatja, hogyan határozható meg egy szál alapértelmezett felhasználói felületi kultúrája.
Important
A CurrentUICulture tulajdonság nem működik megbízhatóan, ha az aktuális száltól eltérő száltal használja. A .NET-keretrendszerben a tulajdonság olvasása megbízható, bár az aktuális száltól eltérő szálra való beállítás nem. A .NET Core-on egy InvalidOperationException kerül, ha egy szál megkísérli olvasni vagy írni a CurrentUICulture tulajdonságot egy másik szálon. Javasoljuk, hogy a CultureInfo.CurrentUICulture tulajdonság használatával kérje le és állítsa be az aktuális kultúrát.
A CultureInfo tulajdonság által visszaadott érték semleges kultúra lehet. A semleges kultúrák nem használhatók olyan formázási módszerekkel, mint az String.Format(IFormatProvider, String, Object[]), DateTime.ToString(String, IFormatProvider)és Convert.ToString(Char, IFormatProvider). A metódussal CultureInfo.CreateSpecificCulture lekérhet egy adott kultúrát, vagy használhatja a tulajdonságot CurrentCulture .