一、新建一个导航栏

拖入一个panel到窗口上做为导航栏的容器,然后再拖入一个NavBarControl到其上,点击NavBarControl控件的右上角三角箭头展开任务列表,选择PaintStyle模式为Navigationpane,也就是同时最大展开的分组数目为1。

二、手动为导航栏添加数据

点击控件右上角三角箭头展开任务列表,选择Run Designer打开设计界面。

设计界面的Main -> Groups/Items/Links为导航栏的分组及子项目编辑界面,我们进入此界面,在右侧的NavBar Groups窗口内点击鼠标焦点至此窗口时,上方的添加按钮可以添加新的分组,在右侧的NavBar Items窗口内点击鼠标焦点至此窗口时,上方的添加按钮可以添加新的子项目,选中每个分组或子项目可以在右侧的属性窗口快捷设置他的常用属性,添加好了多个分组和子项目时,需要将子项目指定到某一分组内,直接用鼠标拖动NavBar Items中的子项目到NavBar Groups中的该分组下。

我们创建好了多个分组和子项目后,直接点击运行,查看此时的效果。

三、捕获导航栏的基本事件

捕获导航栏子项目的鼠标点击事件LinkClicked:

  1. public Form1()
  2. {
  3. InitializeComponent();
  4. OtherInit();
  5. }
  6. /// <summary>
  7. /// 其他的初始化处理
  8. /// </summary>
  9. private void OtherInit()
  10. {
  11. navBarItem1.LinkClicked += Item_Click;
  12. navBarItem2.LinkClicked += Item_Click;
  13. navBarItem3.LinkClicked += Item_Click;
  14. navBarItem4.LinkClicked += Item_Click;
  15. navBarItem5.LinkClicked += Item_Click;
  16. navBarItem6.LinkClicked += Item_Click;
  17. navBarItem7.LinkClicked += Item_Click;
  18. navBarItem8.LinkClicked += Item_Click;
  19. navBarItem9.LinkClicked += Item_Click;
  20. }
  21. /// <summary>
  22. /// 导航栏子项目的点击事件
  23. /// </summary>
  24. private void Item_Click(object sender, NavBarLinkEventArgs e)
  25. {
  26. MessageBox.Show("点击了子项目:" + e.Link.Caption);
  27. }

四、动态更改导航栏数据

只需要根据数据动态的创建分组和子项目,并将子项目添加到分组之下:

  1. NavBarGroup nbGroup1 = new NavBarGroup();
  2. nbGroup1.Name = "nbGroup1";
  3. nbGroup1.Caption = "动态添加的分组";
  4. nbGroup1.SmallImageIndex = -1;
  5. nbGroup1.LargeImageIndex = -1;
  6. //添加到导航栏所有分组集合
  7. navBarControl1.Groups.Add(nbGroup1);
  8. NavBarItem nbItem1 = new NavBarItem();
  9. nbItem1.Name = "nbItem1";
  10. nbItem1.Caption = "动态添加的子项目";
  11. nbItem1.SmallImageIndex = -1;
  12. nbItem1.LargeImageIndex = -1;
  13. nbItem1.LinkClicked += Item_Click;
  14. //添加到导航栏所有子项目集合
  15. navBarControl1.Items.Add(nbItem1);
  16. //添加子项目至某一分组
  17. nbGroup1.ItemLinks.AddRange(new NavBarItemLink[] {
  18. new NavBarItemLink(nbItem1)
  19. });

点击左侧加载控件

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Linq;
using System.Threading.Tasks;
using System.Windows.Forms;
using DevExpress.XtraEditors;
using DevExpress.XtraTab;
using DevExpress.XtraTab.ViewInfo; namespace Demo
{
public partial class XtraForm : DevExpress.XtraBars.Ribbon.RibbonForm
{
public XtraForm()
{
InitializeComponent();
((IXtraTab)xtraTabControl1).ViewInfo.HeaderButtonClick += (s, e) =>
{
//关闭所有page
if (e.Button == TabButtons.Close)
xtraTabControl1.TabPages.ToList().ForEach(x =>
{
x.Dispose();
x = null;
});
}; xtraTabControl1.CloseButtonClick += (s, e) =>
{
//关闭单个page
var args = (ClosePageButtonEventArgs)e;
var page = args.Page as XtraTabPage;
if (page != null)
{
page.Dispose();
page = null;
}
xtraTabControl1.SelectedTabPageIndex -= xtraTabControl1.TabPages.Count;
}; navBarControl1.LinkClicked += (s, e) =>
{
//创建page
CreatePage(e.Link.Item.Caption, e.Link.Item.Tag);
};
}
private void CreatePage(string caption, object tag)
{
if (string.IsNullOrWhiteSpace(caption) || tag == null || string.IsNullOrWhiteSpace(tag.ToString())) return; foreach (XtraTabPage pg in xtraTabControl1.TabPages)
{
if (pg.Text.Contains(caption.Trim()))
{
xtraTabControl1.SelectedTabPage = pg;
return;
}
}
var tabpage = new XtraTabPage() { Text = caption.Trim(), Padding = new Padding(, , , ) }; try
{
var control = Activator.CreateInstance(Type.GetType(tag.ToString().Trim(), false, false)) as UserControl; if (control != null)
{
control.Visible = true;
control.Dock = DockStyle.Fill;
tabpage.Controls.Add(control); tabpage.PageVisible = true;
xtraTabControl1.TabPages.Add(tabpage);
xtraTabControl1.SelectedTabPage = tabpage;
}
}
catch { throw; }
}
//void navBarControl_ActiveGroupChanged(object sender, DevExpress.XtraNavBar.NavBarGroupEventArgs e)
//{
// navigationFrame.SelectedPageIndex = navBarControl1.Groups.IndexOf(e.Group);
//}
void barButtonNavigation_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
int barItemIndex = barSubItemNavigation.ItemLinks.IndexOf(e.Link);
navBarControl1.ActiveGroup = navBarControl1.Groups[barItemIndex];
} private void barButtonItem1_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
//打开文件
userControl11.UpLoadExcel();
}
}
}

2:在navBarItem1属性中

就可以把自定义控件加到tabcontrol里了.

dev NavBarControl控件的更多相关文章

  1. Dev系列控件的AJAX (转)

    介绍Dev系列控件在前台也就是客户端的一些常用方法介绍以及前后台异步通信的方法. 一.Dev Data Edit控件通用属性以及方法: 属性 1.GetEnabled():返回控件是否为可操作状态 2 ...

  2. Winform DevExpress控件库(三) 使用NavBarControl控件定制导航栏

    NavBarControl控件:主要作用是制作包含多个选项组并且每个组里包含多个子选项的导航栏: 位于 工具箱 -> Navigation & Layout(导航栏与布局类控件) 目录下 ...

  3. [DevExpress使用随笔]之NavBarControl控件(一)【转】

    https://blog.csdn.net/HXC_HUANG/article/details/78614092 NavBarControl是具有可扩展组的侧导航控件.一.在Winform窗口中拖入N ...

  4. dev的控件放在没有runat="server"的标签中,回调出现的问题

    dev的控件放在没有runat="server"的标签中,第一次回调是会刷新页面, 有runat="server"时不会刷新页面

  5. ASP.NET Dev ASPxGridView控件使用 ASP.NET水晶报表打印

    1.ASPxGridView控件使用 2.ASP.NET水晶报表客户端打印 3.javascript打印 4.ASPxGridView根据Textbox查询 5. ASPxGridView 列宽 1. ...

  6. Dev系列控件的AJAX使用Demo

    一.Dev Data Edit控件通用属性以及方法: 属性 1.GetEnabled():返回控件是否为可操作状态 2.GetText():返回控件的Text的值 3.SetEnabled():设置控 ...

  7. NavBarControl控件 2015-07-23 16:56 2人阅读 评论(0) 收藏

    NavBarControl控件 1.      新建一个windows窗体应用程序项目 2.      在工具箱中的Navigation& Layout选项卡下找到NavBarControl, ...

  8. dev layoutControl 控件使用

    对于排版控件,用微软的方法都是先拉 label再拉一个 Textbox  ,  虽然微软的控件了有类似于 EXCEL的单元格全并功能,但用起来使终不方便, 今天研究了一下 DEV 的这个控件,比微软的 ...

  9. DEV 第三方控件报表分类汇总

    最近这段时间难得空闲,于是打算做个报表功能,主要实现数据的分类汇总,以便不时之需.首先看看效果: 主要是根据工程类型这个字段进行分类,每个分类下对应的项目金额进行求和,当然,你也可以根据实际需求,进行 ...

随机推荐

  1. C++ 关于MFC多线程编程中的一些注意事项 及自定义消息的处理

    在多线程编程中,最简单的方法,无非就是利用 AfxBeginThread  来创建一个工作线程,看一下这个函数的说明: CWinThread* AFXAPI AfxBeginThread( AFX_T ...

  2. C++ AfxBeginThread的介绍/基本用法

    AfxBeginThread    用户界面线程和工作者线程都是由AfxBeginThread创建的.现在,考察该函数:MFC提供了两个重载版的AfxBeginThread,一个用于用户界面线程,另一 ...

  3. 吴裕雄 python 机器学习-NBYS(1)

    import numpy as np def loadDataSet(): postingList=[['my', 'dog', 'has', 'flea', 'problems', 'help', ...

  4. Redux DevTools浏览器插件调试redux

    与redux的Devtools模块不同,该工具主要依赖浏览器插件完成.模式也比Devtools简单点. redux-devtools 是一个非常棒的工具,它可以让你实时的监控Redux的状态树的Sto ...

  5. cd-hit软件

    参考网址:https://www.jianshu.com/p/57af07b9e986 1.安装 wget https://github.com/weizhongli/cdhit/releases/d ...

  6. eclipce连接数据库增删改查

    1.在mysql中新建一个名为course的数据库,并在其中新建一个course数据表,包含四个字段,id,name,teacher,classname如图(注意:将id设为自动递增,否则后面新增会出 ...

  7. 11.8java课后动手动脑

    package 动手动脑; import javax.swing.*; class AboutException { public static void main(String[] a) { int ...

  8. package.json bin

    [package.json bin] 1.bin field in your package.json which is a map of command name to local file nam ...

  9. JMeter(二十二)与其它工具对比(转载)

    转载自 http://www.cnblogs.com/yangxia-test JMeter工具的扩展性非常好. JMeter工具是开源的.开源不仅仅意味着免费,更重要的是意味着用户可以通过开放的源代 ...

  10. IDEA2017-破解方法

    @方法一 第一步:下载jar 包 地址:https://github.com/locationbai/registerIDEA_2017.3.2_jar 第二部:将下载好的jar放在idea安装目录下 ...