一个跟随鼠标指向的旋钮(WPF)


一、按钮布局

    <Grid x:Name="CircleSliderGrid" MouseDown="CircleSliderGrid_MouseDown" MouseMove="CircleSliderGrid_MouseMove" MouseUp="CircleSliderGrid_MouseUp" MouseLeave="CircleSliderGrid_MouseLeave">
        <Ellipse x:Name="EIIipse" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" RenderTransformOrigin="0.5,0.5">
            <Ellipse.Fill>
                <ImageBrush ImageSource="/图片资源/旋钮.png"/>
            </Ellipse.Fill>
            <Ellipse.RenderTransform>
                <TransformGroup>
                    <ScaleTransform/>
                    <SkewTransform/>
                    <RotateTransform x:Name="Sliderangle" Angle="90"/>
                    <TranslateTransform/>
                </TransformGroup>
            </Ellipse.RenderTransform>
        </Ellipse>
        <Label x:Name="Label" Content="" HorizontalAlignment="Center" VerticalAlignment="Center" Background="{x:Null}" Margin="0,20,0,0" Foreground="White"/>
    </Grid>

效果:
在这里插入图片描述

二、旋钮动作

1.变量定义

        [Browsable(true), Description("实际值"), Category("控件属性")]
        public double Value
        {
            get;
            set;
        }
        [Browsable(true), Description("角度范围起始角度"), Category("控件属性")]
        public double StartAngle
        {
            get
            {
                return SAG;
            }
            set
            {
                if (0 <= value && value <= EndAngle)
                {
                    SAG = value;
                }
            }
        }
        [Browsable(true), Description("角度范围结束角度"), Category("控件属性")]
        public double EndAngle
        {
            get
            {
                return EAG;
            }
            set
            {
                if (StartAngle <= value && value <= 360)
                {
                    EAG = value;
                }
            }
        }
        private Point NewP;
        private bool down = false;
        private double lastAngle,EAG,SAG;

2.控件动作

代码如下:

        private void CircleSliderGrid_MouseMove(object sender, MouseEventArgs e)
        {
            if (down)
            {
                NewP = Mouse.GetPosition(CircleSliderGrid);
                lastAngle = Math.Atan2(CircleSliderGrid.ActualHeight/2 - NewP.Y, CircleSliderGrid.ActualWidth/2 - NewP.X) * (180.0 / 3.14) - 90;
                if (90 - EndAngle <= lastAngle && lastAngle <= 90 - StartAngle)
                {
                    Sliderangle.Angle = lastAngle;
                    Value = 100 - (Sliderangle.Angle + EndAngle - 90) / (EndAngle - StartAngle) * 100;
                    Label.Content = Value.ToString("F2");
                }
                else if (84 - EndAngle <= lastAngle && 90 - EndAngle >= lastAngle && lastAngle < 354)
                {
                    Value = 100;
                    Label.Content = Value.ToString("F2");
                }
                else if (lastAngle >= -270 && lastAngle <= -264 && lastAngle < 354)
                {
                    Value = 0;
                    Label.Content = Value.ToString("F2");
                }
            }
        }
        
        private void CircleSliderGrid_MouseDown(object sender, MouseButtonEventArgs e)
        {
            down = true;
        }
  
        private void CircleSliderGrid_MouseUp(object sender, MouseButtonEventArgs e)
        {
            down = false;
        }

        private void CircleSliderGrid_MouseLeave(object sender, MouseEventArgs e)
        {
            down = false;
        }

效果

控件属性:在这里插入图片描述
运行:
请添加图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值