C++利用EasyX绘制心形线

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/weixin_43669941/article/details/89857255

代码如下

#include <graphics.h>
#include <cmath>
#include <conio.h>

constexpr auto PI = 3.1415926;
constexpr auto ONE_ANGLE = PI / 180;

//该函数用于绘制心形线
//_x: x方向上的偏移量
//_y: y方向上的偏移量
//a: 缩放倍数
void cardioid(int _x, int _y, int a)
{
	int x1, y1, x2, y2;
	double angle = 0;
	while (angle <= 2 * PI)
	{
		x1 = a * (2 * sin(angle) + sin(2 * angle)) + _x;
		y1 = a * (2 * cos(angle) + cos(2 * angle)) + _y;
		angle += ONE_ANGLE;
		x2 = a * (2 * sin(angle) + sin(2 * angle)) + _x;
		y2 = a * (2 * cos(angle) + cos(2 * angle)) + _y;
		line(x1, y1, x2, y2);

		Sleep(5);
	}

}

int main(void)
{
	initgraph(640, 480);
	setlinecolor(RGB(255, 0, 0));

	cardioid(320, 240, 50);

	auto ret = _getch();
	closegraph();
	return 0;
}

效果如下

猜你喜欢

转载自blog.csdn.net/weixin_43669941/article/details/89857255
今日推荐