计算顶部三角形坐标方法:

         /// <summary>
/// 获取顶三角形坐标
/// </summary>
/// <param name="r">外接圆半径(顶点到中心的距离)</param>
/// <param name="n">N角星</param>
/// <param name="x1">左横坐标</param>
/// <param name="y1">纵坐标</param>
/// <param name="x2">又横坐标</param>
private void GetCoordinate(double r, int n, out double x1, out double y1, out double x2)
{
double unitAngle = ;
if(n < )
{
//奇数角星锐角30,偶数角星锐角和为45
unitAngle = n % == ? : ;
}
else
{
//奇数角星锐角和为180,偶数角星锐角和为360
unitAngle = n % == ? / n : / n;
}
double l = Math.PI / ; //弧度单位
double a = Math.Sin( / ( * n) * l), //多角芒星各角连中心分割所得的夹角的一半
b = Math.Sin(unitAngle/ * l), //芒星内角锐角的一半
c = Math.Sin(( - / ( * n) - unitAngle/) * l), //芒星除了内锐角的其他内角与中心点连线的夹角
d = Math.Cos(( / ( * n)) * l);
x1 = (a * r * b) / c; //正弦定理
y1 = (d * r * b) / c;
x2 = r - x1; //x2与x1关于中心点垂线对称,右移r个长度
x1 += r; //右移r个长度
y1 -= r; //下移r个长度
//取正数
x1 = x1 < ? x1 * (-) : x1;
y1 = y1 < ? y1 * (-) : y1;
x2 = x2 < ? x2 * (-) : x2;
}

1、画空心正N角星

思路:通过计算得到顶部一个三角形的坐标,画出三角形,再画出三角形顺时针旋转一周的其他N-1个三角形。组合起来得到一个伪的多角芒星。

         /// <summary>
/// 画多角芒星,正多角星
/// </summary>
/// <param name="r">外接圆半径</param>
/// <param name="n">角数量</param>
/// <returns>返回包含正多角星的Canvas</returns>
private Canvas DrawingPentacle(double r, int n)
{
double x1, x2, y1;
GetCoordinate(r, n, out x1, out y1, out x2);
Canvas canvas = new Canvas() { Width = , Height = };
//重复N次画出N个三角形斜边
for (int i = ; i <= n; i++)
{
DrawingVisual dv = new DrawingVisual();
using (DrawingContext dc = dv.RenderOpen())
{
dc.DrawGeometry(Brushes.LightBlue, new Pen(Brushes.BlueViolet, ), Geometry.Parse(string.Format("M {0},0 L{1},{2} M 50,0 L{3},{2}", r, x1, y1, x2)));
}
//顺时针旋转
dv.Transform = new RotateTransform(i * / n, , ); //作为图片资源放到图片控件中
RenderTargetBitmap rtb = new RenderTargetBitmap(, , , , PixelFormats.Default);
rtb.Render(dv);
Image image = new Image() { Source = rtb };
canvas.Children.Add(image);
}
return canvas;
}

WPF画N角芒星,正N角星的更多相关文章

  1. CSS实现圆角,三角,五角星,五边形,爱心,12角星,8角星,圆,椭圆,圆圈,八卦

    转自:http://blog.csdn.net/chenhongwu666/article/details/38905803 CSS实现圆角,三角,五角星,五边形,爱心,12角星,8角星,圆,椭圆,圆 ...

  2. WPF画箭头

    简介 参考Using WPF to Visualize a Graph with Circular Dependencies的基础上写了一个WPF画箭头的库. 效果图如下: 使用的XAML代码如下: ...

  3. WPF 画线动画效果实现

    原文:WPF 画线动画效果实现 弄了将近三天才搞定的,真是艰辛的实现. 看了很多博客,都太高深了,而且想要实现的功能都太强大了,结果基础部分一直实现不了,郁闷啊~ 千辛万苦终于找到了一个Demo,打开 ...

  4. OpenCV-Python:Harris角点检测与Shi-Tomasi角点检测

    一.Harris角点检测 原理: 角点特性:向任何方向移动变换都很大. Chris_Harris 和 Mike_Stephens 早在 1988 年的文章<A CombinedCorner an ...

  5. 【OpenCV】角点检测:Harris角点及Shi-Tomasi角点检测

    角点 特征检测与匹配是Computer Vision 应用总重要的一部分,这需要寻找图像之间的特征建立对应关系.点,也就是图像中的特殊位置,是很常用的一类特征,点的局部特征也可以叫做“关键特征点”(k ...

  6. 角点检测:Harris角点及Shi-Tomasi角点检测

    角点 特征检测与匹配是Computer Vision 应用总重要的一部分,这需要寻找图像之间的特征建立对应关系.点,也就是图像中的特殊位置,是很常用的一类特征,点的局部特征也可以叫做“关键特征点”(k ...

  7. c# 半角转换为全角 判断是否是全角

    #region 半角转换为全角 /// <summary> /// 半角转换为全角 ////转全角的函数(SBC case) ///任意字符串 ///全角空格为12288,半角空格为32 ...

  8. 提供对字符串的全角->半角,半角->全角转换

    package com.opslab.util.algorithmImpl; import com.opslab.util.StringUtil; /** * 提供对字符串的全角->半角,半角- ...

  9. WPF画线问题,几千条以后就有明显的延迟了。

      我现在是这么画的,class A { private GeometryGroup _lines; private Path _path; public A() {    _path.Data = ...

随机推荐

  1. Android模拟器Genymotion安装向导

    Genymotion简述 Genymotion提供Android虚拟环境的工具集.相信很多Android开发者一定受够了速度慢.体验差效率及其地下的官方模拟器了.如果你没有物理机器,又不想忍受官方模拟 ...

  2. css()和 attr()的区别

  3. Scut:通用配置管理器

    1. 配置节 ConfigSection private List<ConfigNode> _configNodes; public class ConfigNode { public C ...

  4. Python使用Pygame.mixer播放音乐

    Python使用Pygame.mixer播放音乐 frequency这里是调频率... 播放网络中的音频: #!/usr/bin/env python # -*- coding: utf-8 -*- ...

  5. 移動電源ic的概述

    移動電源ic壹種集供電和充電功能於壹體的便攜式充電器,可以給手機等數碼設備隨時隨地充電或待機供電.壹般由鋰電芯或者幹電池作為儲電單元.區別於產品內部配置的電池,也叫外掛電池.壹般配備多種電源轉接頭, ...

  6. Exception starting filter struts2 java.lang.NoClassDefFoundError: org/objectweb/asm/ClassVisitor

    按教程,使用Convention插件进行配置 教程中说只要加入struts2-convention-plugin-2.3.4.1.jar这个jar包就可以使用. 按照这种方法部署后,启动tomcat报 ...

  7. Flask+Mysql搭建网站之数据库问题

    关于 SQLAlchemy (1.0.8) 和 Flask-SQLAlchemy (2.0) SQLALchemy 是Python语言的SQL工具包及对象关系映射(ORM)工具.Flask-SQLAL ...

  8. I - Agri-Net - poj 1258

    貌似就是个裸的最小生成树啊 ******************************************************************************* #inclu ...

  9. URAL 1081

    题目大意:求词典序下第K个长度为N且无相邻位置都为1的0.1序列.无解时输出-1. 例如: input:     output: 3 1        000(所有符合条件的序列有:000,001,0 ...

  10. 总结XX网app中webapp常见的前端错误。

    在2016年12月至2017年1月,这一个月的时间内,我参与了易政网app中webapp前端项目的工作,下面将我在此次项目中犯的错误总结起来,以防下次再犯.也终于知道之前看的文章中的一段话所代表的意义 ...