【WPF】利用Ellipse或Rectangle制作圆形进度条

本文介绍了如何在WPF中利用RenderTransformOrigin和不同的Transform类型,如TranslateTransform、RotateTransform、ScaleTransform等,来创建圆形进度条效果。通过调整这些变换属性,可以实现对象的平移、旋转和缩放,从而达到动态的圆形进度显示。
摘要由CSDN通过智能技术生成

 

 

        public MainViewModel()
        {
            Task.Run(() =>
            {
                while(true)
                {
                    Application.Current.Dispatcher.Invoke(() =>
                    {
                        double second = DateTime.Now.Second * 100 / 60;
                        ProcessValue = CalcProgress(second, 50, 12);
                        ProcessNumber = second + "%";
                    });
                }
            });
        }

        /// <summary>
        /// 计算进度条百分比
        /// </summary>
        /// <param name="progress">百分比</param>
        /// <param name="radius">圆角的度数</param>
        /// <param name="thickness">边框厚度</param>
        /// <returns></returns>
        private DoubleCollection CalcProgress(double progress, double radius, double thickness)
        {
            var r = radius - thickness / 2;
            var perimeter = 2 * Math.PI * r / thickness;
            var step = progress / 100 * perimeter;
            var result = new DoubleCollection() { step, 1000 };
            return result;
        }

        private DoubleCollection processValue;
        /// <summary>
        /// 圆形进度条数组
        /// </summary>
        public DoubleCollection ProcessValue
        {
            get { return 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值