对于一个WPF应用程序,它将需要10 - 20个小图标和图像用于说明目的,将它们作为嵌入式资源存储在程序集中是正确的方法吗?
如果是这样,我如何在XAML中指定图像控件应该从嵌入式资源加载图像?
对于一个WPF应用程序,它将需要10 - 20个小图标和图像用于说明目的,将它们作为嵌入式资源存储在程序集中是正确的方法吗?
如果是这样,我如何在XAML中指定图像控件应该从嵌入式资源加载图像?
当前回答
如果要在多个地方使用图像,那么值得将图像数据只加载一次到内存中,然后在所有image元素之间共享。
要做到这一点,在某处创建一个BitmapSource作为资源:
<BitmapImage x:Key="MyImageSource" UriSource="../Media/Image.png" />
然后,在你的代码中,使用如下代码:
<Image Source="{StaticResource MyImageSource}" />
在我的例子中,我发现我必须将Image.png文件设置为资源而不仅仅是内容的构建操作。这将导致在已编译程序集中携带映像。
其他回答
如何使用资源的完整描述:WPF应用程序资源,内容和数据文件
以及如何引用它们,请阅读“在WPF中打包uri”。
简而言之,甚至还有从被引用/引用程序集引用资源的方法。
Visual Studio 2010 Professional SP1。 . net Framework 4客户端配置文件。 在项目属性上添加PNG图像作为资源。 自动在资源文件夹中创建新文件。 构建操作集到资源。
这招对我很管用:
<BitmapImage x:Key="MyImageSource" UriSource="Resources/Image.png" />
根据Drew Noakes的回答,以下是创建资源字典、向其中添加BitmapImage资源以及在用户控件中引用BitmapImage资源的完整步骤。
在项目根目录下添加Images文件夹。 在Images文件夹下添加MyImage.png。 在“MyImage.png属性”窗口中,将“生成操作”设置为“资源”。 在项目根目录下创建一个名为MainResourceDictionary.xaml的资源字典:
<ResourceDictionary
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<BitmapImage x:Key="MyImageSource" UriSource="Images/MyImage.png" />
</ResourceDictionary>
在控件中添加对资源字典的引用:
<UserControl ...>
<UserControl.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="MainResourceDictionary.xaml" />
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</UserControl.Resources>
...
在控件中引用图像资源:
<UserControl ...>
<UserControl.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="MainResourceDictionary.xaml" />
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</UserControl.Resources>
...
<Image Source="{DynamicResource ResourceKey=ServiceLevel1Source}" />
...
是的,这条路对。你可以使用一个路径在资源文件中使用图像:
<StackPanel Orientation="Horizontal">
<CheckBox Content="{Binding Nname}" IsChecked="{Binding IsChecked}"/>
<Image Source="E:\SWorking\SharePointSecurityApps\SharePointSecurityApps\SharePointSecurityApps.WPF\Images\sitepermission.png"/>
<TextBlock Text="{Binding Path=Title}"></TextBlock>
</StackPanel>
如果您正在使用Blend,为了使它更加简单,并且没有任何问题,为Source属性获取正确的路径,只需将图像从Project面板拖放到设计器上。