自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Android開(kāi)發(fā)之圖形繪制

移動(dòng)開(kāi)發(fā) Android
使用OpenGL ES 2.0繪制形狀需要大量的代碼,因?yàn)槟阈枰峁┐罅康膱D像渲染器管道的細(xì)節(jié)。具體地,你需要定義: * 頂點(diǎn)著色器(Vertex Shader)-OpenGL ES圖像中渲染形狀頂點(diǎn)的代碼*片斷著色器(Fragment Shader) - OpenGL ES渲染形狀表面顏色與紋理的代碼 * 程序(Program) - 包含了你想要用來(lái)繪制形狀的著色器的OpenGL ES對(duì)象 你需要至少一個(gè)頂點(diǎn)著色器來(lái)繪制圖像,一個(gè)片斷著色器去給圖像著色。這些著色器必須被定義和添加到一個(gè)OpenGL ES程序中,它將會(huì)在繪制形狀時(shí)被用到。

用OpenGL定義好要繪制的形狀后,你就可能想把他們繪制在屏幕上。基于OpenGL ES 2.0繪制這些形狀,需要的代碼量比你想象中要多一點(diǎn),這是因?yàn)?.0的API提供了大量對(duì)于圖像渲染管道的控制。 這節(jié)課將會(huì)介紹如何使用OpenGL ES 2.0的API繪制你在前一節(jié)課定義好的形狀。

初始化形狀

在你制圖之前,你必須初始化和加載你計(jì)劃要繪制的形狀。你要在內(nèi)存和處理速率的渲染器中的onSurfaceCreated()方法對(duì)形狀初始化,除非在程序執(zhí)行的過(guò)程中,形狀的結(jié)構(gòu)(原始坐標(biāo))發(fā)生了變化。

  1. public void onSurfachttp://wiki.eoeandroid.com/Drawing_ShapeseCreated(GL10 unused, EGLConfig config) { 
  2.     ... 
  3.     // initialize a triangle 
  4.     mTriangle = new Triangle(); 
  5.     // initialize a square 
  6.     mSquare = new Square(); 
  7.     } 

繪制形狀

使用OpenGL ES 2.0繪制形狀需要大量的代碼,因?yàn)槟阈枰峁┐罅康膱D像渲染器管道的細(xì)節(jié)。具體地,你需要定義: * 頂點(diǎn)著色器(Vertex Shader) - OpenGL ES圖像中渲染形狀頂點(diǎn)的代碼 * 片斷著色器(Fragment Shader) - OpenGL ES渲染形狀表面顏色與紋理的代碼 * 程序(Program) - 包含了你想要用來(lái)繪制形狀的著色器的OpenGL ES對(duì)象 你需要至少一個(gè)頂點(diǎn)著色器來(lái)繪制圖像,一個(gè)片斷著色器去給圖像著色。這些著色器必須被定義和添加到一個(gè)OpenGL ES程序中,它將會(huì)在繪制形狀時(shí)被用到。下面是一個(gè)基本的定義著色器的例子:

  1. private final String vertexShaderCode = 
  2.     "attribute vec4 vPosition;" + 
  3.     "void main() {" + 
  4.     "  gl_Position = vPosition;" + 
  5.     "}"
  6.  
  7.     private final String fragmentShaderCode = 
  8.     "precision mediump float;" + 
  9.     "uniform vec4 vColor;" + 
  10.     "void main() {" + 
  11.     "  gl_FragColor = vColor;" + 
  12.     "}"

包含了OpenGL著色語(yǔ)言(GLSL)的著色器在被OpenGL ES環(huán)境使用之前,必須先被定義。你可以在渲染類中創(chuàng)建一個(gè)實(shí)用的方法來(lái)定義這些著色器:

  1. public static int loadShader(int type, String shaderCode){ 
  2.     // create a vertex shader type (GLES20.GL_VERTEX_SHADER) 
  3.     // or a fragment shader type (GLES20.GL_FRAGMENT_SHADER) 
  4.     int shader = GLES20.glCreateShader(type); 
  5.     // add the source code to the shader and compile it 
  6.     GLES20.glShaderSource(shader, shaderCode); 
  7.     GLES20.glCompileShader(shader); 
  8.     return shader; 
  9.     } 

為了繪制形狀,你必須編寫(xiě)著色器的代碼,并把它們添加到OpenGL ES程序?qū)ο笾?,與程序連接起來(lái)。你可以在繪制對(duì)象的構(gòu)造器做這些事情,這樣它就會(huì)只運(yùn)行一次。

備注:定義OpenGL ES著色器并于程序連接,需要消耗大量的CPU周期和處理時(shí)間,所以你要避免重復(fù)做這個(gè)動(dòng)作。如果你想要獲取執(zhí)行期間著色器的內(nèi)容,你可以在建立代碼使它們只建立一次,并存儲(chǔ)起來(lái)在后面用。

  1. public Triangle() { 
  2.     ... 
  3.     int vertexShader = loadShader(GLES20.GL_VERTEX_SHADER, vertexShaderCode); 
  4.     int fragmentShader = loadShader(GLES20.GL_FRAGMENT_SHADER, fragmentShaderCode); 
  5.     mProgram = GLES20.glCreateProgram();             // create empty OpenGL ES Program 
  6.     GLES20.glAttachShader(mProgram, vertexShader);   // add the vertex shader to program 
  7.     GLES20.glAttachShader(mProgram, fragmentShader); // add the fragment shader to program 
  8.     GLES20.glLinkProgram(mProgram);                  // creates OpenGL ES program executables 
  9.     } 

事情進(jìn)展到此,你可以在實(shí)際中調(diào)用繪制圖形方法了。使用OpenGL ES制圖時(shí),需要你指定幾個(gè)參數(shù),來(lái)告訴渲染器管道要畫(huà)什么和怎樣畫(huà)。既然形狀會(huì)影響到繪制的情況,所以最好的辦法就是給形狀類添加它們各自的邏輯。 可以建立draw()的方法來(lái)繪制形狀。下面的例子就設(shè)定了形狀的頂點(diǎn)著色器的位置和片段著色器的顏色值,然后就執(zhí)行繪制的函數(shù)方法。

  1. public void draw() { 
  2.     // Add program to OpenGL ES environment 
  3.     GLES20.glUseProgram(mProgram); 
  4.     // get handle to vertex shader's vPosition member 
  5.     mPositionHandle = GLES20.glGetAttribLocation(mProgram, "vPosition"); 
  6.     // Enable a handle to the triangle vertices 
  7.     GLES20.glEnableVertexAttribArray(mPositionHandle); 
  8.     // Prepare the triangle coordinate data 
  9.     GLES20.glVertexAttribPointer(mPositionHandle, COORDS_PER_VERTEX, 
  10.                                  GLES20.GL_FLOAT, false
  11.                                  vertexStride, vertexBuffer); 
  12.     // get handle to fragment shader's vColor member 
  13.     mColorHandle = GLES20.glGetUniformLocation(mProgram, "vColor"); 
  14.     // Set color for drawing the triangle 
  15.     GLES20.glUniform4fv(mColorHandle, 1, color, 0); 
  16.     // Draw the triangle 
  17.     GLES20.glDrawArrays(GLES20.GL_TRIANGLES, 0, vertexCount); 
  18.     // Disable vertex array 
  19.     GLES20.glDisableVertexAttribArray(mPositionHandle); 
  20.     } 

只要你代碼齊全,你只需要調(diào)用渲染器 onDrawFrame()方法中的draw()方法來(lái)繪制圖像。當(dāng)應(yīng)用程序運(yùn)行起來(lái)時(shí),應(yīng)該會(huì)得到以下這樣的結(jié)果:

圖1.沒(méi)有使用到投影和攝影視圖的三角形繪制

以上代碼中還是存在一些問(wèn)題。第一,它不會(huì)帶給你朋友很深的影響;第二,當(dāng)你改變手機(jī)設(shè)備的屏幕方向時(shí),這三角形會(huì)被壓扁,改變形狀,這是因?yàn)樗L制對(duì)象的定點(diǎn)坐標(biāo)沒(méi)有根據(jù)GLSurfaceView屏幕顯示的比例設(shè)置好,下節(jié)課的使用投影和攝影視圖可以解決這個(gè)問(wèn)題;最后,這三角形是不動(dòng)的,讓人覺(jué)得沒(méi)勁,在Adding_Motion這節(jié)課,你可以讓形狀旋轉(zhuǎn),將會(huì)接觸到OpenGL ES圖像管道的更多有趣的用法。

原文鏈接:http://docs.eoeandroid.com/training/graphics/opengl/draw.html

責(zé)任編輯:閆佳明 來(lái)源: wiki.eoe.cn
相關(guān)推薦

2023-09-07 08:24:35

圖形編輯器開(kāi)發(fā)繪制圖形工具

2013-12-27 13:00:30

Android開(kāi)發(fā)Android應(yīng)用Context Men

2013-12-26 16:33:24

Android開(kāi)發(fā)Android應(yīng)用引路蜂二維圖形繪制

2011-08-17 14:32:44

iOS開(kāi)發(fā)繪制

2011-11-16 10:35:28

Android 4.0圖形硬件加速繪制技巧

2013-12-04 16:07:27

Android游戲引擎libgdx教程

2022-06-06 10:44:10

C++語(yǔ)言鴻蒙

2023-02-02 14:07:00

圖形編輯器Canvas

2013-02-20 14:32:37

Android開(kāi)發(fā)性能

2013-07-24 18:14:36

Android開(kāi)發(fā)學(xué)習(xí)Android UIButton

2023-10-19 10:12:34

圖形編輯器開(kāi)發(fā)縮放圖形

2012-02-24 15:28:36

ibmdw

2012-05-07 14:25:16

HTML5

2009-10-16 10:36:35

VB.NET繪制GDI

2009-10-23 16:43:01

VB.NET繪制圖形

2011-06-30 15:09:37

QT 繪制 圖形

2013-12-27 13:27:05

Android開(kāi)發(fā)Android應(yīng)用RadioButton

2013-04-15 15:22:06

2011-04-12 08:40:23

IMFAndroid

2013-01-06 12:23:59

Android開(kāi)發(fā)SQLite數(shù)據(jù)庫(kù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)