opengl绘制五星红旗

本文实例为大家分享了opengl绘制五星红旗的具体代码,供大家参考,具体内容如下

主要仪器设备

VisualStudio C++2015

Windows 10环境
opengl库

操作步骤

1.五星红旗的各项参数

1) 旗面为红色,长方形,长与高之比为3:2。
2) 五星的位置参数:
·为便于确定五星之位置,先将旗面对分为四个相等的长方形,将左上方之长方形上下划为十等分,左右划为十五等分。如下图所示:

·大五角星的中心点,在该长方形上五下五、左五右十之处。其画法为:以此点为圆心,以三等分为半径作一圆。在此圆周上,定出五个等距离的点,其一点须位于圆之正上方。然后将此五点中各相隔的两点相联,使各成一直线。此五直线所构成之外轮廓线,即为所需之大五角星。五角星之一个角尖正向上方。

·四颗小五角星的中心点,第一点在该长方形上二下八、左十右五之处,第二点在上四下六、左十二右三之处,第三点在上七下三、左十二右三之处,第四点在上九下一、左十右五之处。其画法为:以以上四点为圆心,各以一等分为半径,分别作四个圆。在每个圆上各定出五个等距离的点,其中均须各有一点位于大五角星中心点与以上四个圆心的各联结线上。然后用构成大五角星的同样方法,构成小五角星。此四颗小五角星均各有一个角尖正对大五角星的中心点。

2.绘制大五角星

因为glut无法根据顶点绘制凹多边形,我只能将图形拆解,分步绘制。我采用的方式是将五角星分解为10个三角形,共用五角星中心点作为顶点,这样就可以使用GL_TRIANGLE_FAN(连接成扇形的三角形系列)几何图元类型进行填充。对于每一个五角星,我们必须知道的参数只有两个,中心点和一个外顶点。

注意到,在连续绘制三角形的过程中,重点是根据A点求得B点坐标或者反之,那么根据正弦定理,我们可以求得b边的长度,根据BC边的与x轴的夹角以及36°角,我们可以得到A点的坐标。进而可以得到每一个三角形另外两点的坐标,一个五角星就绘制完成了。

3.绘制小五角星

小五角星的一个顶点必然在小五角星与大五角星的连线上,确定了这个顶点,就可以按照绘制大五角星的方法来绘制它了。
根据大小五角星中心连线,我们又已知小五角星外接圆半径,就可以轻易求出顶角的坐标了。

4.窗口尺寸变化时图形不变形

如果不加入这一部分考虑,在对窗口进行缩放时会发生五星红旗拉伸、变形的情况。于是增加函数glutReshapeFunc以及glOrtho函数。glutReshapFunc用以指定窗口大小调整是的重绘制函数。glOrtho是创建一个正交平行的视景体。changeSize函数是在窗口大小发生变化时要执行的操作。

代码如下:

#include "gl/glut.h"
#include <math.h>
const GLfloat PI = 3.1415926f;//定义圆周率
void DrawStar(GLfloat px, GLfloat py, GLfloat vx, GLfloat vy,int flag)//位置以及五角星一个外顶点坐标
{
 glBegin(GL_TRIANGLE_FAN);//绘制一系列三角形
 GLfloat vtx[12], vty[12];//1个中心点,10个顶点,顶点的第一个和最后一个相同,其中奇数下标是外顶点,偶数下标是内顶点
 vtx[0] = px;//已知的中心点
 vty[0] = py;
 vtx[1] = vx;//已知的第一个外顶点
 vty[1] = vy;
 GLfloat length1 = sqrt((px - vx)*(px - vx) + (py - vy)*(py - vy));//中心点到外顶点的长度
 GLfloat length2 = length1*sin(0.1*PI) / sin(126.0 / 180 * PI);
 //计算剩下的所有顶点
 double init = atan((vty[1] - vty[0]) / (vtx[1] - vtx[0]));//顶点与中心点连线与x轴的角度
 if (flag)
 init = init - PI;
 for (int i = 2; i < 12; i++) {
  init = init - 0.2*PI;
 if (i % 2 == 0) {//内顶点
  vtx[i] = length2*cos(init) + vtx[0];
  vty[i] = length2*sin(init) + vty[0];
 }
 else {//外顶点
  vtx[i] = length1*cos(init) + vtx[0];
  vty[i] = length1*sin(init) + vty[0];
 }
 }
 for (int i = 0; i < 12; i++) //设置顶点
 glVertex3f(vtx[i], vty[i], 0.5);
 glEnd();
}
void display()
{
 glClear(GL_COLOR_BUFFER_BIT);//完成清除窗口的任务
 //绘制红旗
 glColor3f(1, 0, 0);//确定绘制物体时使用的颜色:红色
 glBegin(GL_QUADS);
 glVertex3f(-0.75, 0.5, 0.5);//位于z=0.5平面的矩形 0.5是相对值
 glVertex3f(0.75, 0.5, 0.5);
 glVertex3f(0.75, -0.5, 0.5);
 glVertex3f(-0.75, -0.5, 0.5);
 glEnd();
 //绘制星星
 glColor3f(1.0, 1.0, 0.0);//设置颜色为黄色
 GLfloat px[5] = { -1.5 / 3,-0.75 / 3,-0.75 / 5,-0.75 / 5,-0.75 / 3 };
 GLfloat py[5] = { 0.25,0.4,0.3,0.15,0.05 };
 GLfloat vx[5] = { -1.5 / 3 };
 GLfloat vy[5] = {0.4};//五星的中心点和其中指定顶点
 //计算其余四星的顶点
 for (int i = 1; i < 5; i++) {
 vx[i] = px[i]-0.05*cos(atan((py[0] - py[i]) / (px[0] - px[i])));
 vy[i] = py[i]-0.05*sin(atan((py[0] - py[i]) / (px[0] - px[i])));
 }
 //绘制
 DrawStar(px[0], py[0], vx[0], vy[0], 0);
 DrawStar(px[1], py[1], vx[1], vy[1], 1);
 DrawStar(px[2], py[2], vx[2], vy[2], 1);
 DrawStar(px[3], py[3], vx[3], vy[3], 1);
 DrawStar(px[4], py[4], vx[4], vy[4], 1);
 glutSwapBuffers();//交换缓冲区
}
void changeSize(GLsizei w, GLsizei h)
{
 if (h == 0)
 h = 1;
 glViewport(0, 0, w, h);
 glMatrixMode(GL_PROJECTION);
 glLoadIdentity();
 int dis = w < h ? w : h;
 glViewport(0, 0, dis, dis);
 glOrtho(-1.5, 1.5, -1.5, 1.5, -1.5, 1.5);
 if (w <= h)
 glOrtho(-1.0, 1.0, 1.0,1.0* h / w, 1.0, -1.0);
 else
 glOrtho(-1.0, 1.0 * w / h, 1.0, 1.0, 1.0, -1.0);

 glMatrixMode(GL_MODELVIEW);
 glLoadIdentity();
}
int main (int argc, char *argv[])
{
 glutInit(&argc,argv);//对glut函数库进行初始化
 glutInitDisplayMode(GLUT_RGB|GLUT_DOUBLE);//指定glutCreateWindow函数将要创建的窗口显示模式 RGB模式 双缓冲
 glutInitWindowPosition(10, 10);//指定窗口位置,窗口的一个角相对整个屏幕的位置
 glutInitWindowSize(400,400);//指定窗口大小,只是一种提示,有可能被其他窗口覆盖
 glutCreateWindow("Simple GLUT App");//打开设置好的窗口,进入glutMainLoop之前这个窗口不会显示

 glOrtho(1.0, 1.0, 1.0, 1.0, 1.0, -1.0);
 glutReshapeFunc(changeSize);  //注册窗口大小改变时回调函数
 glClear(GL_COLOR_BUFFER_BIT);//完成清除窗口的任务
 glutDisplayFunc(display);//与注册相关的回调函数,指定当窗口内容需要重绘时要调用的函数
 glutMainLoop();//进入GLUT事件处理循环,永远不会返回

 return 0;
}

实验结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C#绘制中国国旗的方法

    本文实例讲述了C#绘制中国国旗的方法.分享给大家供大家参考.具体如下: 程序运行截图: 中国国旗被定义在<GB:12982-2004>中,以下是从维基百科条目中华人民共和国国旗中截的一张图,标出了五颗星大致的位置. 建立一个空的C# Windows窗体应用程序,窗体取名FormMain,在窗体中放一个PictureBox,取名为picFlagOfChina,并将Dock属性设置为Fill.程序代码中用到了窗体事件Load和Resize,程序代码如下: using System; using S

  • 给你一面国旗 教你用python画中国国旗

    本文实例为大家分享了python画中国国旗的具体代码,供大家参考,具体内容如下 # author : momo import turtle #中国国旗 turtle.up() turtle.goto(-200,200) turtle.down() turtle.begin_fill() turtle.fillcolor("red") turtle.pencolor("red") for i in range(2): turtle.forward(280) turtl

  • php基于GD库画五星红旗的方法

    本文实例讲述了php基于GD库画五星红旗的方法.分享给大家供大家参考.具体分析如下: 这里实例分析php画的五星红旗(GD库),代码如下: 复制代码 代码如下: <?php header("Content-Type:image/jpeg"); $ing = imagecreatetruecolor(700,410); //新建一个真彩色图像,返回值为一个图像标识符,背景默认为黑色,参数(x_size*y_size) $red = imagecolorallocate($ing,2

  • 使用Python的turtle模块画国旗

    Python的turtle模块画国旗主要用到两个函数:draw_rentangle和draw_star. 至于函数的调用就和我们学的C,C++是一样的.对于turtle画国旗的程序中,首先是查找国旗的画法,才能用程序实现.自己在实现的过程中主要是对turtle.circle()没有准确掌握,所以花了一些不必要的时间.turtle.circle画弧时,海龟(turtle)的方向就是弧的切线方向,也就是说turtle的垂直方向就是圆心在的直线上,给定参数radius就可以画了,程序中第二注意的地方就

  • JavaScript国旗变换效果代码

    1.页面的HTML代码如下: <img id="flag" src="Flags/cn_flag[1].gif" alt="" />  <select name="Country" accesskey="c" id="Country" onchange="change_flag(this);" runat="server" o&g

  • opengl绘制五星红旗

    本文实例为大家分享了opengl绘制五星红旗的具体代码,供大家参考,具体内容如下 主要仪器设备 VisualStudio C++2015 Windows 10环境 opengl库 操作步骤 1.五星红旗的各项参数 1) 旗面为红色,长方形,长与高之比为3:2. 2) 五星的位置参数: ·为便于确定五星之位置,先将旗面对分为四个相等的长方形,将左上方之长方形上下划为十等分,左右划为十五等分.如下图所示: ·大五角星的中心点,在该长方形上五下五.左五右十之处.其画法为:以此点为圆心,以三等分为半径作

  • Android开发之OpenGL绘制2D图形的方法分析

    本文实例讲述了Android开发之OpenGL绘制2D图形的方法.分享给大家供大家参考,具体如下: Android为OpenGL ES支持提供了GLSurviceView组建,这个组建用于显示3D图形.GLSurviceView本身并不提供绘制3的图形的功能,而是由GLSurfaceView.Renderer来完成了SurviceView中3D图形的绘制. 归纳起来,在android中使用OpenGL ES需要3个步骤. 1. 创建GLSurviceView组件,使用Activity来显示GLS

  • Python使用Turtle模块绘制五星红旗代码示例

    在Udacity上课时学到了python的turtle方法,这是一个很经典的用来教小孩儿编程的图形模块,最早起源于logo语言.python本身内置了这个模块,其可视化的方法可以帮助小孩儿对编程的一些基本理念有所理解. 在作业提交的论坛里看到很多turtle画出来的精美图形,想不出什么要画的东西,于是决定拿五星红旗来练练手. 前期准备 五星红旗绘制参数 Turtle官方文档 turtle的基本操作 # 初始化屏幕 window = turtle.Screen() # 新建turtle对象实例 i

  • Android openGl 绘制简单图形的实现示例

    学习五部曲,弄清楚5个W一个H(when(什么时候使用).where(在哪个地方使用?).who(对谁使用).what(是个什么东西).why(为什么要这么用?).一个H即:how(到底该怎么用?)),基本的概念篇主要围绕这几个方面进行分析 1. What? openGl是什么?openGl ES又是什么? 相信很多人从事开发的都或多或少听到过有关OpenGl这个东西,但是平时用的少,只知道有这么个东西,而且学起来不简单,所以大多数人都不能讲出个个所以然来. 官方对OpenGl的描述为: Ope

  • OpenGL绘制Bezier曲线的方法

    本文实例为大家分享了OpenGL绘制Bezier曲线的具体代码,供大家参考,具体内容如下 项目要求: – 使用鼠标在屏幕中任意设置控制点,并生成曲线 – 使用鼠标和键盘的交互操作实现对曲线的修改. 项目总体介绍 本项目利用Bezier曲线生成算法生成可由用户自定义的曲线.可实现核心功能如下: 1.用户用鼠标左击屏幕任意处产生记录点. 2.鼠标右击屏幕任意处由先前的任意个数记录点和其先后关系生成Bezier曲线. 另有辅助输入功能: 1.按键盘'C'键可清除所有记录点. 2.按键盘'R'键可清除上

  • OpenGL绘制贝塞尔曲线

    本文实例为大家分享了OpenGL绘制贝塞尔曲线的具体代码,供大家参考,具体内容如下 最终效果图: 通过3个点形成一条贝塞尔曲线 1. 鼠标问题 在使用鼠标获取坐标的时候,要知道鼠标获取的坐标和屏幕坐标是不同的; openGL使用右手坐标 从左到右,x递增 从下到上,y递增 从远到近,z递增 而鼠标是从左到右增x,同时从上到下也是增y 所以在求 y 的时候,用(屏幕大小-y)来获取 2. 绘制 setpoint 用来绘制点 setline 用来绘制线 setBezier 用来绘制贝塞尔曲线 其中公

  • 使用OpenGL绘制Bezier曲线

    本文实例为大家分享了OpenGL绘制Bezier曲线的具体代码,供大家参考,具体内容如下 最近在看Francis S Hill ,Jr 和 Stephen M Kelley合著的<计算机图形学>(OpenGL版)(第三版)书中有绘制三个控制点的Bezier曲线的代码.自己重新敲了一遍代码.发现了其中的一点小错误,修正过来了.并做了一点小小的改动. 源码见下 #include <windows.h> #include <math.h> #include <gl/GL

  • OpenGL绘制三次Bezier曲线

    本文实例为大家分享了OpenGL绘制三次Bezier曲线的具体代码,供大家参考,具体内容如下 计算公式: 运行结果: 代码如下: #include<gl/glut.h> #include<math.h> #include<windows.h> #include<vector> #include<algorithm> using namespace std; struct Point { int x, y; Point(){}; Point(int

  • Python OpenGL绘制一场烟花盛会

    目录 1. 安装WxGL 2. 快速体验 3. 编写自己的着色器 4. 绽放的烟花 忙碌了一年,今天终于放假了.原本打算好好休息一下,没成想只过了半天就觉得有点无聊.看家人和朋友们都在忙年,那我就用OpenGL导演一场烟花盛会,献给即将到来的新年吧. 一说到OpenGL,很多人都会觉得复杂,其实不然.只要掌握了几个基本的概念,借助于工具软件,任何人都可以很轻松地上手.在制作烟花之前,我先介绍一下WxGL这个三维数据快速可视化工具. 1. 安装WxGL WxGL是一个基于PyOpenGL的三维数据

  • OpenGL通过中点法绘制直线和圆

    本文实例为大家分享了OpenGL绘制直线和圆的具体代码,供大家参考,具体内容如下 #include <gl/glut.h> #include <math.h> static int i=1; void Initial(void) { glClearColor(1.0f, 1.0f, 1.0f, 1.0f); //设置窗口背景颜色为白色 glMatrixMode(GL_PROJECTION); //指定设置投影参数 gluOrtho2D(-200.0,200.0,-200.0,200

随机推荐