【C语言】--学习putpixel画点;画椭圆ellipse;利用ellipse and rectangle 画图;一个最优美的图案

目录

题目【62】:学习putpixel画点

题目【63】:画椭圆ellipse

题目【64】:利用ellipse and rectangle 画图

题目【65】:一个最优美的图案


以下题目的代码均可在VS上运行。注意源文件的后缀要为“.cpp”

题目【62】:学习putpixel画点

#include "stdio.h"
#include "graphics.h"
#include "conio.h"
int main()
{
	int i, j;
	initgraph(640, 680);
	setbkcolor(YELLOW);
	cleardevice();
	for (i = 50;i <= 230;i += 20)
		for (j = 50;j <= 230;j++)
			putpixel(i, j, 1);
	for (j = 50;j <= 230;j += 20)
		for (i = 50;i <= 230;i++)
			putpixel(i, j, 1);
	_getch();
}

题目【63】:画椭圆ellipse

#include "stdio.h"
#include "graphics.h"
#include "conio.h"
int main()
{
	int x = 360, y = 160;
	int num = 20, i;
	int top, bottom;
	initgraph(640,680);
	top = y - 30;
	bottom = y - 30;
	for (i = 0;i < num;i++)
	{
		ellipse(250, 250, 0, 360);
		top -= 5;
		bottom += 5;
	}
	_getch();
}

题目【64】:利用ellipse and rectangle 画图

#include "stdio.h"
#include "graphics.h"
#include "conio.h"
int main()
{
	int i, num = 15, top = 50;
	int left = 20, right = 50;
	initgraph(640, 680);
	for (i = 0;i < num;i++)
	{
		ellipse(250, 250, 0, 360);
		ellipse(250, 250, 0, 360);
		rectangle(20 - 2 * i, 20 - 2 * i, 10 * (i + 2), 10 * (i + 2));
		right += 5;
		left += 5;
		top += 10;
	}
	_getch();
}

题目【65】:一个最优美的图案

#include "graphics.h"
#include "math.h"
#include "dos.h"
#include "conio.h"
#include "stdlib.h"
#include "stdio.h"
#include "stdarg.h"
#define MAXPTS 15
#define PI 3.1415926
struct PTS {
	int x, y;
};
double AspectRatio = 0.85;

void LineToDemo(void)
{
	//struct viewporttype vp;
	struct PTS points[MAXPTS];
	int i, j, h, w, xcenter, ycenter;
	int radius, angle, step;
	double rads;
	printf(" MoveTo / LineTo Demonstration");
	//getviewsettings(&vp);
	//h = vp.bottom - vp.top;
	//w = vp.right - vp.left;
	h = 400;w = 600;
	xcenter = w / 2; /* Determine the center of circle */
	ycenter = h / 2;
	radius = (h - 30) / (AspectRatio * 2);
	step = 360 / MAXPTS; /* Determine # of increments */
	angle = 0; /* Begin at zero degrees */
	for (i = 0; i < MAXPTS; ++i) { /* Determine circle intercepts */
		rads = (double)angle * PI / 180.0; /* Convert angle to radians */
		points[i].x = xcenter + (int)(cos(rads) * radius);
		points[i].y = ycenter - (int)(sin(rads) * radius * AspectRatio);
		angle += step; /* Move to next increment */
	}
	circle(xcenter, ycenter, radius); /* Draw bounding circle */
	for (i = 0; i < MAXPTS; ++i) { /* Draw the cords to the circle */
		for (j = i; j < MAXPTS; ++j) { /* For each remaining intersect */
			moveto(points[i].x, points[i].y); /* Move to beginning of cord */
			lineto(points[j].x, points[j].y); /* Draw the cord */
		}
	}
}
int main()
{
	initgraph(640, 580);
	setcolor(3);
	setbkcolor(GREEN);
	cleardevice();
	LineToDemo();
	system("pause");
	return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

十三衙

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

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

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

打赏作者

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

抵扣说明:

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

余额充值