opengl 笔记(一)

参考《opengl入门教程》、《OpenGL之坐标转换》、《OpenGL绘制管线操作细节》等资料。

复习下留个备忘:)

/*-
 * Opengl Demo Test
 *
 * Fredric  : 2016-7-8
 */
#include <GLUT/GLUT.h>

void display_demo01();

void display_demo02();

void display_demo03();

void display_demo04();

/*
 *   Main Function
 */
int main(int argc, char ** argv)
{
    /*  glutInit
     *  GLUT初始化
     */
    glutInit(&argc, argv);

    /*
     *  int glutCreateWindow(char* name);
     *  产生一个顶层窗口
     *  char* name:窗口名称
     * return int:窗口标记符号,可以glutGetWindow获取引用
     */
    glutCreateWindow("Fredric Practice Demo");

    /*
     *  void glutDisplayFunc(void (*func)(void));
     *  为当前窗口设置显示回调函数
     */
    glutDisplayFunc(display_demo04);

    /*
     * void glutMainLoop()
     * glut程序进入事件循环
     */
    glutMainLoop();

}

//****************************************************************************

/*
 * 基础显示函数demo
 */
void display_demo01(){

    /*
     *  void glClear(GLbitfield mask);
     *  根据mask的要求清除缓冲值
     *  GL_COLOR_BUFFER_BIT:    当前可写的颜色缓冲
     *  GL_DEPTH_BUFFER_BIT:    深度缓冲
     *  GL_ACCUM_BUFFER_BIT:   累积缓冲
     *  GL_STENCIL_BUFFER_BIT: 模板缓冲
     */
    glClear(GL_COLOR_BUFFER_BIT);

    /*
     *  void glRectf (GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2)
     *  等价于:
     *  glBegin(GL_POLYGON);
     *  glVertex2(x1, y1);
     *  glVertex2(x2, y1);
     *  glVertex2(x2, y2);
     *  glVertex2(x1, y2);
     *  glEnd();
     *  在opengl的世界坐标系中,(0,0,0)是屏幕中心的原点,整个窗口范围为-1到1
     *  在下例中绘制的矩形覆盖全部窗口
     */
    glRectf(-1.0f, -1.0f, 1.0f, 1.0f);

    /*
     * opengl命令立即执行
     */
    glFlush();
}

//****************************************************************************

/*
 *  绘制基本图形demo
 */
void display_demo02(){

    //绘制点
    glClear(GL_COLOR_BUFFER_BIT);

    /*
     * 限定一组或多组图元的定义
     */
    glBegin(GL_POINTS);
    /*
     * void glPointSize(    GLfloat size);
     * 定义栅格点的大小,初始大小为1
     */
    glPointSize(5.0f);
    glVertex2f(-0.5f, 0.0f);
    glVertex2f(0.0f, 0.0f);
    glVertex2f(0.5f, 0.0f);
    glEnd();
    glFlush();

    //绘制直线
    glClear(GL_COLOR_BUFFER_BIT);
    glBegin(GL_LINES);

    //下例中会绘制两条直线
    glVertex2f(-0.5f, 0.0f);
    glVertex2f(0.5f, 0.0f);

    glVertex2f(-0.5f, -0.3f);
    glVertex2f(0.5f, 0.3f);
    glEnd();
    glFlush();

    //绘制多边形
    glClear(GL_COLOR_BUFFER_BIT);
    glBegin(GL_POLYGON);
    glVertex2f(-0.5f, 0.0f);
    glVertex2f(0.5f, 0.0f);
    glVertex2f(-0.5f, -0.3f);
    glVertex2f(0.5f, 0.3f);
    glEnd();
    glFlush();

    //绘制圆
    int n = 40;
    float pi = 3.1415926;
    float d  = 0.5f;

    glClear(GL_COLOR_BUFFER_BIT);
    glBegin(GL_POLYGON);

    for(int i = 0; i < n; i++){
        glVertex2f(d*cos(2*pi/n*i), d*sin(2*pi/n*i));
    }

    glEnd();
    glFlush();

}

//*********************************************************************************

/*
 * 颜色基本处理demo
 */
void display_demo03(){

    float pi = 3.1415926;

    glClear(GL_COLOR_BUFFER_BIT);

    glBegin(GL_TRIANGLE_FAN);

    /*
     *  void glColor3f (GLfloat red, GLfloat green, GLfloat blue);
     *  R\G\B 三原色值
     */
    glColor3f(1.0f, 1.0f, 1.0f);
    glVertex2f(0.0f, 0.0f);
    for(int i=0; i<=8; ++i) {
        glColor3f(i * 0x04, 0, 0);
        glVertex2f(cos(i*pi/4), sin(i*pi/4));
    }
    glEnd();
    glFlush();
}

//***********************************************************************************

/*
 * 绘制立体基本形状demo
 * 在opengl的绘制管线中,主要分为两部分工作:
 * 1、模型观测变化:即具体物体的现实位置和角度
 * 2、投影变换:即将3维信息的图像影射到2维的屏幕中
 * 此过程中,涉及6个坐标:
 * 1、属于模型观测变换:
 * 1.1、MC(Model Coordinate) -> 模型坐标,即物体对象自己的坐标,如我们说一个正方形的定点1,1,是相对自己的某个原点0,0;
 * 1.2、WC(Word Coordinate) -> 世界坐标,将N多物体的模型坐标,统一到一个公共的坐标系;
 * 1.3、VC(View Coordinate) -> 观测坐标,理解为观察的角度,即相机摆放的位置和角度
 * 2、属于投影变换:
 * 2.1、PC(Project Coordinate) -> 将上述模型变换后的3维信息映射到2维平面上,分为正交、斜投影、透射投影等,其中透射投影包涵近小远大的概念;
 * 2.2、NC(Normalization Coordinate) -> 将投影变换的结果归一化到一个单位为1的空间内
 * 3、视口变换:
 * 3.1 DC(Device Coordinate) -> 实际在设备即屏幕上显示的坐标
 */
void display_demo04(){

    /*
     *  opengl功能启用,例如:
     *  GL_DEPTH_TEST:启用深度测试,根据坐标远近实现遮挡
     *  GL_ALPHA_TEST:根据其透明程度看是否被遮挡
     *  GL_AUTO_NORMAL:能够进行光线反射
     *  GL_TEXTURE_2D:启用二维纹理
     */
    glEnable(GL_DEPTH_TEST);

    glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);

    /*
     *  void glMatrixMode (GLenum mode);
     *  GL_PROJECTION: 对投影视图进行操作
     *  GL_MODELVIEW:  对模型视图进行操作
     *  GL_TEXTURE:    对纹理进行操作
     */
    glMatrixMode(GL_PROJECTION);

    //把当前矩阵设置为单位矩阵
    glLoadIdentity();

    /*
     *  void gluPerspective (GLdouble fovy, GLdouble aspect, GLdouble zNear, GLdouble zFar)
     *  fovy:视角
     *  aspect:宽高比
     *  zNear:近点距离
     *  zFar:远点距离
     */
    gluPerspective(75, 1, 1, 1000);

    glMatrixMode(GL_MODELVIEW);

    glLoadIdentity();

    /*
     *  gluLookAt (GLdouble eyeX, GLdouble eyeY, GLdouble eyeZ, GLdouble centerX, GLdouble centerY, GLdouble centerZ, GLdouble upX, GLdouble upY, GLdouble upZ)
     *  eyeX/Y/Z:相机在世界坐标中的位置
     *  centerX/Y/Z:物体在世界坐标中的位置
     *  upX/Y/Z: 相机的方向(相对世界坐标系)
     */
    gluLookAt(0, -100, 200, 0, 50, 10, 0, 0, 1);

    glColor3f(1.0f, 0.5f, 0.0f);

    /*
     *  glRotatef (GLfloat angle, GLfloat x, GLfloat y, GLfloat z)
     *  angle:旋转的方向
     *  x/y/z: 旋转的方向向量
     */
    glRotatef(-80.0f,10.0f,5.0f,0.0f);

    /*
     *  void APIENTRY glutSolidSphere(GLdouble radius, GLint slices, GLint stacks)
     *  radius:半径
     *  slices:经线数量
     *  stacks:纬线数量
     */
    glutWireCube(100);

    glFlush();

}
时间: 2024-12-17 03:50:01

opengl 笔记(一)的相关文章

OpenGL笔记12

OpenGL入门学习[十二] 片断测试其实就是测试每一个像素,只有通过测试的像素才会被绘制,没有通过测试的像素则不进行绘制.OpenGL提供了多种测试操作,利用这些操作可以实现一些特殊的效果.我们在前面的课程中,曾经提到了“深度测试”的概念,它在绘制三维场景的时候特别有用.在不使用深度测试的时候,如果我们先绘制一个距离较近的物体,再绘制距离较远的物体,则距离远的物体因为后绘制,会把距离近的物体覆盖掉,这样的效果并不是我们所希望的.如 果使用了深度测试,则情况就会有所不同:每当一个像素被绘制,Op

OpenGL笔记2.1 角的顶点vertex

本次课程所要讲的是绘制简单的几何图形,在实际绘制之前,让我们先熟悉一些概念.向量:http://zh.wikipedia.org/wiki/%E7%9F%A2%E9%87%8F 一.点.直线和多边形我们知道数学(具体的说,是几何学)中有点.直线和多边形的概念,但这些概念在计算机中会有所不同. 数学上的点,只有位置,没有大小.但在计算机中,无论计算精度如何提高,始终不能表示一个无穷小的点.另一方面,无论图形输出设备(例如,显示器)如何精 确,始终不能输出一个无穷小的点.一般情况下,OpenGL中的

OpenGL笔记10

今天我们先简单介绍Windows中常用的BMP文件格式,然后讲OpenGL的像素操作.虽然看起来内容可能有点多,但实际只有少量几个知识点,如果读者对诸如“显示BMP图象”等内容比较感兴趣的话,可能不知不觉就看完了. 像素操作可以很复杂,这里仅涉及了简单的部分,让大家对OpenGL像素操作有初步的印象. 学过多媒体技术的朋友可能知道,计算机保存图象的方法通常有两种:一是“矢量图”,一是“像素图”.矢量图保存了图象中每一几何物体的位置.形状.大小等信 息,在显示图象时,根据这些信息计算得到完整的图象

OpenGL笔记2.2 镂空

在第二课中,我们学习了如何绘制几何图形,但大家如果多写几个程序,就会发现其实还是有些郁闷之处.例如:点太小,难以看清楚:直线也太细,不舒服:或者想画虚线,但不知道方法只能用许多短直线,甚至用点组合而成. 这些问题将在本课中被解决. 下面就点.直线.多边形分别讨论. 1.关于点 点的大小默认为1个像素,但也可以改变之.改变的命令为glPointSize,其函数原型如下: void glPointSize(GLfloat size); size必须大于0.0f,默认值为1.0f,单位为“像素”. 注

OpenGl笔记 12.1 stencil 模版 缓冲区

在OpenGL中存在着多种缓冲区,这些缓冲区大致分为: 深度缓冲区:存储每个像素的深度值,当启动深度测试时,片段像素深度值和深度缓冲区深度值进行比较,决定片段哪些像素点数据可以替换到颜色缓冲区中. 模板缓冲区(Stencil Buffer):与颜色缓冲区和深度缓冲区类似,模板缓冲区可以为屏幕上的每个像素点保存一个无符号整数值.这个值的具体意义视程序的具体应用而定.在渲染的过程中,可以用这个值与一个预先设定的参考值相比较,根据比较的结果来决定是否更新相应的像素点的颜色值.这个比较的过程被称为模板测

OpenGL笔记15 顶点数据

这次讲的所有内容都装在一个立方体中,呵呵.呵呵,绘制一个立方体,简单呀,我们学了第一课第二课,早就会了.先别着急,立方体是很简单,但是这里只是拿立方体做一个例子,来说明OpenGL在绘制方法上的改进.从原始一点的办法开始一个立方体有六个面,每个面是一个正方形,好,绘制六个正方形就可以了. glBegin(GL_QUADS);     glVertex3f(...);     glVertex3f(...);     glVertex3f(...);     glVertex3f(...); //

OpenGL笔记11

我们在前一课中,学习了简单的像素操作,这意味着我们可以使用各种各样的BMP文件来丰富程序的显示效果,于是我们的OpenGL图形程序也不再像以前总是 只显示几个多边形那样单调了.——但是这还不够.虽然我们可以将像素数据按照矩形进行缩小和放大,但是还不足以满足我们的要求.例如要将一幅世界地图绘制 到一个球体表面,只使用glPixelZoom这样的函数来进行缩放显然是不够的.OpenGL纹理映射功能支持将一些像素数据经过变换(即使是比较不规 则的变换)将其附着到各种形状的多边形表面.纹理映射功能十分强

OpenGL笔记9

今天介绍关于OpenGL混合的基本知识.混合是一种常用的技巧,通常可以用来实现半透明.但其实它也是十分灵活的,你可以通过不同的设置得到不同的混合结果,产生一些有趣或者奇怪的图象.混合是什么呢?混合就是把两种颜色混在一起.具体一点,就是把某一像素位置原来的颜色和将要画上去的颜色,通过某种方式混在一起,从而实现特殊的效果.假设我们需要绘制这样一个场景:透过红色的玻璃去看绿色的物体,那么可以先绘制绿色的物体,再绘制红色玻璃.在绘制红色玻璃的时候,利用“混合”功能,把将要绘制上去的红色和原来的绿色进行混

OpenGL笔记13

前一段时间里,论坛有位朋友问什么是状态机.按我的理解,状态机就是一种存在于理论中的机器,它具有以下的特点: 1. 它有记忆的能力,能够记住自己当前的状态. 2. 它可以接收输入,根据输入的内容和自己的状态,修改自己的状态,并且可以得到输出. 3. 当它进入某个特殊的状态(停机状态)的时候,它不再接收输入,停止工作. 理论说起来很抽象,但实际上是很好理解的. 首先,从本质上讲,我们现在的电脑就是典型的状态机.可以对照理解: 1. 电脑的存储器(内存.硬盘等等),可以记住电脑自己当前的状态(当前安装