winform tabpage 绘制关闭按钮点击关闭事件和双击tab关闭页面

原创 2015年07月09日 14:03:37

ps:尝试下新的编辑器,看看啥感觉哈。
界面效果图
说明:
1.button1用于添加tab页面
2.button2用户删除当前tab页面
3.tabcontrol 命名MainTabControl
关键部分:绘制关闭的“x”按钮点击关闭当前tab页面,双击tab标签关闭tab页面。

绘制”x”代码部分(网络上拷贝)

//绘制“X”号即关闭按钮  
        private void MainTabControl_DrawItem(object sender, DrawItemEventArgs e)
        {

            try
            {
                Rectangle myTabRect = this.MainTabControl.GetTabRect(e.Index);

                //先添加TabPage属性     
                e.Graphics.DrawString(this.MainTabControl.TabPages[e.Index].Text
                , this.Font, SystemBrushes.ControlText, myTabRect.X + 2, myTabRect.Y + 2);

                //再画一个矩形框  
                using (Pen p = new Pen(Color.White))
                {
                    myTabRect.Offset(myTabRect.Width - (CLOSE_SIZE + 3), 2);
                    myTabRect.Width = CLOSE_SIZE;
                    myTabRect.Height = CLOSE_SIZE;
                    e.Graphics.DrawRectangle(p, myTabRect);

                }

                //填充矩形框  
                Color recColor = e.State == DrawItemState.Selected ? Color.White : Color.White;
                using (Brush b = new SolidBrush(recColor))
                {
                    e.Graphics.FillRectangle(b, myTabRect);
                }

                //画关闭符号  
                using (Pen objpen = new Pen(Color.Black))
                {
                    //"\"线  
                    Point p1 = new Point(myTabRect.X + 3, myTabRect.Y + 3);
                    Point p2 = new Point(myTabRect.X + myTabRect.Width - 3, myTabRect.Y + myTabRect.Height - 3);
                    e.Graphics.DrawLine(objpen, p1, p2);

                    //"/"线  
                    Point p3 = new Point(myTabRect.X + 3, myTabRect.Y + myTabRect.Height - 3);
                    Point p4 = new Point(myTabRect.X + myTabRect.Width - 3, myTabRect.Y + 3);
                    e.Graphics.DrawLine(objpen, p3, p4);
                }

                e.Graphics.Dispose();
            }
            catch(Exception ex)
            {
                MessageBox.Show(ex.Message);
            }


        }
        //=======================================================================  

点击”x”关闭tab页面

//关闭按钮功能  
        private void MainTabControl_MouseDown(object sender, MouseEventArgs e)
        {
            if (e.Button == MouseButtons.Left)
            {
                int x = e.X, y = e.Y;

                //计算关闭区域     
                Rectangle myTabRect = this.MainTabControl.GetTabRect(this.MainTabControl.SelectedIndex);

                myTabRect.Offset(myTabRect.Width - (CLOSE_SIZE + 3), 2);
                myTabRect.Width = CLOSE_SIZE;
                myTabRect.Height = CLOSE_SIZE;

                //如果鼠标在区域内就关闭选项卡     
                bool isClose = x > myTabRect.X && x < myTabRect.Right
                 && y > myTabRect.Y && y < myTabRect.Bottom;

                if (isClose == true)
                {
                    this.MainTabControl.TabPages.Remove(this.MainTabControl.SelectedTab);
                }
            }


        }

双击选项卡关闭tab页面

private void MainTabControl_MouseDoubleClick(object sender, EventArgs e) {
            MainTabControl.TabPages.Remove(MainTabControl.SelectedTab); 
        }

button1,button2 click事件

private void button1_Click(object sender, EventArgs e)
        {
            string title = "text";
            bool ifExits = false;
            foreach (TabPage tb in this.MainTabControl.TabPages) {
                if (tb.Text == title) {
                    ifExits=true; 
                }
            }
            if (!ifExits)
            {
                TabPage tabtage = new TabPage();
                tabtage.Text = title;
                tabtage.ToolTipText = title;
                TemplateForm form = new TemplateForm();
                form.FormBorderStyle = FormBorderStyle.None; //隐藏子窗体边框(去除最小花,最大化,关闭等按钮)
                form.TopLevel =
                false; //指示子窗体非顶级窗体
                tabtage.Controls.Add(form);//将子窗体载入panel
                form.Show();

                MainTabControl.TabPages.Add(tabtage);
                MainTabControl.SelectedTab = tabtage;
                //image = new Bitmap(TestTabPageTabControl.Properties.Resources.box_okay);  
            }
        }

        private void button2_Click(object sender, EventArgs e)
        {
            if (MainTabControl.SelectedTab != null)
            {
                MainTabControl.TabPages.Remove(MainTabControl.SelectedTab);
            }
        }

form load事件

private void testForm_Load(object sender, System.EventArgs e)
        {
            //清空控件  
            //this.MainTabControl.TabPages.Clear();  
            //绘制的方式OwnerDrawFixed表示由窗体绘制大小也一样  
            this.MainTabControl.DrawMode = TabDrawMode.OwnerDrawFixed;
            this.MainTabControl.Padding = new System.Drawing.Point(CLOSE_SIZE, CLOSE_SIZE / 2);
            this.MainTabControl.DrawItem += new DrawItemEventHandler(this.MainTabControl_DrawItem);
            this.MainTabControl.MouseDown += new System.Windows.Forms.MouseEventHandler(this.MainTabControl_MouseDown);
            this.MainTabControl.MouseDoubleClick += new System.Windows.Forms.MouseEventHandler(this.MainTabControl_MouseDoubleClick);
        }

代码都比较简单 流程也简单 效果也就不是特别好看 做一个记录,免得忘记了

c#中给tabpage增加关闭按钮

先来看下效果 要实现这个功能,我们分两步来走,首先是需要绘制这个按钮,然后再对这个按钮的事件作出响应 1、将tabcontrol的绘制模式属性修改为OwnerDrawFixed,这...
  • u013944260
  • u013944260
  • 2017年08月05日 15:11
  • 897

在tabpage中添加关闭按钮

以下是main窗体部分源码 ====================================== //在tabPage中添加关闭按钮         const int CLOSE_SI...
  • u011072140
  • u011072140
  • 2017年03月29日 18:11
  • 590

贴一段关闭tabpage的源码

private void tabControl1_MouseDoubleClick(object sender, MouseEventArgs e) { ...
  • abcjennifer
  • abcjennifer
  • 2010年08月08日 14:44
  • 3626

C#的TabControl模拟IE7程序事例,带关闭的按钮的TabPage.

  • 2010年06月10日 17:47
  • 43KB
  • 下载

选项卡带关闭按钮的TabControl

选项卡带关闭按钮的TabControl   很多软件,像FireFox之类的多页面组织的软件,都在选项卡标签的右边放一按钮,以方便用户关闭选项卡。然而dotnet自带的TabControl并没有...
  • az44yao
  • az44yao
  • 2014年06月19日 15:18
  • 9045

C#重绘TabControl的Tabpage标签,添加图片及关闭按钮

  • 2011年04月08日 09:07
  • 66KB
  • 下载

C#—Dev XtraTabControl动态增加Tab和关闭选项卡方法

记录一下以免以后忘了 添加xtraTabControl的CloseButtonClick事件 添加using DevExpress.XtraTab; private void xtra...
  • huang369509940
  • huang369509940
  • 2014年03月02日 22:41
  • 9200

TabControl添加关闭按钮

TabControl添加关闭按钮 原文:http://www.cnblogs.com/sufei/archive/2009/11/28/1612823.html const in...
  • u013908405
  • u013908405
  • 2015年12月24日 10:40
  • 1082

winform用tabcontrol切换mdi子窗口及为tabcontrol的page添加关闭按钮

  • 2013年12月19日 16:02
  • 160KB
  • 下载

c#重写TabControl控件实现关闭按钮的方法

转载自:http://www.jb51.net/article/35248.htm 1.c#里面的TabControl控件没有关闭按钮,而且很难看。 2.有一些已经做好的第三方控件,但是收费。 ...
  • mao_mao37
  • mao_mao37
  • 2016年04月21日 20:33
  • 3165
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:winform tabpage 绘制关闭按钮点击关闭事件和双击tab关闭页面
举报原因:
原因补充:

(最多只允许输入30个字)