OpenGL几种简单图形的绘制

简介: 圆、五角星、正弦函数图形的绘制

仅做学习交流, 切勿商业用途



//----------------------画圆---------------------------------
    glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
    glClear(GL_COLOR_BUFFER_BIT);
    //设置颜色
    glColor3f(1.0f, 0.0f, 0.0f);
    //开始渲染
    glBegin(GL_POLYGON);
    const int n = 55;//当n为3时为三角形;n为4时是四边形,n为5时为五边形。。。。。
    const GLfloat R = 0.5f;//圆的半径
    const GLfloat pi = 3.1415926f;
    for (int i = 0; i < n; i++)
    {
        glVertex2f(R*cos(2 * pi / n*i), R*sin(2 * pi / n*i));
    }
    //结束渲染
    glEnd();
    //强制刷新缓存区,保证绘制命令得以执行
    glFlush();


五角星


//// ------------------------五角形----------------------------///*
// 设五角星的五个顶点分布位置关系如下:
// A
// E       B
// 
// D   C
// 首先,根据余弦定理列方程,计算五角星的中心到顶点的距离a
// (假设五角星对应正五边形的边长为.0)
// a = 1 / (2-2*cos(72*Pi/180));
// 然后,根据正弦和余弦的定义,计算B的x坐标bx和y坐标by,以及C的y坐标
// (假设五角星的中心在坐标原点)
// bx = a * cos(18 * Pi/180);
// by = a * sin(18 * Pi/180);
// cy = -a * cos(18 * Pi/180);
// 五个点的坐标就可以通过以上四个量和一些常数简单的表示出来
// */
    const GLfloat Pi = 3.1415926536f;
     GLfloat a = 1 / (2-2*cos(72*Pi/180));
     GLfloat bx = a * cos(18 * Pi/180);
     GLfloat by = a * sin(18 * Pi/180);
     GLfloat cy = -a * cos(18 * Pi/180);
     GLfloat
     PointA[2] = { 0, a },
     PointB[2] = { bx, by },
     PointC[2] = { 0.5, cy },
     PointD[2] = { -0.5, cy },
     PointE[2] = { -bx, by };
     glClear(GL_COLOR_BUFFER_BIT);
     // 按照A->C->E->B->D->A的顺序,可以一笔将五角星画出
     glBegin(GL_LINE_LOOP);
     glVertex2fv(PointA);
     glVertex2fv(PointC);
     glVertex2fv(PointE);
     glVertex2fv(PointB);
     glVertex2fv(PointD);
     glEnd();
     glFlush();


正弦函数


//----------- 画出正弦函数的图形---------------
    /*
     由于OpenGL默认坐标值只能从-1到1,(可以修改,但方法留到以后讲)
     所以我们设置一个因子factor,把所有的坐标值等比例缩小,
     这样就可以画出更多个正弦周期
     试修改factor的值,观察变化情况
     */
    const GLfloat factor = 0.1f;
    GLfloat x;
    glClear(GL_COLOR_BUFFER_BIT);
    glBegin(GL_LINES);
    glVertex2f(-1.0f, 0.0f);
    glVertex2f(1.0f, 0.0f);        // 以上两个点可以画x轴
    glVertex2f(0.0f, -1.0f);
    glVertex2f(0.0f, 1.0f);        // 以上两个点可以画y轴
    glEnd();
    glBegin(GL_LINE_STRIP);
    for(x=-1.0f/factor; x<1.0f/factor; x+=0.01f)
    {
        glVertex2f(x*factor, sin(x)*factor);
    }
    glEnd();
    glFlush();




目录
相关文章
|
存储 缓存 Java
Android OpenGL 显示基本图形及相关概念解读
Android OpenGL 显示基本图形及相关概念解读
Android OpenGL 显示基本图形及相关概念解读
|
图形学
学习OpenGL ES之绘制更多的图形
学习OpenGL ES之绘制更多的图形
|
缓存
VS2008集成QT的OpenGL开发(实现二维图形的旋转)
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/78148300 ...
1106 0
|
Android开发 图形学
Android官方开发文档Training系列课程中文版:OpenGL绘图之图形定义
原文地址:http://android.xsoftlab.net/training/graphics/opengl/shapes.html 使用OpenGL绘制图形的第一步就是要定义一个图形。
861 0
|
缓存 Windows 编解码
NeHe的OpenGL教程2(Bang翻译Delphi版)-如何绘制平面图形
NeHe的OpenGL教程2(Bang翻译Delphi版)-如何绘制平面图形 这一课中,我将教您如何创建三角形和四边形。如下图: program lesson2a; {    OpenGL DelphiXE    出处:根据NeHe代码翻译而来(http://nehe.
829 0
|
缓存 Windows
NeHe的OpenGL教程3(Bang翻译Delphi版)-如何给图形着色
NeHe的OpenGL教程3(Bang翻译Delphi版)-如何给图形着色 作为第二课的扩展,我将教你如何使用颜色。你将理解两种着色模式,在左图中,三角形用的是光滑着色,四边形用的是平面着色。
893 0
|
缓存 Windows
NeHe的OpenGL教程4(Bang翻译Delphi版)-如何让图形旋转
NeHe的OpenGL教程4(Bang翻译Delphi版)-如何让图形旋转 在这一课里,我将教会你如何旋转三角形和四边形。左图中的三角形沿Y轴旋转,四边形沿着X轴旋转。
988 0