目录
简单的框架,也就是每一个开发的程序公用的代码。下面以绘制一个四边形带为例。
#include <gl/glut.h>
void reshape(int w, int h)
{
glViewport(0, 0, w, h);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
glOrtho(-2, 2, -2, 2, -10, 10);
glMatrixMode(GL_MODELVIEW);
glLoadIdentity();
}
void Display() //显示
{
glShadeModel(GL_FLAT);
//绘图
glClear(GL_COLOR_BUFFER_BIT); //清空颜色缓冲
glBegin(GL_QUAD_STRIP); //图元
glColor3f(1, 0, 0);
glVertex2f( -0.3, 0.5);
glVertex2f(-0.2,-0.5);
glVertex2f(0.2, 0.5);
glVertex2f(0.2,-0.5);
glColor3f(0, 1, 0);
glVertex2f(0.6, 0.5);
glVertex2f(0.7, -0.5);
glColor3f(0, 0, 1);
glVertex2f(1.2, 0.5);
glVertex2f(0.9, -0.5);
glColor3f(0, 1, 1);
glVertex2f(1.8, 0.5);
glVertex2f(1.3, -0.5);
glEnd();
glFlush(); //清空并执行缓冲区指令
}
int main(int argc, char** argv)
{
//glut初始化
glutInit(&argc, argv); //对命令行参数进行处理
glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB); //初始化窗口显示模式为单缓冲和RGB颜色模式
glutInitWindowSize(700, 700); //初始化窗口大小为700px*700px
glutInitWindowPosition(200, 100); //初始化窗口显示位置
glutCreateWindow("显示页面"); //创建窗口
glutDisplayFunc(Display); //设置显示回调函数
glutReshapeFunc(reshape);
glutMainLoop(); //循环
return 0;
}
运行结果
图元的类型
下面提供几种图元绘制的代码,只用替换display()函数中glBegin()和glEnd()函数之间的内容就可以了。
//点的绘制
glPointSize(5.0f); //设置点的大小
glBegin(GL_POINTS); //图元
glColor3f(1, 1, 0);
glVertex2f(1,1);
glVertex2f(0.5, 0.5);
glVertex2f(0.3, 0.3);
glColor3f(1, 0, 1);
glVertex2f(-1,1);
glVertex2f(-0.5, 0.5);
glVertex2f(-0.3, 0.3);
glVertex2f(-1,-1);
glColor3f(1,1,1);
glVertex2f(1,-1);
glVertex2f(0.5, -0.5);
glVertex2f(0.3, -0.3);
glEnd();
//线的绘制
glLineWidth(0.5f); //设置线的宽度
glBegin(GL_LINES); //图元
glColor3f(1, 1, 0);
glVertex2f(0.2,0.4);
glVertex2f(0, 0);
glColor3f(1, 0, 0);
glVertex2f(0.3, 0.5);
glVertex2f(0.5,0.33);
glEnd();
//点划线
glLineWidth(4.0f); //设置线的宽度
glEnable(GL_LINE_STIPPLE); //控制开始
glLineStipple(2, 0xff00);
glColor3f(1, 1, 0);
glBegin(GL_LINES); //图元
//glColor3f(1, 1, 0);
glVertex2f(0.5, 0.5);
glVertex2f(-0.5, 0.5);
//glColor3f(1, 0, 0);
glVertex2f(-0.5, -0.5);
glVertex2f(0.5, -0.5);
glEnd();
//三角形带的绘制
glBegin(GL_TRIANGLE_STRIP);
glColor3f(1, 1, 0);
glVertex2f(0,0.5);
glVertex2f(0, 0);
glVertex2f(0.1, 0.7);
glColor3f(1, 0, 0);
glVertex2f(0.3, 0);
glColor3f(1, 0, 1);
glVertex2f(0.6,0.8);
glColor3f(0,1,1);
glVertex2f(0.7,-0.1);
glColor3f(1, 1, 0);
glVertex2f(1, 0.7);
glColor3f(0, 1, 0);
glVertex2f(1.1, 0.1);
glColor3f(0, 1, 1);
glVertex2f(1.3, 0.6);
glEnd();
//画线段
glLineWidth(4.0f);
glBegin(GL_LINE_STRIP);
glColor3f(1,1,0);
glVertex2f(0,0);
glVertex2f(0, 0.5);
glColor3f(1, 0, 1);
glVertex2f(0.2, 0.4);
glColor3f(0,1,1);
glVertex2f(0.3,0);
glEnd();
//GL_LINE_LOOP
glBegin(GL_LINE_LOOP);
glLineWidth(4.0f);
glColor3f(1, 1, 0);
glVertex2f(0,0);
glVertex2f(0.5,-0.5);
glVertex2f(0.6, 0.4);
glVertex2f(0.2, 0.3);
glEnd();
//GL_TRIANGLE_FAN
glBegin(GL_TRIANGLE_FAN);
glColor3f(1, 1, 0);
glVertex2f(0,0);
glVertex2f(0.6, 0.1);
glVertex2f(0.5, 0.3);
glColor3f(1, 0, 1);
glVertex2f(0.4, 0.4);
glColor3f(0, 1, 0);
glVertex2f(-0.1,0.3);
glColor3f(0, 0, 1);
glVertex2f(-0.2, 0.2);
glColor3f(0, 1, 1);
glVertex2f(-0.1, -0.1);
glEnd();
//GL_POLYGON
glBegin(GL_POLYGON);
glColor3f(1, 1,0);
glVertex2f(0, 0);
glVertex2f(0.3,-0.2);
glVertex2f(0.5, -0.1);
glVertex2f(0.6, 0.7);
glVertex2f(0.4, 0.6);
glVertex2f(0.2, 0.5);
glEnd();
为了模拟光滑表面,OpenGL在渲染时根据顶点颜色通过插值计算各片元的颜色;为了模拟平面,可调用glShadeModel(GL_FLAT)将默认着色器从GL_SMOOTH改为GL_FLAT。
void glShadeModel(GL_SMOOTH); //平滑着色
void glShadeModel(GL_FLAT); //恒定着色
GL_FLAT导致OpenGL渲染后续图元的时候,使用最后一个顶点的颜色给图元着色。
如果片元alpha值未通过应用程序指定的比较测试,alpha测试特性将其丢弃。要使用alpha测试,应用程序必须启用它并指定比较测试。要启用和禁用alpha测试,可使用参数GL_ALPHA_TEST调用相应函数。
glEnable(GL_ALPHA_TEST); //启用alpha测试
glAlphaFunc(GL_GREATER, 0.f); //大于接受
还有以下参数
GL_ALWAYS(始终通过),
GL_NEVER(始终不通过),
GL_LESS(小于则通过),
GL_LEQUAL(小于等于则通过),
GL_EQUAL(等于则通过),
GL_GEQUAL(大于等于则通过),
GL_NOTEQUAL(不等于则通过)
例子
//alpha测试
glColorMask(GL_TRUE, GL_TRUE, GL_FALSE, GL_FALSE);
glEnable(GL_ALPHA_TEST); //启用alpha测试
glAlphaFunc(GL_GREATER, 0.4); //大于接受
glBegin(GL_QUAD_STRIP); //图元
glColor4f(1, 1, 0,0.3);
glVertex2f(-0.2, 0.5);
glVertex2f(-0.2, -0.5);
glColor4f(1, 0, 0,0.5);
glVertex2f(0.2, 0.5);
glVertex2f(0.2, -0.5);
glEnd();
//定义裁剪平面数组
GLdouble equn[4] = { 1,-1,0,0 };
//设置裁剪平面
glEnable(GL_CLIP_PLANE0);
glClipPlane(GL_CLIP_PLANE0, equn);
Ax+By+Cz+D>=0 部分会被保留。
文章浏览阅读3.6k次。用人工智能普惠体育发展。
文章浏览阅读10w+次,点赞92次,收藏495次。表单提交方式一:直接利用form表单提交html页面代码:<!DOCTYPE html><html><head><meta charset="UTF-8" /><title>Insert title here</title></head><body><form action="h..._提交表单
文章浏览阅读5.1k次。Unity Spine SkeletonGraphic 重复播放 过度残影Bug 解决方案不推荐使用SetToSetupPose和Setup Pose相关,代码直接贴上/// <summary>/// Spine播放设置/// </summary>/// <param name="trackIndex">填写0</param>/// <param name="animationName">动画名</param>/// &l_unity skeletongraphic
文章浏览阅读3.5k次。一、推导过程:二、结果:边缘分布x1,x2 各自依然服从 μi,写反差矩阵 Σii 的多元高斯分布;条件概率分布给定 xj 求 xi 的分布:μi|j=μi+ΣijΣ−1jj(xj−μj)Σi|j=Σjj−ΣTijΣ−1iiΣij..._高斯分布的条件概率
文章浏览阅读339次,点赞8次,收藏8次。Ratelimitcache: Python缓存库,支持速率限制项目链接: https://gitcode.com/simonw/ratelimitcache?utm_source=artical_gitcode如果你正在寻找一个Python缓存库,并且希望对缓存操作进行速率限制,那么Ratelimitcache可能是你的理想选择。什么是Ratelimitcache?Ratelimitca..._python ratelimit基于什么
文章浏览阅读2.3k次,点赞2次,收藏8次。Xpath和CSS信息提取的方法异同点_xpath 获取css
文章浏览阅读454次。正交频分复用(OFDM)是一种在现代通信系统中广泛使用的调制技术,它具有高效的频谱利用和抗多径衰落等特点。64QAM(64-ary Quadrature Amplitude Modulation)是一种调制方式,可以在每个符号中传输更多的位信息。在OFDM系统中,保持载波同步对确保数据传输的可靠性至关重要。_基于ofdm+64qam系统的载波同步matlab仿真,
文章浏览阅读67次。Jdk1.8 + Tomcat8.5 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。若包含,则为maven项目,否则为非maven项目。Springboot毕设项目超市商品销售管理系统37x2w(java+VUE+Mybatis+Maven+Mysql)Springboot + mybatis + Maven + Vue 等等组成,B/S模式 + Maven管理等等。其他版本理论上也可以。_vue+springboot+mybatis商品管理系统
文章浏览阅读3w次,点赞2次,收藏4次。转载自: http://blog.csdn.net/zouqin369/article/details/6913692 今天去公司设置好IP后,无论怎么样都上不了internet,再次打开本地后发现默认网关自动消失,cmd下输入ipconfig后的现象如下: 物理地址. . . . . . . . . . . . . : 00-22-64-55-76-8F DHCP 已启用_禁止修改网关命令
文章浏览阅读482次。Extjs的窗口是可以加载自己的HTML的,但这样两个页面就相当独立了,传参是个问题 ,网上也没有很好的解答清楚,猫猫今天就说清楚这个模式的传参要点。_extjs中打开网页怎么传参
文章浏览阅读811次。win_win port 进程
文章浏览阅读1.2k次。Ch3点到点数据链路层知识点1. 点到点数据链路层要解决的主要问题2. 常见的帧管理(帧定界)方法3. CRC的计算4. 流量控制的基本原理5. 常见错误及其处理机制6. 滑动窗口的概念、形式及工作原理7. ARQ(Automatic Repeat reQuest)协议工作原理:8. 连续ARQ(Go-back-N ARQ)工作原理(特别注意累计确认):9. 选择重传ARQ工作原理10. 了解(高..._hdlc go-back-n