本文告诉大家如何在 WPF 获取资源文件包含 # 号的文件资源
我遇到一个有意思的设计师小伙伴,他的文件命名喜欢使用 #数字
的方式命名,例如写一个图片文件,他的命名是 Image#1.png
和 Image#2.png
的格式
如果在 WPF 中拖入的图片,通过属性设置作为资源,默认是可以在 XAML 里面进行引用,使用相对或绝对路径引用,如下面代码
<Grid>
<Image x:Name="Image" Width="200" Height="200" Stretch="Fill" Source="lindexidoubi.png" />
</Grid>
以上代码需要在解决方案里面放一个 lindexidoubi.png 文件,同时设置属性生成作为资源,可以在 csproj 上看到代码如下
<Project Sdk="Microsoft.NET.Sdk.WindowsDesktop">
<PropertyGroup>
<OutputType>WinExe</OutputType>
<TargetFramework>netcoreapp3.1</TargetFramework>
<UseWPF>true</UseWPF>
</PropertyGroup>
<ItemGroup>
<Resource Include="lindexidoubi.png" />
</ItemGroup>
</Project>
在后台代码可以使用如下代码获取
var streamResourceInfo = Application.GetResourceStream(new Uri("lindexidoubi.png", UriKind.Relative));
看起来这样的代码清真,但是我遇到的设计师给了我一堆图片,这些图片的命名都有 # 号
于是我更换了 xaml 的代码如下
<Grid>
<Image x:Name="Image" Width="200" Height="200" Stretch="Fill" Source="lindexi#doubi.png" />
</Grid>
运行时将不会有任何显示,在 Loaded 事件里面尝试获取图片的 Source 拿到的是空
public MainWindow()
{
InitializeComponent();
Loaded += MainWindow_Loaded;
}
private void MainWindow_Loaded(object sender, RoutedEventArgs e)
{
var imageSource = Image.Source;
}
而通过后台代码,如下面代码获取将提示找不到文件
var streamResourceInfo = Application.GetResourceStream(new Uri("lindexi#doubi.png", UriKind.Relative));
提示的内容如下
System.IO.IOException:“找不到资源“lindexi”。”
可以看到,传入的是 lindexi#doubi.png
但忽略了 #
后面的内容。这是因为 Uri 转义的问题,需要使用如下代码才能拿到
var streamResourceInfo = Application.GetResourceStream(new Uri(Uri.EscapeDataString("lindexi#doubi.png"), UriKind.Relative));
同理,需要在 XAML 将 #
转义,通过 Uri.EscapeDataString 可以了解到 #
可以的转义如下
<Grid>
<Image x:Name="Image" Width="200" Height="200" Stretch="Fill" Source="lindexi%23doubi.png" />
</Grid>
于是我就不用和设计师打起来了
在 WPF 中是支持资源的文件路径名包含了 # 号的,但是在使用的时候需要进行转义,通过 Uri 的 EscapeDataString 方法而不是 EscapeUriString 方法进行转换才能拿到资源
可以通过如下方式获取本文的源代码,先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin 9b8e547f21e4a36d4c5aafec87e08d0ef4bcacb5
以上使用的是 gitee 的源,如果 gitee 不能访问,请替换为 github 的源
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
获取代码之后,进入 CarqawlawyofuwairfuJalbeewhaidearheebee 文件夹
本文会经常更新,请阅读原文: https://blog.lindexi.com/post/WPF-%E5%A6%82%E4%BD%95%E6%89%BE%E5%88%B0%E8%B5%84%E6%BA%90%E6%96%87%E4%BB%B6%E8%B7%AF%E5%BE%84%E5%8C%85%E5%90%AB-%E5%8F%B7%E7%9A%84%E6%96%87%E4%BB%B6.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接: https://blog.lindexi.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。