厚积薄发,丰富的公用类库积累,助你高效进行系统开发(2)----常用操作

自从上篇随笔《厚积薄发,丰富的公用类库积累,助你高效进行系统开发(1)》一文以来,得到同行很多人的鼎力支持和关注,并且在大家的推动下,这篇文章也是上榜博客头条、编辑推荐、10天内推荐排行等荣誉,很多人对这些类库很是感兴趣,也希望进一步详细介绍相关类库的使用。本随笔系列将逐步介绍相关的类库的详细使用,并逐步整理成CHM的帮助文档,作为类库使用的指引手册,同时我会对类库进行进一步的丰富、提炼和优化,随笔将逐步发送,感谢大家的支持和鼓励。
1、程序配置管理辅助类 AppConfig **
实现效果
1、 本辅助类主要是用来方便获取或设置系统配置项的辅助类,实现快速读写配置文件的内容,可以用于读取
.exe.Config文件或者Web.config的文件内容,或者可以读取指定文件的配置项。
2、 辅助类默认从当前目录中按顺序检索Web.Config和
.exe.Config文件。如果找到一个,则使用它作为默认的配置文件,不需要指定文件路径。
3、 读取的文件格式是一般的XML配置文件格式,如下所示。

<?xml version="1.0" encoding="utf-8" ?>   
<configuration>   
  <configSections>   
    <section name="dataConfiguration"   
             type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data"/>   
  </configSections>   
  <connectionStrings>   
    <add name="DataAccess" providerName="System.Data.SqlClient"   
         connectionString="Persist Security Info=False;Data Source=(local);Initial Catalog=Warehouse;User ID=sa;Password=123456"/>   
  </connectionStrings>   
  <dataConfiguration defaultDatabase="DataAccess"/>   
   
  <appSettings>   
    <!--软件名称-->   
    <add key="ApplicationName" value="深田之星仓库管理系统"/>   
    <!--开发商名称-->   
    <add key="Manufacturer" value="广州爱启迪技术有限公司"/>   
    <!--字典、权限组件的数据库类型:access、sqlserver等,默认为sqlserver可不写-->   
    <add key="ComponentDbType" value="sqlserver"/>   
  </appSettings>   
</configuration>  

实现代码

1、 读取配置项目。
AppConfig config = new AppConfig();    
string Manufacturer = config.AppConfigGet("Manufacturer");    
string ApplicationName = config.AppConfigGet("ApplicationName");    
string AppWholeName = string.Format("{0}-{1}", Manufacturer, ApplicationName);  

2、 读取复杂的连接字符串配置,如上面的EnterpriseLibrary的连接字符串 DataAccess 配置项目的ConnectString。

/// <summary>    
/// 测试数据库是否正常连接    
/// </summary>    
/// <returns></returns>    
public static bool TestConnection(string connectionString)    
{    
    bool result = false;    
   
    using (DbConnection connection = new SqlConnection(connectionString))    
    {    
        connection.Open();    
        if (connection.State == System.Data.ConnectionState.Open)    
        {    
            result = true;    
        }    
    }    
   
    return result;    
}    
   
public static bool TestConnection()    
{    
    AppConfig config = new AppConfig();    
    return TestConnection(config.GetConnectionString("DataAccess"));    
}  

3、 写入配置项内容。

AppConfig config = new AppConfig();    
//保存地址(标准调用)    
config.AppConfigSet("PictureRootDir", this.txtPath.Text);    
   
//保存EnterpriseLibray数据库配置项(自定义设置)    
string connectionString = string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0}Database1.mdb;User ID=Admin;Jet OLEDB:Database Password=;", System.AppDomain.CurrentDomain.BaseDirectory);    
config.SetConnectionString("DataAccess", connectionString);    
//更新配置文件,以便起效    
ConfigurationManager.RefreshSection("dataConfiguration");    
ConfigurationManager.RefreshSection("connectionStrings");   
ConfigurationManager.RefreshSection("appSettings"); 

**2、消息提示对话框辅助类 MessageUtil******


** 实现效果**
1、本辅助类主要是用来方便实现标准统一的消息提示对话框,由于各种按钮的样式、标题都进行了统一分装,因此调用的时候,这些参数都可以不用考虑,省却很多繁琐的参数指定,是Winform开发中非常常用的一个类库辅助类。

2、封装的消息提示对话框包括个各种常用的对话框,如下所示:

实现代码

MessageUtil.ShowTips("提示信息对话框");    
MessageUtil.ShowWarning("警告消息提示框");    
MessageUtil.ShowError("错误消息提示框");    
   
MessageUtil.ShowYesNoAndTips("提示对话框,有Yes/No按钮");    
MessageUtil.ShowYesNoAndWarning("警告对话框,有Yes/No按钮");    
MessageUtil.ShowYesNoAndError("错误对话框,有Yes/No按钮");    
MessageUtil.ShowYesNoCancelAndTips("提示对话框,有Yes/No/Cancel按钮");    
   
MessageUtil.ConfirmYesNo("确认对话框,有Yes/No对话框");  
MessageUtil.ConfirmYesNoCancel("确认对话框,有Yes/No/Cancel对话框"); 

3、日历类辅助类 CCalendar
** 实现效果**
1、 本辅助类主要是用来方便显示日期时间、农历、生肖的日历类,并可以计算农历很多属性,并且通过一个函数提供一个全面的日期信息,可以用于装饰界面的效果。
2、 其效果如下所示

** 实现代码**** **

CCalendar cal = new CCalendar();  
this.lblCalendar.Text = cal.GetDateInfo(System.DateTime.Now).Fullinfo;  

一般节日会提示相关的节日信息,另外可以通过修改XML文件,实现对节日、时间提示等信息调整。

<?xml version="1.0" encoding="gb2312" ?>   
<HELLO>   
   
  <!-- 公历节日开始 -->   
  <AD>   
    <feast day="0101" name="元旦" sayhello="yes">   
      <hello>新年好!祝您在新的一年里身体健康,事业进步!</hello>   
      <!-- 从网站根目录算起 -->   
      <img>./img/theme/0101.gif</img>   
    </feast>   
    <feast day="0202" name="世界湿地日" sayhello="no">   
      <img></img>   
      <hello></hello>   
    </feast>   
    <feast day="0210" name="国际气象节" sayhello="no">   
      <img></img>   
      <hello></hello>   
    </feast>   
    <feast day="0214" name="情人节" sayhello="yes">   
      <hello>祝天下有情人终成眷属!</hello>   
      <img>./img/theme/0214.gif</img>   
    </feast>   
    <feast day="0301" name="世界图书日" sayhello="no">   
      <img></img>   
      <hello></hello>   
    </feast>   
.............

4、托盘图标辅助类 NotifyIconHelper **
** 实现效果

1、 本辅助类主要是用来方便动态设置托盘图标。该辅助类用于一些实时连接要求或者状态变化能够及时通过图表来显示的程序,通过闪动的图标及文本,可以有效提示用户相关的程序状态,提供用户的使用体验。
2、 动态设置托盘图标,其效果如下所示


** 实现步骤**

1、在主窗体添加一个NotifyIcon组件,并设置好相关的属性,如下所示

2、 在代码引用相关的代码实现动态调用。

** 实现代码**

public partial class FrmMain : Form    
{    
    private NotifyIconHelper notifyHelper;    
    private const string ClientName = "数据采集终端";//PC式采集器终端    
   
    public frmMain()    
    {    
        InitializeComponent();    
   
        this.Text = ClientName;    
        //初始化托盘图标    
        notifyHelper = new NotifyIconHelper(this.notifyIcon1);    
        notifyHelper.Icon_Conntected = Resources.Connected;    
        notifyHelper.Icon_Shrink1 = Resources.shrink1;    
        notifyHelper.Icon_Shrink2 = Resources.shrink2;    
        notifyHelper.Icon_UnConntect = Resources.unConnected;    
        notifyHelper.Text_Conntected = string.Format("{0}:终端已经连接", ClientName);    
        notifyHelper.Text_UnConntect = string.Format("{0}:终端未连接", ClientName);    
        notifyHelper.NotifyStatus = NotifyIconHelper.Status.TwinkleNotice;    
    }    
   
    /// <summary>    
    /// 设置托盘图标的状态    
    /// </summary>    
    /// <param name="status"></param>    
    public void SetNotifyStatus(NotifyIconHelper.Status status)    
    {                
        notifyHelper.NotifyStatus = status;    
   
        if (status == NotifyIconHelper.Status.Offline)    
        {    
            this.Invoke(new MethodInvoker(delegate()    
            {    
                this.Icon = notifyHelper.Icon_UnConntect;    
            }));                    
        }    
        else if (status == NotifyIconHelper.Status.Online)    
        {    
            this.Invoke(new MethodInvoker(delegate()    
            {    
                this.Icon = notifyHelper.Icon_Conntected;    
            }));       
        }    
    }  

**5、DataTable操作辅助类 DataTableHelper **
实现效果
1、本辅助类主要是用来方便对DataTable进行相关操作的辅助类,该类是非常常用的工具类,常用与数据显示、转换和报表生成等操作中。
2、 提供的操作,包括有创建表、DataTable和实体类集合IList<T>相互转化、表排序、表过滤等操作,以求达到快速进行DataTable操作的目的。

实现代码
1、 根据字段创建表对象,多个列用逗号(,)分开,默认为表对象的列为string。

string columns = @"流水号,备注,供货商,操作员,库房名称,备件编号(pm码),备件名称,图号,规格型号,材质,备件属类,备件类别,
单位,最新单价(元),入库数量,总价,入库日期,来源,库位,部门,使用位置";    
DataTable dt = DataTableHelper.CreateTable(columns);   

2、根据字段创建表对象,多个列用逗号(,)分开。如需要制定列的类型,在字段后加上“|int”格式的字符。

string tableColumns = "ID|int,ItemNo,ItemName,StockQuantity|int,Manufacture,MapNo,Specification,Material,ItemBigType,ItemType,
Unit,Price|decimal,Source,StoragePos,UsagePos,Note,WareHouse,Dept";    
DataTable dt = DataTableHelper.CreateTable(tableColumns);  

3、 实体类转DataTable对象操作ListToDataTable,其对应的反操作函数DataTableToList使用方法类似。

string where = GetSearchSql();    
IList<CustomerInfo> list = BLLFactory<Customer>.Instance.Find(where, this.winGridViewPager1.PagerInfo);    
DataTable dt = DataTableHelper.ToDataTable<CustomerInfo>(list);    
this.winGridViewPager1.DataSource = dt.DefaultView;    
this.winGridViewPager1.dataGridView1.Refresh(); 

4、 DataTable对象排序操作SortedTable,可对表多列进行排序操作。

string where = GetSearchSql();    
IList<CustomerInfo> list = BLLFactory<Customer>.Instance.Find(where, this.winGridViewPager1.PagerInfo);    
DataTable dt = DataTableHelper.ToDataTable<CustomerInfo>(list);    
DataTable dtSort = DataTableHelper.SortedTable(dt, new string[]{"Number asc", "Type desc"});
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容