万花尺模拟程序

万花尺模拟程序

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


// 程序名称:万花尺(又名万花规)模拟程序
// 编译环境:Visual Studio 2013,EasyX 2017-9-19
// 程序作者:鼠瓜
// 最后更新:2012-12-9
//
#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_s("%d", &R);
	printf("请输入内部动圆半径(小于静圆半径):");
	scanf_s("%d", &r);
	printf("请输入内部动圆上的作图点到圆心的距离(小于动圆半径):");
	scanf_s("%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;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@Hwang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值