Winform开发:在ProgressBar显示百分比数字

本文介绍了一种在进度条上直接显示百分比的方法,通过创建一个派生自ProgressBar的自定义进度条类MyProgressBar,并在该类中重写OnPaint方法来实现进度条上的文本绘制。

如果不使用Label而是直接在进度条上显示文字,可以扩展一个派生类自己画,代码如下:

    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();

            var progressBar = new MyProgressBar()
                {
                    Location = new Point(20, Bottom - 150),
                    Size = new Size(Width - 60, 50),
                    Anchor = AnchorStyles.Left | AnchorStyles.Right | AnchorStyles.Bottom
                };
            this.Controls.Add(progressBar);

            var timer = new Timer {Interval = 150};
            timer.Tick += (s, e) => progressBar.Value = progressBar.Value%100 + 1;
            timer.Start();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
        }
    }

    public class MyProgressBar : ProgressBar
    {
        public MyProgressBar()
        {
            SetStyle(ControlStyles.UserPaint | ControlStyles.AllPaintingInWmPaint, true);
        }

        protected override void OnPaint(PaintEventArgs e)
        {
            Rectangle rect = ClientRectangle;
            Graphics g = e.Graphics;

            ProgressBarRenderer.DrawHorizontalBar(g, rect);
            rect.Inflate(-3, -3);
            if (Value > 0)
            {
                var clip = new Rectangle(rect.X, rect.Y, (int) ((float) Value/Maximum*rect.Width), rect.Height);
                ProgressBarRenderer.DrawHorizontalChunks(g, clip);
            }

            string text = string.Format("{0}%", Value * 100 / Maximum);;
            using (var font = new Font(FontFamily.GenericSerif, 20))
            {
                SizeF sz = g.MeasureString(text, font);
                var location = new PointF(rect.Width/2 - sz.Width/2, rect.Height/2 - sz.Height/2 + 2);
                g.DrawString(text, font, Brushes.Red, location);
            }
        }
    }

 

转载于:https://www.cnblogs.com/feiyuhuo/p/5896857.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值