`
melord
  • 浏览: 146008 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

OpenGL ES教程I之创建OpenGL视图(原文对照)

阅读更多

OpenGL ES Tutorial for Android – Part I – Setting up the view

 

I'm going to write a couple of tutorials on using OpenGL ES on Android phones. The theory of OpenGL ES is the same on different devices so it should be quite easy to convert them to another platform.

我将写一些关于在Andoird 手机上使用OpenGL Es的教程。理论上OpenGL ES适用于不同的设备(平台),因此很容易被移植到其它平台。

I can't always remember where I found particular info so I might not always be able to give you the right reference. If you feel that I have borrowed stuff from you but have forgotten to add you as a reference, please e-mail me.

我常常忘了我所搜集的资料的来源与出处,所以(在某些资料方面)我可能不能给出正确的引用。如果您觉得我使用了您的资料而没有标明引用(位置),请发电子邮件给我。

In the code examples I will have two different links for each function. The actual function will be linked to the android documentation and after that I will also link the OpenGL documentations. Like this:

在示例代码中,我对每个函数将使用两种不同的链接。点击函数将链接到Android docAndroid doc太简单了,建议还是链接到OpenGL doc吧),在函数后面,我会添加一个到OpenGL docs的链接,如下:

gl.glClearColor(0.0f, 0.0f, 0.0f, 0.5f);  // OpenGL docs.

So, let's start.

好了,(言归正传)让我们这就开始OpenGL学习之旅吧。

In this tutorial I will show you how to set up your OpenGL ES view that’s always a good place to start.

在本教程中,我将(先)展示怎样来建立OpenGL ES界面,通常这是一个好的开始。

Setting up an OpenGL ES View

Setting up a OpenGL view has never been hard and on Android it is still easy. There really are only two things you need to get started.

Android中建立一个OpenGL视图非常简单,您需要做的只有两件事。

GLSurfaceView

GLSurfaceView is a API class in Android 1.5 that helps you write OpenGL ES applications.

GLSurfaceViewAndroid1.5中帮助您编写OpenGL ES应用程序的API类(,其具有以下功能)

·         Providing the glue code to connect OpenGL ES to the View system.

·         Providing the glue code to make OpenGL ES work with the Activity life-cycle.

·         Making it easy to choose an appropriate frame buffer pixel format.

·         Creating and managing a separate rendering thread to enable smooth animation.

·         Providing easy-to-use debugging tools for tracing OpenGL ES API calls and checking for errors.

·         提供了OpenGL ES连接View系统的粘合代码。

·         提供了OpenGL ESActivity生命周期协作的粘合代码。

·         易于选择合适的帧缓冲像素格式。

·         创建和管理独立的渲染线程来启用平滑动画(效果)

·         提供易于使用的调试工具来跟踪OpenGL ES API调用与检查错误。

If you want to get going fast with your OpenGL ES application this is where you should start.

The only function you need to call on is:

如果您想快速着手OpenGL ES应用程序,请从这里开始

您需要调用的唯一函数是:

public void  setRenderer(GLSurfaceView.Renderer renderer)

Read more at: GLSurfaceView

GLSurfaceView.Renderer

GLSurfaceView.Renderer is a generic render interface. In your implementation of this renderer you should put all your calls to render a frame.

GLSurfaceView.Renderer是一个通用的渲染接口,您必须实现此类的抽象方法来画(动画中的)帧
There are three functions to implement:

您需要实现的三个方法如下:

// Called when the surface is created or recreated.

// 当平面创建或或重新创建的时候调用

 

public void onSurfaceCreated(GL10 gl, EGLConfig config)

 

// Called to draw the current frame.

// 画当前帧

public void onDrawFrame(GL10 gl)

 

// Called when the surface changed size.

// 当视图大小变更的时候调用,如屏幕横纵切换

public void onSurfaceChanged(GL10 gl, int width, int height)

onSurfaceCreated

Here it's a good thing to setup things that you don't change so often in the rendering cycle. Stuff like what color to clear the screen with, enabling z-buffer and so on.

推荐将一些在渲染周期中不会变更的代码放到此处,如设置屏幕初始颜色,开始Z轴缓冲等。

onDrawFrame

Here is where the actual drawing take place.

在此函数中进行绘画(帧)

onSurfaceChanged

If your device supports flipping between landscape and portrait you will get a call to this function when it happens. What you do here is setting upp the new ratio.
Read more at:
GLSurfaceView.Renderer

如果您的设备支持横竖屏切换,那么在切换发生时,您就需要在此方法中重新设置新的横纵比例了。

Putting it together

First we create our activity, we keep it clean and simple.

首先,创建一个尽可能的简洁 Activity

package se.jayway.opengl.tutorial;

 

import android.app.Activity;

import android.opengl.GLSurfaceView;

import android.os.Bundle;

 

public class TutorialPartI extends Activity {

    /** Called when the activity is first created. */

    @Override

    public void onCreate(Bundle savedInstanceState) {

            super.onCreate(savedInstanceState);

               GLSurfaceView view = new GLSurfaceView(this);

             view.setRenderer(new OpenGLRenderer());

             setContentView(view);

    }

}

Our renderer takes little bit more work to setup, look at it and I will explain the code a bit more.

更多的render设置,请见我扩展的renderer

package se.jayway.opengl.tutorial;

 

import javax.microedition.khronos.egl.EGLConfig;

import javax.microedition.khronos.opengles.GL10;

 

import android.opengl.GLU;

import android.opengl.GLSurfaceView.Renderer;

 

public class OpenGLRenderer implements Renderer {

        /*

         * (non-Javadoc)

         *

         * @see

         * android.opengl.GLSurfaceView.Renderer#onSurfaceCreated(javax.

         * microedition.khronos.opengles.GL10, javax.microedition.khronos.

         * egl.EGLConfig)

         */

        public void onSurfaceCreated(GL10 gl, EGLConfig config) {

                // Set the background color to black ( rgba ).

                // 设置背景颜色为黑色 ( rgba ).

                gl.glClearColor(0.0f, 0.0f, 0.0f, 0.5f);  // OpenGL docs.

                // Enable Smooth Shading, default not really needed.

                // 开启平滑阴影,实际上不需要(默认的shadeModel就是GL_SMOOTH

                gl.glShadeModel(GL10.GL_SMOOTH);// OpenGL docs.

                // Depth buffer setup.

                // 设置深度缓冲

                gl.glClearDepthf(1.0f);// OpenGL docs.

                // Enables depth testing.

                // 启用深度测试

                gl.glEnable(GL10.GL_DEPTH_TEST);// OpenGL docs.

                // The type of depth testing to do.

                // 设置深度测试类型

                gl.glDepthFunc(GL10.GL_LEQUAL);// OpenGL docs.

                // Really nice perspective calculations.

                // 真实透视计算

                gl.glHint(GL10.GL_PERSPECTIVE_CORRECTION_HINT, // OpenGL docs.

                          GL10.GL_NICEST);

        }

 

        /*

         * (non-Javadoc)

         *

         * @see

         * android.opengl.GLSurfaceView.Renderer#onDrawFrame(javax.

         * microedition.khronos.opengles.GL10)

         */

        public void onDrawFrame(GL10 gl) {

                // Clears the screen and depth buffer.

                // 清除屏幕和深度(Z轴)缓冲

                gl.glClear(GL10.GL_COLOR_BUFFER_BIT | // OpenGL docs.

                           GL10.GL_DEPTH_BUFFER_BIT);

        }

 

        /*

         * (non-Javadoc)

         *

         * @see

         * android.opengl.GLSurfaceView.Renderer#onSurfaceChanged(javax.

         * microedition.khronos.opengles.GL10, int, int)

         */

        public void onSurfaceChanged(GL10 gl, int width, int height) {

                // Sets the current view port to the new size.

                //设置当前视窗新大小

                gl.glViewport(0, 0, width, height);// OpenGL docs.

                // Select the projection matrix

                // 选择投影方式为透视投影

                gl.glMatrixMode(GL10.GL_PROJECTION);// OpenGL docs.

                // Reset the projection matrix

                // 重置投影矩阵

                gl.glLoadIdentity();// OpenGL docs.

                // Calculate the aspect ratio of the window

                // 计算窗口视角比例

                GLU.gluPerspective(gl, 45.0f,

                                   (float) width / (float) height,

                                   0.1f, 100.0f);

                // Select the modelview matrix

                // 选择变换方式为modelview

                gl.glMatrixMode(GL10.GL_MODELVIEW);// OpenGL docs.

                // Reset the modelview matrix

                // 重置变换矩阵

                gl.glLoadIdentity();// OpenGL docs.

        }

}

Fullscreen

Just add this lines in the OpenGLDemo class and you will get fullscreen.

只需要在OpenGLDemo类中添加如下代码,就可以让Activity全屏。建议还是在Manifest.xml中配置全屏

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        this.requestWindowFeature(Window.FEATURE_NO_TITLE); // (NEW)

        getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,

            WindowManager.LayoutParams.FLAG_FULLSCREEN); // (NEW)

        ... // Previous code.

    }

This is pretty much all you need to get your view up and running. If you compile and run it you will see a nice black screen.

如果想要运行创建的OpenGL视图,以上就已经足够了,编译运行此应用,你可以看到一个纯黑色的屏幕。不过GLSurfaceView运行于独立的线程,所以需要将此线程同步到Android主线程中,做法是在Activity pause时,GLSurfaceViewpauseActivity resume时,GLSurfaceView线程也resume

References

The info used in this tutorial is collected from:
Android Developers
OpenGL ES 1.1 Reference Pages

You can download the source for this tutorial here: Tutorial_Part_I.zip
You can also checkout the code from: code.google.com

Next tutorial: OpenGL ES Tutorial for Android – Part II – Building a polygon

Per-Erik Bergman
Consultant at
Jayway

 

分享到:
评论

相关推荐

    Android开发之OpenGL ES教程

    Android平台上的OpenGL ES教程主要帮助开发者了解如何在Android应用程序中集成和使用这个库来创建交互式的图形界面。 在Android上设置OpenGL ES视图是开发过程中的第一步,而`GLSurfaceView`是实现这一目标的关键...

    Android OpenGL ES 简明开发教程

    ### Android OpenGL ES 开发教程详解 #### 概述与历史沿革 OpenGL ES(OpenGL for Embedded Systems)作为OpenGL API的子集,专为移动设备、PDA和游戏主机等嵌入式系统设计,旨在简化3D图形应用的开发流程。自2003...

    西蒙iPhone-OpenGL ES 教程【中文翻译版PDF】

    这份iPhone OpenGL ES教程是为iOS开发者准备的,它涵盖了如何在Xcode中利用OpenGL ES模板创建3D图形应用的基本步骤。教程特别强调了深度缓冲的重要性,以及如何在不使用深度缓冲的情况下,只使用2D坐标来处理3D图形...

    OpenGL ES 1.0 教程

    OpenGL ES 1.0 教程是一份专为学习移动设备和嵌入式系统图形编程设计的资源。OpenGL ES(Embedded Systems)是OpenGL标准的精简版本,特别针对低功耗设备,如智能手机、平板电脑和掌上电脑,如Windows CE平台。这个...

    基于WinCE的OpenGL ES教程

    总之,"基于WinCE的OpenGL ES教程"将引导你通过两个不同的开发环境,学习如何在有限的嵌入式系统资源下利用OpenGL ES创建高性能的图形应用。无论你是经验丰富的WinCE开发者还是初学者,这些教程都将为你提供宝贵的...

    opengles 2.0教程

    - 实例代码:`opengles_sample`可能包含了一些实际的示例代码,通过分析和运行这些代码,可以加深对OpenGL ES 2.0的理解。 - 在线教程:网上有许多教程和指南,如LearnOpenGLES.com、OpenGL-Tutorial.org等,它们...

    android开发之OpenGL ES教程

    本教程将聚焦于Android上的OpenGL ES 3D游戏开发,介绍如何设置OpenGL ES视图,这是任何图形应用的基础。 首先,我们要了解的是`GLSurfaceView`。在Android 1.5版本中引入的`GLSurfaceView`是一个API类,它为编写...

    西蒙iphone opengl es 第00章

    西蒙(可能是指一位知名的教程作者或讲师)的"iPhone OpenGL ES 第00章"很可能是系列教程的开篇,旨在引导学习者入门这个强大的图形编程框架。在这个章节中,通常会涵盖以下几个核心知识点: 1. **OpenGL ES 概述**...

    wince 的OpenGL+ES教程

    在Windows CE (Wince)平台上,OpenGL ES提供了图形渲染的能力,使得开发者可以创建高性能的2D和3D图形应用。在EVC4.0(Embedded Visual C++ 4.0)和VS2005(Visual Studio 2005)中使用OpenGL ES,需要特别注意与...

    OPENGL ES 3.0编程指南 原书第2版 中文版 笔记1

    OpenGL ES 3.0 是移动设备和嵌入式系统上用于图形渲染的开放标准,它在OpenGL的基础上进行了优化,特别适合资源有限的环境。在iOS平台上,通常与EAGLContext一起使用,来构建和管理OpenGL ES上下文。以下是基于...

    opengl-es.zip_opengl_opengl es

    在“opengl es.zip”这个压缩包中,包含的"opengl es.txt"文件可能是一份关于如何使用OpenGL ES绘制立体图形的教程或指南。下面我们将深入探讨OpenGL ES的基础知识和如何从简单到复杂地构建立体图形。 1. **基本...

    Android平台使用OpenGLES2.0显示YUV数据

    本教程主要探讨如何在Android系统上,利用OpenGLES2.0图形库来处理和显示从Camera获取的YUV原始数据。YUV是一种常见的颜色空间,广泛应用于视频编码和解码,因为它对带宽的要求相对较低,特别适合移动设备。 首先,...

    opengles 3.0游戏开发(上)

    在"opengles3.0游戏开发(上(1))"中,可能包含了一系列的实例项目,这些项目可能会涵盖上述知识点,如建立基本的游戏框架、创建3D模型、实现基本的交互功能等。每个案例都是一个具体的应用场景,通过实践来巩固...

    openGL ES for Iphone

    ### OpenGL ES for iPhone – 关键知识点详解 #### 一、OpenGL ES for iPhone 概述 OpenGL ES (OpenGL for Embedded Systems) 是一个为嵌入式设备(如智能手机和平板电脑)设计的图形渲染库。它是一种跨平台的应用...

    【OpenGL ES】立方体手动旋转(更新版)

    在 Android 平台上,我们可以使用 OpenGL ES 进行3D图形编程,创建丰富的视觉效果。本资源主要讲解如何使用 OpenGL ES 绘制一个立方体,并通过触摸事件实现手动控制立方体的旋转,同时解决了立方体在旋转过程中可能...

    使用OpenGL ES对YUV图片进行显示

    OpenGL ES 是一种跨语言、跨平台的图形库,主要用于嵌入式系统,如智能手机、平板电脑等设备上,用于创建2D和3D图形。在Android等系统中,OpenGL ES被广泛应用于游戏开发、图像处理等领域。YUV是视频和图像编码中...

    OpenGL ES 3.0 Cookboook

    - **SurfaceView与OpenGL ES**:利用SurfaceView类创建一个可以绘制OpenGL ES内容的视图。 - **EGL管理上下文**:通过EGL(Embedded Graphics Library)来管理OpenGL ES的渲染上下文。 **2. iOS平台** - **Metal...

    OpenGLES demo - 5. 深度测试

    在"OpenGLES demo - 5. 深度测试"这个项目中,我们将深入探讨如何利用OpenGL ES实现深度测试,并通过源码分析来理解其实现细节。 首先,深度测试的基本概念是基于每个像素的Z值(或称为深度值),它表示该像素在3D...

    opengl es api手册

    OpenGL ES API手册是Android平台3D图形开发的重要参考资料,它为开发者提供了在移动设备上创建高性能、低功耗的3D图形应用的工具。OpenGL ES(OpenGL for Embedded Systems)是OpenGL的一个子集,专为嵌入式设备如...

Global site tag (gtag.js) - Google Analytics