배율, 테마, 고대비 등에 맞춘 이미지 및 자산 로드 등

앱은 디스플레이 배율 인수, 테마, 고대비 및 기타 런타임 컨텍스트에 맞게 조정된 이미지 리소스 파일(또는 기타 자산 파일)을 로드할 수 있습니다. 이러한 이미지는 명령적 코드 또는 XAML 태그에서 참조할 수 있으며 예를 들어 이미지Source 속성입니다. 앱 패키지 매니페스트 원본 파일(Package.appxmanifest의 파일)에 표시될 수도 있습니다. 예를 들면 Visual Studio 매니페스트 디자이너의 시각적 자산 탭에 앱 아이콘으로 또는 타일 또는 알림에 표시됩니다. 이미지의 파일 이름에 한정자를 사용하고 선택적으로 이를 ResourceContext를 사용하여 동적으로 로드하여 디스플레이 배율, 테마, 고대비, 언어 및 다른 컨텍스트에 대한 사용자의 런타임 설정과 가장 적합한 가장 적절한 이미지 파일이 로드되도록 할 수 있습니다.

이미지 리소스는 이미지 리소스 파일에 포함되어 있습니다. 이미지를 자산으로, 이를 포함하는 파일을 자산 파일로 생각할 수 있습니다. 그리고 이러한 리소스 파일을 프로젝트의 \Assets 폴더에서 찾을 수 있습니다. 이미지 리소스 파일 이름에 한정자를 사용하는 방법에 대한 배경 지식은 언어, 규모 및 기타 한정자에 맞게 리소스 조정을 참조하세요.

이미지에 대한 일반적인 한정자는 scale, theme, contrast, targetsize 등이 있습니다.

배율, 테마, 대비에 대한 이미지 리소스 인증

scale 한정자의 기본값은 scale-100입니다. 따라서 이러한 두 변형은 동일합니다(둘 다 이미지를 배율 100 또는 배율 인수 1로 제공).

\Assets\Images\logo.png
\Assets\Images\logo.scale-100.png

파일 이름 대신 폴더 이름에서 한정자를 사용할 수 있습니다. 한정자별로 여러 자산 파일을 가지는 것이 좋은 전략일 것입니다. 설명을 위해 이 두 변형은 위의 두 변형과 동일합니다.

\Assets\Images\logo.png
\Assets\Images\scale-100\logo.png

다음은 디스플레이 크기, 테마 및 고대비의 다양한 설정에 대해 /Assets/Images/logo.png라는 이미지 리소스의 변형을 제공할 수 있는 방법의 예입니다. 이 예에서는 폴더 이름 지정을 사용합니다.

\Assets\Images\contrast-standard\theme-dark
	\scale-100\logo.png
	\scale-200\logo.png
\Assets\Images\contrast-standard\theme-light
	\scale-100\logo.png
	\scale-200\logo.png
\Assets\Images\contrast-high
	\scale-100\logo.png
	\scale-200\logo.png

XAML 태그와 코드에서 이미지 또는 다른 자산 참조

리소스 이미지의 이름 또는 식별자는 모든 한정자가 제거된 경로 및 파일 이름입니다. 폴더 및/또는 파일의 이름을 이전 섹션의 예와 같이 지정하는 경우 단일 이미지 리소스를 가지며 이름(절대 경로로서)은 /Assets/Images/logo.png입니다. 다음은 XAML 태그에서 해당 이름을 사용하는 방법입니다.

<Image x:Name="myXAMLImageElement" Source="ms-appx:///Assets/Images/logo.png"/>

여기에서 앱 패키지에서 제공되는 파일을 참조하기 때문에 ms-appx URI 스키마를 사용합니다. URI 스키마를 참조하세요. 명령적 코드에서 동일한 이미지 리소스를 참조하는 방법은 다음과 같습니다.

this.myXAMLImageElement.Source = new BitmapImage(new Uri("ms-appx:///Assets/Images/logo.png"));

ms-appx를 사용하여 앱 패키지에서 임의의 어떤 파일이든 로드할 수 있습니다.

var uri = new System.Uri("ms-appx:///Assets/anyAsset.ext");
var storagefile = await Windows.Storage.StorageFile.GetFileFromApplicationUriAsync(uri);

ms-appx-web 스키마는 웹 구획의 ms-appx와 동일한 파일에 액세스합니다.

<WebView x:Name="myXAMLWebViewElement" Source="ms-appx-web:///Pages/default.html"/>
this.myXAMLWebViewElement.Source = new Uri("ms-appx-web:///Pages/default.html");

이러한 예에 제공된 모든 시나리오는 UriKind를 유추하는 Uri 생성자 오버로드를 사용합니다. 스키마 또는 기관을 포함하는 유효한 절대 URI를 지정하거나 위의 예에서와 같이 앱 패키지 기관 기본값을 기다립니다.

이 예 URI에서 스키마("ms-appx" 또는 "ms-appx-web") 다음에 "://"로 시작하는 절대 경로가 나오는 것을 확인하세요. 절대 경로에서 처음 "/"는 패키지 루트에서 경로를 해석하도록 합니다.

참고 항목

ms-resource(문자열 리소스에 대해) 및 ms-appx(-web)(이미지 및 기타 자산에 대해) URI 스키마는 자동 한정자 일치를 수행하여 현재 컨텍스트에 가장 적합한 리소스를 찾을 수 있습니다. ms-appdata URI 스키마(앱 데이터를 로드하는 데 사용됨)는 모든 이러한 자동 일치를 수행하지 않지만 ResourceContext.QualifierValues의 콘텐츠에 응답할 수 있으며 URI에 전체 실제 파일 이름을 사용하는 앱 데이터에서 명시적으로 적절한 자산을 로드할 수 있습니다. 앱 데이터에 대한 자세한 내용은 설정 및 기타 앱 데이터 저장 및 검색을 참조하세요. 웹 URI 스키마(http, https, ftp 등)는 자동 일치를 수행하지 않습니다. 이 경우 수행할 작업에 대한 정보는 클라우드에 이미지 호스팅 및 로드를 참조하세요.

이미지 파일이 프로젝트 구조의 위치에 있는 경우 절대 경로가 좋은 선택입니다. 이미지 파일을 이동하려고 하지만 참조 XAML 태그 파일과 관련된 동일한 위치에 있도록 하고자 하는 경우 절대 경로 대신 포함하는 태그 파일과 관련된 경로를 사용하고자 할 수 있습니다. 이를 수행하면 URI 스키마를 사용하지 않아도 됩니다. 이 경우 XAML 태그에서 상대 경로 사용하기 때문에 자동 한정자 일치를 여전히 사용할 수 있습니다.

<Image Source="Assets/Images/logo.png"/>

언어, 배율, 고대비에 대한 타일 및 알림 메시지를 참조하세요.

targetsize에 대한 이미지 리소스 인증

동일한 이미지 리소스의 여러 변형에 scaletargetsize 한정자를 사용할 수 있지만 리소스의 단일 변형에 둘 다를 사용할 수는 없습니다. 또한 TargetSize 한정자 없이 하나 이상의 변형을 정의해야 합니다. 해당 변형은 scale에 대한 값을 정의하거나 기본값 scale-100을 가져야 합니다. 따라서 /Assets/Square44x44Logo.png 리소스의 이러한 두 변형은 유효합니다.

\Assets\Square44x44Logo.scale-200.png
\Assets\Square44x44Logo.targetsize-24.png

그리고 이 두 변형은 유효합니다.

\Assets\Square44x44Logo.png // defaults to scale-100
\Assets\Square44x44Logo.targetsize-24.png

하지만 이 변형은 잘못되었습니다.

\Assets\Square44x44Logo.scale-200_targetsize-24.png

앱 패키지 매니페스트에서 이미지 파일 참조

폴더 및/또는 파일의 이름을 이전 섹션의 유효한 두 예 중 하나와 같이 지정하는 경우 단일 앱 아이콘 이미지 리소스를 가지며 이름(상대 경로로서)은 Assets\Square44x44Logo.png입니다. 앱 패키지 매니페스트에서 이름으로 리소스를 참조합니다. 모든 URI 스키마를 사용하지 않아도 됩니다.

add resource, english

이렇게만 하면 운영 체제는 자동 한정자 일치를 수행하여 현재 컨텍스트에 가장 적합한 리소스를 찾을 수 있습니다. 지역화하거나 이러한 방법으로 자격을 얻을 수 있는 앱 패키지 매니페스트의 모든 항목 목록을 보려면 지역화할 수 있는 매니페스트 항목을 참조하세요.

layoutdirection에 대한 이미지 리소스 인증

이미지 미러링을 참조하세요.

특정 언어 또는 다른 컨텍스트에 대한 이미지 로드

앱 지역화의 가치 제안에 대한 자세한 내용은 세계화 및 지역화를 참조하세요.

기본 ResourceContext(ResourceContext.GetForCurrentView에서 가져옴)에는 기본 런타임 컨텍스트(즉, 현재 사용자와 시스템에 대한 설정)를 나타내는 각 한정자 이름에 대한 한정자 값이 포함됩니다. 이미지 파일은 이름의 한정자를 기반으로 해당 런타임 컨텍스트의 한정자 값과 일치합니다.

하지만 앱에서 시스템 설정을 재정의하여 로드할 일치하는 이미지를 찾을 때 사용할 언어, 배율, 또는 기타 한정자 값을 명시하고자 할 수 있습니다. 예를 들어 로드할 고대비 이미지 및 그 시점을, 정확하게 제어하고자 할 수 있습니다.

이는 새 ResourceContext(기본값 대신)를 구성하고 해당 값을 재정의한 다음 이미지 조회에서 해당 컨텍스트 개체를 사용하여 수행할 수 있습니다.

var resourceContext = new Windows.ApplicationModel.Resources.Core.ResourceContext(); // not using ResourceContext.GetForCurrentView 
resourceContext.QualifierValues["Contrast"] = "high";
var namedResource = Windows.ApplicationModel.Resources.Core.ResourceManager.Current.MainResourceMap[@"Files/Assets/Logo.png"];
var resourceCandidate = namedResource.Resolve(resourceContext);
var imageFileStream = resourceCandidate.GetValueAsStreamAsync().GetResults();
var bitmapImage = new Windows.UI.Xaml.Media.Imaging.BitmapImage();
bitmapImage.SetSourceAsync(imageFileStream);
this.myXAMLImageElement.Source = bitmapImage;

전역 수준에서 동일한 효과를 얻으려면 기본 ResourceContext에서 한정자 값을 재정의할 수 있습니다. 그러나 이 대신 ResourceContext.SetGlobalQualifierValue를 호출하는 것이 좋습니다. SetGlobalQualifierValue를 호출하는 값을 한 번 설정하면 조회를 위해 해당 값을 사용할 때마다 기본 ResourceContext에 적용됩니다. 기본적으로 ResourceManager 클래스는 ResourceContext 기본값을 사용합니다.

Windows.ApplicationModel.Resources.Core.ResourceContext.SetGlobalQualifierValue("Contrast", "high");
var namedResource = Windows.ApplicationModel.Resources.Core.ResourceManager.Current.MainResourceMap[@"Files/Assets/Logo.png"];
this.myXAMLImageElement.Source = new Windows.UI.Xaml.Media.Imaging.BitmapImage(namedResource.Uri);

한정자 값 변경 이벤트에 대한 응답으로 이미지 업데이트

실행 중인 앱은 기본 리소스 컨텍스트의 한정자 값에 영향을 미치는 시스템 설정의 변경에 응답할 수 있습니다. 이러한 모든 시스템 설정은 ResourceContext.QualifierValues에서 MapChanged 이벤트를 호출합니다.

이 이벤트에 대한 응답으로 기본적으로 ResourceManager가 사용하는 ResourceContext 기본값의 도움으로 이미지를 다시 로드할 수 있습니다.

public MainPage()
{
    this.InitializeComponent();

    ...

    // Subscribe to the event that's raised when a qualifier value changes.
    var qualifierValues = Windows.ApplicationModel.Resources.Core.ResourceContext.GetForCurrentView().QualifierValues;
    qualifierValues.MapChanged += new Windows.Foundation.Collections.MapChangedEventHandler<string, string>(QualifierValues_MapChanged);
}

private async void QualifierValues_MapChanged(IObservableMap<string, string> sender, IMapChangedEventArgs<string> @event)
{
    var dispatcher = this.myImageXAMLElement.Dispatcher;
    if (dispatcher.HasThreadAccess)
    {
        this.RefreshUIImages();
    }
    else
    {
        await dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () => this.RefreshUIImages());
    }
}

private void RefreshUIImages()
{
    var namedResource = Windows.ApplicationModel.Resources.Core.ResourceManager.Current.MainResourceMap[@"Files/Assets/Logo.png"];
    this.myImageXAMLElement.Source = new Windows.UI.Xaml.Media.Imaging.BitmapImage(namedResource.Uri);
}

중요 API