# HZHControls控件库 **Repository Path**: charlie1688/net_winform_custom_control ## Basic Information - **Project Name**: HZHControls控件库 - **Description**: HZHControls控件库,c#的winform自定义控件,对触屏具有更好的操作支持,项目是基于framework4.0,完全原生控件开发,没有使用任何第三方控件,你可以放心的用在你的项目中(winfromcontrol/winformcontrol/.net)。还有更丰富的工业控件持续增加中~~~ - **Primary Language**: C# - **License**: MPL-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1263 - **Created**: 2024-09-25 - **Last Updated**: 2024-09-25 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 官网 ### [https://www.hzhcontrols.cn/](https://www.hzhcontrols.cn/) # NetWinform自定义控件 ### [English README.md(gitee)](https://gitee.com/kwwwvagaa/net_winform_custom_control/blob/master/README.md) #### 介绍 c#winform自定义控件,`对触屏具有更好的操作支持`,项目是基于framework4.0,完全原生控件开发,`没有使用任何第三方控件`,你可以放心的用在你的项目中。 博客地址:[https://www.cnblogs.com/bfyx](https://www.cnblogs.com/bfyx/p/11364884.html) 码云:[https://gitee.com/kwwwvagaa/net_winform_custom_control.git](https://gitee.com/kwwwvagaa/net_winform_custom_control.git) 欢迎前来交流探讨:[点击加入QQ群568015492](//shang.qq.com/wpa/qunwpa?idkey=6e08741ef16fe53bf0314c1c9e336c4f626047943a8b76bac062361bab6b4f8d) #### 如果我的代码对您有用就扫一下吧! ![输入图片说明](https://images.gitee.com/uploads/images/2019/0905/180337_91c70c54_301547.jpeg "zanshangma.jpg") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0905/180345_49207d1d_301547.jpeg "zfb1.jpg") #### 源码仅用于交流学习,开源协议为[MPL2.0](https://gitee.com/kwwwvagaa/net_winform_custom_control/blob/master/LICENSE),如商业使用请进群联系群主 #### 来都来了,点个`Star`再走吧 #### NuGet ``` csharp Install-Package HZH_Controls ``` ``` csharp 以下列出内容仅为部分控件,更多控件效果,请下载源码查看Demo运行效果! ``` ![输入图片说明](https://images.gitee.com/uploads/images/2019/0903/084635_85b9e4a3_301547.gif "1.gif") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0903/084848_9aaca7d2_301547.gif "3.gif") #### 样例 ##### 1、提示窗效果图 ![样例图片](https://images.gitee.com/uploads/images/2019/0808/142043_887cb342_301547.png "提示框1.png") ![样例图片](https://images.gitee.com/uploads/images/2019/0808/142050_1f5588a0_301547.png "提示框2.png") ``` csharp if (FrmDialog.ShowDialog(this, "是否再显示一个没有取消按钮的提示框?", "模式窗体测试", true) == System.Windows.Forms.DialogResult.OK) { FrmDialog.ShowDialog(this, "这是一个没有取消按钮的提示框", "模式窗体测试"); } ``` ##### 2、多输入窗体 ![样例图片](https://images.gitee.com/uploads/images/2019/0808/142218_4c506097_301547.png "多输入窗体.png") ``` csharp FrmInputs frm = new FrmInputs("动态多输入窗体测试", new string[] { "姓名", "电话", "身份证号", "住址" }, new Dictionary() { { "电话", HZH_Controls.TextInputType.Regex }, { "身份证号", HZH_Controls.TextInputType.Regex } }, new Dictionary() { { "电话", "^1\\d{10}$" }, { "身份证号", "^\\d{18}$" } }, new Dictionary() { { "电话", KeyBoardType.UCKeyBorderNum }, { "身份证号", KeyBoardType.UCKeyBorderNum } }, new List() { "姓名", "电话", "身份证号" }); frm.ShowDialog(this); ``` ``` csharp /// /// 功能描述:构造函数 /// 作  者:HZH /// 创建日期:2019-08-05 10:57:26 /// 任务编号:POS /// /// 窗体标题 /// 输入项名称 /// 输入项对应输入类型,key:输入项名称,如不设置默认不控制输入 /// 输入项对应正则规则,当imTypes=Regex时有效,key:输入项名称,如不设置默认不控制输入 /// 文本框键盘,key:输入项名称,如不设置默认英文键盘 /// 必填输入项名称 /// 输入项默认值,key:输入项名称 public FrmInputs( string strTitle, string[] inPutLabels, Dictionary inTypes = null, Dictionary regexs = null, Dictionary keyBoards = null, List mastInputs = null, Dictionary defaultValues = null) ``` ##### 3、Temp1窗体 ![样例图片](https://images.gitee.com/uploads/images/2019/0808/143753_15610b9f_301547.png "temp.png") ``` csharp //新建窗体FrmTemp1Test继承HZH_Controls.Forms.FrmTemp1 FrmTemp1Test frm = new FrmTemp1Test(); frm.ShowDialog(this); ``` ##### 4、有确定取消的窗体1 ![样例图片](https://images.gitee.com/uploads/images/2019/0808/144723_55252cf2_301547.png "oc1.png") ``` csharp //新建窗体FrmOKCancel1Test继承HZH_Controls.Forms.FrmWithOKCancel1 FrmOKCancel1Test frm = new FrmOKCancel1Test(); frm.ShowDialog(this); ``` ##### 5、有确定取消的窗体2 ![样例图片](https://images.gitee.com/uploads/images/2019/0808/145516_07d73ec0_301547.png "oc2.png") ``` csharp //新建窗体FrmOKCancel2Test继承HZH_Controls.Forms.FrmWithOKCancel2 FrmOKCancel2Test frm = new FrmOKCancel2Test(); frm.ShowDialog(this); ``` ##### 6、单标题窗体 ![样例图片](https://images.gitee.com/uploads/images/2019/0808/145718_ff035712_301547.png "t.png") ``` csharp //新建窗体FrmWithTitleTest继承HZH_Controls.Forms.FrmWithTitle FrmWithTitleTest frm = new FrmWithTitleTest(); frm.ShowDialog(this); ``` ##### 7、控件 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0827/113554_d1712a44_301547.png "1.png") *文本框键盘效果* ![样例图片](https://images.gitee.com/uploads/images/2019/0808/153812_40d919ea_301547.png "k1.png") ![样例图片](https://images.gitee.com/uploads/images/2019/0808/153820_31e8fea6_301547.png "k2.png") ![样例图片](https://images.gitee.com/uploads/images/2019/0808/153829_37e4dff5_301547.png "k3.png") `手写输入需要搜狗的手写支持,请复制HandInput文件夹到运行目录下` *时间控件效果* ![样例图片](https://images.gitee.com/uploads/images/2019/0808/160404_b8cf7353_301547.png "time1.png") ![样例图片](https://images.gitee.com/uploads/images/2019/0808/160411_902d4f6d_301547.png "time2.png") ![样例图片](https://images.gitee.com/uploads/images/2019/0808/160418_c92391ba_301547.png "time3.png") *下拉列表数据绑定* ``` csharp //使用方法同原生ComboBox类似 List> lstCom = new List>(); for (int i = 0; i < 5; i++) { lstCom.Add(new KeyValuePair(i.ToString(), "选项" + i)); } this.ucComboBox1.Source = lstCom; this.ucComboBox2.Source = lstCom; this.ucComboBox1.SelectedIndex = 1; this.ucComboBox2.SelectedIndex = 1; ``` *树数据绑定* ``` csharp //使用方法同原生Treeview相同,设置属性IsShowByCustomModel=true则启用自定义模式,否则为原始树 for (int i = 0; i < 5; i++) { TreeNode tn = new TreeNode(" 父节点" + i); for (int j = 0; j < 5; j++) { tn.Nodes.Add(" 子节点" + j); } this.treeViewEx1.Nodes.Add(tn); } ``` *列表数据绑定* ``` csharp //可自定义颜色字体等 List lst = new List(); for (int i = 0; i < 5; i++) { lst.Add(new ListEntity() { ID = i.ToString(), Title = "选项" + i, ShowMoreBtn = true, Source = i }); } this.ucListExt1.SetList(lst); ``` *横向列表数据绑定* ``` csharp List> lstHL = new List>(); for (int i = 0; i < 30; i++) { lstHL.Add(new KeyValuePair(i.ToString(), "选项" + i)); } this.ucHorizontalList1.DataSource = lstHL; ``` ##### 8、Datagridview ![样例图片](https://images.gitee.com/uploads/images/2019/0812/105558_55920c3b_301547.png "table.png") ``` csharp List lstCulumns = new List(); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "ID", HeadText = "编号", Width = 70, WidthType = SizeType.Absolute }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Name", HeadText = "姓名", Width = 50, WidthType = SizeType.Percent }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Age", HeadText = "年龄", Width = 50, WidthType = SizeType.Percent }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Birthday", HeadText = "生日", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((DateTime)a).ToString("yyyy-MM-dd"); } }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Sex", HeadText = "性别", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((int)a) == 0 ? "女" : "男"; } }); this.ucDataGridView1.Columns = lstCulumns; this.ucDataGridView1.IsShowCheckBox = true; List lstSource = new List(); for (int i = 0; i < 20; i++) { TestModel model = new TestModel() { ID = i.ToString(), Age = 3 * i, Name = "姓名——" + i, Birthday = DateTime.Now.AddYears(-10), Sex = i % 2 }; lstSource.Add(model); } this.ucDataGridView1.DataSource = lstSource; this.ucDataGridView1.First(); ``` >当使用分页控件时,不再需要指定DataSource数据源属性,只需要指定翻页控件的DataSource属性即可 >如果预置的表格行无法满足你的需求,你还可以自定义行控件,具体做法为: 1. 新增自定义控件,实现接口IDataGridViewRow 2. 参照UCDataGridViewRow实现你自定义的行 3. 设置datagridview的RowType属性即可 >Page属性定义了翻页控件,如果UCPagerControl不满足你的需求,请自定义翻页控件并继承UCPagerControlBase, 当为空时不启用翻页控件,当启用翻页控件时每页将显示适当的数据,不再出现滚动条。 ##### 9、翻页控件 ![样例图片](https://images.gitee.com/uploads/images/2019/0812/105558_55920c3b_301547.png "table.png") >另一种分页控件样式 ![样例图片](https://images.gitee.com/uploads/images/2019/0815/164510_06392eeb_301547.png "page.png") ``` csharp List lstCulumns = new List(); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "ID", HeadText = "编号", Width = 70, WidthType = SizeType.Absolute }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Name", HeadText = "姓名", Width = 50, WidthType = SizeType.Percent }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Age", HeadText = "年龄", Width = 50, WidthType = SizeType.Percent }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Birthday", HeadText = "生日", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((DateTime)a).ToString("yyyy-MM-dd"); } }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Sex", HeadText = "性别", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((int)a) == 0 ? "女" : "男"; } }); this.ucDataGridView1.Columns = lstCulumns; this.ucDataGridView1.IsShowCheckBox = true; List lstSource = new List(); for (int i = 0; i < 20; i++) { TestModel model = new TestModel() { ID = i.ToString(), Age = 3 * i, Name = "姓名——" + i, Birthday = DateTime.Now.AddYears(-10), Sex = i % 2 }; lstSource.Add(model); } UCPagerControl page = new UCPagerControl(); //UCPagerControl2 page = new UCPagerControl2(); page.DataSource = lstSource; this.ucDataGridView1.Page = page; this.ucDataGridView1.First(); ``` >如果UCPagerControl不满足你的需求,请自定义翻页控件并继承UCPagerControlBase,比如改变样式,增加逻辑等等 >如果需要下标从10开始的一页数据,可以设置StartIndex=10,然后调用GetCurrentSource()即可,用法如下: ``` csharp m_page.DataSource=lstSource; m_page.PageSize = ShowCount; m_page.StartIndex=10; this.dgv.DataSource = m_page.GetCurrentSource(); ``` >翻页控件可用于任何列表形式的控件,以上代码示例仅以datagridview说明用法,用法如下: 1. 设置属性DataSource数据源 2. 设置属性PageSize每页显示数据量 3. 设置时间ShowSourceChanged,在时间中向目标控件设置当前页数据源 4. 如果页面加载后没有显示第一页数据,可以手动调用一下GetCurrentSource()并赋值给目标控件即可,例如: ``` csharp m_page.DataSource=lstSource; m_page.PageSize = ShowCount; this.dgv.DataSource = m_page.GetCurrentSource(); ``` ##### 10、气泡提示效果图(5种内置及自定义样式) ![样例图片](https://images.gitee.com/uploads/images/2019/0812/112144_6af9389c_301547.png "tips.png") ``` csharp FrmTips.ShowTipsError(this, "Error提示信息"); FrmTips.ShowTipsInfo(this, "Info提示信息"); FrmTips.ShowTipsSuccess(this, "Success提示信息"); FrmTips.ShowTipsWarning(this, "Warning提示信息"); /*自定义可使用 public static FrmTips ShowTips( Form frm, string strMsg, int intAutoColseTime = 0, bool blnShowCoseBtn = true, ContentAlignment align = ContentAlignment.BottomLeft, Point? point = null, TipsSizeMode mode = TipsSizeMode.Small, Size? size = null, TipsState state = TipsState.Default) */ ``` ##### 11、多线程操作等待 ![样例图片](https://images.gitee.com/uploads/images/2019/0808/144201_932c5259_301547.png "waiting.png") ``` csharp //此窗体一般用在耗时线程操作时显示等待动图,如下为多线程耗时操作时样例 ControlHelper.ThreadRunExt(this, () => { Thread.Sleep(5000); ControlHelper.ThreadInvokerControl(this, () => { FrmTips.ShowTipsSuccess(this, "FrmWaiting测试"); }); }, null, this); //ControlHelper.ThreadRunExt为开启一个线程执行任务 //ControlHelper.ThreadInvokerControl为异步委托 调用控件 ``` ``` csharp /// /// 使用一个线程执行一个操作 /// /// 父控件 /// 执行内容 /// 执行后回调 /// 执行期间禁用控件列表 /// 执行期间是否显示等待提示 /// 执行期间等待提示内容,默认为“正在处理,请稍候...” /// 延迟显示等待提示时间 public static void ThreadRunExt( Control parent, Action func, Action callback, Control[] enableControl = null, bool blnShowSplashScreen = true, string strMsg = null, int intSplashScreenDelayTime = 200) ``` ##### 12、菜单导航控件 ![样例图片](https://images.gitee.com/uploads/images/2019/0815/103949_9fdb0d12_301547.png "menu.png") ``` csharp List lstMenu = new List(); for (int i = 0; i < 5; i++) { MenuItemEntity item = new MenuItemEntity() { Key = "p" + i.ToString(), Text = "菜单项" + i, DataSource = "这里编写一些自定义的数据源,用于扩展" }; item.Childrens = new List(); for (int j = 0; j < 5; j++) { MenuItemEntity item2 = new MenuItemEntity() { Key = "c" + i.ToString(), Text = "菜单子项" + i + "-" + j, DataSource = "这里编写一些自定义的数据源,用于扩展" }; item.Childrens.Add(item2); } lstMenu.Add(item); } this.ucMenu1.DataSource = lstMenu; ``` >如果预置的样式无法满足你的需求,你还可以自定义节点控件,具体做法为: 1. 新增自定义控件,实现接口IMenuItem,可分别定义父节点和子节点 2. 参照UCMenuChildrenItem或UCMenuParentItem实现你自定义的节点 3. 设置UCMenu的父节点ParentItemType属性和子节点ChildrenItemType属性即可 >如果要修改节点样式,比如背景色等,可使用UCMenu的ParentItemStyles或ChildrenItemStyles,比如 ``` csharp this.ucMenu1.ParentItemStyles = new Dictionary() { {"BackColor",Color.Red } }; this.ucMenu1.ChildrenItemStyles = new Dictionary() { {"BackColor",Color.Yellow } }; ``` >菜单默认显示样式为Fill,当菜单项较多时会导致子项无法显示,此时你应修改菜单样式为Top即可 ``` csharp this.ucMenu1.MenuStyle = MenuStyle.Top; ``` ##### 13、按钮组 ![样例图片](https://images.gitee.com/uploads/images/2019/0815/155103_ced4e03c_301547.png "btnGroup.png") ``` csharp ucBtnsGroup1.DataSource = new Dictionary() { { "1", "男" }, { "0", "女" } }; ucBtnsGroup2.IsMultiple = true; ucBtnsGroup2.DataSource = new Dictionary() { { "1", "河南" }, { "2", "北京" }, { "3", "湖南" }, { "4", "上海" } }; ucBtnsGroup2.SelectItem = new List() { "2","3"}; ``` ##### 14、Tab页 ![样例图片](https://images.gitee.com/uploads/images/2019/0817/104555_cc0b40fc_301547.png "tab.png") ##### 15、步骤控件 ![样例图片](https://images.gitee.com/uploads/images/2019/0817/162039_98824330_301547.png "1.png") ![样例图片](https://images.gitee.com/uploads/images/2019/0819/091013_f4ab8661_301547.png "2.png") ##### 16、有标题的面板 ![样例图片](https://images.gitee.com/uploads/images/2019/0817/162107_8a576e36_301547.png "2.png") ##### 17、进度条 进度条支持圆环或扇形显示,支持百分比和数值显示 ![样例图片](https://images.gitee.com/uploads/images/2019/0819/083846_335ab0b5_301547.gif "1.gif") ![样例图片](https://images.gitee.com/uploads/images/2019/0819/083853_94e1f3f6_301547.gif "2.gif") ![样例图片](https://images.gitee.com/uploads/images/2019/0820/115413_8a6564c5_301547.gif "2.gif") ![样例图片](https://images.gitee.com/uploads/images/2019/0822/085500_2943930c_301547.gif "1.gif") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0823/133831_0cf0344d_301547.gif "5.gif") ##### 18、面包屑导航 ![样例图片](https://images.gitee.com/uploads/images/2019/0819/111929_25c71140_301547.png "1.png") ##### 19、开关 ![样例图片](https://images.gitee.com/uploads/images/2019/0819/160415_121416e0_301547.png "switch.png") ##### 20、ListView ![样例图片](https://images.gitee.com/uploads/images/2019/0822/113629_bfa4fbc2_301547.png "listview.png") ![样例图片](https://images.gitee.com/uploads/images/2019/0822/113641_3cd8df3f_301547.png "listview2.png") ListView的项元素提供了接口实现,当你觉得我写的子项并不能满足你的需求的时候,你可以添加一个控件,实现接口,然后将你的控件指定给Listview的属性ItemType即可了。 同样的,我也提供了翻页控件,属性Page,只要是继承UCPagerControlBase的翻页控件都可以兼容哦,当然你也可以不用翻页控件。 看一下调用吧 ``` csharp List lstSource = new List(); for (int i = 0; i < 200; i++) { lstSource.Add("项-" + i); } //使用分页控件 var page = new UCPagerControl2(); page.DataSource = lstSource; this.ucListView1.Page = page; //不使用分页控件 //this.ucListView1.DataSource = lstSource; ``` ##### 21、水波 ![样例图片](https://images.gitee.com/uploads/images/2019/0823/090215_71d3c692_301547.gif "2.gif") ##### 22、波形图表 ![样例图片](https://images.gitee.com/uploads/images/2019/0823/090247_789712bc_301547.gif "1.gif") ``` csharp //timer事件中定时随机添加数字 Random r = new Random(); int i = r.Next(100, 1000); this.ucWaveWithSource1.AddSource(i.ToString(), i); ``` ##### 23、树表格 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0826/154617_e0b57ff6_301547.png "treegrid.png") ``` csharp private void FrmTemp1Test_Load(object sender, EventArgs e) { this.ucDataGridView1.RowType = typeof(UCDataGridViewTreeRow); this.ucDataGridView1.IsAutoHeight = true; List lstCulumns = new List(); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "ID", HeadText = "编号", Width = 70, WidthType = SizeType.Absolute }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Name", HeadText = "姓名", Width = 50, WidthType = SizeType.Percent }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Age", HeadText = "年龄", Width = 50, WidthType = SizeType.Percent }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Birthday", HeadText = "生日", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((DateTime)a).ToString("yyyy-MM-dd"); } }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Sex", HeadText = "性别", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((int)a) == 0 ? "女" : "男"; } }); this.ucDataGridView1.Columns = lstCulumns; this.ucDataGridView1.IsShowCheckBox = true; List lstSource = new List(); for (int i = 0; i < 200; i++) { TestModel model = new TestModel() { ID = i.ToString(), Age = 3 * i, Name = "姓名——" + i, Birthday = DateTime.Now.AddYears(-10), Sex = i % 2 }; lstSource.Add(model); AddChilds(model, 5); } var page = new UCPagerControl2(); page.DataSource = lstSource; this.ucDataGridView1.Page = page; this.ucDataGridView1.First(); } private void AddChilds(TestModel tm, int intCount) { if (intCount <= 0) return; tm.Childrens = new List(); for (int i = 0; i < 5; i++) { TestModel model = new TestModel() { ID = i.ToString(), Age = 3 * i, Name = intCount + "——" + i, Birthday = DateTime.Now.AddYears(-10), Sex = i % 2 }; tm.Childrens.Add(model); AddChilds(model, intCount - 1); } } ``` ##### 24、表格下拉框 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0828/174756_ecc838e5_301547.png "dropdowngrid.png") ``` csharp List lstCulumns = new List(); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "ID", HeadText = "编号", Width = 70, WidthType = SizeType.Absolute }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Name", HeadText = "姓名", Width = 100, WidthType = SizeType.Absolute }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Age", HeadText = "年龄", Width = 100, WidthType = SizeType.Absolute }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Birthday", HeadText = "生日", Width = 120, WidthType = SizeType.Absolute, Format = (a) => { return ((DateTime)a).ToString("yyyy-MM-dd"); } }); lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Sex", HeadText = "性别", Width = 100, WidthType = SizeType.Absolute, Format = (a) => { return ((int)a) == 0 ? "女" : "男"; } }); this.ucComboxGrid1.GridColumns = lstCulumns; List lstSourceGrid = new List(); for (int i = 0; i < 100; i++) { TestModel model = new TestModel() { ID = i.ToString(), Age = 3 * i, Name = "姓名——" + i, Birthday = DateTime.Now.AddYears(-10), Sex = i % 2 }; lstSourceGrid.Add(model); } this.ucComboxGrid1.GridDataSource = lstSourceGrid; ``` ##### 25、滑块 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0829/112813_d4d2a09b_301547.gif "1.gif") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0830/102356_7cbfed3b_301547.gif "2.gif") ##### 26、文字提示(toolTips) ![输入图片说明](https://images.gitee.com/uploads/images/2019/0829/154507_199fdff5_301547.png "anchorTips.png") ``` csharp HZH_Controls.Forms.FrmAnchorTips.ShowTips(button1, "测试提示信息\nLEFT", AnchorTipsLocation.LEFT); HZH_Controls.Forms.FrmAnchorTips.ShowTips(button1, "测试提示信息\nRIGHT", AnchorTipsLocation.RIGHT); HZH_Controls.Forms.FrmAnchorTips.ShowTips(button1, "测试提示信息\nTOP", AnchorTipsLocation.TOP); HZH_Controls.Forms.FrmAnchorTips.ShowTips(button1, "测试提示信息\nBOTTOM", AnchorTipsLocation.BOTTOM); ``` ##### 26、LED数字 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0902/181109_92cf14c4_301547.gif "1.gif") ##### 27、滚动文字 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0903/100148_7d7f8980_301547.gif "4.gif") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0903/100217_d09dff79_301547.gif "5.gif") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0903/100225_6cf0a534_301547.gif "6.gif") ##### 28、仪表 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0904/095910_0dd8ec1e_301547.png "yibiao.png") ##### 29、管道 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0904/181918_43024834_301547.gif "1.gif") ##### 30、瓶子 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0905/152444_d1b13c6d_301547.png "pingzi.png") ##### 31、传送带 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0905/152454_bd9c45cf_301547.gif "3.gif") ##### 32、管道阀门 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0906/165031_e365fd63_301547.gif "5.gif") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0906/165040_4ad642d8_301547.gif "6.gif") ##### 33、鼓风机 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0909/134327_6e99dd33_301547.png "fj.png") ##### 34、信号灯 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0909/162334_5a8c6b42_301547.gif "1.gif") ##### 35、警灯 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0910/094631_ab30696f_301547.gif "2.gif") ##### 36、温度计 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0910/163155_5bee72e6_301547.png "wdj.png") ##### 37、组织架构图 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0911/143628_cfaee8b4_301547.gif "1.gif") #### 38、图标 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0912/151717_4fe896c4_301547.png "1.png") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0912/151726_2b603d87_301547.png "2.png") #### 39、柱状图 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0917/152524_0d8024a8_301547.png "zzt.png") #### 40、饼状图 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0923/142525_558c4581_301547.png "bzt.png") #### 40、折线图 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0924/150550_248a013c_301547.gif "1.gif") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0924/150557_13fd9f5f_301547.png "1.png") ![输入图片说明](https://images.gitee.com/uploads/images/2019/0924/150604_73e0864b_301547.png "2.png") #### 41、雷达图 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0925/150733_a92c2d24_301547.png "ldt.png") #### 42、资源加载窗体 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0926/101018_94d1c71f_301547.gif "1.gif") #### 43、金字塔图 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0926/144247_8dcdd0a6_301547.png "jzt.png") #### 44、控件水印组件 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0927/145944_e31fb93c_301547.gif "1.gif") #### 45、表单验证组件 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0928/094554_4b5aa376_301547.png "yz.png") #### 46、采样控件 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0928/151849_b1b6309f_301547.png "cy.png") ``` csharp 注意观察控件交叉的地方,没有遮挡。 控件根据设置的驱动裁剪有效工作区域来实现无遮挡。 ``` #### 47、倒影组件 ![输入图片说明](https://images.gitee.com/uploads/images/2019/0928/163958_cf233dc5_301547.png "dy.png") #### 48、导航菜单 ![输入图片说明](https://images.gitee.com/uploads/images/2019/1009/085904_b118d7cc_301547.png "cd.png") ![输入图片说明](https://images.gitee.com/uploads/images/2019/1011/112138_8b47726f_301547.png "cd.png") ![输入图片说明](https://images.gitee.com/uploads/images/2019/1012/105648_ac1ac7d0_301547.gif "1.gif") #### 49、分隔标签线 ![输入图片说明](https://images.gitee.com/uploads/images/2019/1009/110329_4d443363_301547.png "fgx.png") #### 50、时间轴 ![输入图片说明](https://images.gitee.com/uploads/images/2019/1009/150312_c4211fcc_301547.png "sjz.png") #### 51、穿梭框 ![输入图片说明](https://images.gitee.com/uploads/images/2019/1010/113134_99cfa388_301547.gif "1.gif") #### 52、引用区块 ![输入图片说明](https://images.gitee.com/uploads/images/2019/1015/090854_152076a0_301547.png "qk.png") #### 最后的话 最后,喜欢请点下stars,如果有其他一些什么常用的控件可以在留言哦 对你有用的话请打赏一下吧,谢谢。