慢羊羊的空间

无为,无我,无欲,居下,清虚,自然

万花尺(又叫万花规)模拟程序

万花尺相信很多人小时候都玩过吧,将一个满是齿牙的小圆套在一个大圆里面,用笔放进小圆的洞里,然后转圈圈画,就可以画出很多美丽有趣的图案。这个程序就是万花尺的模拟程序。

下面是几组数据和执行效果的抓图:

代码如下:

////////////////////////////////////////////
// 程序名称:万花尺(又名万花规)模拟程序
// 编译环境:Visual C++ 6.0,EasyX 2011惊蛰版
// 程序编写:yangw80 <yw80@qq.com>
// 最后更新:2011-2-26
//
#include <graphics.h>
#include <stdio.h>
#include <conio.h>
#include <math.h>
#define PI 3.1415926536

void main()
{
	int R;		// 外部静圆半径
	int r;		// 内部动圆半径
	int dr;		// 内部动圆上的作图点到圆心的距离

begin:
	// 获取用户输入
	printf("请输入外部静圆半径(小于 240):");
	scanf("%d",&R);
	printf("请输入内部动圆半径(小于静圆半径):");
	scanf("%d",&r);
	printf("请输入内部动圆上的作图点到圆心的距离(小于动圆半径):");
	scanf("%d",&dr);
	system("cls");

	// 求执行次数(最小公倍数/静圆半径)
	int m = R, n = r;
	int tmp;
	while(n != 0)
	{
		tmp = m % n;
		m = n;
		n = tmp;
	}
	double maxdegree = r / m * 2 * PI;

	// 初始化
	initgraph(640, 480);	// 创建绘图窗口
	setorigin(320, 240);	// 设定圆心坐标
	
	// 绘图
	int x, y;
	for(double degree = 0; degree < maxdegree; degree += 0.01)
	{
		x = (int)(dr * cos(degree*(double(R) / r - 1)) + (R - r) * cos(degree));
		y = (int)(dr * sin(degree*(double(R) / r - 1)) - (R - r) * sin(degree));
		putpixel(x, y, GREEN);
	}
	outtextxy(-320, 220, _T("绘制完毕,按 ESC 退出,按其他键重新开始"));

	// 重新开始,或退出程序
	char c = getch();
	closegraph();
	if (c != 27) goto begin;
}