Click here to Skip to main content
Click here to Skip to main content

A TabControl with tab page closing capability

, 12 Dec 2005
Rate this:
Please Sign up or sign in to vote.
An extension of the tab control that adds a closing 'X' at the left side of the tab page: pressing it will close the tab page.

Sample Image

Introduction

I was writing an application that uses a TabControl. I needed to give my user the ability to close tab pages dynamically, so I was looking for a tab control that has a close sign on every page, but could not find one. So I started developing one. The result of this development is the following class: TabControlEx.

Using the code

To use the the tab control, I perform the following action:

  1. Add a regular TabControl to my form.
  2. Edit the Designer file (if your form name is Form1, you need to edit the Form1.Designer.cs file).

You need to change the type of the tab control from "System.Windows.Forms.TabControl" to "Yoramo.GuiLib.TabControlEx". You also need to change the instantiation statement (in the "InitializeComponent" method) to create the correct type of tab control.

The TabControlEx Code

TabControlEx derives from System.Windows.Forms.TabControl. It implements the OnDrawItem to draw the 'x' sign on the page (Close sign) and the OnMouseClick to figure out if the close sign has been clicked. In the constructor, I have changed the DrawMode to TabDrawMode.OwnerDrawFixed to activate the OnDrawItem. In order to enable the application to refuse closing a tab, or to provide an event to enable saving data, I have defined an event called PreRemoveTabPage.

using System;
using System.Windows.Forms;
using System.Drawing;

namespace Yoramo.GuiLib
{
    public delegate bool PreRemoveTab(int indx);
    public class TabControlEx : TabControl
    {
        public TabControlEx()
            : base()
        {
            PreRemoveTabPage = null;
            this.DrawMode = TabDrawMode.OwnerDrawFixed;
        }

        public PreRemoveTab PreRemoveTabPage;

        protected override void OnDrawItem(DrawItemEventArgs e)
        {
            Rectangle r = e.Bounds;
            r = GetTabRect(e.Index);
            r.Offset(2, 2);
            r.Width = 5;
            r.Height = 5;
            Brush b = new SolidBrush(Color.Black);
            Pen p = new Pen(b);
            e.Graphics.DrawLine(p, r.X, r.Y, r.X + r.Width, r.Y + r.Height);
            e.Graphics.DrawLine(p, r.X + r.Width, r.Y, r.X, r.Y + r.Height);

            string titel = this.TabPages[e.Index].Text;
            Font f = this.Font;
            e.Graphics.DrawString(titel, f, b, new PointF(r.X + 5, r.Y));
        }
        protected override void OnMouseClick(MouseEventArgs e)
        {
            Point p = e.Location;
            for (int i = 0; i < TabCount; i++)
            {
                Rectangle r = GetTabRect(i);
                r.Offset(2, 2);
                r.Width = 5;
                r.Height = 5;
                if (r.Contains(p))
                {
                    CloseTab(i);
                }
            }
        }

        private void CloseTab(int i)
        {
            if (PreRemoveTabPage != null)
            {
                bool closeIt = PreRemoveTabPage(i);
                if (!closeIt)
                    return;
            }
            TabPages.Remove(TabPages[i]);
        }
    }
}

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

Share

About the Author

Yoramo
Architect
Israel Israel
No Biography provided

Comments and Discussions

 
QuestionThanks Pinmemberwilmarux20-Jun-13 11:02 
Newssources of a similar control Pinmemberjrocnuck28-Mar-07 17:42 
Questiongreat code, image? PinmemberNorberto Olazabal28-Mar-07 17:29 
AnswerRe: great code, image? PinmemberYoramo31-Mar-07 5:22 
GeneralTight code Pinmemberskeletal4528-Feb-07 0:30 
GeneralOnMouseDown -- no valid operation PinmemberFish19813-May-06 12:36 
GeneralRe: OnMouseDown -- no valid operation PinmemberFish19813-May-06 12:43 
AnswerRe: OnMouseDown -- no valid operation PinmemberYoramo3-May-06 14:55 
GeneralRe: OnMouseDown -- no valid operation PinmemberFish19815-May-06 5:03 
GeneralGreat Code Pinmemberfiredraken23-Mar-06 19:08 
GeneralRe: Great Code PinmemberYoramo23-Mar-06 20:00 
GeneralRe: Great Code Pinmemberfiredraken23-Mar-06 20:45 
GeneralRe: Great Code PinmemberYoramo24-Mar-06 7:36 
GeneralVisual style lost PinmemberNikhil_be_IT13-Mar-06 23:53 
GeneralRe: Visual style lost PinmemberYoramo23-Mar-06 19:56 
GeneralRe: Visual style lost Pinmemberzvi12346721-Sep-10 0:27 
Generalw00t PinmemberBerger20064-Jan-06 10:44 
GeneralRe: w00t PinmemberYoramo14-Jan-06 22:22 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web04 | 2.8.141216.1 | Last Updated 12 Dec 2005
Article Copyright 2005 by Yoramo
Everything else Copyright © CodeProject, 1999-2014
Layout: fixed | fluid