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

1 using System;
  2 using System.Collections.Generic;
  3 using System.ComponentModel;
  4 using System.Data;
  5 using System.Drawing;
  6 using System.Linq;
  7 using System.Text;
  8 using System.Windows.Forms;
  9 
 10 
 11 namespace TabControlTest
 12 {
 13     public partial class Form1 : Form
 14     {
 15         public Form1()
 16         {
 17             InitializeComponent();
 18         }
 19 
 20         const int CLOSE_SIZE = 15;
 21 //tabPage标签图片
 22         Bitmap image = new Bitmap("E:\\1\\2.jpg");
 23 //绘制“X”号即关闭按钮
 24         private void MainTabControl_DrawItem(object sender, DrawItemEventArgs e)
 25         {
 26 
 27             try
 28             {
 29                 Rectangle myTabRect = this.MainTabControl.GetTabRect(e.Index);
 30 
 31                 //先添加TabPage属性   
 32                 e.Graphics.DrawString(this.MainTabControl.TabPages[e.Index].Text
 33                 , this.Font, SystemBrushes.ControlText, myTabRect.X + 2, myTabRect.Y + 2);
 34 
 35                 //再画一个矩形框
 36                 using (Pen p = new Pen(Color.White))
 37                 {
 38                     myTabRect.Offset(myTabRect.Width - (CLOSE_SIZE + 3), 2);
 39                     myTabRect.Width = CLOSE_SIZE;
 40                     myTabRect.Height = CLOSE_SIZE;
 41                     e.Graphics.DrawRectangle(p, myTabRect);
 42                  
 43                 }
 44 
 45                 //填充矩形框
 46                 Color recColor = e.State == DrawItemState.Selected ? Color.White : Color.White;
 47                 using (Brush b = new SolidBrush(recColor))
 48                 {
 49                     e.Graphics.FillRectangle(b, myTabRect);
 50                 }
 51 
 52                 //画关闭符号
 53                 using (Pen objpen = new Pen(Color.Black))
 54                 {
 55                     //"\"线
 56                     Point p1 = new Point(myTabRect.X + 3, myTabRect.Y + 3);
 57                     Point p2 = new Point(myTabRect.X + myTabRect.Width - 3, myTabRect.Y + myTabRect.Height - 3);
 58                     e.Graphics.DrawLine(objpen, p1, p2);
 59 
 60                     //"/"线
 61                     Point p3 = new Point(myTabRect.X + 3, myTabRect.Y + myTabRect.Height - 3);
 62                     Point p4 = new Point(myTabRect.X + myTabRect.Width - 3, myTabRect.Y + 3);
 63                     e.Graphics.DrawLine(objpen, p3, p4);
 64                       ////=============================================
 65                     Bitmap bt = new Bitmap(image);
 66                     Point p5 = 
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现Winform中TabControl控件tabpage标签页边缘变成圆角、不显示边框颜色、标签文字侧着显示的效果,可以通过以下步骤: 1. 新建一个类,继承自TabControl,重写OnPaint方法,添加以下代码: ```csharp protected override void OnPaint(PaintEventArgs e) { base.OnPaint(e); // 设置TabControl控件的Region属性 System.Drawing.Drawing2D.GraphicsPath path = new System.Drawing.Drawing2D.GraphicsPath(); Rectangle rect = this.ClientRectangle; rect.Inflate(-10, -10); path.AddRoundRectangle(rect, 20); this.Region = new Region(path); // 设置标签页文字竖排侧着显示 foreach (TabPage tabpage in this.TabPages) { tabpage.Text = ""; tabpage.Paint += new PaintEventHandler(TabPage_Paint); } } private void TabPage_Paint(object sender, PaintEventArgs e) { TabPage tabpage = (TabPage)sender; Graphics g = e.Graphics; g.RotateTransform(-90); g.TranslateTransform(-tabpage.Height, 0); SizeF size = g.MeasureString(tabpage.Text, tabpage.Font); g.DrawString(tabpage.Text, tabpage.Font, Brushes.Black, (tabpage.Width - size.Width) / 2, (tabpage.Height - size.Height) / 2); } ``` 2. 添加一个自定义控件类,继承自TabPage,重写OnPaint方法,添加以下代码: ```csharp protected override void OnPaint(PaintEventArgs e) { base.OnPaint(e); // 不显示边框颜色 ControlPaint.DrawBorder(e.Graphics, this.ClientRectangle, Color.Transparent, ButtonBorderStyle.None); } ``` 3. 在窗体中使用自定义控件类,即可实现TabControl控件tabpage标签页边缘变成圆角、不显示边框颜色、标签文字侧着显示的效果。 需要注意的是,上述代码中使用了一个自定义的GraphicsPath类,在AddRoundRectangle方法中设置了圆角大小,可以根据需要进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值