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,一经查实,立即删除!

相关文章

C# 调用 Delphi Dll链接库方法及示例

每种编程语言调用DLL的方法都不尽相同&#xff0c;在此只对用C#调用Delphi DLL的方法进行介绍 首先要搞清楚一点的是&#xff1a;什么是托管,什么是非托管&#xff1f; 一般可以认为&#xff1a;非托管代码主要是基于win 32平台开发的DLL&#xff0c;activeX的组件&#xff0c;…

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

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

Android之HttpClient 和HttpResponse 小结

三步曲: 1.创建HttpGet或者HttpPost对象,将要请求的URL对象构造方法传入HttpGet、HttpPost对象 2.通过HttpClent接口的实现类DefaultClent.的excute(HttpUriRequest request)而我们已经知道HttpGet和HttpPost类都实现了 HttpUriRequest接口,所以这里面,我们可…

python代理charles_Mitmproxy + Python 做拦截代理

在测试过程中&#xff0c;我们经常用到Charles、Fiddler等抓包工具&#xff0c;通过抓取http请求进行相关的测试、问题排查。但是在一些特殊场景下&#xff0c;例如我们的数据传输是加密的&#xff0c;可能需要抓取到数据后再进行解密&#xff0c;这个使用抓包工具就不能完全符…

js 编程时注意事项

Tip1: 网页中用js动态加载的元素&#xff0c;这些元素的click等事件响应必须写在这个加载部分的代码后面&#xff0c;否则事件不能正常响应。转载于:https://www.cnblogs.com/liubingna/archive/2013/03/05/2945244.html

Java中Iterator(迭代器)的用法及其背后机制的探究

在Java中遍历List时会用到Java提供的Iterator&#xff0c;Iterator十分好用&#xff0c;原因是&#xff1a; 迭代器是一种设计模式&#xff0c;它是一个对象&#xff0c;它可以遍历并选择序列中的对象&#xff0c;而开发人员不需要了解该序列的底层结构。迭代器通常被称为“轻量…

在c语言中,字符串topt65的长度是,谭浩强c__程序设计第13章.ppt

谭浩强c__程序设计第13章第13章 输入输出流 13.1 C的输入和输出 13.2 标准输出流 13.3 标准输入流 13.4 文件操作与文件流 13.5 字符串流 13.1 C的输入和输出 13.1.1 输入输出的含义 以前所用到的输入和输出&#xff0c;都是以终端为对象的&#xff0c;即从键盘输入数据&#x…

世界大百科全书!耶鲁大学教授再出神作!用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:…

Android之文件读写

一、基本概念 在Android应用中保存文件,保存的位置有两处 ①手机自带的存储空间,较小(如200M),适合保存一些小文件,Android中保存位置在data/data/应用包名/files目录 ②外存储设备如SD卡,较大,适合保存大文件如视频,Android中保存位置在mnt/sdcard目录,保存在sdcar…

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

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

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

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

【F12一下,看看页面里的第一行】——说说浏览器兼容性模式

面试官&#xff1a;请你谈谈标准(Standards)模式、怪异(Quirks)模式、准标准(Almost Standards)模式&#xff0c;当你打开IE9时候会看见&#xff0c;浏览器模式&#xff0c;文档模式&#xff0c;兼容性视图&#xff0c;这些又是什么&#xff1f; 尼玛啊......这些都是什么鸟东西…

java学习第七天

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

大一计算机课实训总结1000字,大一计算机实训报告.doc

文档介绍&#xff1a;大一计算机实训报告.doc大一计算机实训报告总结及相关经验当迈入中南大学的第一刻时,我知道我的新的生活开始了。而不知不觉第一学期即将在漫漫寒冬中结束,计算机课上有很多感受,是应该对自己所学有个总结的时候了。计算机应用是实践性很强的课程,它要求我…

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

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采纳标准可扩展…

Andorid之网络通信框架Volley使用和总结

Volley Volley 是 Google 推出的 Android 异步网络请求框架和图片加载框架。在 Google I/O 2013 大会上发布。 从名字由来和配图中无数急促的火箭可以看出 Volley 的特点:特别适合数据量小,通信频繁的网络操作

如何进行服务器选购[转]

各大服务器厂商为了更突出产品热点&#xff1a;开始在服务、方案方面进行花样翻新、包装&#xff0c;但万变不离其中&#xff0c;不管厂商们怎么样包装&#xff0c;只要我们抓住重点分析&#xff0c;希望下面的文章能够为您提供一些参考与帮助&#xff1a;详情点击&#xff1a;…

闲鱼有微信小程序吗_微信小程序商品展示页面(仿咸鱼)

项目中做了一个商品发布展示的页面&#xff0c;记录下来解决问题&#xff1a;想在setData中更改数组具体下标中的某个值let one "lowMoney[" 0 "].money";this.setData({[one]: (product.currentPrice * 0.1).toFixed(2), //1折})快去发布商品吧~~~已下…