Silverlight 下换肤的实现
来源:互联网 发布:搜狗输入法优化版下载 编辑:程序博客网 时间:2024/05/06 01:48
幸好 Nikhil Kothari 想了个办法解决了这个问题。在使用方式上,借鉴了 asp.net 的 Theme机制。只要在 Silverlight 程序的根目录下定义一个 Themes目录,并按要求往其中放入相关的皮肤文件即可。这里建议的方式是每一个控件一个单独的 xaml, 其中放了一个 UserControl.之所以用 UserControl 的目的是为了能用 Expression Blend 进行可视化设计,非常直观。
主要实现思想:
1. 继承了一个自定义的 App 子类. 使用者需要将现有的 App.xaml 改成使用该类才行。
(同时这个 App 类还实现了根据 initParameters 在 xaml 中动态指定加载的 UserControl 和Theme 的功能)
其中设置一个 ThemeName 属性来定义 Theme 名称。
2. 在 App 启动时,根据这个属性名动态去加载相关 xaml 的 xml 文件,并解析之。这些皮肤的 xaml 文件在VS 里是要把 Build Action 设置成 Content 的。这样可以生成到 xap 包里去,以便于加载。
3. 在读取多个 xaml 文件并解析的过程中对同样的 Style 根据优先级做了相应的覆盖合并。最终形成一个总的 xaml文件内容。
4. 用 XamlReader 的 Load 方法加载最终的文档。将其中的资源都抽取出来,并塞到 App.Resources字典里去。
5. 然后正常的控件视觉树开始创建。其中的视觉元素指定了 StaticResource 样式,这时它就能从 App的资源字典里获取到皮肤样式。
注意:这里自始至终没有动态对控件指定 Style 的机制。因为 Silverlight 目前不支持。
这个解决方案的主要思想就是在视觉树加载之前,动态的修改了 App 中的资源,后续的样式应用机制仍然是 framework默认的。
- Silverlight 下换肤的实现
- Silverlight 下换肤的实现
- Silverlight 下换肤的实现
- Silverlight中本地化的实现
- silverlight回车登录的实现
- Silverlight 实现GlobalCalendar的国际化
- Silverlight多语言的实现
- 使用Silverlight实现 FLASH的动画效果
- Silverlight笔记:模态窗体的实现
- Silverlight工具栏的实现与加载
- silverlight / wpf 旋转动画的实现
- 实现自定义Silverlight的安装界面
- Silverlight 实现RIA端到端的优势
- Silverlight实现的简单拖拽效果
- Silverlight 4 报表打印的简单实现
- Silverlight实现的3D黑白棋
- Silverlight实现的3D黑白棋
- 在Silverlight中实现marquee的效果
- camelCase命名约定
- Silverlight动态设置样式
- tasklet和workqueue
- TFS强制解除签出锁定
- 小议大小端模式对C语言的共用体结构的影响
- Silverlight 下换肤的实现
- 实现一个高效C++委托类(多分派)
- 吹响期末考试复习的集结号
- 给年轻程序员的几句话
- 2012移动互联网六大创业趋势
- mutable关键字
- App Store 状态列表
- SQL Server取汉字拼音函数
- SQL动态游标