WPF实现数据拾取器

dbe6b3498b92dbf71bf48f15de1eee3a.png

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

93b24c4ff92d41699b3d438eff288ff3.png 

b53aa86788bd8edbe5a892b99b1b9eb2.png

     由于在WPF中没有现成的数据拾取器控件,所以我们自己实现一个。

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

01

代码如下

一、创建 RoundPicker.cs 继承 Control代码如下。

60c7c1c74b316d68bcaa3b35ec651265.png

RoundPicker.cs实现思路如下

1、基于Canvas绘制Button或者其他控件 。

2、已知圆的半径嵌套使用for循环,然后进行添加控件如下。

 var value =  x * x + y * y;

 double rIn = radius - thickness, rOut = radius + thickness;

 if (value >= rIn * rIn && value <= rOut * rOut)

{

     //此处进行Add的话就是在圆四周绘制控件。

     //效果如下

4e4f5e11a8990d9721d70f446ff2a42c.png

}

 如果需要内部也能追加上控件需要增加逻辑如下。

 else if (value < rIn * rIn && value < rOut * rOut)

 {

    //效果如下

47579e98176c600f3f6d5baddaa1f49d.png

}

1218e0678ae381466c8d958b7250ae8d.png

using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;namespace WPFDevelopers.Controls
{public class RoundPicker : Control{private Canvas _canvas;private char[] _singleLastName = new char[444] {'赵', '钱', '孙', '李', '周', '吴', '郑', '王', '冯', '陈','褚', '卫', '蒋', '沈', '韩', '杨', '朱', '秦', '尤', '许','何', '吕', '施', '张', '孔', '曹', '严', '华', '金', '魏','陶', '姜', '戚', '谢', '邹', '喻', '柏', '水', '窦', '章','云', '苏', '潘', '葛', '奚', '范', '彭', '郎', '鲁', '韦','昌', '马', '苗', '凤', '花', '方', '俞', '任', '袁', '柳','酆', '鲍', '史', '唐', '费', '廉', '岑', '薛', '雷', '贺','倪', '汤', '滕', '殷', '罗', '毕', '郝', '邬', '安', '常','乐', '于', '时', '傅', '皮', '卞', '齐', '康', '伍', '余','元', '卜', '顾', '孟', '平', '黄', '和', '穆', '萧', '尹','姚', '邵', '湛', '汪', '祁', '毛', '禹', '狄', '米', '贝','明', '臧', '计', '伏', '成', '戴', '谈', '宋', '茅', '庞','熊', '纪', '舒', '屈', '项', '祝', '董', '梁', '杜', '阮','蓝', '闵', '席', '季', '麻', '强', '贾', '路', '娄', '危','江', '童', '颜', '郭', '梅', '盛', '林', '刁', '钟', '徐','邱', '骆', '高', '夏', '蔡', '田', '樊', '胡', '凌', '霍','虞', '万', '支', '柯', '昝', '管', '卢', '莫', '经', '房','裘', '缪', '干', '解', '应', '宗', '丁', '宣', '贲', '邓','郁', '单', '杭', '洪', '包', '诸', '左', '石', '崔', '吉','钮', '龚', '程', '嵇', '邢', '滑', '裴', '陆', '荣', '翁','荀', '羊', '於', '惠', '甄', '麴', '家', '封', '芮', '羿','储', '靳', '汲', '邴', '糜', '松', '井', '段', '富', '巫','乌', '焦', '巴', '弓', '牧', '隗', '山', '谷', '车', '侯','宓', '蓬', '全', '郗', '班', '仰', '秋', '仲', '伊', '宫','宁', '仇', '栾', '暴', '甘', '钭', '厉', '戎', '祖', '武','符', '刘', '景', '詹', '束', '龙', '叶', '幸', '司', '韶','郜', '黎', '蓟', '薄', '印', '宿', '白', '怀', '蒲', '邰','从', '鄂', '索', '咸', '籍', '赖', '卓', '蔺', '屠', '蒙','池', '乔', '阴', '郁', '胥', '能', '苍', '双', '闻', '莘','党', '翟', '谭', '贡', '劳', '逄', '姬', '申', '扶', '堵','冉', '宰', '郦', '雍', '舄', '璩', '桑', '桂', '濮', '牛','寿', '通', '边', '扈', '燕', '冀', '郏', '浦', '尚', '农','温', '别', '庄', '晏', '柴', '瞿', '阎', '充', '慕', '连','茹', '习', '宦', '艾', '鱼', '容', '向', '古', '易', '慎','戈', '廖', '庾', '终', '暨', '居', '衡', '步', '都', '耿','满', '弘', '匡', '国', '文', '寇', '广', '禄', '阙', '东','欧', '殳', '沃', '利', '蔚', '越', '夔', '隆', '师', '巩','厍', '聂', '晁', '勾', '敖', '融', '冷', '訾', '辛', '阚','那', '简', '饶', '空', '曾', '毋', '沙', '乜', '养', '鞠','须', '丰', '巢', '关', '蒯', '相', '查', '後', '荆', '红','游', '竺', '权', '逯', '盖', '益', '桓', '公', '仉', '督','晋', '楚', '闫', '法', '汝', '鄢', '涂', '钦', '归', '海','岳', '帅', '缑', '亢', '况', '后', '有', '琴', '商', '牟','佘', '佴', '伯', '赏', '墨', '哈', '谯', '笪', '年', '爱','阳', '佟', '言', '福'};private Random _random = new Random();private int _rdnumber;public string SelectItem{get { return (string)GetValue(SelectItemProperty); }set { SetValue(SelectItemProperty, value); }}public static readonly DependencyProperty SelectItemProperty =DependencyProperty.Register("SelectItem", typeof(string), typeof(RoundPicker), new PropertyMetadata("闫"));static RoundPicker(){DefaultStyleKeyProperty.OverrideMetadata(typeof(RoundPicker), new FrameworkPropertyMetadata(typeof(RoundPicker)));}public override void OnApplyTemplate(){base.OnApplyTemplate();_canvas = GetTemplateChild("PART_Canvas") as Canvas;if (_canvas == null) return;}int zIndex = 0, count = 0;public RoundPicker(){this.Loaded += (s, e) =>{if (_canvas == null) return;double radius = 5;double thickness = 0.4;double rIn = radius - thickness, rOut = radius + thickness;double left = 10d, top = 10d;var brushConverter = new BrushConverter();var ellipse = new Ellipse{Stroke = (Brush)brushConverter.ConvertFromString("#F56C6C"),StrokeThickness = 2,SnapsToDevicePixels = true,UseLayoutRounding = true,Fill = (Brush)brushConverter.ConvertFromString("#F2F6FC"),};_canvas.Children.Add(ellipse);for (double y = radius; y >= -radius; --y){for (double x = -radius; x < rOut; x += 1){_rdnumber = _random.Next(444);var button = new Button{Width = 20,Height = 20,Cursor = Cursors.Hand,Content= _singleLastName[_rdnumber],UseLayoutRounding = true,Padding = new Thickness(0),Style = (Style)this.FindResource("PrimaryButton")};button.RenderTransformOrigin = new Point(.5, .5);button.RenderTransform = new ScaleTransform();button.MouseMove += (sender, ex) =>{var btn = sender as Button;Panel.SetZIndex(btn, 1);var doubleAnimation = new DoubleAnimation {To = 2,Duration = TimeSpan.FromMilliseconds(100),};var scaleTransform = btn.RenderTransform as ScaleTransform;scaleTransform.BeginAnimation(ScaleTransform.ScaleXProperty, doubleAnimation);scaleTransform.BeginAnimation(ScaleTransform.ScaleYProperty, doubleAnimation);};button.MouseLeave += (sender, ex) =>{var btn = sender as Button;var scaleTransform = btn.RenderTransform as ScaleTransform;var doubleAnimation = new DoubleAnimation{To = 1,Duration = TimeSpan.FromMilliseconds(100)};scaleTransform.BeginAnimation(ScaleTransform.ScaleXProperty, doubleAnimation);scaleTransform.BeginAnimation(ScaleTransform.ScaleYProperty, doubleAnimation);Panel.SetZIndex(btn, 0);};button.Click += (sender, ex) => {var btn = sender as Button;SelectItem = btn.Content.ToString();};double value = x * x + y * y;if (value >= rIn * rIn && value <= rOut * rOut){_canvas.Children.Add(button);Canvas.SetTop(button, top);Canvas.SetLeft(button, left);}else if (value < rIn * rIn && value < rOut * rOut){_canvas.Children.Add(button);Canvas.SetTop(button, top);Canvas.SetLeft(button, left);}left = left + button.Width + 1;}left = 10d;top = top + 21;}ellipse.Width = top + 9;ellipse.Height = top + 9;//Panel.SetZIndex(ellipse, 0);//count = _canvas.Children.Count + 1;};}}
}

二、创建RoundPicker.xaml代码如下

c05570c9af101348aebd4c4b2855b72e.png

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:controls="clr-namespace:WPFDevelopers.Controls"><ResourceDictionary.MergedDictionaries><ResourceDictionary Source="Basic/ControlBasic.xaml"/></ResourceDictionary.MergedDictionaries><Style TargetType="{x:Type controls:RoundPicker}" BasedOn="{StaticResource ControlBasicStyle}"><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="{x:Type controls:RoundPicker}"><Canvas x:Name="PART_Canvas"></Canvas></ControlTemplate></Setter.Value></Setter>
</Style></ResourceDictionary>

三、创建RoundPickerExample.xaml代码如下

085045d4fac74cc1af4d55ec8bd60bc5.png

<UserControl x:Class="WPFDevelopers.Samples.ExampleViews.RoundPickerExample"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"xmlns:wpfdev="https://github.com/yanjinhuagood/WPFDevelopers"mc:Ignorable="d" d:DesignHeight="450" d:DesignWidth="800"><Grid><UniformGrid><wpfdev:RoundPicker Margin="100" x:Name="RoundPicker"/><TextBlock Text="{Binding ElementName=RoundPicker,Path=SelectItem}"FontSize="120" FontFamily="仿宋"VerticalAlignment="Center"Margin="0,120,0,0"/></UniformGrid></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

d19f92a2e9fb2333cc37b361080cdaca.png

扫一扫关注我们,

d887c52dfe35246e426b151ef0e726df.gif

更多知识早知道!

6582071a79d3908b7ea9e179027ecc58.gif

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

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

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

相关文章

CAS的安装与配置(一)服务器端配置

一、搭建Java Web服务器环境 CATALINA_HOME D:\Java\apache-tomcat-6.0.14 安装完毕&#xff0c;启动Tomcat &#xff0c;在浏览器上 测试 http://localhost:8080/ 出现上述界面&#xff0c;表明系统成功搭建。 二、使用Java Keytool工具为系统生成HTTPS证书&#xff0c;并…

某大型银行深化系统之十六:性能设计之一

传送门 ☞ 轮子的专栏 ☞ 转载请注明 ☞ http://blog.csdn.net/leverage_1229 1队列服务质量评估 通过引入排队系统&#xff0c;定义系统中各项业务流程的产生和业务服务模型&#xff0c;描述工作项产生规律和服务规律的概率来计算系统的性能。 在对排队进行分析时&#xff0c;…

Android之React native的介绍和入门指南

链接&#xff1a;http://zhuanlan.zhihu.com/FrontendMagazine/19996445数月前&#xff0c;Facebook 对外宣布了正在开发的 React Native 框架&#xff0c;这个框架允许你使用 JavaScript 开发原生的 iOS 应用——就在今天&#xff0c;Beta 版的仓库释出了&#xff01; 基于 P…

mysql 堆叠查询_SQL 注入方法 - 盲注、报错注入、UNION查询注入与堆叠注入

盲注关键点是 根据页面返回内容分析 Payload 中的问题是否为真&#xff0c;然后通过多次测试遍历出想要的数据布尔盲注目标地址&#xff1a;http://newspaper.com/items.php?id2对应的SQL语句&#xff1a;SELECT title, description, body FROM items WHERE ID 2然后攻击者尝…

清华教授转述:读博6年未毕业被认定为自控力不够,或将影响个人贷款额度

全世界只有3.14 % 的人关注了爆炸吧知识图片来源&#xff1a;网络来源&#xff1a;募格课堂、微博人文清华、中国教育报、学位与写作据清华大学“人文清华”讲坛官方微博人文清华发布&#xff0c;清华大学公共管理学院院长江小涓教授在一次演讲中透露&#xff0c;互联网银行工作…

缕一缕c#可null类型

在古时候&#xff0c;引用类型是的默认值就是null&#xff0c;值类型是不可以赋值null的&#xff0c;所以那时候&#xff0c;“未将对象引用到实例”这个错误&#xff0c;是引用类型的。后来&#xff0c;值类型也可以赋值null了&#xff0c;只要在值类型变量定义的时候&#xf…

[原]NYOJ-开灯问题-77

大学生程序代写 //http://acm.nyist.net/JudgeOnline/problem.php?pid77/*题目77题目信息运行结果本题排行讨论区开灯问题时间限制&#xff1a;3000 ms | 内存限制&#xff1a;65535 KB难度&#xff1a;1描述有n盏灯&#xff0c;编号为1~n&#xff0c;第1个人把所有灯打开&a…

Android之Windows下搭建React Native Android开发环境(差不多搞了一天)

Android之Windows下搭建React Native Android开发环境 穷逼买不起mac,但是他们都说React Native Android只能在mac下面运行,然后到网上各种找资料看能不能在Windows下面搭建开发环境,找了几篇,但是讲得不够详细,没有图片,很虚,然后我用自己的小米手机尝试了…

这6部顶级数学纪录片,告诉你数学一点都不无趣!

全世界只有3.14 % 的人关注了爆炸吧知识丘成桐曾说&#xff0c;“中国数学发展很快&#xff0c;但距离欧洲和美国还有相当大的差距”&#xff0c;在美国排名前20的顶尖大学里&#xff0c;包括哈佛大学、普林斯顿大学、斯坦福大学、加州大学伯克利分校等&#xff0c;具有国际一流…

JAVA兔子繁衍_Java 编程经典案例之兔子繁殖迭代问题

题目有一对兔子&#xff0c;从出生后第3个月起每个月都生一对兔子&#xff0c;小兔子长到第三个月后每个月又生一对兔子&#xff0c;假如兔子都不死&#xff0c;问第6个月的兔子总数为多少&#xff1f;分析首先我们要明白题目的意思指的是每个月的兔子总对数&#xff1b;假设将…

检查可执行文件所需要的共享库

1.3 ldd 和 ldconfigldd 是用来检查可执行文件所需要的共享库。例如&#xff1a;$ ldd /bin/lslibtermcap.so.2 > /lib/libtermcap.so.2 (0x4001c000)libc.so.6 > /lib/libc.so.6 (0x40020000)/lib/ld-linux.so.2 > /lib/ld-linux.so.2 (0x40000000)我们在 /bin/ls 程…

C# GTS四轴运动控制器实例(固高科技步进电机不带编码器) -V1

注&#xff1a;由于电机不带编码器&#xff0c;无法做home和当前位置信息读取&#xff01;功能&#xff1a;三个轴的点位运动&#xff1a;前进后退&#xff0c;并分别显示每个轴的移动脉冲数(可以换算为距离)&#xff01;开发环境&#xff1a;VS2017硬件设备&#xff1a;固高科…

node.js npm常用命令

npm是一个node包管理和分发工具&#xff0c;已经成为了非官方的发布node模块&#xff08;包&#xff09;的标准。有了npm&#xff0c;可以很快的找到特定服务要使用的包&#xff0c;进行下载、安装以及管理已经安装的包。 1、npm install moduleNames&#xff1a;安装Node模块 …

编程珠玑第三章

第三章的总的原则&#xff1a; 1.将重复性代码改到数组中&#xff0c;使用最简单的数据结构---数组来表示一段冗长的相类似的代码往往可以达到最佳效果 2.封装复杂的结构时&#xff0c;使用抽象的术语对她进行定义&#xff0c;并将那些操作表示成一个类。 3.尽可能地使用高级工…

java基础巩固笔记(6)-注解

2019独角兽企业重金招聘Python工程师标准>>> java基础巩固笔记(6)-注解 标签&#xff1a; java [TOC] 注解&#xff08;Annotation&#xff09;&#xff0c;也叫元数据。一种代码级别的说明。它是JDK1.5及以后版本引入的一个特性&#xff0c;与类、接口、枚举是在同…

男人都能有多浪漫?

1 如何对付有拖延症的朋友&#xff01;▼2 男人能有多浪漫&#xff1f;&#xff08;via.MOM南菁&#xff09;▼3 现实版&#xff1a;别说话吻我&#xff1f;&#xff08;素材来源网络&#xff0c;侵删&#xff09;▼4 注入了灵魂的神作&#xff01;&#xff08;素材来源网络…

在业务层实现记录请求日志

前言上次&#xff0c;我们介绍了如何《在业务层实现响应缓存》。今天&#xff0c;我们同样使用IPipelineBehavior&#xff0c;介绍如何在业务层实现记录请求日志&#xff0c;用于跟踪每个请求执行的耗时。Demo创建ASP.NET Core Web API项目&#xff0c;引用Nuget包&#xff1a;…

InfoQ —— 腾讯游戏大数据服务场景与应用

简介 周东祥&#xff0c;本人从2010年毕业进入腾讯互动娱乐部门工作&#xff0c;一直致力在腾讯游戏运营开发工作。先后负责SAP业务受理系统&#xff0c;盗号自助系统&#xff0c;元数据系统以及近2年在腾讯游戏大数据运营开发中积累大量的大数据开发与应用经验。 介绍 数据采集…

如何加强测评机构自身的规范化管理, 不断提高测评的能力和水平

0&#xff0e;引言 随着用户消费习惯从产品转向服务&#xff0c;服务已经成为企业向客户提供的主要商品。而等级保护测评服务作为信息系统建设的新要素&#xff0c;用户对信息安全等级保护测评服务&#xff08;以下简称服务&#xff09;的认同会影响用户的消费行为。对于信息安…

气溶胶光学厚度反演的两种方式(卫星探测和基地观测反演)

基地观测反演&#xff1a;目前在地基大气气溶胶光学特性遥感方面&#xff0c;太阳光度计测量是应用较多也是最为可靠的一种测量方法&#xff0c;太阳光度计除了可以用于地基观测太阳直接辐射通量外&#xff0c;还可以用来观测天空各方向上的辐射反演气溶胶粒子的谱分布和散射相…