Defining app resources (XAML)
Purpose
Windows is used worldwide, on a variety of different machines and form factors. It is vital to design applications so that resources, such as strings and images, are separated from their code. This lets them be independently maintained and localized, and also customized for different scaling factors, accessibility options, and a myriad of other user and machine contexts.
App developers should separate resources from code, and use the resource management system in Windows to handle the selection of the most appropriate resources that best match a particular user's runtime environment. This enables:
- The display of different resources based on different configurations and user settings for language, region, DPI, and other form factors.
- Increasing the reach of your app to audiences that vary in culture, region, or language by providing resources tailored to each audience.
- The ability to localize resources separately from the code, so that translators do not need to be able to compile your code. This minimizes the potential for bugs to be introduced during localization.
- The ability to maintain the code separately from the content of the resources. This permits code to be fixed or enhanced in a single code base, with a minimum of risk of altering localized content.
There are two types of resources:
- File resources are simply resources stored as files on disk (such as images, HTML, XML or XAML files).
- Embedded resources are resources stored within some container Resource File (such as ResW and ResJSON).
In Windows file resources are deployed as loose files on disk, and string resources are compiled from their source files and embedded in a Package Resource Index (PRI) file.
The topics in this section concentrate on the techniques used for app resources that are done differently depending on your programming model, and in this case we assume you're using XAML and one of the related code languages (C#, C++, Visual Basic) to write your app.
- See App resources and localization for other topics that describe app resources as an architectural concept, which doesn't get into the specifics of how to accomplish tasks in a particular programming model.
- See Defining app resources (HTML) if you're using JavaScript and HTML to write your app.
In this section
Topic | Description |
---|---|
You can add images and other file resources to your app, and reference those files from within your app. |
|
Put string resources into resource files, and reference those strings from your code or markup. |
|
You can name resources by using qualifiers. The qualifiers identify the context in which a version of a resource should be used. |
|
You can load string resources from objects such as resource files, libraries, controls, and app packages and manifests. |
|
Learn to load file resources from various locations. |