winform隐藏tablcontrol的标签

本文介绍如何在WinForm应用中使用TabControl替代多个独立窗体来实现类似安装程序的步骤导航功能。通过解决TabControl标签隐藏及背景透明问题,利用第三方库CSKIN的TabControl实现这一目标。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

因为项目原因,需要实现类似于安装程序里面的上一步下一步,而且还要跳步,最开始实现方式是把每个步奏设置为一个独立的窗体,然后show,close,代码可想而知,后来灵光一闪想到用tabControl,正准备大干一场时,发现这货居然表头不能隐藏,用了一些别扭的方法后勉强隐藏了,又发现这货背景色不能设置为透明。。。好在天无绝人之路,前几天搜到了大名鼎鼎的CSKIN(请原谅我的无知。。。),用了插件带的tabcontrol,发现可以背景色透明,再加上这几天搜索的结果,于是想能不能扩展一下,达到需求,废话少说,直接上代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Collections;
using System.Windows.Forms;

namespace WindowsFormsApplication1
{
    /// <summary>
    /// 文件名:TabControlUltimate
    /// 描述:基于SkinTabControl的选项卡,隐藏头部,支持子选项卡load事件
    /// 作者:Bright
    /// 日期:2017/4/27 22:48:33
    /// 修改记录:
    ///         R1:
    ///             作者   
    ///             日期     
    ///             原因
    ///         R2:
    ///             作者   
    ///             日期     
    ///             原因
    /// </summary>
    public class TabControlUltimate : CCWin.SkinControl.SkinTabControl
    {
        protected override void OnCreateControl()
        {
            if( !this.DesignMode && TabCount > 0 )
            {
                System.Windows.Forms.Panel p = new System.Windows.Forms.Panel();
                p.SuspendLayout();
                this.SuspendLayout();
                p.Parent = this.Parent;
                p.BackColor = System.Drawing.Color.Transparent;
                p.Size = new System.Drawing.Size( this.Size.Width, this.TabPages[0].Size.Height );
                p.Location = new System.Drawing.Point( this.Location.X, this.Location.Y + this.Size.Height - this.TabPages[0].Size.Height );
                this.Parent = p;
                this.Location = new System.Drawing.Point( 0, this.TabPages[0].Size.Height - this.Size.Height );
                this.ResumeLayout( false );
                p.ResumeLayout( false );
            }
            base.OnCreateControl();
        }

        protected override void OnPaint( System.Windows.Forms.PaintEventArgs e )
        {
            if( this.DesignMode )
            {
                
            }
            base.OnPaint( e );
        }

        protected override void OnKeyDown( KeyEventArgs e )
        {
            // 屏蔽control+tab
            if(e.Modifiers == Keys.Control&& e.KeyCode == Keys.Tab )
            {
                e.Handled = true;
                return; //trap CTRL+TAB 

            }
            else if( e.Modifiers == (Keys.Control | Keys.Shift) && e.KeyCode == Keys.Tab )
            {
                e.Handled = true;
                return; //trap  CTRL+SHIFT+TAB
            }
            else
            {

                base.OnKeyDown( e );

            }
        }


        /// <summary>
        /// 显示索引值的选项卡
        /// </summary>
        /// <param name="i"></param>
        /// <returns>null成功,非null表示失败原因</returns>
        public virtual string ShowIndex( int i )
        {
            if( i < 0 || i>= TabPages.Count )
            {
                return "out of index";
            }

            SelectedIndex = i;
            return null;
        }

        /// <summary>
        /// 显示索引值的选项卡
        /// </summary>
        /// <param name="tab_name">子选项卡Name</param>
        /// <returns>null成功,非null表示失败原因</returns>
        public virtual string ShowIndex(string tab_name)
        {
            if( TabPages.ContainsKey(tab_name) )
            {
                this.SelectTab( tab_name );
                return null;
            }
            else
            {
                return "out of index";
            }
        }

        /// <summary>
        /// 显示下一个选项卡
        /// </summary>
        public virtual void ShowNext()
        {
            ShowIndex( SelectedIndex + 1 );
        }

        /// <summary>
        /// 显示上一个选项卡
        /// </summary>
        public virtual void ShowPre()
        {
            ShowIndex( SelectedIndex - 1 );
        }

        /// <summary>
        /// 初始化选项卡控件
        /// </summary>
        public virtual void InitTab()
        {
            SelectedIndex = 0;
        }

        // 用于记录选项卡有没有选中过
        private Hashtable selected_time = new Hashtable();

        protected override void OnSelectedIndexChanged( EventArgs e )
        {
            base.OnSelectedIndexChanged( e );
            if( !selected_time.ContainsKey( SelectedTab.Name ) )
            {
                EventHandler eh = (EventHandler)event_list[SelectedTab.Name];
                if( eh!= null )
                {
                    eh( event_list[SelectedTab.Name], e );
                }
                
            }
            
            selected_time[SelectedTab.Name] = 1;
        }

        private Hashtable event_list = new Hashtable();
        /// <summary>
        /// 为子选项卡添加第一次选中的事件,需要在初始化前使用
        /// </summary>
        /// <param name="tab_name">子选项卡Name</param>
        /// <param name="e">事件参数</param>
        public void TabPageLoadBind(string tab_name, EventHandler e)
        {
            event_list[tab_name] = e;
        }

    }
}


调用示例

 private void Form1_Load( object sender, EventArgs e )
        {
            mytab1.TabPageLoadBind( "skinTabPage3", ( obj, ee ) =>
            {
                MessageBox.Show( "skinTabPage3" );
            } );

            mytab1.TabPageLoadBind( "skinTabPage4", ( obj, ee ) =>
            {
                MessageBox.Show( "skinTabPage4" );
            } );

            // 初始化之前进行事件绑定
            mytab1.InitTab();
        }


这个控件可以为子选项卡添加类似于load的事件,而且还屏蔽了用快捷键方式切换tab,虽然叫ultimate,但还不是最终版,最终版应该是改造tabpage,把事件加在tabpage上,然后还要为新的tabcontrol分配设计器任务,不过这个超出了本人的能力,现在这个已经满足要求了,有知道最终版做法的请说明一下,谢谢
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值