#include "Dependencies\glew\glew.h"
#include "Dependencies\freeglut\freeglut.h"
#include <stdio.h>
GLint array[1000][2]; //保存要显示的坐标点
int length=0;
class screenPt {
private:
GLint x, y;
public:
/* Default Constructor:initializes coordinate position to (0,0). */
screenPt() {
x = y = 0;
}
void setCoords(GLint xCoordValue, GLint yCoordValue) {
x = xCoordValue;
y = yCoordValue;
}
GLint getx() const {
return x;
}
GLint gety() const {
return y;
}
void incrementx() {
x++;
}
void decrementy() {
y--;
}
};
void init(void) {
glClearColor(1.0, 1.0, 1.0, 0.0);//窗口颜色(红:[0.0~1.0]R, 绿:[0.0~1.0]G,蓝:[0.0~1.0]B, 透明度:[0.0~1.0]A)
/*使用正投影将世界坐标系二位矩形区域的内容映射到屏幕上,区域的x坐标值从0.0到200.0,y坐标值从0.0到150.0*/
glMatrixMode(GL_PROGRAM);
gluOrtho2D(0.0, 200.0, 0.0, 150.0);
}
void setPixel(void)
{
glClear(GL_COLOR_BUFFER_BIT);//GL_COLOR_BUFFER_BIT是一个OpenGL符号常量,用来指定它的颜色缓存(刷新缓存)中的位值,该缓存将使用glClearColor函数中指定的值来设定。
glColor3f(1.0f, 0.0f, 0.0f);//设置线段颜色为红色
glPointSize(5.f); //设置点的大小
glBegin(GL_POINTS);
for (size_t i = 0; i <=length; i++)
{
glVertex2i(array[i][1], array[i][2]);
}
glEnd();
glFlush();//执行所有的OpenGL程序
}
void circlePlotPoints(GLint xc, GLint yc, screenPt circPt)
{
//setPixel(xc + circPt.getx(), yc + circPt.gety());
//setPixel(xc - circPt.getx(), yc + circPt.gety());
//setPixel(xc + circPt.getx(), yc - circPt.gety());
//setPixel(xc - circPt.getx(), yc - circPt.gety());
//setPixel(xc + circPt.gety(), yc + circPt.getx());
//setPixel(xc - circPt.gety(), yc + circPt.getx());
//setPixel(xc + circPt.gety(), yc - circPt.getx());
//setPixel(xc - circPt.gety(), yc - circPt.getx());
printf("(%d,%d)\n", xc + circPt.getx(), yc + circPt.gety());
//要显示的坐标点保存至array[1000][2]
array[length][1] = xc + circPt.getx(), array[length][2] = yc + circPt.gety();
}
void circleMidpoint(void)
{
screenPt circPt;
GLint xc = 0;
GLint yc = 0;
GLint radius = 50;
GLint p = 1 - radius; // Initial value for midpiont parameter.
circPt.setCoords(0, radius);// Set coords for top point of circle.
void circlePlotPoints(GLint, GLint, screenPt);
/* Plot the initial point in each circle quadrant. */
circlePlotPoints(xc, yc, circPt);
/* Calculate next point and plot in each octant. */
while (circPt.getx()<circPt.gety()) {
length++;
circPt.incrementx();
if (p<0)
p += 2 * circPt.getx() + 1;
else {
circPt.decrementy();
p += 2 * (circPt.getx() - circPt.gety()) + 1;
}
circlePlotPoints(xc, yc, circPt);
}
}
int main(int argc, char *argv[])
{
glutInit(&argc, argv);//初始化GULT
glutInitDisplayMode(GLUT_RGB | GLUT_SINGLE);//设置显示模式
glutInitWindowPosition(300,500);//设置左上角窗口显示位置
glutInitWindowSize(400, 300);//设置窗口显示的宽与高
glutCreateWindow("中点画圆算法");//创建一个窗口
init();//执行初始化程序
circleMidpoint();
glutDisplayFunc(setPixel);//把图形显示在窗口
glutMainLoop();//显示所有并进入等待状态
}
Wizen123
- 粉丝: 13
- 资源: 4
最新资源
- 视频编码中基于改进DAG-SVM模型的H.266/VVC快速CU分区决策算法
- 第二章Rust初步.pptx
- 工具变量-中国农村统计面板数据集(2000-2022年).xlsx
- 第五章.pptx
- The official Meta Llama 3 GitHub site
- 第一章最终.pptx
- 基于Rust的网络软件设计与实现-20241117.docx
- 基于simulink的三自由度汽车操纵模型仿真与分析, 汽车三自由度操纵模型仿真与分析 基于simulink三自由度汽车操纵模型,包含侧向,侧倾和横摆 操纵模型附带具体数据参数,有详细的公式文档说明
- qt-everywhere-opensource-src-5.2.1.tar
- Docker容器技术的基本概念、安装与管理方法及其实用技巧入门指南
- 电池管理(BMS)控制系统 电动客车电池管理系统SOC估算单元设计 设计一款电池管理系统,它包含着以下功能: 1、搭建考虑温度的二阶RC电池Simulink模型,监测并且采集每节电池的电压、采集一部
- 嵌入式系统中的TC305触摸传感器原理与应用详解
- stm32g431 esc 无感foc非线性磁链观测器 速度环 电流环 零速双闭环启动 带载运行 堵转力矩保持 算法资料 只卖资料,没有硬件实物 资料包括cubemx配置文件,mdk项目文件,调试笔
- 扫描文件_QQ浏览器_20250103.pdf
- Python U盘小偷工具
- qt-everywhere-opensource-src-5.0.1.tar
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈