WinForm界面开发之“OutLookBar”工具条

简介:

在很多软件界面中,一个好的界面、方便的导航除了为软件增色不少外,也提高了用户体验,促进软件的良性发展,因为我们的软件一般需要有菜单、工具条、状态条等这些基本的东西,但是工具条本身应该是一些常用的快捷键,内容不能放置太多,否则会容易给客户凌乱的感觉。菜单条则可以分类,但是好像每次去点击,一步步深入,则显得比较麻烦。本篇我介绍一下一个很好的导航条OutlookBar控件。

在我的2个版本的送水软件中,都用到了OutLookBar的工具条,使用的界面效果如下所示。

                   

左边的工具条它们都是同一个控件来的,控件提供了一种类似Outlook方式的工具条,用来切换各种业务窗口,用上这个控件,肯定为您的程序增色不少。这个控件结合上面介绍的布局控件"WeifenLuo.WinFormsUI.Docking"(具体见文章WinForm界面开发之布局控件"WeifenLuo.WinFormsUI.Docking"的使用),那么效果会更好。下面介绍下如何在代码中使用这个Outlookbar工具控件。

 1、首先创建一个窗体,用来放置该控件,由于该控件不是一个可视化的控件,因此需要做一些特别的处理,如添加一个ImageList控件,并把OutlookBar控件中用到的图标加载进来,记得选择一些好看的图片哦。

2、在MainToolWindow窗体的构造函数或者Load事件中添加OutlookBar的初始化代码和设置代码,如下所示。

        private  OutlookBar outlookBar1  =   null ;

        
public  MainToolWindow()
        {
            InitializeComponent();

            InitializeOutlookbar();            
        }

        
private   void  InitializeOutlookbar()
        {
            outlookBar1 
=   new  OutlookBar();

            
#region  销售管理
              OutlookBarBand outlookShortcutsBand 
=   new  OutlookBarBand( " 销售管理 " );
            outlookShortcutsBand.SmallImageList 
=   this .imageList;
            outlookShortcutsBand.LargeImageList 
=   this .imageList;
            outlookShortcutsBand.Items.Add(
new  OutlookBarItem( " 订单管理 " 0 ));
            outlookShortcutsBand.Items.Add(
new  OutlookBarItem( " 客户管理 " 1 ));
            outlookShortcutsBand.Items.Add(
new  OutlookBarItem( " 水票管理 " 2 ));
            outlookShortcutsBand.Items.Add(
new  OutlookBarItem( " 套餐管理 " 3 ));
            outlookShortcutsBand.Items.Add(
new  OutlookBarItem( " 今日盘点 " 5 ));
            outlookShortcutsBand.Items.Add(
new  OutlookBarItem( " 来电记录 " 6 ));
            outlookShortcutsBand.Items.Add(
new  OutlookBarItem( " 送货记录 " 7 ));
            outlookShortcutsBand.Background 
=  SystemColors.AppWorkspace;
            outlookShortcutsBand.TextColor 
=  Color.White;
            outlookBar1.Bands.Add(outlookShortcutsBand);
            
            
#endregion

            
#region  产品库存管理
              OutlookBarBand mystorageBand 
=   new  OutlookBarBand( " 产品库存管理 " );
            mystorageBand.SmallImageList 
=   this .imageList;
            mystorageBand.LargeImageList 
=   this .imageList;
            mystorageBand.Items.Add(
new  OutlookBarItem( " 产品管理 " 2 ));
            mystorageBand.Items.Add(
new  OutlookBarItem( " 库存管理 " 3 ));
            mystorageBand.Background 
=  SystemColors.AppWorkspace;
            mystorageBand.TextColor 
=  Color.White;
            outlookBar1.Bands.Add(mystorageBand); 
            
#endregion

            .
            
            outlookBar1.Dock 
=  DockStyle.Fill;
            outlookBar1.SetCurrentBand(
0 );
            outlookBar1.ItemClicked 
+=   new  OutlookBarItemClickedHandler(OnOutlookBarItemClicked);
            outlookBar1.ItemDropped 
+=   new  OutlookBarItemDroppedHandler(OnOutlookBarItemDropped);

            
// outlookBar1.FlatArrowButtons = true;
             this .panel1.Controls.AddRange( new  Control[] { outlookBar1 });
        }

        
private   void  OnOutlookBarItemClicked(OutlookBarBand band, OutlookBarItem item)
        {
            
switch  (item.Text)
            {
                
#region  销售管理

                  
case   " 订单管理 " :
                    Portal.gc.MainDialog.ShowContent(
" 订单管理 " typeof (FrmOrder));
                    
break ;
                
case   " 客户管理 " :
                    Portal.gc.MainDialog.ShowContent(
" 客户管理 " typeof (FrmCustomer));
                    
break ;
                
case   " 水票管理 " :
                    Portal.gc.MainDialog.ShowContent(
" 水票管理 " typeof (FrmTicketHistory));
                    
break ;
                
case   " 套餐管理 " :
                    FrmYouhui dlg 
=   new  FrmYouhui();
                    dlg.ShowDialog();
                    
break ;
                
case   " 来电记录 " :
                    Portal.gc.MainDialog.ShowContent(
" 来电记录 " typeof (FrmComingCall));
                    
break ;
                
case   " 送货记录 " :
                    Portal.gc.MainDialog.ShowContent(
" 送货记录 " typeof (FrmDeliving));
                    
break ;

                
#endregion

                
#region  产品库存管理
                  
case   " 产品管理 " :
                    Portal.gc.MainDialog.ShowContent(
" 产品管理 " typeof (FrmProduct));
                    
break ;
                
case   " 库存管理 " :
                     Portal.gc.MainDialog.ShowContent(
" 库存管理 " typeof (FrmStock));
                    
break
                
#endregion

                ..

                
default :
                    
break ;
            }
        }

        
private   void  OnOutlookBarItemDropped(OutlookBarBand band, OutlookBarItem item)
        {
            
//             string message = "Item : " + item.Text + " was dropped";
            
//             MessageBox.Show(message);            
        }

在代码中注意绑定相关项目的图标序号,否则如果序号不正确,可能会出错的,其实整个控件就是提供展示一些图标,并用同一的事件对鼠标的事件进行处理,用户根据OutlookBarItem的文本内容来判断处理,虽然模式有点落后,不过个人感觉控件还是非常好用,方便。

最后呈上相关的控件文件:http://files.cnblogs.com/wuhuacong/UtilityLibrary.rar

本文转自博客园伍华聪的博客,原文链接:WinForm界面开发之“OutLookBar”工具条,如需转载请自行联系原博主。



目录
相关文章
|
8月前
|
存储 设计模式 开发框架
总结开发中基于DevExpress的Winform界面效果
总结开发中基于DevExpress的Winform界面效果
|
7月前
|
开发框架 前端开发 JavaScript
在Winform界面中使用自定义控件,丰富界面的效果处理
在Winform界面中使用自定义控件,丰富界面的效果处理
|
Java C# 索引
C#之 十九 使用WinForm控件
C#之 十九 使用WinForm控件
260 0
|
Shell C++ C语言
38【WinForm】WinForm常见窗体技术汇总
- 窗体调用外部程序与渐变窗体 - 按回车键跳转窗体中的光标焦点 - 剪切板操作
103 0
|
机器学习/深度学习 数据可视化 程序员
WinForm控件属性大全
WinForm控件属性大全
468 0
|
测试技术
艾伟:WinForm控件开发总结(二)------使用和调试自定义控件
在上一篇文章里我们创建了一个简单的控件FirstControl,现在我来介绍一下怎么使用和调试自己的控件。我希望将过程写的尽可能的详细,让想学习控件开发的朋友容易上手,高手们见谅。       在同一个solution里添加一个Windows Application工程(在Solution Explorer里右键点击CustomControlSample solution选择Add->New Project…),命名为TestControl。
905 0

热门文章

最新文章