tabcontrol动态生成选项卡,并且在选项卡中添加窗体
http://blog.csdn.net/zx13525079024/article/details/6084733
今天在论坛上看到有人问到,如果在点击TRVEVIEW时动态生成tabcontrol的选项卡,并在选项卡中添加窗体,于是写了一个DEMO,供大家参考
demo下载:http://download.csdn.net/source/2920757

- public partial class Form5 : Form
- {
- public Form5()
- {
- InitializeComponent();
- }
- private void Form5_Load(object sender, EventArgs e)
- {
- TreeNode root = new TreeNode("电话缴费");
- root.Name = "root";
- treeView1.Nodes.Add(root);
- TreeNode tnMobile = new TreeNode("中国移动");
- tnMobile.Name = "mobile";
- root.Nodes.Add(tnMobile);
- TreeNode tnUnion = new TreeNode("中国联通");
- tnUnion.Name = "union";
- root.Nodes.Add(tnUnion);
- root.Expand();
- }
- private TabPage tbMobile = null;
- private TabPage tbUnion = null;
- private void treeView1_AfterSelect(object sender, TreeViewEventArgs e)
- {
- if (treeView1.SelectedNode.Name=="mobile")
- {
- if (ErgodicModiForm("tbmobile", tabControl1))
- {
- tbMobile = new TabPage("中国移动");
- tbMobile.Name = "tbmobile";
- tabControl1.Controls.Add(tbMobile);
- Form6 form = new Form6();
- form.TopLevel = false;
- form.BackColor = Color.White;
- form.Anchor = AnchorStyles.Top | AnchorStyles.Left | AnchorStyles.Right;
- form.FormBorderStyle = FormBorderStyle.None;
- form.Show();
- tbMobile.Controls.Add(form);
- }
- tabControl1.SelectedTab = tbMobile;
- }
- else if (treeView1.SelectedNode.Name=="union")
- {
- if (ErgodicModiForm("tbunion", tabControl1))
- {
- tbUnion = new TabPage("中国联通");
- tbUnion.Name = "tbunion";
- tabControl1.Controls.Add(tbUnion);
- Form2 form = new Form2();
- form.TopLevel = false;
- form.BackColor = Color.White;
- form.Anchor = AnchorStyles.Top | AnchorStyles.Left | AnchorStyles.Right;
- form.FormBorderStyle = FormBorderStyle.None;
- form.Show();
- tbUnion.Controls.Add(form);
- }
- tabControl1.SelectedTab = tbUnion;
- }
- }
- /// </summary>
- /// <param name="MainTabControlKey">选项卡的键值</param>
- /// <param name="objTabControl">要添加到的TabControl对象</param>
- /// <returns></returns>
- private Boolean ErgodicModiForm(string MainTabControlKey, TabControl objTabControl)
- {
- //遍历选项卡判断是否存在该子窗体
- foreach (Control con in objTabControl.Controls)
- {
- TabPage tab = (TabPage)con;
- if (tab.Name == MainTabControlKey)
- {
- return false;//存在
- }
- }
- return true;//不存在
- }
- }

public partial class Form5 : Form
{
public Form5()
{
InitializeComponent();
}
private void Form5_Load(object sender, EventArgs e)
{
TreeNode root = new TreeNode("电话缴费");
root.Name = "root";
treeView1.Nodes.Add(root);
TreeNode tnMobile = new TreeNode("中国移动");
tnMobile.Name = "mobile";
root.Nodes.Add(tnMobile);
TreeNode tnUnion = new TreeNode("中国联通");
tnUnion.Name = "union";
root.Nodes.Add(tnUnion);
root.Expand();
}
private TabPage tbMobile = null;
private TabPage tbUnion = null;
private void treeView1_AfterSelect(object sender, TreeViewEventArgs e)
{
if (treeView1.SelectedNode.Name=="mobile")
{
if (ErgodicModiForm("tbmobile", tabControl1))
{
tbMobile = new TabPage("中国移动");
tbMobile.Name = "tbmobile";
tabControl1.Controls.Add(tbMobile);
Form6 form = new Form6();
form.TopLevel = false;
form.BackColor = Color.White;
form.Anchor = AnchorStyles.Top | AnchorStyles.Left | AnchorStyles.Right;
form.FormBorderStyle = FormBorderStyle.None;
form.Show();
tbMobile.Controls.Add(form);
}
tabControl1.SelectedTab = tbMobile;
}
else if (treeView1.SelectedNode.Name=="union")
{
if (ErgodicModiForm("tbunion", tabControl1))
{
tbUnion = new TabPage("中国联通");
tbUnion.Name = "tbunion";
tabControl1.Controls.Add(tbUnion);
Form2 form = new Form2();
form.TopLevel = false;
form.BackColor = Color.White;
form.Anchor = AnchorStyles.Top | AnchorStyles.Left | AnchorStyles.Right;
form.FormBorderStyle = FormBorderStyle.None;
form.Show();
tbUnion.Controls.Add(form);
}
tabControl1.SelectedTab = tbUnion;
}
}
/// </summary>
/// <param name="MainTabControlKey">选项卡的键值</param>
/// <param name="objTabControl">要添加到的TabControl对象</param>
/// <returns></returns>
private Boolean ErgodicModiForm(string MainTabControlKey, TabControl objTabControl)
{
//遍历选项卡判断是否存在该子窗体
foreach (Control con in objTabControl.Controls)
{
TabPage tab = (TabPage)con;
if (tab.Name == MainTabControlKey)
{
return false;//存在
}
}
return true;//不存在
}
}
tabcontrol动态生成选项卡,并且在选项卡中添加窗体的更多相关文章
- c#在panel或groupbox中添加窗体,实现点击不同按钮或combox时panel中窗体切换,在xtratabcontrol中添加窗体
参考panel添加窗体: http://blog.csdn.net/illegalname/article/details/65444249 http://blog.csdn.net/Eastmoun ...
- winform中动态生成多行label,同时添加滚动条
设计思路大概是这样的,Form内添加一个groupBox,groupBox内添加一个panel,panel的属性AutoScroll=true,在panel内动态添加label. 原始From如下: ...
- js动态创建style节点(js文件中添加css)
ie6 不能 document.createElement('style') 然后append到head标签里.所以就找到这样个好文章 --------------------- 有很多提供动态创建 ...
- Android 动态背景的实现以及SurfaceView中添加EditText控件
首先还是一贯作风,我们先看案例: \ 静态图看不出来效果,如果用过此软件(扎客)的同学们都知道,她的背景会动.怎么样,是不是觉得很时尚,起码比静态的要好(个人观点).其实实现起来并不复杂,这个如果让做 ...
- 向Docx4j生成的word文档中添加布局--第二部分
原文标题:Adding layout to your Docx4j-generated word documents, part 2 原文链接:http://blog.iprofs.nl/2012/1 ...
- C# 动态生成word文档 [C#学习笔记3]关于Main(string[ ] args)中args命令行参数 实现DataTables搜索框查询结果高亮显示 二维码神器QRCoder Asp.net MVC 中 CodeFirst 开发模式实例
C# 动态生成word文档 本文以一个简单的小例子,简述利用C#语言开发word表格相关的知识,仅供学习分享使用,如有不足之处,还请指正. 在工程中引用word的动态库 在项目中,点击项目名称右键-- ...
- jQuery EasyUI中DataGird动态生成列的方法
EasyUI中使用DataGird显示数据列表中,有时需要根据需要显示不同的列,例如,在权限管理中,不同的用户登录后只能查看自己权限范围内的列表字段,这就需要DataGird动态组合列,下面介绍Eas ...
- 用js动态生成css代码
有时候我们需要利用js来动态生成页面上style标签中的css代码,方法很直接,就是直接创建一个style元素,然后设置style元素里面的css代码,最后把它插入到head元素中.但有些兼容性问题我 ...
- (转载)PHP 动态生成表格
(转载)http://hi.baidu.com/shawns/item/c7d51f351c6a0482b711dba6 提要:PHP能够高效地生成HTML代码,其中,动态生成表格是实际应用中经常碰到 ...
随机推荐
- linux 内存
[转]Linux 查看内存(free buffer cache) 转自:http://elf8848.iteye.com/blog/1995638 Linux下如何查内存信息,如内存总量.已使用量.可 ...
- Codeforces Round #345 (Div. 2) E. Table Compression 并查集+智商题
E. Table Compression time limit per test 4 seconds memory limit per test 256 megabytes input standar ...
- Android 通过应用设置系统日期和时间的方法
Android 通过应用设置系统日期和时间的方法 android 2.3 android 4.0 测试可行,不过需要ROOT权限. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ...
- 使用WebStorm运行vue项目
在WebStorm中怎么打开一个已有的项目,这个不用多说,那么如何运行一个vue项目呢? 1.点击下图中右上角的红框. 2.在出现的弹框中选中左上角“+”下的“npm”,如下图所示. 3.选中第二步的 ...
- 步步向前之Element-UI
Table 固定表头 只要在el-table元素中定义了height属性,即可实现固定表头的表格,而不需要额外的代码.例如: <el-table :data="tableData3&q ...
- 配置kubernetes.client的参数遇到的坑
配置kubernetes.client遇到的一些坑: 一,job-name不能重名,如果job-name已经有了,再创建job,则会发生冲突cliflict 这样将会报以下错误:Reason : Co ...
- gdb break 断点设置
http://sourceware.org/gdb/current/onlinedocs/gdb/ 断点设置 gdb断点分类: 以设置断点的命令分类: breakpoint 可以根据行号.函数.条件生 ...
- React Native商城项目实战03 - 包装Navigator
1.在Home目录下新建首页详细页HomeDetail.js /** * 首页详情页 */ import React, { Component } from 'react'; import { App ...
- leetcode206 反转链表 两种做法(循环,递归)
反转链表 leetcode206 方法1 循环 public ListNode reverseList(ListNode head) { if (head == null || head.next = ...
- Spring mvc注解说明
编号 注解 说明 位置 备注 1 @Controller 将类变成Spring Bean 类 现阶段 @Controller . @Service 以及 @Repository 和 @Componen ...