WPF实现拟物旋转按钮

c3a0d993693d5a295595349811e38991.png

WPF开发者QQ群: 340500857  | 微信群 -> 进入公众号主页 加入组织

767823395424dce73c09d91d03cd9fb7.png 

5aa9468673d35439b6c31b779c0276f6.png

be4c34c21bcc675be34fbdf9fcbaabb7.png

有小伙伴提出需要实现鼠标经过旋转进度条增加。                           

     由于在WPF中没有现成的鼠标经过旋转控件,所以我们自己实现一个。

PS:有更好的方式欢迎推荐。

01

代码如下

一、创建 VolumeControl.cs 继承 UserControl代码如下。

8517873895cc310bf7a48f77a94713e0.png

VolumeControl.cs实现思路如下

1、TicksArray :存放刻度值集合 。

2、处理鼠标按下,鼠标移动,鼠标抬起 事件 。

3、将鼠标移动将坐标点转为角度。

Math.Atan2

4、设置图片2的角度。

504e4634d9def886847ef9df816200dc.png

using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Input;
using System.Windows.Media;
using WPFDevelopers.Controls;namespace WPFDevelopers.Samples.ExampleViews
{/// <summary>/// VolumeControl.xaml 的交互逻辑/// </summary>public partial class VolumeControl : UserControl{public static readonly DependencyProperty AngleProperty =DependencyProperty.Register("Angle", typeof(double), typeof(VolumeControl), new UIPropertyMetadata());public double Angle{get { return (double)GetValue(AngleProperty); }set { SetValue(AngleProperty, value); }}public IList<ScaleItem> TicksArray{get { return (IList<ScaleItem>)GetValue(TicksArrayProperty); }private set { SetValue(TicksArrayProperty, value); }}public static readonly DependencyProperty TicksArrayProperty =DependencyProperty.Register("TicksArray", typeof(IList<ScaleItem>), typeof(VolumeControl));private Point _center;private Brush defaultColor = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#151515"));private Brush selectColor = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#FF81FB00"));public VolumeControl(){InitializeComponent();List<ScaleItem> shortticks = new List<ScaleItem>();for (int i = 0; i < 36; i++)shortticks.Add(new ScaleItem { Index = i, Background = defaultColor });shortticks[0].Background = selectColor;this.TicksArray = shortticks;_center = new Point(this.ActualWidth / 2, this.ActualHeight / 2);this.MouseLeftButtonDown += new MouseButtonEventHandler(OnMouseLeftButtonDown);this.MouseUp += new MouseButtonEventHandler(OnMouseUp);this.MouseMove += new MouseEventHandler(OnMouseMove);}private void OnMouseLeftButtonDown(object sender, MouseButtonEventArgs e){Mouse.Capture(this);}private void OnMouseUp(object sender, MouseButtonEventArgs e){Mouse.Capture(null);}private void OnMouseMove(object sender, MouseEventArgs e){if (Mouse.Captured == this){if (Angle >= 360){Angle = 0;TicksArray.ToList().ForEach(y =>{if (y.Index.Equals(0))y.Background = selectColor;y.Background = defaultColor;});}var curPoint = e.GetPosition(this);var relPoint = new Point(curPoint.X - _center.X, curPoint.Y - _center.Y);var angle = Math.Atan2(relPoint.X, relPoint.Y);Angle += angle;var max = Angle / 10;TicksArray.Where(x => x.Index <= max).ToList().ForEach(y =>{y.Background = selectColor;});}}}
}

二、创建VolumeControl.xaml代码如下

5ad7c7ab983204801aba0a0623ab6506.png

<UserControl x:Class="WPFDevelopers.Samples.ExampleViews.VolumeControl"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:ec="http://schemas.microsoft.com/expression/2010/controls"xmlns:local="clr-namespace:WPFDevelopers.Samples.ExampleViews"Width="400" Height="400"><Grid><Image Source="/WPFDevelopers.Samples;component/Images/ZooSemy/0.png" /><Imagex:Name="PART_Image"RenderTransformOrigin="0.5,0.5"Source="/WPFDevelopers.Samples;component/Images/ZooSemy/1.png"><Image.RenderTransform><RotateTransform Angle="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:VolumeControl}}, Path=Angle}" /></Image.RenderTransform></Image><Ellipse x:Name="PART_Ellipse" Margin="70"RenderTransformOrigin="0.5,0.5"><Ellipse.RenderTransform><RotateTransform Angle="-90" /></Ellipse.RenderTransform></Ellipse><ec:PathListBox IsHitTestVisible="False" ItemsSource="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:VolumeControl}}, Path=TicksArray}"><ec:PathListBox.ItemTemplate><DataTemplate><BorderWidth="16"Height="16"Background="{Binding Background}"BorderBrush="#353537"BorderThickness="1"CornerRadius="3"SnapsToDevicePixels="True"UseLayoutRounding="True" ><TextBlock Text="{Binding Index}"HorizontalAlignment="Center"Foreground="White"/></Border></DataTemplate></ec:PathListBox.ItemTemplate><ec:PathListBox.LayoutPaths><ec:LayoutPathDistribution="Even"Orientation="OrientToPath"SourceElement="{Binding ElementName=PART_Ellipse}" /></ec:PathListBox.LayoutPaths></ec:PathListBox></Grid>
</UserControl>

三、创建ZooSemyExample.xaml代码如下

0597bd5d88b035957ae779b77b691537.png

<UserControl x:Class="WPFDevelopers.Samples.ExampleViews.ZooSemyExample"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:WPFDevelopers.Samples.ExampleViews"mc:Ignorable="d" d:DesignHeight="450" d:DesignWidth="800"><Grid><local:VolumeControl/></Grid>
</UserControl>

02


效果预览

鸣谢素材提供者 - 王涛

源码地址如下

github:https://github.com/yanjinhuagood/WPFDevelopers.git

gitee:https://gitee.com/yanjinhua/WPFDevelopers.git

WPF开发者QQ群: 340500857 

blogs: https://www.cnblogs.com/yanjinhua

Github:https://github.com/yanjinhuagood

出处:https://www.cnblogs.com/yanjinhua

版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。

转载请著名作者 出处 https://github.com/yanjinhuagood

a086b6ad9baff1f4065121992cf8e30f.png

扫一扫关注我们,

ace80ebf6dcaac35a39e6df7755cb5ab.gif

更多知识早知道!

e2c710127cf3b92248ea39d1d9337473.gif

点击阅读原文可跳转至源代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/295833.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高一被清华姚班录取,高三委拒谷歌offer,一个重度网瘾少年到理论计算机科学家的蜕变...

全世界只有3.14 % 的人关注了爆炸吧知识去年3月15日&#xff0c;ACM 计算理论年会&#xff08;STOC&#xff09;Danny Lewin 最佳学生论文奖揭晓&#xff0c;获奖论文作者为来自麻省理工学院的陈立杰和来自 Weizmann Institute 的 Roei Tell。ACM STOC &#xff08;Symposium o…

世界大百科全书!耶鲁大学教授再出神作!用1000幅图片,讲明白45亿年历史......

▲点击查看哈佛大学本杰明教授曾说&#xff1a;“越是到了高等教育的阶段&#xff0c;人们就越重视从历史中总结经验&#xff0c;尤其是精英阶段。很多人都想好好读读历史&#xff0c;但是一直以来&#xff0c;读历史都有一个问题&#xff1a;看着满满都是字的大部头&#xff0…

Hostonly cookie是什么鬼?

点击上方蓝字关注我们吧知道cookie hostonly属性的请举手&#x1f9d0;01Cookie常见姿势、疑难梳理目前w3c定义浏览器存放每个cookie需要包含以下字段&#xff1a;cookie属性基本描述举例备注namevaluecookie键值对ida3fWaexpirescookie过期时间expiresTue, 10-Jul-2013 08:30:…

系统即将关机请保存关机是由nt_设置Windows电脑自动关机

为了减少长时间沉迷电脑而忘记时间&#xff0c;设置Windows电脑自动关机是必要的事。 在我的电脑里&#xff0c;每到晚上10点都会自动关机。当然不会立刻关机&#xff0c;而是设置了1分钟的预留时间给自己保存一些文档资料。 Windows内建的Shutdown指令让人很方便的对这些进行操…

华为网络设备上的常用安全技术(一)

安全技术1&#xff1a;ACL 说明&#xff1a;ACL &#xff08;Access Control List&#xff0c;访问控制列表&#xff09;主要用来实现流识别功能。网络设备为过滤数据包&#xff0c;需要配置一系列的匹配规则&#xff0c;以识别需要过滤的报文。在识别出特定的报文之后&#xf…

java学习第七天

2019独角兽企业重金招聘Python工程师标准>>> 内部类 在类的内部也可以定义另一个类 ------------------------------------------------------------//类嵌套类,类中带有类//内部类跟方法一样&#xff0c;可以使用全部的访问权限修饰符,用法是一样的 接口 Int…

并不是每个女生都能穿出这种效果......

1 阿姨&#xff0c;我需要一个你▼2 像极了是悬空的...▼3 放弃吧&#xff0c;整点阳间的...▼4 一个人如何自拍&#xff1f;&#xff08;Twitter&#xff1a;Kskb_Tsuki&#xff09;▼5 哥哥表示睡着了就把她饼干吃了...&#xff08;via.dy俩小小赵&#xff09;▼6 敲法器…

手把手教你学Dapr - 1. .Net开发者的大时代

Dapr全称Distributed Application Runtime&#xff0c;分布式应用运行时Dapr的口号简化云原生应用开发&#xff0c;聚焦在应用的核心逻辑&#xff0c;让代码简单、可移植Dapr的目标最佳实践的构建块任何语言或框架一致性&#xff0c;可移植&#xff0c;开放的API采纳标准可扩展…

电子计算机制作探测,如何自己制作一个简易的金属探测器

这是一个金属探测电路&#xff0c;它可以隔着地毯探测出地毯下的硬币或金属片。这个小装置很适合动手自制。一、元器件的准备电路中的NPN型三极管型号为9014&#xff0c;三极管VT1的放大倍数不要太大&#xff0c;这样可以提高电路的灵敏度。VD1-VD2为1N4148。电阻均为1/8W。金属…

“对不起,我们只招父母毕业于名牌院校的孩子”:最可怕的,是你还以为学历不重要...

全世界只有3.14 % 的人关注了爆炸吧知识1 近日&#xff0c;有一条新闻引发网友热议。成都某小学入学面试&#xff0c;要求家长除了带照片和身份证件之外&#xff0c;还要带“父母学历证书原件及复印件”。网上有种说法&#xff0c;该小学筛选的标准是父母毕业于211院校。后来眼…

.NET 6 对 StackOverflow 的优化

.NET 6 对 StackOverflow 的优化Intro去年写了一系列的傻逼代码, 其中有一篇 写了多年代码&#xff0c;你会 StackOverflow 吗&#xff0c;昨天一不小心又写了一个 StackOverflow 代码。。然后想把新的代码加到原来 StackOverflow 的示例中&#xff0c;把原来的示例项目改成了 …

Android之从网络上获取图片的两种方式讲解:thread+handle和AsyncTask方式

从网络上获取图片是一个比较耗时的操作,放在主线程会导致阻塞主线程,响应超时,所以我们不能把它放在主线程里操作,必须放在一个子线程里,我打算采用两种方式去实现。1、采用thread去获取图片,获取到后通过handle把消息发送到与主线程绑定的消息队列中(也就是主线程的loo…

推荐16款非常有创意的婚礼请贴

为什么80%的码农都做不了架构师&#xff1f;>>> 日期&#xff1a;2012-4-5 来源&#xff1a;GBin1.com 婚约是标志着你和你的伴侣很快就要有新的开始了&#xff0c;一起开始那段新的历程&#xff01;婚礼是整个人生旅途中的一个重要里程碑&#xff0c;在婚礼的邀请…

三年磨一剑,五次被拒稿,交大博士坚持稿件申诉,终发表学科顶刊

全世界只有3.14 % 的人关注了爆炸吧知识本文来源&#xff1a;募格学术三年磨一剑&#xff0c;经历五轮审稿被拒&#xff0c;他坚持不懈&#xff0c;最终申诉成功发表物理顶刊&#xff1b;厚积薄发、精益求精&#xff0c;他潜心科研&#xff0c;2年内发表6篇高水平论文&#xff…

Java内部类详解(转)

说起内部类这个词&#xff0c;想必很多人都不陌生&#xff0c;但是又会觉得不熟悉。原因是平时编写代码时可能用到的场景不多&#xff0c;用得最多的是在有事件监听的情况下&#xff0c;并且即使用到也很少去总结内部类的用法。今天我们就来一探究竟。下面是本文的目录大纲&…

.NET Conf 2021 正在进行中,带你看一看微软带来了什么内容

今年最大的.NET活动正在进行, 可以通过Channel9 https://channel9.msdn.com/Events/dotnetConf/2021 看具体的Session 。微软和社区一直在努力统一.NET技术栈。从Visual Studio 到 SQL 和 Azure &#xff0c;所有功能聚集一堂&#xff0c;让您在桌面、网络、移动和跨平台开发梦…

C# js调用winform方法,C# JS与winform通信

关键组件&#xff1a;System.windows.Forms.WebBroswer 关键声明:类前声明 namespace gdi___ {[System.Security.Permissions.PermissionSet(System.Security.Permissions.SecurityAction.Demand, Name "FullTrust")][System.Runtime.InteropServices.ComVisibleAtt…

下班忘打卡了什么后果_工厂园区安装人脸识别门禁系统有什么好处?

通常情况下&#xff0c;工厂园区的人员流动都是比较频繁且巨大的。厂区的人员不断的进进出出&#xff0c;主要集中在上下班的时间段里面。对于工厂园区的管理人员来说&#xff0c;怎样管理好人员的进出安全与快捷高效通行&#xff0c;与此同时完成上下班的考勤尤其重要。当前的…

史上最难逻辑题!据说99.9%的人都做不出来……

全世界只有3.14 % 的人关注了爆炸吧知识非常「逻辑」撩人于无形普林斯顿大学博士生 Raymond Smullyan 是一位非常厉害逻辑高手。在Smullyan与他非常迷恋的女音乐家的第一次约会上&#xff0c;他用了一招意想不到“逻辑”方法&#xff0c;撩她于无形。他说道&#xff1a;“我们来…

手把手教你学Dapr - 3. 使用Dapr运行第一个.Net程序

注意&#xff1a;文章中提到的命令行工具即是Windows Terminal/PowerShell/cmd其中的一个&#xff0c;推荐使用Windows Terminal运行命令行工具的时候建议以管理员身份&#xff0c;避免踩坑为了保证操作顺畅&#xff0c;建议使用PowerShell先执行一下set-ExecutionPolicy Remot…