此文来源于CSDN博客,转载出处(夏天的树人的专栏)
跟Vincent 讨论一下这种图案,他使用js 实现了这种玫瑰线的图案,使用html5的新功能。而发现,使用其他的语言也可以实现到这种图案。效果还很不错。
数学公式:p=a*sin(num*angle);
我想尝试一个实验,使用其他语言是不是可以一样生成,经过测试原理是一样的。这次使用c#的绘图API。前提是,我对C#不熟悉,看这种文档花了不少时间。而且很不熟悉,c#运作.硬头皮写了一个。不过幸运的是,图案生成了。
步骤一:创建一个c# 的windows 应用程序。名为玫瑰线
在属性面板上的事件上Paint 添加这个事件
c#源码:
当中区别是使用不同度制就会出现不同的结果了。但是公式是一样的。
// double[] point1 = getPoint(200, (i-1)*Math.PI/180, 2);
//double[] point2 = getPoint(200,i*Math.PI/180,2);
double[] point1 = getPoint(200, (i - 1) , 5);
double[] point2 = getPoint(200, i , 5);
在这里,我通过三角函数转换求出点的办法求出x和y的坐标值,然后从开始点,一个接一个点连线下去。
p0--p1-->p2-->p3...一直这样连接下去。这样就能够出现我们想看到的图案。
view plaincopy to clipboardprint?
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
namespace 玫瑰线
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Paint(object sender, PaintEventArgs e)
{
Graphics g = e.Graphics;
Pen p = new Pen(Color.Black, 1);
for (int i = 1; i <=360; i++)
{
// double[] point1 = getPoint(200, (i-1)*Math.PI/180, 2);
//double[] point2 = getPoint(200,i*Math.PI/180,2);
double[] point1 = getPoint(200, (i - 1) , 5);
double[] point2 = getPoint(200, i , 5);
g.DrawLine(p, 250+Convert.ToInt32(point1[0]), 200+Convert.ToInt32(point1[1]), 250+Convert.ToInt32(point2[0]), 200+Convert.ToInt32(point2[1]));
}
}
private double[] getPoint(int r,double i,int num)
{
double len = r * Math.Sin(num * i);
double[] point = Change(len, i);
return point;
}
private double[] Change(double len, double angle)
{
double[] array = new double[2];
array[0]=len * Math.Cos(angle);
array[1] =len * Math.Sin(angle);
return array;
}
}
}