首页 > 代码库 > 资源: 资源限定符概述, 资源限定符示例

资源: 资源限定符概述, 资源限定符示例

资源限定符概述

  • 资源限定符示例



示例
1、资源限定符概述
Resource/Qualifiers/Summary.xaml

<Page    x:Class="Windows10.Resource.Qualifiers.Summary"    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"    xmlns:local="using:Windows10.Resource.Qualifiers"    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"    mc:Ignorable="d">    <Grid Background="Transparent">        <StackPanel Margin="10 0 10 10">            <TextBlock Name="lblMsg" Margin="0 10 0 0" />        </StackPanel>    </Grid></Page>

Resource/Qualifiers/Summary.xaml.cs

/* * qualifiers - 限定符,在 uwp 中支持通过限定符来命名资源。限定符用于标识某个资源文件使用场景的上下文 * * 本例用于演示如何获取系统支持的全部限定符 * 关于限定符的规则及示例参见 /Resource/Qualifiers/Demo.xaml */using System;using Windows.ApplicationModel.Resources.Core;using Windows.Foundation.Collections;using Windows.Graphics.Display;using Windows.UI.Xaml;using Windows.UI.Xaml.Controls;namespace Windows10.Resource.Qualifiers{    public sealed partial class Summary : Page    {        public Summary()        {            this.InitializeComponent();            this.Loaded += Summary_Loaded;        }        private void Summary_Loaded(object sender, RoutedEventArgs e)        {            // 列举出系统支持的全部限定符,及其对应的值            IObservableMap<string, string> qualifiers = ResourceContext.GetForCurrentView().QualifierValues;            foreach (var qualifier in qualifiers)            {                lblMsg.Text += string.Format("{0}: {1}", qualifier.Key, qualifier.Value);                lblMsg.Text += Environment.NewLine;            }            lblMsg.Text += Environment.NewLine;            // 常用的有:Scale, DeviceFamily, Language, TargetSize, 其他的都不常用            // 获取当前的缩放比例            string scale;            ResourceContext.GetForCurrentView().QualifierValues.TryGetValue("Scale", out scale);            lblMsg.Text += "缩放比例: " + scale;            lblMsg.Text += Environment.NewLine;            // 获取当前的缩放比例(Windows.Graphics.Display.ResolutionScale 枚举)            lblMsg.Text += "ResolutionScale: " + DisplayInformation.GetForCurrentView().ResolutionScale;            lblMsg.Text += Environment.NewLine;            // 获取当前的设备类型            string deviceFamily;            ResourceContext.GetForCurrentView().QualifierValues.TryGetValue("DeviceFamily", out deviceFamily);            lblMsg.Text += "设备类型: " + deviceFamily;            lblMsg.Text += Environment.NewLine;            // 获取当前的语言类型            string language;            ResourceContext.GetForCurrentView().QualifierValues.TryGetValue("Language", out language);            lblMsg.Text += "语言类型: " + language;            lblMsg.Text += Environment.NewLine;        }    }}


2、资源限定符示例
Resource/Qualifiers/Demo.xaml

<Page    x:Class="Windows10.Resource.Qualifiers.Demo"    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"    xmlns:local="using:Windows10.Resource.Qualifiers"    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"    mc:Ignorable="d">    <Grid Background="Transparent">        <StackPanel Margin="10 0 10 10">            <TextBlock Name="lblMsg" Margin="5" />                        <!--                限定符用于标识某个资源文件使用场景的上下文,本例通过 DeviceFamily 和 Scale 两种限定符来演示实际效果(关于系统支持的全部限定符参见 /Qualifiers/Summary.xaml),规则总结如下                1、命名规则                    a) 文件夹式: folder/qualifiername-value/qualifiername-value/filename.ext 或者 folder/qualifiername-value/qualifiername-value_qualifiername-value/filename.ext 等                    b) 文件名式: folder/filename.qualifiername-value_qualifiername-value.ext 等(多个限定符之间用“_”分隔)                    c) 文件夹式和文件名式可以混合使用                2、调用规则: 直接引用 folder/filename.ext,系统将自动根据限定符指定的上下文做匹配                3、无论是资源名,还是限定符都不区分大小写                4、同一个资源的限定符不能重复,否则编译报错。比如 folder/filename.scale-100.png 和 folder/scale-100/filename.png 其实是同名限定符资源,不能共存                5、对于非 scale 限定符资源,如果匹配不到,系统则会去调用对应的无限定符资源                6、对于 scale 限定符资源,只要有一个 scale 资源就不会去调用对应的无限定符资源。当无法精确匹配时,系统先去找临近的更大比例的,找不到的话再按从大到小的顺序找小比例的                7、语言限定符有一个特殊性,其限定符名称可以是 language 或 lang,用文件夹式的话是不需要限定符名称的。比如文件名式 filename.language-en-US.png 或 filename.lang-en-US.png 对应的文件夹式为 en-US/filename.png                            另外:限定符 TargetSize 用于限定图标的大小,不能和 Scale 共存                1、TargetSize 主要用于桌面 Windows 资源管理器中显示的文件类型关联图标或协议图标                2、TargetSize 限定的是一个正方形图标,其值的单位是像素,类似 filename.targetsize-16.png, filename.targetsize-32.png 等                3、当无法精确匹配时,系统先去找临近的更大像素的,找不到的话再按从大到小的顺序找小像素的                4、去 Package.appxmanifest 的“可见资产”看看,标识为“比例”的对应的是 Scale 限定符,标识为“目标大小”的对应的是 TargetSize 限定符            -->            <StackPanel Orientation="Horizontal">                <Image Source="/Resource/Qualifiers/myImage1.png" Width="100" Height="100" HorizontalAlignment="Left" Margin="5" />                <Image Source="/Resource/Qualifiers/myImage2.png" Width="100" Height="100" HorizontalAlignment="Left" Margin="5" />            </StackPanel>            <StackPanel Orientation="Horizontal" Margin="0 10 0 0">                <Image Source="/Resource/Qualifiers/myImage3.png" Width="100" Height="100" HorizontalAlignment="Left" Margin="5" />                <Image Source="/Resource/Qualifiers/myImage4.png" Width="100" Height="100" HorizontalAlignment="Left" Margin="5" />            </StackPanel>        </StackPanel>    </Grid></Page>

Resource/Qualifiers/Demo.xaml.cs

/* * 本例用于演示限定符的实际效果 */using System;using Windows.Graphics.Display;using Windows.UI.Xaml;using Windows.UI.Xaml.Controls;namespace Windows10.Resource.Qualifiers{    public sealed partial class Demo : Page    {        public Demo()        {            this.InitializeComponent();            this.Loaded += Demo_Loaded;        }        private void Demo_Loaded(object sender, RoutedEventArgs e)        {            // 获取当前的缩放比例            string scale;            Windows.ApplicationModel.Resources.Core.ResourceManager.Current.DefaultContext.QualifierValues.TryGetValue("Scale", out scale);            lblMsg.Text += "缩放比例: " + scale;            lblMsg.Text += Environment.NewLine;            // 获取当前的缩放比例(Windows.Graphics.Display.ResolutionScale 枚举)            lblMsg.Text += "ResolutionScale: " + DisplayProperties.ResolutionScale.ToString();            lblMsg.Text += Environment.NewLine;            // 获取当前的设备类型            string deviceFamily;            Windows.ApplicationModel.Resources.Core.ResourceManager.Current.DefaultContext.QualifierValues.TryGetValue("DeviceFamily", out deviceFamily);            lblMsg.Text += "设备类型: " + deviceFamily;            lblMsg.Text += Environment.NewLine;                    }    }}


注:本例的资源文件结构

|Resource|--Qualifiers|----deviceFamily-desktop|------scale-100|--------MyImage4.png|----deviceFamily-mobile|------MyImage4.scale-100.png|----scale-100|------MyImage1.png|----scale-140|------MyImage1.png|----scale-180|------MyImage1.png|----MyImage1.png|----MyImage2.png|----MyImage2.scale-100.png|----MyImage2.scale-140.png|----MyImage2.scale-180.png|----MyImage3.DeviceFamily-Desktop_scale-100.png|----MyImage3.DeviceFamily-Mobile_scale-100.png|----MyImage3.png|----MyImage4.png

资源: 资源限定符概述, 资源限定符示例