WPF-24:绘制正多边形
一般来说绘制正N边形,使用Blend直接画出来就好。不过可能是博主受WInform影响比较大,比较喜欢使用画出来的图形。如果要绘制正N边形,前面的绘制五角星的公式可以通用的(http://blog.csdn.net/yysyangyangyangshan/article/details/9378871)。
主要是利用圆,根据三角函数和圆的半径计算出圆上的N个点即可。
计算N各点的方法如下:
private PointCollection GetPolygonPoint(Point center, double r,int polygonBound)
{
double g = 18; double perangle = 360 / polygonBound; double pi = Math.PI; List<Point> values = new List<Point>(); for (int i = 0; i < (int) polygonBound; i++)
{
Point p2 = new Point(r * Math.Cos((g + 36) * pi / 180), r * Math.Sin((g + 36) * pi / 180)); values.Add(p2); g += perangle;
} PointCollection pcollect = new PointCollection(values); return pcollect;
}
g是起始角度,也是可以修改的。这个方法默认是在原点画出,r表示半径,polygonBound表示边数。
对五角星类做一下简单的修改,
public partial class RegularPolygonControl : UserControl
{
private double radius = 20; private Brush selectBackground = new SolidColorBrush(Color.FromRgb(0xEB, 0x42, 0x00)); private Brush unselectBackgroud = new SolidColorBrush(Color.FromRgb(0x99, 0x93, 0x93)); /// <summary>
/// 半径
/// </summary>
public double Radius
{
get
{
object result = GetValue(RadiusProperty); if (result == null)
{
return radius;
} return (double)result;
} set
{
SetValue(RadiusProperty, value); this.InvalidateVisual();
}
} public static DependencyProperty RadiusProperty =
DependencyProperty.Register("Radius", typeof(double), typeof(RegularPolygonControl), new UIPropertyMetadata()); /// <summary>
/// 选中颜色
/// </summary>
public Brush SelectBackground
{
get
{
object result = GetValue(SelectBackgroundProperty); if (result == null)
{
return selectBackground;
} return (Brush)result;
} set
{
SetValue(SelectBackgroundProperty, value); //this.InvalidateVisual();
}
} public static DependencyProperty SelectBackgroundProperty =
DependencyProperty.Register("SelectBackground", typeof(Brush), typeof(RegularPolygonControl), new UIPropertyMetadata()); /// <summary>
/// 未选中颜色
/// </summary>
public Brush UnSelectBackground
{
get
{
object result = GetValue(UnSelectBackgroundProperty); if (result == null)
{
return unselectBackgroud;
} return (Brush)result;
} set
{
SetValue(UnSelectBackgroundProperty, value);
}
} public static DependencyProperty UnSelectBackgroundProperty =
DependencyProperty.Register("UnSelectBackground", typeof(Brush), typeof(RegularPolygonControl), new UIPropertyMetadata()); protected override void OnRender(System.Windows.Media.DrawingContext dc)
{
base.OnRender(dc); Point center = new Point(); PointCollection Points = GetPolygonPoint(center, Radius, 12); Canvas ca = new Canvas(); Polygon plg = new Polygon(); plg.Points = Points; plg.Stroke = Brushes.Transparent; plg.StrokeThickness = 2; plg.Fill = this.SelectBackground; plg.FillRule = FillRule.Nonzero; ca.Children.Add(plg); ca.HorizontalAlignment = System.Windows.HorizontalAlignment.Stretch; ca.VerticalAlignment = System.Windows.VerticalAlignment.Stretch; this.Content = ca;
} /// <summary>
///根据半径和圆心确定N个点
/// </summary>
/// <param name="center"></param>
/// <returns></returns>
private PointCollection GetPolygonPoint(Point center, double r,int polygonBound)
{
double g = 18; double perangle = 360 / polygonBound; double pi = Math.PI; List<Point> values = new List<Point>(); for (int i = 0; i < (int) polygonBound; i++)
{
Point p2 = new Point(r * Math.Cos((g + 36) * pi / 180), r * Math.Sin((g + 36) * pi / 180)); values.Add(p2); g += perangle;
} PointCollection pcollect = new PointCollection(values); return pcollect;
}
}
效果如下:
再做一下简单的变化,可以绘制出一般抽奖用的转盘图形,修改如下,
public class TurnTable : UserControl
{
private double radius = 20; private Brush selectBackground = new SolidColorBrush(Color.FromRgb(0xEB, 0x42, 0x00)); private Brush unselectBackgroud = new SolidColorBrush(Color.FromRgb(0x99, 0x93, 0x93)); /// <summary>
/// 半径
/// </summary>
public double Radius
{
get
{
object result = GetValue(RadiusProperty); if (result == null)
{
return radius;
} return (double)result;
} set
{
SetValue(RadiusProperty, value); this.InvalidateVisual();
}
} public static DependencyProperty RadiusProperty =
DependencyProperty.Register("Radius", typeof(double), typeof(TurnTable), new UIPropertyMetadata()); /// <summary>
/// 选中颜色
/// </summary>
public Brush SelectBackground
{
get
{
object result = GetValue(SelectBackgroundProperty); if (result == null)
{
return selectBackground;
} return (Brush)result;
} set
{
SetValue(SelectBackgroundProperty, value); //this.InvalidateVisual();
}
} public static DependencyProperty SelectBackgroundProperty =
DependencyProperty.Register("SelectBackground", typeof(Brush), typeof(TurnTable), new UIPropertyMetadata()); protected override void OnRender(System.Windows.Media.DrawingContext dc)
{
base.OnRender(dc); Point center = new Point(); PointCollection Points = GetPolygonPoint(center, Radius, 12); Canvas ca = new Canvas(); Polygon plg = new Polygon(); plg.Points = Points; plg.Stroke = Brushes.Black; plg.StrokeThickness = 2; plg.Fill = this.SelectBackground; plg.FillRule = FillRule.Nonzero; ca.Children.Add(plg); //外接圆
Brush b = new SolidColorBrush(Colors.Yellow); Pen p = new Pen(b, 2); var path = new Path(); double circleRadius = Radius + 10; EllipseGeometry eg = new EllipseGeometry(center, circleRadius, circleRadius); path.Stroke = Brushes.Black; path.StrokeThickness = 1; path.Data = eg; ca.Children.Add(path); ca.HorizontalAlignment = System.Windows.HorizontalAlignment.Stretch; ca.VerticalAlignment = System.Windows.VerticalAlignment.Stretch; this.Content = ca;
} /// <summary>
///根据半径和圆心确定N个点
/// </summary>
/// <param name="center"></param>
/// <returns></returns>
private PointCollection GetPolygonPoint(Point center, double r, int polygonBound)
{
double g = 18; double perangle = 360 / polygonBound; double pi = Math.PI; List<Point> values = new List<Point>(); for (int i = 0; i < (int)polygonBound; i++)
{
Point p2 = new Point(r * Math.Cos((g + 36) * pi / 180), r * Math.Sin((g + 36) * pi / 180)); values.Add(p2); values.Add(center); g += perangle;
} PointCollection pcollect = new PointCollection(values); return pcollect;
}
}
这样 两个控件一起看一下效果,
<Window x:Class="TestSomeGraphics.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Width="1200" Height="900" xmlns:my="clr-namespace:TestSomeGraphics"> <Grid>
<my:RegularPolygonControl HorizontalAlignment="Left" x:Name="regularControl1" Radius="200" SelectBackground="Gray"
Margin="235,358,0,-358" />
<my:TurnTable HorizontalAlignment="Left" Radius="100" Margin="639,358,0,0" x:Name="turnTableControl1" VerticalAlignment="Top" />
</Grid> </Window>
如图,
代码下载:http://download.csdn.net/detail/yysyangyangyangshan/6326307
WPF-24:绘制正多边形的更多相关文章
- wpf 后台绘制圆弧
wpf 前台绘制圆弧很简单,如:<Path x:Name="path_data" Stroke="#FFE23838" StrokeThickness=& ...
- C#WPF 如何绘制几何图形 图示教程 绘制sin曲线 正弦 绘制2D坐标系 有图有代码
原文:C#WPF 如何绘制几何图形 图示教程 绘制sin曲线 正弦 绘制2D坐标系 有图有代码 C#WPF 如何绘制几何图形? 怎么绘制坐标系?绘制sin曲线(正弦曲线)? 这离不开Path(Syst ...
- WPF 图形绘制 及各种线帽、箭头的实现
原文:WPF 图形绘制 及各种线帽.箭头的实现 /// <summary> /// 矩形类 /// </summary> public sealed ...
- WPF特效-绘制实时2D激光雷达图
原文:WPF特效-绘制实时2D激光雷达图 接前两篇: https://blog.csdn.net/u013224722/article/details/80738619 https://blog.cs ...
- 在WPF中绘制多维数据集
原文 https://stuff.seans.com/2008/08/13/drawing-a-cube-in-wpf/ 是时候使用WPF绘制一个简单的3D对象了.作为WPF中3D图形的快速介绍,让我 ...
- 【C#】第3章补充(一)如何在WPF中绘制正弦曲线
分类:C#.VS2015 创建日期:2016-06-19 使用教材:(十二五国家级规划教材)<C#程序设计及应用教程>(第3版) 一.要点 本例子提前使用了教材第13章介绍的基本知识. 二 ...
- WPF 如何绘制不规则按钮,并且有效点击范围也是不规则的
最近在做一个东西,如地图,点击地图上的某一区域,这一区域需要填充成其他颜色.区域是不规则的,而且点击该区域的任一点,都能够变色.普通的按钮只是简单的加载一幅图肯定是不行的.查了很多资料,终于把它搞定了 ...
- WPF拖动绘制
using System; using System.Windows; using System.Windows.Controls; using System.Windows.Input; using ...
- wpf GeometryDrawing 绘制文字
<GeometryDrawing x:Key="GeometryDrawingText"> <GeometryDrawing.Geometry> <R ...
随机推荐
- poj 3176 Cow Bowling(dp基础)
Description The cows don't use actual bowling balls when they go bowling. They each take a number (i ...
- [Cycle.js] Introducing run() and driver functions
Currently the code looks like : // Logic (functional) function main() { return { DOM: Rx.Observable. ...
- 解决 Google 重定向,体验 Google 本味
想要体验原汁原味的 Google(google.com),下面的方案是我用过的较方便的方案. 欢迎更正及补充 Chrome 扩展 Chrone 商店有一款禁止重定向的扩展 NoCountryRedir ...
- RHEL-resolv.conf文件修改后重启被还原
修改resolve.conf文件之后,reboot或service restart network时,修改的内容被还原.关闭NetworkManager即可.# chkconfig |grep Net ...
- css设置滚动条颜色与样式以及如何去掉与隐藏滚动条
我们大家在浏览网页的时偶尔会看到很漂亮的各种颜色样式的滚动条,这就是通过css代码控制来实现的,于是本人搜集整理一番,这里和大家分享一下使用CSS设置滚动条颜色以及如何去掉滚动条的方法,需要的朋友可以 ...
- listener笔记
listener 分四步: 在被观察者类中创建 onXXListener Interface,包含一个方法:xxxListener(object o),参数根据需要观察者需要设定. public in ...
- oracle常用自定义函数集合
1.Oracle 判断值是否为数字的函数CREATE OR REPLACE FUNCTION ISNUMBER(MyStr VARCHAR2) RETURN NUMBERIS STR VARCHAR ...
- 查看Sql语句执行速度
原文链接:http://www.cnblogs.com/New-world/archive/2012/11/28/2793560.htmlMS_SQL模糊查询like和charindex的对比 lik ...
- 我的django之旅(二)模板和静态文件
我的django之旅(二)模板和静态文件 标签(空格分隔): django 1.为什么要使用模板 在上一篇博文中,提到了HttpReponse,但是HttpReponse只能传送字符串,如果要构建一个 ...
- java 时区处理机制(0时区转换到服务器时区)
package com.globalroam.util; import java.util.Calendar; import java.util.Date; import java.util.Time ...