Android OpenGL ES 绘图 -- 添加颜色

OpenGL 添加颜色

注: 参考:http://wiki.jikexueyuan.com/project/opengl-es-basics/add-color.html

前面的例子显示的正方形都是白色,看其来不是很吸引人,本篇介绍如何添加颜色。OpenGL ES 使用颜色是我们熟知的 RGBA 模式(红,绿,蓝,透明度)。

颜色的定义通常使用 Hex 格式 0xFF00FF 或十进制格式(255,0,255), 在 OpenGL 中却是使用 0…1 之间的浮点数表示。0 为 0,1 相当于 255(0xFF)。

最简单的上色方法叫做顶点着色 (Vertxt coloring),可以使用单色,也可以定义颜色渐变或者使用材质(类同于二维图形中各种 Brush 类型)。

Flat coloring(单色)

是通知 OpenGL 使用单一的颜色来渲染,OpenGL 将一直使用指定的颜色来渲染直到你指定其它的颜色。
指定颜色的方法为

public abstract void glColor4f(float red, float green, float blue, float alpha)。  

缺省的 red,green,blue 为 1,代表白色。这也是为什么前面显示的正方形都是白色的缘故。
只需在绘画前调用该方法,即可添加颜色

        gl.glColor4f(0.5f, 0.5f, 1.0f, 1.0f);
        // Draw REC A.
        drawREC(gl);

编译运行,正方形颜色变成了蓝色:

Smooth coloring (平滑颜色过渡)

当给每个顶点定义一个颜色时,OpenGL 自动为不同顶点颜色之间生成中间过渡颜色(渐变色)。
为每个顶点定义一个颜色值:

// The colors mapped to the vertices.
float[] colors = {
 1f, 0f, 0f, 1f, // vertex 0 red
 0f, 1f, 0f, 1f, // vertex 1 green
 0f, 0f, 1f, 1f, // vertex 2 blue
 1f, 0f, 1f, 1f, // vertex 3 magenta
};  

颜色定义的顺序和顶点的顺序是一致的。为了提高性能,和顶点坐标一样,我们也把颜色数组放到Buffer 中:

// float has 4 bytes, colors (RGBA) * 4 bytes
ByteBuffer cbb
 = ByteBuffer.allocateDirect(colors.length * 4);
cbb.order(ByteOrder.nativeOrder());
colorBuffer = cbb.asFloatBuffer();
colorBuffer.put(colors);
colorBuffer.position(0);  

最后修改 drawREC 方法,如下:

        //开启点坐标管道
        gl.glEnableClientState(GL10.GL_VERTEX_ARRAY);
        //开启点颜色管道
        gl.glEnableClientState(GL10.GL_COLOR_ARRAY);
        //传入点坐标
        gl.glVertexPointer(3, GL10.GL_FLOAT, 0, vertexBuffer);
        //传入点颜色数组
        gl.glColorPointer(4, GL10.GL_FLOAT, 0, colorBuffer);
        //根据点与绘线顺序绘面
        gl.glDrawElements(GL10.GL_TRIANGLES, indices.length,
                GL10.GL_UNSIGNED_SHORT, indexBuffer);
        //关闭点颜色管道
        gl.glDisableClientState(GL10.GL_COLOR_ARRAY);
        //关闭点坐标管道
        gl.glDisableClientState(GL10.GL_VERTEX_ARRAY);

编译运行结果如下:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值