C# tabconctrol切換事件

來源:互聯網
上載者:User

標籤:

tabconctrol沒有click事件,切換page時,調用SelectedIndexChanged事件;

private void tabControl1_SelectedIndexChanged(object sender, System.EventArgs e) 

   switch(this.tabControl1.SelectedIndex) 
   { 
    case 0: 
       MessageBox.Show("tabPage1 is Selected"); 
     break; 
    case 1: 
       MessageBox.Show("tabPage2 is Selected"); 
     break; 
   } 
}

 

以下摘抄擴充:

http://www.cnblogs.com/wang2650/archive/2011/11/07/2240421.html

 

在WinForm開 發的過程中,MDI是一種常見的形式。在MDI主表單開啟的子表單處於活動狀態的只有一個,很多時候我們需要在開啟的MDI子窗 體中切換。然而.Net的架構並沒有提供一種易見的切換方式,當然可以通過“Ctrl+Tab”來切換,但是這種方式是不易見的,並且只能按照開啟表單的 順序來切換。

      下面來介紹一種結合了TabCotrol控制項的軟體設計形式。

       

       這種設計形式要解決三個問題:

      (1)TabControl的TabPage要和表單對應

      (2)TabControl的TabPage切換的時候,對應的表單要啟用

      (3)表單的建立或關閉,對應的TabPage要建立或撤銷

      下面就來一步步的解決這些問題

      首先拖一個TabControl控制項到MDI主視窗中,設定其DOCK為Bottom或者TOP,根據需要也可以設定到左或右。設定其Height為0。主表單添加如下代碼:

       //切換TabPage,將對應的表單啟用
        private void tabControl_SelectedIndexChanged(object sender, EventArgs e)
        {
            if (this.MdiChildren.Length > 0)
            {
                for (int i = 0; i < this.MdiChildren.Length; i++)
                {
                    if (this.tabControl.SelectedIndex == i)
                    {
                        this.MdiChildren[i].Activate();
                        return;
                    }
                }
            }
        }

 

or

  //切換TabPage,將對應的表單啟用
        private void tabControl_SelectedIndexChanged(object sender, EventArgs e)
        {
            this.ChangeTabPage();
        }

        //子表單切換啟用
        private void ChangeTabPage()
        {
            if (this.MdiChildren.Length > 0 && tabControl.SelectedIndex > -1)
            {
                for (int i = 0; i < this.MdiChildren.Length; i++)
                {
                    if (this.tabControl.SelectedIndex == i)
                    {
                        this.MdiChildren[i].WindowState = FormWindowState.Maximized;
                        this.MdiChildren[i].Visible = true;
                        this.MdiChildren[i].Activate();

                    }
                    else if (this.MdiChildren[i].Visible == true)
                    {
                        this.MdiChildren[i].Visible = false;
                    }
                }
            }

        }
        //增加TabPage,將對應的表單啟用
        private void tabControl_ControlAdded(object sender, ControlEventArgs e)
        {
            if (this.tabControl.SelectedIndex == 0)
            this.ChangeTabPage();
        }

        //關閉TabPage,將對應的表單關閉
        private void tabControl_ControlRemoved(object sender, ControlEventArgs e)
        {
            //if (this.tabControl.SelectedIndex == 0)
                //this.ChangeTabPage();
        }

       //表單關閉的時候,撤銷對應的TabPage
        public void RemoveTabPage(TabPage tb)
        {
            this.MultiPageControl.TabPages.Remove(tb);
            if (this.tabControl.TabPages.Count == 0)
            {
                this.TabControlSize = new Size(this.TabControlSize.Width, 0);
            }
        }

        //表單建立的時候,建立對應的TabPage
        public void AddTabPage(TabPage tb)
        {
            if (this.tabControl.TabPages.Count == 0)
            {
                this.TabControlSize = new Size(this.TabControlSize.Width, 20);
            }
            this.MultiPageControl.TabPages.Add(tb);
            this.MultiPageControl.SelectedTab = tb;
        }

         //擷取TabControl控制項,以便子表單調用(唯讀)
        public TabControl MultiPageControl
        {
            get
            {
                return this.tabControl;
            }
        }

        //擷取TabControl控制項的Size屬性,以便子表單調用

        public Size TabControlSize
        {
            get
            {
                return this.tabControl.Size;
            }
            set
            {
                this.tabControl.Size = value;
            }
        }

       對應子表單,每個表單開啟的時候,主表單都需要建立一個TabPage,關閉的時候,都要撤銷一個TabPage,也就是說所有的子表單都有共同的屬性和功能,所以我設定了一個父表單來實現這些功能,子表單通過繼承而擁有這些功能。

        private frmMain frMain = null;
        private TabPage tabPage = new TabPage();

        private void frmTabMain_ParentChanged(object sender, EventArgs e)
        {
            if (this.MdiParent != null)
            {

               this.tabPage.Text = this.Text + "  ";
                frMain = this.MdiParent as frmMain;//擷取主表單
                frMain.AddTabPage(tabPage);//調用主表單方法,建立一個TabPage
            }
        }

        //表單被啟用,對應的TabPage也呈選中狀態

        private void frmTabMain_Enter(object sender, EventArgs e)
        {
            if (this.frMain != null)
            {
                for (int i = 0; i < this.frMain.MdiChildren.Length; i++)
                {
                    if (this.frMain.MdiChildren[i] == this)
                    {
                        this.frMain.MultiPageControl.SelectedIndex = i;
                    }
                }
            }
        }

        //表單關閉,調用主表單方法,撤銷對應TabPage
        private void frmTabTitleMain_FormClosed(object sender, FormClosedEventArgs e)
        {


            this.Dispose();

            this.frMain.RemoveTabPage(tabPage);
        }

       //表單載入的時候,將表單的標題賦給對應的TabPage

        private void frmTabMain_Load(object sender, EventArgs e)
        {
           // this.tabPage.Text = this.Text;
        }

 

C# tabconctrol切換事件

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.