EasyX趣味化编程note2,绘制基本图形

news2025/1/23 4:08:20

创意化编程,让编程更有趣

今天介绍的仍为比较简单的效果,由浅入深来进行学习

介绍每个函数都会附上代码和运行结果,感兴趣的大家可以复制粘贴运行一下看看效果,也可以自己进行改动,非常好玩且加深印象。

上节课的知识还是很重要哒,放在这里啦note1

接下来我们正式开始介绍图形化的实现

目录

创意化编程,让编程更有趣

创建窗体的函数

销毁窗体的函数

修改中心坐标函数

缩放函数

绘制点的函数

圆的绘制

直线函数

绘制矩形

绘制椭圆

绘制扇形

绘制一段弧

接下来进行绘制更加复杂的图形

polygon函数

polyline函数

绘制图形时的格式

setlinecolor函数

void setlintstyle

​编辑填充图形

setfillcolor函数

fill+绘制函数的函数

设置背景颜色


在画图之前,我们首先要先创建一个窗体

创建窗体的函数

initgraph(int width,int height,int flag*NULL);

width为窗体宽度,height为窗体高度,最后一个参数可省略暂时不用管。

创建窗体后,我们必然要销毁掉窗体

销毁窗体的函数

void closegraph();

接下来创建一个宽800,高600的窗体,然后调用函数关闭它

int main()
{
	initgraph(800, 600);


	closegraph();
	return 0;
}

运行代码后,发现一个窗体一闪而过,我们可以暂时使用getchar函数暂时阻塞程序的运行,要使用getchar函数,我们又要包含头文件stdio.h。

加入代码后再次运行,效果如图

有了窗体,我们可以尝试画一些基本的图形来看一下

在运行后会出现两个窗体,终端还有创建的窗体,如果觉得不想要它可以改变终端

进入开发者选项后将由windows控制改为控制台主机即可

提前介绍一下画圆的函数

circle(int x,int y,int radius);

x,y为圆心的坐标,radius为圆的半径,加入这段代码,绘制圆心为0,0,半径为300的圆,运行后效果如图

发现只有四分之一的圆,这是为什么呢?


介绍一下Easyx内的坐标系统,分为物理坐标和逻辑坐标,物理坐标和逻辑坐标的初始的坐标系都为下图

他们两个的不同的是

物理坐标系使描述窗体的坐标体系的,坐标原点和轴方向不可以更改,而逻辑坐标用于绘图的坐标体系。他的坐标原点和轴方向可以改变。

修改中心坐标函数

void setorgin(int x,int y);

将中心坐标改为坐标400,300的点,但此时y轴的方向依然是向下的

缩放函数

void setaspectratio(float xasp,float yasp);

xasp为x轴方向上的缩放因子,yasp为y轴方向上的缩放因子,如果传参数为负,则反转坐标系,将第二个参数设置为-1,更改y轴的方向,这时就形成了我们所更加熟练应用的坐标系。

添加后再次运行:

接下来是各种图形的绘制,Easyx配置了形形色色的绘制函数,让我们从绘制点来开始学习

绘制点的函数

void putpixel(int x,int y,COLORREF color);

x,y为在坐标轴的位置,COLOR color是绘制点的颜色,可以用RGB表示颜色,也可以用相应的颜色的大写英文字母来表示。

如下图

试着用绘制点的函数绘制一些点,因为一个点只有一像素,只绘制一个很难看清楚到底绘制出没有,利用for循环和设置随机数的函数生成多个点以便观察。因为我们创建的窗体大小有限制,要对生成的随机数进行处理,不能越过窗体的宽度和高度。

代码如下

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1,-1);
	for (int i = 0; i < 1000; i++)
	{
		int x = rand() % (800 + 1) - 400;
		int y = rand() % (600 + 1) - 300;
		putpixel(x, y,WHITE);
	}
	//circle(0, 0, 300);
	getchar();
	closegraph();
	return 0;
}

运行后效果如图所示

圆的绘制

前边已经介绍过绘制圆的函数,不再详细描述,利用这个函数,我们画一组圆环,中心坐标不变,半径依次增大20像素,直到半径等于300为止。

代码如下

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	for (int i = 0; i <= 300; i+=50)
	{
		circle(0, 0, i);
	}
	
	getchar();
	closegraph();
	return 0;
}

运行后如图所示

直线函数

void line(int x1,int y1,int x2,int y2)

(x1 ,y1)(x2 ,y2)分别为起始点的坐标和终止点的坐标,即线的两端。

使用一下看看效果

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	line(200, 200, -200, -200);
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	getchar();
	closegraph();
	return 0;
}

浅浅的绘制出坐标系,观察第一个画出的线的效果。

绘制矩形

void rectangle(int left,int top,int right,int bottom);

传入的参数和绘制直线的差不多,但表示的是一个矩形的左上角点的坐标和左下角点的坐标,知道了两个点,可以做出一个矩形。

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	//画出坐标系
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	//绘制矩形
	rectangle(-100,100,200,-200);
	getchar();
	closegraph();
	return 0;
}

运行后如图

绘制椭圆

void ellipse(int left,int top,int right,int bottom);

这个函数的参数和绘制矩形的一样就是在矩形内确定一个唯一的椭圆,画一下清晰可见

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	//画出坐标系
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	//绘制矩形
	rectangle(-100,100,100,-200);
	ellipse(-100, 100, 100, -200);
	getchar();
	closegraph();
	return 0;
}

更改了矩形的形状,更加体现出这个函数绘制椭圆的形状,如果矩形位正方形,那画出的椭圆就是一个正方形的内接圆。

绘制扇形

void pie(int left,int top,int right,int bottom,double stangle,double endangle);

前边的参数和椭圆的一模一样,后两个参数分别为扇形的起始角度和终止角度,其实就是在上边的椭圆中截取一段,这一段是由该椭圆的原点的x轴开始,顺时针截取一段扇形

代码如下

#define Pai 3.14 
int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	//画出坐标系
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	//绘制矩形
	rectangle(-100,100,100,-200);
	//ellipse(-100, 100, 100, -200);
	//将椭圆函数注释掉
	pie(-100, 100, 100, -200, 0, Pai / 4);
	getchar();
	closegraph();
	return 0;
}

运行后如图,发现正确绘制出一个扇形

绘制一段弧

void arc(int left,int top,int right,int bottom,double stangle,double endangle);

扇形和弧的区别我想大家都知道,直接改变上述代码,把绘制扇形的函数改为绘制弧的函数

代码如下

#define Pai 3.14 
int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	//画出坐标系
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	//绘制矩形
	rectangle(-100,100,100,-200);
	//ellipse(-100, 100, 100, -200);
	//将椭圆函数注释掉
	//pie(-100, 100, 100, -200, 0, Pai / 4);
	//绘制一段弧
	arc(-100, 100, 100, -200, 0, Pai / 4);
	getchar();
	closegraph();
	return 0;
}

运行后效果如下

vectory,嘿嘿

接下来进行绘制更加复杂的图形

有了上边的讲解,接下来绘制一些稍微复杂一点点的图形()

绘制三角形就是利用line函数,确定三角形的三个顶点,依次连接即可

代码如下

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	//绘制坐标系
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	//绘制三角形
	line(0, 100, 50, -50);
	line(50, -50, -50, -50);
	line(-50, -50, 0, 100);
	
	getchar();
	closegraph();
	return 0;
}

运行后结果如下

是不是觉得好麻烦?

polygon函数

void polygon(const POINT*points,int num);

第一个函数是一个指针,指向数组的首元素,数组里装的是点的坐标,第二个参数阐明有多少个点,用这个函数绘制这个三角形。

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	//绘制坐标系
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	//绘制三角形
	/*line(0, 100, 50, -50);
	line(50, -50, -50, -50);
	line(-50, -50, 0, 100);
	*/

	POINT points[] = { {0,100},{50,-50},{-50,-50} };
	polygon(points, 3);
	getchar();
	closegraph();
	return 0;
}

运行后和上边的三角形一模一样。

没有简单很多?如果再装其他的点的坐标,就可以绘制其他的图形,例如矩形,梯形,等等等等,是不是很实用。

我们来画出一个五边形,利用数学知识,确定好各个点的坐标,可以用角度来表示,更简单一点。

分析如下

由于确定坐标位置要用到sin和cos函数,要包含头文件math.h

代码如下

#include <math.h>
#define Pai 3.14
int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	//绘制坐标系
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	int r = 200;//半径
	//初始角度
	double theta = Pai / 2;
	//递增角度
	double delta = 2 * Pai / 5;
	POINT points[5];//定义一个数组,存放点的坐标
	for (int i = 0; i < 5; i++)
	{
		points[i].x = cos(theta + i * delta) * r;
		points[i].y = sin(theta + i * delta) * r;
	}
	polygon(points, 5);
	getchar();
	closegraph();
	return 0;
}

运行后如图

怎么改成五角星呢?其实很简单,把递增角度72°改为144°即可,还是循环五次哦

运行后如下图所示

就不解释啦,大家随便一想就可以明白。

然而

这个函数会将传入的坐标依次连接,如果我们想画一个W型呢,找好坐标,用ploygon函数的话

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1,-1);
	line(400, 0, -400, 0);
	line(0, 300, 0, -300);
	POINT points[] = { {-200,200},{-100,0},{0,80},{100,0},{200,200} };
	polygon(points, 5);
	getchar();
	closegraph();
	return 0;
}

运行后如图

而我想要的是不封口的,即最后点不连接第一个点

polyline函数

这个函数和polygon几乎一模一样,不同的是他不会连接最后一个点和第一个点来封闭图形,使用polyline函数再次运行

成功!

绘制图形时的格式

前边所学绘制出的图形描边颜色都默认为白色,现在来更改他,利用

setlinecolor函数

void setlinecolor(COLORREF color);

设置描边颜色,一定要在绘制图形之前设置

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	setlinecolor(YELLOW);
	for (int i = 0; i <= 300; i+=50)
	{
		circle(0, 0, i);
	}
	
	getchar();
	closegraph();
	return 0;
}

还是之前画圆的代码,设置描边颜色后

还可以设置描边的样式

void setlintstyle

void setlinestyle(int style,int thickness=1;const DWORD *puserstyle=NULL,DOWRD usesrstylecount=0);

稀里哗啦一大堆,我们只需要关注前两个参数即可

第一个参数style有很多种类型,可以利用操作符|来进行连接使用,使描边多样式

从线型,端点样式,连接样式里面各挑出几个不容易明白的进行说明

首先说明一下第二个参数为描边的粗细,我们可以设置粗一点更加容易观察。

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1, -1);
	setlinecolor(BLUE);
	//线型为实线,端点为圆弧,连接处为斜接
	setlinestyle(PS_SOLID | PS_ENDCAP_ROUND | PS_JOIN_MITER, 60);
	POINT points[] = { {-200,200},{-100,0},{0,80},{100,0},{200,200} };
	polyline(points, 5);
    //连接处为斜面
	//setlinestyle(PS_SOLID | PS_ENDCAP_FLAT | PS_JOIN_BEVEL, 60);
	//POINT points[] = { {-200,200},{-100,0},{0,80},{100,0},{200,200} };
	//polyline(points, 5);
	getchar();
	closegraph();
	return 0;
}

线型为实线,端点为圆弧,连接为斜接,运行后如图

把第一次绘图的注释掉,把下边的解注释


填充图形

在此之前绘制的所有图形都是十分单调的,没有什么花里胡哨可言,当我们将这些图形进行颜色的填充就可以变得好玩一些。

填充函数只需要在绘制函数前加一个solid即可

solid+图形函数名

例如矩形,三角形,椭圆,只需要将circle换一下即可

绝不仅仅是白色

setfillcolor函数

void setfillcolor(COLORREF color);

设置填充颜色,然后绘制图形,代码如下

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1,-1);
	
	setfillcolor(BLUE);
	solidcircle(0, 0, 200);
	getchar();
	closegraph();
	return 0;
}

运行后效果如下

如果我们想要红色的描边,红色的填充,而不是将描边颜色也改变,就要使用fill函数

fill+绘制函数的函数

改变上述代码,将solid改为fill,再次运行

设置背景颜色

setbkcolor(颜色);

将上述代码,设置背景颜色为白色,但是仅仅用这个函数是不行的,我们在创建窗体时,默认窗体已经被黑色填满

cleardevice();

将使用新的颜料粉刷一遍窗体,设置好新的背景后,就可以开始粉刷

代码如下

int main()
{
	initgraph(800, 600);
	setorigin(400, 300);
	setaspectratio(1,-1);
	

	setbkcolor(WHITE);
	cleardevice();
	setlinecolor(RED);
	setlinestyle(PS_SOLID,5);
	setfillcolor(BLUE);
	fillcircle(0, 0, 200);
	getchar();
	closegraph();
	return 0;
}

运行后如下图

我们今天所学的大概就是如此啦

接下来只会更加精彩哦,欢迎大家点赞评论哇!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1051304.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

wsl2 更新报错问题解决记录

1、问题 win10 中安装的 wsl2&#xff0c;启动 docker desktop 时提示 wsl2 有问题&#xff1a; 于是点击推荐的地址连接到微软&#xff0c;下载 wsl2 的更新文件。之后运行&#xff0c;又报错&#xff1a; 更新被卡住。 2、解决方法 WinR 输入 cmd 打开命令行窗口&#x…

基于Vue+ELement搭建动态树与数据表格实现分页模糊查询

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是Java方文山&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的专栏《ELement》。&#x1f3af;&#x1f3af; &#x1…

self-XSS漏洞SRC挖掘

本文由掌控安全学院 - 一朵花花酱 投稿 Markdown是一种轻量级标记语言&#xff0c;创始人为约翰格鲁伯&#xff08;John Gruber&#xff09;。它允许人们使用易读易写的纯文本格式编写文档&#xff0c;然后转换成有效的 XHTML&#xff08;或者HTML&#xff09;文档。这种语言吸…

MySQL数据库基本操作--DDL

文章目录 1. DDL2. 对数据库的常用操作3. 对表结构的常用操作数据类型数值类型字符串类型日期类型 基本操作修改表结构格式 1. DDL DDL(Data Definition Language)&#xff0c;数据定义语言&#xff0c;该语言部分包括以下内容&#xff1a; 对数据库的常用操作对表结构的常用…

我与南非的三次邂逅

点击文末“阅读原文”即可参与节目互动 剪辑、音频 / 卷圈 运营 / SandLiu 卷圈 监制 / 姝琦 产品统筹 / bobo 场地支持 / 声湃轩天津录音间 特别感谢 / 南非旅游局、日光派对 本期节目中&#xff0c;我们邀请了一位特别的嘉宾索导&#xff0c;她将带领我们走进南非&…

ide unknown command (empty parse result): / 问题及解决方案

vs studio端口冲突了 在属性 web 修改端口号就能解决 搞定

18661 2020 金属卤化物灯 钪钠系列 性能要求 学习记录

声明 本文是学习GB-T 18661-2020 金属卤化物灯 钪钠系列 性能要求. 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 1 范围 本标准规定了钪钠系列金属卤化物灯的分类与命名、主要尺寸、基本参数、技术要求、试验方法、检 验规则、标志、包装、运输和…

CSS详细基础(六)边框样式

本期是CSS基础的最后一篇~ 目录 一.border属性 二.边框属性复合写法 三.CSS修改表格标签 四.内边距属性 五.外边距属性 六.其他杂例 1.盒子元素水平居中 2.清除网页内外元素边距 3.外边距的合并与塌陷 4.padding不会撑大盒子的情况 七.综合案例——新浪导航栏仿真 …

微信小程序写一个将图片对象转成base64字符串的函数

这个我只能比较遗憾的说 小程序中大部分操作文件的API都是异步的 所以这个函数 我们还是要异步返回 其实大家肯定也都喜欢同步的 imageToBase64(image) {return new Promise((resolve, reject) > {const filePath image.path;// 获取图片文件大小wx.getFileInfo({filePath…

马尔萨斯《人口原理》读后

200 多年前的书&#xff0c;很多人都说旧的东西过时了&#xff0c;但我觉得它只是被修正了&#xff0c;内核并不过时。毕竟&#xff0c;静态存量分析这本身就不符合现实&#xff0c;用现在的话说&#xff0c;建模就错了&#xff0c;但马尔萨斯的理论核心并不仅仅是一个模型&…

IO流 之 缓冲流(字节缓冲流和字符缓冲流)

缓冲流对原始流进行了包装&#xff0c;以提高原始流读写数据的性能。 字节缓冲流&#xff08;BufferedInputStream和BufferedOutputStream&#xff09; 字节缓冲流在内存中提供了一个默认为8kb的区域&#xff0c;用于缓冲&#xff0c;当流开始时&#xff0c;先读取一个8kb的内…

【Orange Pi】Orange Pi5 Plus 安装记录

官网&#xff1a;Orange Pi - Orangepi 主控芯片&#xff1a;Rockchip RK3588(8nm LP制程&#xff09;NPU&#xff1a;内嵌的 NPU 支持INT4/INT8/INT16/FP16混合运算&#xff0c;算力高达 6Top支持的操作系统&#xff1a; Orangepi OS&#xff08;Droid&#xff09;Orangepi O…

[JAVAee]MyBatis

目录 MyBatis简介 MyBatis的准备工作 框架的添加 连接数据库字符串的配置 MyBatis中XML路径的配置 ​编辑 MyBatis的使用 各层的实现 进行数据库操作 增加操作 拓展 修改操作 删除操作 查询操作 结果映射 单表查询 多表查询 like模糊查询 动态SQL / MyBa…

【超详细】Wireshark教程----Wireshark 分析ICMP报文数据试验

一&#xff0c;试验环境搭建 1-1 试验环境示例图 1-2 环境准备 两台kali主机&#xff08;虚拟机&#xff09; kali2022 192.168.220.129/24 kali2022 192.168.220.3/27 1-2-1 网关配置&#xff1a; 编辑-------- 虚拟网路编辑器 更改设置进来以后 &#xff0c;先选择N…

[Linux]Git

文章摘于GitHub博主geeeeeeeeek 文章目录 1.1 Git 简易指南创建新仓库工作流添加与提交推送改动 1.2 创建代码仓库git init用法讨论裸仓库 例子 git clone用法讨论仓库间协作 例子用法讨论栗子 1.3 保存你的更改git add用法讨论缓存区 栗子 git commit用法讨论记录快照&#xf…

数据统计-EXCEL中常用函数及操作

最近经常需要做一些数据统计工作&#xff0c;整理下EXCEL常用的函数及操作&#xff0c;总结及分享出来&#xff0c;后续会不断更新。 一、VLOOKUP函数 同表查询&#xff1a;VLOOKUP(A2,$A:$G,1,0) 跨表查询&#xff1a; VLOOKUP(A2,Sheet2!$A:$G,1,0) 跨工作薄&#xff1a; 跨…

GD32F10x的输出模式

1. 单片机型号的识别。 2. GPIO的输出模式。 1. 开漏模式 2.推挽模式 3.复用开漏模式 4.复用推挽模式。 开漏模式&#xff1a;&#xff08;写入位设置&#xff0c;输出数据寄存器来控制MOS&#xff09; 只有N-MOS管导通。PMOS不导通。 当N-MOS的栅极为0&#xff0c;N-MOS管…

Windows 下安装和配置 Redis (详细图文)

目录 下载 Redis安装 Redis配置 Redis修改密码(可选)配置环境变量注册系统服务 Redis 桌面管理工具附&#xff1a;开源项目微服务商城项目前后端分离项目 下载 Redis 访问 Redis 下载地址&#xff1a;https://github.com/tporadowski/redis/releases 下载 Redis 时&#xff0c…

unity 鼠标标记 左键长按生成标记右键长按清除标记,对象转化为子物体

linerender的标记参考 unity linerenderer在Game窗口中任意画线_游戏内编辑linerender-CSDN博客 让生成的标记转化为ARMarks游戏对象的子物体 LineMark.cs using System.Collections; using System.Collections.Generic; using UnityEngine;public class LineMark : MonoBeh…

二十二,加上各种贴图

使用pbr的各种贴图&#xff0c;albedo,金属度&#xff0c;ao,法线&#xff0c;粗糙度&#xff0c;可以更好的控制各个片元 1&#xff0c;先加上纹理坐标 texCoords->push_back(osg::Vec2(xSegment, ySegment)); geom->setVertexAttribArray(3, texCoords, osg::Array::BI…