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”工具条,如需转载请自行联系原博主。



目录
相关文章
|
10月前
|
Java C# 索引
C#之 十九 使用WinForm控件
C#之 十九 使用WinForm控件
150 0
|
11月前
38【WinForm】WinForm常见窗体技术汇总
- 窗体调用外部程序与渐变窗体 - 按回车键跳转窗体中的光标焦点 - 剪切板操作
56 0
|
11月前
|
数据挖掘 Python
【WinForm】WinForm实现音乐播放器
示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。
82 0
AppleWatch开发入门五——菜单控件的使用
AppleWatch开发入门五——菜单控件的使用
184 0
AppleWatch开发入门五——菜单控件的使用
|
Android开发 iOS开发 UED
[UWP]浅谈按钮设计
原文:[UWP]浅谈按钮设计 一时兴起想谈谈UWP按钮的设计。 按钮是UI中最重要的元素之一,可能也是用得最多的交互元素。好的按钮设计可以有效提高用户体验,构造让人眼前一亮的UI。而且按钮通常不会影响布局,小小的按钮无论怎么改也不会对性能有多大影响,所以不少注重细节的设计师最为热衷修改按钮。
1477 0
|
Web App开发 搜索推荐 C#
用WPF窗体打造个性化界面的图片浏览器
原文:用WPF窗体打造个性化界面的图片浏览器 本文使用WPF窗体(XAML及C#)与Win Form控件(FolderBrowserDialog)结合的方式, 演示制作了一个简易漂亮的WPF图片浏览器。
809 0
|
Web App开发 数据可视化 C#