通过画五角星,回顾啦三角函数

最终程序代码(c#winform paint事件里):

Graphics g = e.Graphics;
Pen pen = new Pen(Color.Yellow, 3);
Brush brush = new SolidBrush(Color.Red);
Point[] star = new Point[10];
double angle = Math.PI / 180;
for (int i = 0; i < 10; i += 2)
            {
                star[i].X = (int)(150 + 80 * Math.Cos(angle * 36 * i + angle * 270));
                star[i].Y = (int)(90 + 80 * Math.Sin(angle * 36 * i + angle * 270));
                star[i + 1].X = (int)(150 + 30 * Math.Cos(angle * 36 * i + angle * 36 + angle * 270));
                star[i + 1].Y = (int)(90 + 30 * Math.Sin(angle * 36 * i + angle * 36 + angle * 270));

            }
g.FillPolygon(brush, star);
g.DrawPolygon(pen, star);



最终程序效果图:

正五角形


五角星程序演化记:

浅析:

       循环处代码作用是得到五角星10个端点坐标,作为FillPolygon和DrawPolygon函数的输入。

       为得到五角星的十个端点坐标,首先可以分析得到,十个端点与五角星中心点的连线把一圈分成啦10份,每份占36度,这也是angle*36的由来,至于(150, 90)这是中心点的坐标。

       这里运用数学及物理中三角函数知识可知,angel*36可以理解成角速度w,每次要旋转多少度,里面 i无论加多少,只是把三角函数图像左右移动而已,不影响图像的形状,至于80和30则是振幅,这里是因为五角星的五个端点离中心点的距离不一样。

那么第一个版本的五角星程序就出现了,假设有个笛卡尔坐标系,那么取画五角星的起点为x轴正向的点,坐标为(150+80*cos0,90+80*sin0).可以写出如下程序:

for (int i = 0; i < 10; i += 2)
            {
                star[i].X = (int)(150 + 80 * Math.Cos(angle * 36 * i));
                star[i].Y = (int)(90 + 80 * Math.Sin(angle * 36 * i));
                star[i + 1].X = (int)(150 + 30 * Math.Cos(angle * 36 * i + angle * 36));
                star[i + 1].Y = (int)(90 + 30 * Math.Sin(angle * 36 * i + angle * 36));

            }



效果图:

五角星1


【注】可以看出,这个五角星是相对于x轴对称,那么我们想得到正五角星,那么就得将其逆时针旋转90度或者将其顺时针旋转270度,这里考虑到程序画布坐标系y轴正向是竖直向下的,所以如果应该把起点坐标写成(150+80*cos(0+270*angle),90+80*sin(0+270*angle)),即是最终的程序了-^^-。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值