Android基于OpenGL在GLSurfaceView上绘制三角形及使用投影和相机视图方法示例

作者:pku_android 时间:2023-06-08 03:59:42 

本文实例讲述了Android基于OpenGL在GLSurfaceView上绘制三角形及使用投影和相机视图方法。分享给大家供大家参考,具体如下:

定义三角形

OpenGL 允许我们使用三维坐标来定义物体。在绘制三角形前,我们需要定义它各个点的坐标。我们一般使用数组来存储各个顶点的坐标。

OpenGL ES 默认 [0,0,0] (X,Y,Z) 在GLSurfaceView的中心,[1,1,0]在右上角,[-1,-1,0]在左下角。

绘制三角形

在绘制三角形之前,我们必须告诉OpenGL我们正在使用顶点数组。然后我们才使用绘制函数画出三角形。

实验步骤:

1. 添加新的类Triangle

代码如下:


public class Triangle {
 public Triangle()
 {
    float triangleCoords[] = {
         // X, Y, Z 这是一个等边三角形
         -0.5f, -0.25f, 0,
          0.5f, -0.25f, 0,
          0.0f, 0.559016994f, 0
       };
       // 初始化三角形的顶点缓存
       ByteBuffer vbb = ByteBuffer.allocateDirect(
           // (# of coordinate values * 4 bytes per float)
           triangleCoords.length * 4);
       vbb.order(ByteOrder.nativeOrder());// 使用设备硬件本身的字节序
       triangleVB = vbb.asFloatBuffer(); // 从ByteBuffer中创建一个浮点缓存
       triangleVB.put(triangleCoords); // 向浮点缓存中添加顶点坐标
       triangleVB.position(0); // 使缓存读第一个坐标
 }
 public void draw(GL10 gl)
 {
   gl.glColor4f(0.63671875f, 0.76953125f, 0.22265625f, 0.0f); //设置当前颜色
   gl.glVertexPointer(3, GL10.GL_FLOAT, 0, triangleVB);//设置顶点
   gl.glDrawArrays(GL10.GL_TRIANGLES, 0, 3);//绘制三角形
 }
 private FloatBuffer triangleVB;
}

2. 在myGLRenderer类中添加成员privateTriangle mTriangle并在构造函数中初始化。

代码如下:


public myGLRenderer()
{
   mTriangle = new Triangle();
}

3. 在myGLRenderer类的onSurfaceCreated()函数最后添加glEnableClientState()方法来启用顶点数组。

代码如下:


@Override
public void onSurfaceCreated(GL10 gl, EGLConfig config) {
   // TODO Auto-generated method stub
   gl.glClearColor(0.5f, 0.5f, 0.5f, 1.0f);
   gl.glEnableClientState(GL10.GL_VERTEX_ARRAY);
}

4. 在myGLRenderer类的onDrawFrame()函数最后添加三角形绘制方法。

代码如下:


@Override
public void onDrawFrame(GL10 gl) {
   // TODO Auto-generated method stub
   gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT);
   mTriangle.draw(gl);
}

这样,我们便完成了一个平面三角形的绘制。但我们发现这个三角形并不像我们定义的那样是一个等边三角形,这是由于OpenGL总假设我们的屏幕是一个正方形,这样在绘制的时候最终图形会随着屏幕长宽比例的不同而被拉伸。为了得到正确的显示,我们需要将图形投影到正确的位置。这一功能我们在下一节进行实现。

Android设备屏幕通常不是正方形的,而OpenGL总是默认地将正方形坐标系投影到这一设备上,这就导致图形无法按真实比例显示。要解决这一问题,我们可以使用OpenGL 的投影模式和相机视图将图形的坐标进行转换以适应不同的设备显示。

实验步骤:

1. 修改myGLRenderer类的onSurfaceCreated()函数来启用GL10.GL_PROJECTION模式,计算屏幕的长宽比并使用这一比例来转换物体的坐标。

代码如下:


@Override
public void onSurfaceChanged(GL10 gl, int width, int height) {
   // TODO Auto-generated method stub
   gl.glViewport(0, 0, width, height);
   float ratio = (float) width / height;
   gl.glMatrixMode(GL10.GL_PROJECTION); // 设置当前矩阵为投影矩阵
   gl.glLoadIdentity(); // 重置矩阵为初始值
   gl.glFrustumf(-ratio, ratio, -1, 1, 3, 7); // 根据长宽比设置投影矩阵
}

2. 修改myGLRenderer的onDrawFrame()方法,启用MODELVIEW模式,并使用GLU.gluLookAt()来设置视点。

代码如下:


@Override
public void onDrawFrame(GL10 gl) {
 // TODO Auto-generated method stub
   gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT);
   // 设置当前矩阵为模型视图模式
   gl.glMatrixMode(GL10.GL_MODELVIEW);
   gl.glLoadIdentity();  // reset the matrix to its default state
   // 设置视点
   GLU.gluLookAt(gl, 0, 0, -5, 0f, 0f, 0f, 0f, 1.0f, 0.0f);
   mTriangle.draw(gl);
}

这样,我们绘制的图形比例就总是正确的,不再受设备的影响而被拉伸变形了。

希望本文所述对大家Android程序设计有所帮助。

标签:Android,OpenGL,GLSurfaceView
0
投稿

猜你喜欢

  • Spring Boot自定义Starter组件开发实现配置过程

    2022-05-31 16:07:12
  • C# 如何在MVC3中取消备用控制器的选择

    2023-02-16 06:48:18
  • java实现砸金蛋抽奖功能

    2022-02-22 01:26:50
  • java三个环境变量配置简单教程

    2023-11-28 20:45:30
  • C#中const,readonly和static关键字的用法介绍

    2021-08-17 15:33:45
  • Java实现计算器设计

    2023-08-18 13:36:54
  • SpringBoot如何实现定时任务示例详解

    2023-10-11 23:24:42
  • Android开发之绘制平面上的多边形功能分析

    2023-12-13 13:31:57
  • 详解SpringBoot禁用Swagger的三种方式

    2022-02-28 23:49:08
  • Android仿QQ圆形头像个性名片

    2021-08-24 02:40:46
  • Java精确抽取网页发布时间

    2022-03-24 17:20:11
  • 基于Class.forName()用法及说明

    2021-06-20 19:09:30
  • java UDP实现一个聊天工具的示例代码

    2021-09-19 18:41:47
  • java向下转型基础知识点及实例

    2022-07-01 11:48:38
  • java定时任务Timer和TimerTask使用详解

    2023-07-13 00:29:33
  • Android 实现把bitmap图片的某一部分的颜色改成其他颜色

    2022-12-28 00:12:03
  • java @Value(

    2023-10-05 02:54:47
  • 第三方包jintellitype实现Java设置全局热键

    2023-09-25 10:33:50
  • Android实现的仿淘宝购物车demo示例

    2023-09-04 08:59:19
  • springboot整合mybatisplus的方法详解

    2023-05-20 18:35:05
  • asp之家 软件编程 m.aspxhome.com