最近要用到界面控件DevExpress。一句话:很好很强大,比起VS自带的winform界面,种类和花样要多了不少。然而,强力的功能带来了庞大的信息量,所以我打算通过一些小模块来和大家一起对它进行探讨和研究。今天先研究一下它的换肤功能。在控件中,其默认提供了18中风格让我们选择,如下图:

下面就看看怎么实现让界面切换到选中风格的功能。先建立一个项目,引入一个button和一个grid如下图:

由于在devExpress.skins.skinManager.Default.Skins中只有13中皮肤所以我们要手动添加5种,找到Designer.cs文件,添加下列代码:

this.iPaintStyle.CategoryGuid = new System.Guid("d0173875-bf7b-4740-b252-5047db62606c");

this.iPaintStyle.LinksPersistInfo.AddRange(new DevExpress.XtraBars.LinkPersistInfo[] {

new DevExpress.XtraBars.LinkPersistInfo(this.ipsDefault),

new DevExpress.XtraBars.LinkPersistInfo(this.ipsWXP),

new DevExpress.XtraBars.LinkPersistInfo(this.ipsOXP),

new DevExpress.XtraBars.LinkPersistInfo(this.ipsO2K),

new DevExpress.XtraBars.LinkPersistInfo(this.ipsO3)});

private DevExpress.XtraBars.BarButtonItem ipsWXP;

private DevExpress.XtraBars.BarButtonItem ipsOXP;

private DevExpress.XtraBars.BarButtonItem ipsO2K;

private DevExpress.XtraBars.BarButtonItem ipsO3;

private DevExpress.XtraBars.BarButtonItem ipsDefault;

this.ipsDefault = new DevExpress.XtraBars.BarButtonItem();

this.ipsWXP = new DevExpress.XtraBars.BarButtonItem();

this.ipsOXP = new DevExpress.XtraBars.BarButtonItem();

this.ipsO2K = new DevExpress.XtraBars.BarButtonItem();

this.ipsO3 = new DevExpress.XtraBars.BarButtonItem();

//

// ipsDefault

//

this.ipsDefault.Caption = "Default";

this.ipsDefault.CategoryGuid = new System.Guid("d0173875- bf7b-4740-b252-5047db62606c");

this.ipsDefault.Description = "Default";

this.ipsDefault.Id = 15;

this.ipsDefault.Name = "ipsDefault";

this.ipsDefault.ItemClick += new DevExpress.XtraBars.ItemClickEventHandler(this.ips_ItemClick);

//

// ipsWXP

//

this.ipsWXP.Caption = "Windows XP";

this.ipsWXP.CategoryGuid = new System.Guid("d0173875-bf7b-4740-b252-5047db62606c");

this.ipsWXP.Description = "WindowsXP";

this.ipsWXP.Id = 11;

this.ipsWXP.ImageIndex = 5;

this.ipsWXP.Name = "ipsWXP";

this.ipsWXP.ItemClick += new DevExpress.XtraBars.ItemClickEventHandler(this.ips_ItemClick);

//

// ipsOXP

//

this.ipsOXP.Caption = "Office XP";

this.ipsOXP.CategoryGuid = new System.Guid("d0173875-bf7b-4740-b252-5047db62606c");

this.ipsOXP.Description = "OfficeXP";

this.ipsOXP.Id = 12;

this.ipsOXP.ImageIndex = 3;

this.ipsOXP.Name = "ipsOXP";

this.ipsOXP.ItemClick += new DevExpress.XtraBars.ItemClickEventHandler(this.ips_ItemClick);

//

// ipsO2K

//

this.ipsO2K.Caption = "Office 2000";

this.ipsO2K.CategoryGuid = new System.Guid("d0173875-bf7b-4740-b252-5047db62606c");

this.ipsO2K.Description = "Office2000";

this.ipsO2K.Id = 13;

this.ipsO2K.ImageIndex = 4;

this.ipsO2K.Name = "ipsO2K";

this.ipsO2K.ItemClick += new DevExpress.XtraBars.ItemClickEventHandler(this.ips_ItemClick);

//

// ipsO3

//

this.ipsO3.Caption = "Office 2003";

this.ipsO3.CategoryGuid = new System.Guid("d0173875-bf7b-4740-b252-5047db62606c");

this.ipsO3.Description = "Office2003";

this.ipsO3.Id = 14;

this.ipsO3.ImageIndex = 6;

this.ipsO3.Name = "ipsO3";

this.ipsO3.ItemClick += new DevExpress.XtraBars.ItemClickEventHandler(this.ips_ItemClick);

然后将其添加到barManager的项中。

this.barManager1.Items.AddRange(new DevExpress.XtraBars.BarItem[] {

this.barSubItem1,

this.barSubItem2,

this.ipsWXP,

this.ipsOXP,

this.ipsO2K,

this.ipsO3,

this.ipsDefault,

this.iPaintStyle});

然后添加这几种风格的点击事件。

private void ips_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)

{

barManager1.GetController().PaintStyleName = e.Item.Description;

InitPaintStyle(e.Item);

barManager1.GetController().ResetStyleDefaults();

DevExpress.LookAndFeel.UserLookAndFeel.Default.SetDefaultStyle();

}

然后将皮肤初始化并为其注册选择事件。

private void iPaintStyleStyle_Init()

{

BarItem item = null;

for (int i = 0; i < barManager1.Items.Count; i++)

{

if (barManager1.Items[i].Description == barManager1.GetController().PaintStyleName)

item = barManager1.Items[i];

}

InitPaintStyle(item);

}

private void InitPaintStyle(BarItem item)

{

if (item == null)

{

iPaintStyle.ImageIndex = item.ImageIndex;

iPaintStyle.Caption = item.Caption;

iPaintStyle.Hint = item.Description;

}

}

void InitSkins()

{

barManager1.ForceInitialize();

foreach (DevExpress.Skins.SkinContainer cnt in DevExpress.Skins.SkinManager.Default.Skins)

{

BarButtonItem item = new BarButtonItem(barManager1, skinMask + cnt.SkinName);

iPaintStyle.AddItem(item);

item.ItemClick += new ItemClickEventHandler(OnSkinClick);

}

}

void OnSkinClick(Object sender, ItemClickEventArgs e)

{

string skinName = e.Item.Caption.Replace(skinMask, "");

DevExpress.LookAndFeel.UserLookAndFeel.Default.SetSkinStyle(skinName);

barManager1.GetController().PaintStyleName = "Skin";

iPaintStyle.Caption = iPaintStyle.Hint = e.Item.Caption;

iPaintStyle.Hint = iPaintStyle.Caption;

iPaintStyle.ImageIndex = -1;

}

大功告成:初始化winform的时候调用下面两个方法就可以进行换肤了。

iPaintStyleStyle_Init();

InitSkins();

效果如下:

转自http://www.cnblogs.com/xuekai-to-sharp/p/3759675.html

慧都学院2017全新DevExpress线下研修班火热报名中!

标签:DevExpress皮肤

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,尊重他人劳动成果

文章转载自:慧都控件

11

好文不易,鼓励一下吧!

devexpress java_DevExpress使用心得一:换肤相关推荐

  1. [DevExpress]skin窗体换肤

    转自:http://www.evget.com/article/2014/10/10/21667.html 最近在学习 DevExpress 这个控件,将窗体换肤的一些心得记录下来,分享给大家: [D ...

  2. DevExpress 换肤

    在devexpress中,换肤就很简单,不需要我们自己去制造皮肤,官文就有很丰富的皮肤包.下面来讲解一下这个问题. 注意,我这儿用的是DevExpress 8.1.5,在老版本中可能不支持.如果是7. ...

  3. Devexpress控件使用皮肤,设置默认皮肤及动态换肤

    DevExpress是一个比较有名的界面控件套件,提供了一系列的界面控件套件的DotNet界面控件. 关于皮肤的使用网上可以搜到很多示例,在些做个整理. 1.程序引用 DevExpress.Bonus ...

  4. android view设置按钮颜色_Android 主题换肤技术方案分析

    写在前面 Android TV 电视开发,主题换肤,我感觉有两种层级的方式,一种是 系统级,另一种 是应用级, 我记得很早在 Linux 桌面开发的时候,我们之前的公司在GTK+上也实现了一套换肤UI ...

  5. Swift 换肤方案的实现使用SwiftTheme框架

    SwiftTheme 框架进行换肤 本地创建多个plist文件 设置不同图片颜色数组 飞机票 demo Foundationimport SwiftTheme// 创建一个枚举类型进行换肤 enum ...

  6. Spring Boot一键换肤,so easy!

    SpringMVC 源码分析系列最后一篇,和大家聊一聊 Theme. Theme,就是主题,点一下就给网站更换一个主题,相信大家都用过类似功能,这个其实和前面所说的国际化功能很像,代码其实也很像,今天 ...

  7. 关于如何换肤、子类化的解决方案

    对于应用程序的换肤及子类化.下面是我尝试过一些方法,以在CAboutDlg中子类化其中的Button为例: 第一种:直接用现成的类 1.自己写一个类class CButtonXP : public C ...

  8. vue中利用scss实现整体换肤和字体大小设置

    一.前言 利用Sass预处理实现换肤和字体大小调整. 思路及达到的效果:字体大小的适配使用window.devicePixelRatio的值和需要调整的差量进行控制.页面初始化是的字体适配可以根据de ...

  9. android换肤动画,Android-换肤ThemeSkinning使用

    1.png 2.png 3.png 1.集成步骤: 1.添加依赖 compile 'com.solid.skin:skinlibrary:1.4.3' 参考源码版本 2.让你的 Application ...

最新文章

  1. 和12岁小同志搞创客开发:Mind+编程软件简介、安装及使用
  2. python使用matplotlib可视化线图(line plot)、移除可视化结果的所有坐标轴信息(remove all axis in matplotlib graph)
  3. 最新版ffmpeg 提取视频关键帧
  4. weka arff稀疏数据写法
  5. [剑指offer]面试题第[52]题[Leedcode][第160题][JAVA][相交链表][双指针]
  6. (进阶篇)Redis6.2.0 集群 主从复制_原理剖析_02
  7. 怎么用python画圆柱_python-如何绘制具有非恒定半径的圆柱
  8. 广义线性模型——逻辑回归(logistic regression)
  9. C# 自定义类型通过实现IFormattable接口,来输出指定的格式和语言文化的字符串(例:DateTime)...
  10. cgroup: Control Group 分析 转载
  11. 【三维路径规划】基于matlab遗传算法无人机三维路径规划【含Matlab源码 1526期】
  12. java上下左右_上下左右代替maquee的滚动代码
  13. 工作笔记——海康威视网络摄像头接入华为云VIS服务
  14. DevExpress 主从表折叠显示
  15. html绑定drag事件,HTML-Drag事件(拖拽)
  16. php的命令执行函数,PHP命令执行函数 - osc_joe3czc9的个人空间 - OSCHINA - 中文开源技术交流社区...
  17. a non-fatal error occured whilst loading database modules
  18. 全国计算机一级的分类,有关全国计算机一级
  19. 微信小程序:获取用户权限
  20. GitHub学生认证示范

热门文章

  1. 作为一名前端开发工程师,你必须掌握的WEB模板引擎:Handlebars
  2. =======================================以前的======================================
  3. 用PyQt实现透明桌面时钟小部件
  4. 软件设计的火花——Brooks新作及《人月神话》三十五周年讨论会纪要
  5. 莫烦Matplotlib可视化第三章画图种类代码学习
  6. 在Java里怎将字节数转换为我们可以读懂的格式?
  7. aws v2.2.exe_如何在AWS Elastic Beanstalk上部署Rails 5.2 PostgreSQL应用
  8. 探索性数据分析(EDA):Python
  9. 机器学习:分类_机器学习基础:K最近邻居分类
  10. 快速学习一个新的模块