在Winform框架界面中改变并存储界面皮肤样式的方法

时间:2021-11-27 00:49:23

在本篇介绍的winform界面样式改变及存储操作中,是指基于devexpress进行界面样式的变化。一般情况下,默认我们会为客户提供多种devexpress的界面皮肤以供个人喜好选择,默认devexpress提供40余种皮肤样式,用户可以根据自己的喜好,选择较为美观、得体的皮肤,为了方便,我们对用户的皮肤选择进行记录,并可以动态改变。

1、界面皮肤的选择

winform开发框架(包括混合式winform开发框架)皮肤如下界面所示。

在Winform框架界面中改变并存储界面皮肤样式的方法

在皮肤集合中打开,可以看到很多界面皮肤可供选择

在Winform框架界面中改变并存储界面皮肤样式的方法

上面初始化的皮肤代码,是通过调用skinhelper的devexpress内在辅助类实现的,通过添加一个ribbongallerybaritem控件对象,然后添加如下代码实现的

?
1
devexpress.xtrabars.helpers.skinhelper.initskingallery(rgbiskins, true);

以及在ribbon控件上添加一个小的皮肤下拉按钮,如下代码所示

?
1
2
this.ribboncontrol.toolbar.itemlinks.clear();
this.ribboncontrol.toolbar.itemlinks.add(rgbiskins);

如果我们固定设置界面一种皮肤,那么调用下面的代码直接设置即可,如下所示。

?
1
userlookandfeel.default.setskinstyle("office 2010 blue");

2、界面皮肤的保存和显示

不过,我们如果希望皮肤可以随意更改并可以存储到配置文件中,那么我们就需要对它进行一定的加工处理。

首先我们编写一个设置皮肤名称的函数,如下所示。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/// <summary>
  /// 设置用户界面的皮肤
  /// </summary>
  private void setskinstyle()
  {
   //从配置文件读取skinname的值,如无则使用标准样式
   string skinname = config.appconfigget("skinname");
   skinname = string.isnullorempty(skinname) ? "office 2010 blue" : skinname;
 
   foreach (galleryitemgroup group in rgbiskins.gallery.groups)
   {
    foreach (galleryitem item in group.items)
    {
     if (string.concat(item.tag) == skinname)
     {
      item.checked = true;
      rgbiskins.gallery.makevisible(item);
      userlookandfeel.default.setskinstyle(skinname);
      return;
     }
     item.checked = false;
    }
   }
  }

这样我们在皮肤改变后,重新读取配置,并重新设置界面的皮肤即可。

那么我们需要实现ribbongallerybaritem控件对象的单击事件galleryitemclick,

如下代码所示。

?
1
2
3
4
5
rgbiskins.galleryitemclick += (object sender, galleryitemclickeventargs e) =>
{
 config.appconfigset("skinname", string.concat(e.item.tag));
 setskinstyle();
};

这样综合起来就是两个函数代码实现了,如下所示

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/// <summary>
  /// 初始化皮肤设置
  /// </summary>
  private void initskinstyle()
  {
   //初始化皮肤样式名称
   devexpress.xtrabars.helpers.skinhelper.initskingallery(rgbiskins, true);
   rgbiskins.galleryitemclick += (object sender, galleryitemclickeventargs e) =>
   {
    config.appconfigset("skinname", string.concat(e.item.tag));
    setskinstyle();
   };
   this.ribboncontrol.toolbar.itemlinks.clear();
   this.ribboncontrol.toolbar.itemlinks.add(rgbiskins);
   this.ribboncontrol.minimized = true;//默认最小化
   //userlookandfeel.default.setskinstyle("office 2010 blue");
   setskinstyle();
  }
 
  /// <summary>
  /// 设置用户界面的皮肤
  /// </summary>
  private void setskinstyle()
  {
   //从配置文件读取skinname的值,如无则使用标准样式
   string skinname = config.appconfigget("skinname");
   skinname = string.isnullorempty(skinname) ? "office 2010 blue" : skinname;
 
   foreach (galleryitemgroup group in rgbiskins.gallery.groups)
   {
    foreach (galleryitem item in group.items)
    {
     if (string.concat(item.tag) == skinname)
     {
      item.checked = true;
      rgbiskins.gallery.makevisible(item);
      userlookandfeel.default.setskinstyle(skinname);
      return;
     }
     item.checked = false;
    }
   }
  }

然后在主界面的初始化代码中进行调用即可,同时记得在app.config文件中增加一个skinname的配置项,方便程序进行存储皮肤名称。

在Winform框架界面中改变并存储界面皮肤样式的方法

这样就可以实现我们皮肤的变化及存储功能了,修改皮肤,并重启程序,系统依旧使用保存好的皮肤,功能符合预期。

在Winform框架界面中改变并存储界面皮肤样式的方法

这个功能不算复杂,提供代码方便大家进行复制使用。

以上这篇在winform框架界面中改变并存储界面皮肤样式的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:http://www.cnblogs.com/wuhuacong/p/6562365.html