openGL 第章节 例子

cpp 复制代码
#include "stdafx.h"
#include <GL/glut.h>
#include <iostream>
#include <iostream>

using namespace std;



GLsizei winWidth = 600, winHeight = 500;
GLint xRaster = 25, yRaster = 150 , xRastar1=25;


GLubyte label[36] = { 'J', 'a', 'n', 'F', 'e', 'b', 'M', 'a', 'r',
'A', 'p', 'r', 'M', 'a', 'y', 'J', 'u', 'n',
'J', 'u', 'l', 'A', 'u', 'g', 'S', 'e', 'p',
'O', 'c', 't', 'N', 'o', 'v', 'D', 'e', 'c' };
GLint dataValue[12] = { 420, 342, 324, 310, 262, 185,
190, 196, 217, 240, 312, 438 };


void init(void)
{
    glClearColor(1.0, 1.0, 1.0, 1.0);
    glMatrixMode(GL_PROJECTION);
    gluOrtho2D(0.0, 600.0, 0.0, 500.0);
}


void lineGraph(void)
{
    GLint month, k;
    GLint x = 30;
    

    glClear(GL_COLOR_BUFFER_BIT);
    glColor3f(0.0, 0.0, 1.0);
    glBegin(GL_LINE_STRIP); /*划线 不闭合折线*/
    for (k = 0; k < 12; k++)
        glVertex2i(x + k * 50, dataValue[k]); /*30,420  80,342  130,324 180,310 230,262 280,185  330,190  380,196  430,217  480,240  530,312  580,438*/
    glEnd();


    glColor3f(1.0, 0.0, 0.0);
    for (k = 0; k < 12; k++)
    {
        glRasterPos2i(xRaster + k * 50, dataValue[k] - 4); /*更改光栅点的位置 第一个参数由第31行减5,第二个参数由第31行减4*/
        glutBitmapCharacter(GLUT_BITMAP_9_BY_15, '*'); /*在每一个折点上画 '*' ps:不能有空格 GLUT_BITMAP_9_BY_15:一种固定宽度字体,每个字符都放在一个9x15像素的矩形框内*/
    }


    glColor3f(1.0, 0.0, 0.0); /*设置字体颜色*/
    xRastar1 = 20;
    for (month = 0; month < 12; month++)
    {
        glRasterPos2i(xRastar1, yRaster); /*x=20,y=150*/
        for (k = 3 * month; k < 3 * month + 3; k++) /*每一个内循环写一个月份*/ {
            glutBitmapCharacter(GLUT_BITMAP_HELVETICA_12, label[k]);/*GLUT_BITMAP_HELVETICA_12 一种12点均匀间距的Helvetica字体  */
        }
        xRastar1 += 50; /*x坐标向前推进50个单位*/
    }
    glFlush();
}


void barChart(void)
{
    GLint month, k;

    cout << "222"<< "\n";
    glClear(GL_COLOR_BUFFER_BIT);
    glColor3f(1.0, 0.0, 0.0);
    for (k = 0; k < 12; k++)
        glRecti(20 + k * 50, 165, 40 + k * 50, dataValue[k]); /*画矩形 x左下,y左下,x右上,y右上 每个条形图间隔20个单位*/
    glColor3f(0.0, 0.0, 0.0);
    xRaster = 20;
    for (month = 0; month < 12; month++)
    {
        glRasterPos2i(xRaster, yRaster);
        for (k = 3 * month; k < 3 * month + 3; k++) {
            glutBitmapCharacter(GLUT_BITMAP_HELVETICA_12, label[k]);
        }
        xRaster += 50;
    }
    glFlush();
}


void winReshapeFcn(GLint newWidth, GLint newHeight)
{
    glMatrixMode(GL_PROJECTION);
    glLoadIdentity();
    gluOrtho2D(0.0, GLdouble(newWidth), 0.0, GLdouble(newHeight));


    glClear(GL_COLOR_BUFFER_BIT);
}


void main(int argc, char** argv)
{
    glutInit(&argc, argv);
    glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB);
    glutInitWindowPosition(100, 100);
    glutInitWindowSize(winWidth, winHeight);
    glutCreateWindow("多点画线");


    init();
    glutDisplayFunc(lineGraph);
    glutReshapeFunc(winReshapeFcn);
    glutMainLoop();


} 
相关推荐
Mintopia2 小时前
四叉树:二维空间的 “智能分区管理员”
前端·javascript·计算机图形学
Mintopia1 天前
三维空间的 “切蛋糕大师”:八叉树的底层奥秘与妙用
前端·javascript·计算机图形学
Mintopia2 天前
B 样条曲线:计算机图形学里的 “曲线魔术师”
前端·javascript·计算机图形学
Mintopia13 天前
探索屏幕空间效果:SSR 与 SSAO 的奇妙之旅
前端·javascript·计算机图形学
Mintopia14 天前
计算机图形学:屏幕空间效果的奇幻之旅
前端·javascript·计算机图形学
Porien15 天前
Vulkan-记录 官方教程的详细步骤(记录踩坑)
c++·计算机图形学
Mintopia16 天前
计算机图形学之自定义着色器:用 GLSL 在 JavaScript 中绘制奇幻光影
前端·javascript·计算机图形学
Mintopia17 天前
在数字画布上跳华尔兹:用 JavaScript 粒子系统模拟自然奇观
前端·javascript·计算机图形学
Mintopia18 天前
当虚拟角色学会 “偷师”:揭秘运动捕捉的魔法世界
前端·javascript·计算机图形学
Mintopia20 天前
骨骼动画:让数字角色跳出生命之舞
前端·javascript·计算机图形学