主要介绍一下在silverlight里的资源文件(图片, 视频, 字体之类)设置不同的Build
Action时在XAML或是后台C#里如何引用的问题.
就拿图片文件作例子来介绍各种Build Action的情况(选中一个文件后按F4打开vs属性面板就可以看到Build Action选项,
并可以更改)
假如我们有两个图片文件分别叫silverlight.png和sl.jpg, 把silverlight.png添加到应用的根目录里,
和我们的MainPage.xaml文件在一个文件夹, sl.jpg放到一个新建的images文件夹里
1. Resource:
选择这种生成方式后,该资源文件会被嵌入到该应用的程序集中,就是说打开生成的xap是看不到这个文件的.
可以用相对于当前的XAML文件的相对Uri访问, 如<Image Source="silverlight.png"
/>或是<Image Source="./silverlight.png" />, 在子文件夹里的可以用<Image
Source=”./images/sl.jpg” />访问到
最保险的方式是采用特有的程序集资源URI访问,格式为
<Image
Source="/{assemblyShortName};component/Foo.jpg"/>
,
这种方式还可以引用到xap中的其他程序集中的图片
修改我们的两个图片的引用方式为
复制内容到剪贴板
代码:
<Image
Source="/SilverlightApplication1;component/silverlight.png"/>
<Image Source="/SilverlightApplication1;component/images/sl.jpg"
Height="100"/>
你可以发现一样可以正常显示
如果没找到文件的话,系统不会再找别的位置了, 会触发ImageFailed事件
在Build Action为Resource时, 可以用一下几种相对URI来引用资源文件
复制内容到剪贴板
代码:
<Image
Source="/SilverlightApplication1;component/silverlight.png"
Height="100"/>
<Image Source="./silverlight.PNG" Height="100" />
<Image Source="silverlight.PNG" Height="100" />
<Image Source="/SilverlightApplication1;component/images/sl.jpg"
Height="100"/>
<Image Source="./images/sl.jpg" Height="100" />
注意这种生成方式的系统资源可以直接用
Application.GetResourceStream(uri).Stream在代码里来得到
2. Content:
用这种方式生成XAP后文件会被添加到xap文件中,用压缩工具打开我们生成的xap后可以看到我们的图片文件,silverlight.png在应用
的"根"目录, 而sl.jpg文件存放在images文件夹中
这种情况下, 访问这两个图片的相对Uri需要以"/"开始
复制内容到剪贴板
代码:
<Image Source="/silverlight.PNG" Height="100" />
<Image Source="/images/sl.jpg" Height="100" />
注意在这种方式下, 如果没有在xap中找到图片文件,
那么silverlight会自动从当前xap应用所在的文件夹下来找所需图片文件,如果还没有找到那么就触发ImageFailed事件,
这种方式比较适合在多个程序集引用相同文件时采用
3. None:
None表示不作生成处理, 我们的图片文件不会被拷贝到XAP文件中,需要考虑的是"CopyToOutputDirectory"这个选项,
这个选项有三个选择"Do not copy","Copy always","Copy if newer", 因为我们需要引用图片文件,
我们可以选择后两个中的一个,这样在项目编译后,可以看到在xap的所在文件里会有一个silverlight.png文件和一个images文件夹,
sl.jpg文件就在images文件夹里
引用文件的Uri方式同第二种Content方式
在大多数情况下, 我们希望把video/audio文件放到xap的外面,因为这种文件一般都比较大, 会影响silverlight应用的加载,
而且一般的视频音频文件都是压缩格式的,放到xap中也不会起到减少他们文件大小的作用.
类似图片视频这种资源文件生成操作为None时和他们没有被添加到项目里是一样的, 都可以用绝对Uri进行引用
小结:
相对Uri引用:[/i]
复制内容到剪贴板
代码:
<Image Source="/silverlight.PNG" Height="100" />
<Image Source="/images/sl.jpg" Height="100" />
[i]绝对路
径引用:
复制内容到
剪贴板
代码:
<Image
Source="http://localhost:50235/clientbin/silverlight.PNG" Height="100"
/>
<Image Source="http://localhost:50235/clientbin/images/sl.jpg"
Height="100" />
4. EmbeddedResource:
这种方式会把文件嵌入到程序集中, silverlight无法通过Uri引用在xaml和c#里对这个文件进行使用,
微软不建议在silverlight采用这种方式在程序集里嵌入资源.
如果有这种需求可以用
Reflection.Assembly.GetExecutingAssembly().GetManifestResourceStream(string
path)
相关的方法得到文件的stream引用
我建议直接改为第一种的"Resource"方式, 然后采用第一种的引用方式就可以了
关于Resource方式和EmbeddedResource的不同我不多介绍了,
如果感兴趣的话可以用reflector工具打开你的程序集dll文件, 在Resources目录下可以看到两者的不同之处,
用Resource嵌入的资源会被系统放到AppName.g.resources中,而采用EmbeddedResource方式的资源会被直接放到
Resources目录下,其他的细节就不介绍了.
转帖:http://bbs.blueidea.com/thread-2941697-1-1.html
分享到:
相关推荐
Resx文件是一种.NET框架中的资源文件格式,用于存储字符串、图像和其他类型的数据。每个语言对应一个Resx文件,例如英文版为"Resources.resx",法文版为"Resources.fr-FR.resx"。 步骤1:创建Resx文件 在Visual ...
在XAML中,这些资源可以通过URI引用并整合到UI设计中。 8. **安全性与验证**:对于电子签名,安全性和数据完整性至关重要。开发者可能需要集成数字证书或哈希算法来验证签名的合法性,防止篡改。同时,确保数据传输...
然而,在 Silverlight 开发中,我们经常会遇到各种错误代码,对这些错误代码的理解和解决非常重要。 下面我们将对 Silverlight 错误代码进行分类和解释: 语法错误 * 2000:文档不是格式良好的 XAML。 * 2001:不...
1. 引入ArcGIS for Silverlight库:在项目中添加对ArcGIS for Silverlight的引用,这通常通过NuGet包管理器或者手动导入dll文件实现。 2. 创建Map控件:在XAML文件中,创建一个Map控件作为地图容器,这是展示地图的...
在Silverlight中实现国际化是一项重要的任务,特别是在...总之,Silverlight的国际化实现主要依赖于资源文件和适当的文化信息设置。正确理解和应用这些概念,可以帮助开发者构建出能够跨越文化和语言障碍的高效应用。
DownloadStringAsync(Uri address, Object userToken) - 以字符串的形式下载指定的 URI 的资源 UploadStringAsync(Uri address, string data) - 以字符串的形式上传数据到指定的 URI。所使用的 HTTP 方法默认为 POST...
尽管Silverlight内置的Image控件可以显示静态的JPEG、PNG和GIF图像,但默认情况下并不支持播放GIF动画。这是因为Silverlight 4之前的版本不提供内置的GIF解码器。然而,开发者可以通过使用第三方库或自定义控件来...
- **所引用的程序集资源文件**:访问位于外部程序集中的资源文件。 - **内容文件PackURI**:说明如何使用PackURI访问内容文件。 - **源站点PackURI**:使用PackURI访问源站点文件。 - **页面文件**:描述如何使用...
分享的"NetCore下WPF开发以及基于Prism的模块化开发学习总结-大纲.png"和"NetCore下WPF基于Prism的模块化开发.pptx"文件,应包含了作者在实践中遇到的问题及其解决方案,可以作为学习和参考的重要资源。 总之,掌握...