定义形状

编写:jdneo - 原文:http://developer.android.com/training/graphics/opengl/shapes.html

在一个OpenGL ES View的上下文(Context)中定义形状,是创建你的杰作所需要的第一步。在了解关于OpenGL ES如何定义图形对象的基本知识之前,通过OpenGL ES 绘图可能会有些困难。

这节课将讲解OpenGL ES相对于Android设备屏幕的坐标系,定义形状和形状表面的基本知识,如定义一个三角形和一个矩形。

定义一个三角形

OpenGL ES允许我们使用三维空间的坐标来定义绘画对象。所以在我们能画三角形之前,必须先定义它的坐标。在OpenGL 中,典型的办法是为坐标定义一个浮点型的顶点数组。为了高效起见,我们可以将坐标写入一个ByteBuffer,它将会传入OpenGl ES的图形处理流程中:

  1. public class Triangle {
  2. private FloatBuffer vertexBuffer;
  3. // number of coordinates per vertex in this array
  4. static final int COORDS_PER_VERTEX = 3;
  5. static float triangleCoords[] = { // in counterclockwise order:
  6. 0.0f, 0.622008459f, 0.0f, // top
  7. -0.5f, -0.311004243f, 0.0f, // bottom left
  8. 0.5f, -0.311004243f, 0.0f // bottom right
  9. };
  10. // Set color with red, green, blue and alpha (opacity) values
  11. float color[] = { 0.63671875f, 0.76953125f, 0.22265625f, 1.0f };
  12. public Triangle() {
  13. // initialize vertex byte buffer for shape coordinates
  14. ByteBuffer bb = ByteBuffer.allocateDirect(
  15. // (number of coordinate values * 4 bytes per float)
  16. triangleCoords.length * 4);
  17. // use the device hardware's native byte order
  18. bb.order(ByteOrder.nativeOrder());
  19. // create a floating point buffer from the ByteBuffer
  20. vertexBuffer = bb.asFloatBuffer();
  21. // add the coordinates to the FloatBuffer
  22. vertexBuffer.put(triangleCoords);
  23. // set the buffer to read the first coordinate
  24. vertexBuffer.position(0);
  25. }
  26. }

默认情况下,OpenGL ES会假定一个坐标系,在这个坐标系中,[0, 0, 0](分别对应X轴坐标, Y轴坐标, Z轴坐标)对应的是GLSurfaceView的中心。[1, 1, 0]对应的是右上角,[-1, -1, 0]对应的则是左下角。如果想要看此坐标系的插图说明,可以阅读OpenGL ES开发手册。

注意到这个形状的坐标是以逆时针顺序定义的。绘制的顺序非常关键,因为它定义了哪一面是形状的正面(希望绘制的一面),以及背面(使用OpenGL ES的Cull Face功能可以让背面不要绘制)。更多关于该方面的信息,可以阅读OpenGL ES开发手册。

定义一个矩形

在OpenGL中定义三角形非常简单,那么你是否想要来点更复杂的呢?比如,定义一个矩形?有很多方法可以用来定义矩形,不过在OpenGL ES中最典型的办法是使用两个三角形拼接在一起:

再一次地,我们需要逆时针地为三角形顶点定义坐标来表现这个图形,并将值放入一个ByteBuffer中。为了避免由两个三角形重合的那条边的顶点被重复定义,可以使用一个绘制列表来告诉OpenGL ES图形处理流程应该如何画这些顶点。下面是代码样例:

  1. public class Square {
  2. private FloatBuffer vertexBuffer;
  3. private ShortBuffer drawListBuffer;
  4. // number of coordinates per vertex in this array
  5. static final int COORDS_PER_VERTEX = 3;
  6. static float squareCoords[] = {
  7. -0.5f, 0.5f, 0.0f, // top left
  8. -0.5f, -0.5f, 0.0f, // bottom left
  9. 0.5f, -0.5f, 0.0f, // bottom right
  10. 0.5f, 0.5f, 0.0f }; // top right
  11. private short drawOrder[] = { 0, 1, 2, 0, 2, 3 }; // order to draw vertices
  12. public Square() {
  13. // initialize vertex byte buffer for shape coordinates
  14. ByteBuffer bb = ByteBuffer.allocateDirect(
  15. // (# of coordinate values * 4 bytes per float)
  16. squareCoords.length * 4);
  17. bb.order(ByteOrder.nativeOrder());
  18. vertexBuffer = bb.asFloatBuffer();
  19. vertexBuffer.put(squareCoords);
  20. vertexBuffer.position(0);
  21. // initialize byte buffer for the draw list
  22. ByteBuffer dlb = ByteBuffer.allocateDirect(
  23. // (# of coordinate values * 2 bytes per short)
  24. drawOrder.length * 2);
  25. dlb.order(ByteOrder.nativeOrder());
  26. drawListBuffer = dlb.asShortBuffer();
  27. drawListBuffer.put(drawOrder);
  28. drawListBuffer.position(0);
  29. }
  30. }

该样例可以看作是一个如何使用OpenGL创建复杂图形的启发,通常来说,我们需要使用三角形的集合来绘制对象。在下一节课中,我们将学习如何在屏幕上画这些形状。

(转)使用OpenGL显示图像(二)定义Shapes的更多相关文章

  1. (转)使用OpenGL显示图像(三)绘制Shapes

    绘制形状 编写:jdneo - 原文:http://developer.android.com/training/graphics/opengl/draw.html 在定义了使用OpenGL绘制的形状 ...

  2. openGL实现二维图形和三维图形

    openGL是一个强大的底层图形库,其命令最初的时候使用C语言实现的.openGL定义了一个图形程序接口,常用于制作处理三维图像,功能强大,调用方便,在图像处理十分受欢迎. 实现图形主要使用的是ope ...

  3. SQL编程篇 (二) 定义与流程控制

    分类: sql编程:标准的sql 编程 * 纯sql 在标准的编程中又分为 sqlserver-->T-sql oracle-->pl-sql(扩展) 变量:在使用变量之前先定义 声明变量 ...

  4. OpenGL(二)——函数库简述

    简述 1. OpenGL用到的库分为OpenGL核心库.OpenGL实用库.OpenGL辅助库和OpenGL工具库(不是必须) 2. OpenGL核心库 核心库包含有115个函数,函数名的前缀为gl ...

  5. OpenGL屏幕二维坐标转化成三维模型坐标

    我们把OpenGL里模型的三维坐标往二维坐标的转化称为投影,则屏幕上的二维坐标往三维坐标转化则可以称为反投影,下面我们来介绍一下反投影的方法. 主要是gluUnProject函数的使用,下面是代码: ...

  6. OpenGL 知识二

    OpenGL综述 September 14, 2014 学习OpenGL是学习计算机图形学的一个工具,因为计算机上图形的显示要依靠底层的软件和硬件,学习图形学除了学习基本的概念,线,曲面,图形生成,变 ...

  7. OpenGL(二十三) 各向异性纹理过滤

    如果使用一般的纹理过滤,当观察方向跟模型表面不是相互垂直的的情况下,会出现纹理信息的丢失,表现为图像看上去比较模糊,如下图所示,远处场景的细节信息很差: 针对这种情况,可以采用同向异性过滤的方式处理纹 ...

  8. OpenGl(二)点线设置、多边形镂空

    1. 改变点的大小 OpenGL中默认点的大小是1个像素,使用函数glPointSIze可以调整点的大小,入参是GLfloat,相当于是浮点数. 相关代码: void myDisplay(void) ...

  9. OpenGL(二十二) gluBuild2DMipmaps 加载Mip纹理贴图

    当纹理被用于渲染一个面积比它本身小很多的对象时,会由于纹理图像的降采样率不足而导致混叠现象,主要的表现特征是纹理图像的闪烁,出现纹理躁动.特别是在场景远近移动变换时,这种闪烁情况更为明显,严重可能会影 ...

随机推荐

  1. express中 使用session与cookie

    1.express如何使用session与cookie : https://www.jianshu.com/p/1839e482274e  或  https://www.cnblogs.com/chy ...

  2. JS当中的无限分类递归树

    列表转换成树形结构方法定义: //javascript 树形结构 function toTree(data) { // 删除 所有 children,以防止多次调用 data.forEach(func ...

  3. 高并发大流量专题---11、Web服务器的负载均衡

    高并发大流量专题---11.Web服务器的负载均衡 一.总结 一句话总结: 推荐使用nginx七层(应用层)负载均衡的实现:配置那是相当的简单 http{ upstream cluster{ serv ...

  4. centos7.4 搭建lnmp

    系统:阿里云 centos7.4 Php:PHP 7.1.13 (cli) Mysql:mysql5.7 Nginx:nginx/1.12.2 一.更新centos7 yum源 cp /etc/yum ...

  5. 命令连接redis

    cd到redis的bin目录 ./redis-cli -h 输入info,看是否要验证 清空所有key FLUSHALL

  6. Java并发:搞定线程池(上)

    原文地址:https://www.nowcoder.com/discuss/152050?type=0&order=0&pos=6&page=0 本文是在原文的基础+理解,想要 ...

  7. Visual Studio禁用IntelliSense

    通过Everything搜索feacp.dll,然后修改其名字或者直接删除之. 重启Visual Studio.

  8. 嵌入式C语言3.2 关键字---自定义数据类型

    1. struct 结构体 基本语法 struct myabc{ unsigned int a; unsigned int b; unsigned int c; unsigned int d; } 调 ...

  9. PAT甲级——A1155 HeapPaths【30】

    In computer science, a heap is a specialized tree-based data structure that satisfies the heap prope ...

  10. Tomcat服务的配置

    首先到Apache官网,下载tomcat,在官网有两种tomcat,一种是安装版,一种是压缩版,对于安装版的一台机器只能安装一个tomcat,而对于压缩版的tomcat一台机器可以安装多个tomcat ...