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();




目录
相关文章
ly~
|
1月前
|
数据可视化 BI API
除了 OpenGL,还有哪些常用的图形库可以在 C 语言中使用?
除了OpenGL,C语言中还有多个常用的图形库:SDL,适合初学者,用于2D游戏和多媒体应用;Allegro,高性能,支持2D/3D图形,广泛应用于游戏开发;Cairo,矢量图形库,支持高质量图形输出,适用于数据可视化;SFML,提供简单接口,用于2D/3D游戏及多媒体应用;GTK+,开源窗口工具包,用于创建图形用户界面。这些库各有特色,适用于不同的开发需求。
ly~
151 4
|
3月前
|
C# Windows 开发者
当WPF遇见OpenGL:一场关于如何在Windows Presentation Foundation中融入高性能跨平台图形处理技术的精彩碰撞——详解集成步骤与实战代码示例
【8月更文挑战第31天】本文详细介绍了如何在Windows Presentation Foundation (WPF) 中集成OpenGL,以实现高性能的跨平台图形处理。通过具体示例代码,展示了使用SharpGL库在WPF应用中创建并渲染OpenGL图形的过程,包括开发环境搭建、OpenGL渲染窗口创建及控件集成等关键步骤,帮助开发者更好地理解和应用OpenGL技术。
242 0
|
6月前
|
前端开发 API vr&ar
Android开发之OpenGL绘制三维图形的流程
即将连载的系列文章将探索Android上的OpenGL开发,这是一种用于创建3D图形和动画的技术。OpenGL是跨平台的图形库,Android已集成其API。文章以2D绘图为例,解释了OpenGL的3个核心元素:GLSurfaceView(对应View)、GLSurfaceView.Renderer(类似Canvas)和GL10(类似Paint)。通过将这些结合,Android能实现3D图形渲染。文章介绍了Renderer接口的三个方法,分别对应2D绘图的构造、测量布局和绘制过程。示例代码展示了如何在布局中添加GLSurfaceView并注册渲染器。
198 1
Android开发之OpenGL绘制三维图形的流程
|
存储 缓存 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 ...
1146 0