Android下用OpenGL画的一个旋转的圆形
by
at 2010-12-15 17:02:32
original http://www.javaeye.com/topic/843106
这是我在android下用OGL ES画的第一个图形,Render的override部分引用了其它同学的一些代码
怎么上截图?
public class GLRender implements Renderer{
float rotateAngle;
//顶点数组,GL ES只能用这个办法画圆吗?
private float[] vertices = new float[720];
//度到弧度的转换
public float DegToRad(float deg)
{
return (float) (3.14159265358979323846 * deg / 180.0);
}
@Override
public void onDrawFrame(GL10 gl) {
// TODO Auto-generated method stub
// 进入这个函数第一件要做的事就是清除屏幕和深度缓存
gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT);
//画圆形
drawCircle(gl);
}
public void drawCircle(GL10 gl)
{
//重置投影矩阵
gl.glLoadIdentity();
// 移动操作,移入屏幕(Z轴)5个像素, x, y , z
gl.glTranslatef(0.0f, 0.0f, -5.0f);
//旋转, angle, x, y , z
gl.glRotatef(rotateAngle, 1.0f, 0.0f, 0.0f);
// 设置当前色为红色, R, G, B, Alpha
gl.glColor4f(1.0f, 0.1f, 0.1f, 1.0f);
//设置圆形顶点数据,这个是在创建时生成
FloatBuffer verBuffer = FloatBuffer.wrap(vertices);
//设置顶点类型为浮点坐标(GL_FLOAT),不设置或者设置错误类型将导致图形不能显示或者显示错误
gl.glVertexPointer(2, GL10.GL_FLOAT, 0, verBuffer);
//打开顶点数组
gl.glEnableClientState(GL10.GL_VERTEX_ARRAY);
//向OGL发送实际画图指令
gl.glDrawArrays(GL10.GL_TRIANGLE_FAN, 0, 360);
//关闭顶点数组功能
gl.glDisableClientState(GL10.GL_VERTEX_ARRAY);
//画图结束
gl.glFinish();
//更改旋转角度
rotateAngle += 0.5;
}
@Override
public void onSurfaceChanged(GL10 gl, int width, int height) {
// TODO Auto-generated method stub
float ratio = (float) width / height;
//设置OpenGL场景的大小
gl.glViewport(0, 0, width, height);
//设置投影矩阵
gl.glMatrixMode(GL10.GL_PROJECTION);
//重置投影矩阵
gl.glLoadIdentity();
// 设置视口的大小
gl.glFrustumf(-ratio, ratio, -1, 1, 1, 10);
// 选择模型观察矩阵
gl.glMatrixMode(GL10.GL_MODELVIEW);
// 重置模型观察矩阵
gl.glLoadIdentity();
}
@Override
public void onSurfaceCreated(GL10 gl, EGLConfig config) {
// TODO Auto-generated method stub
// 启用阴影平滑
gl.glShadeModel(GL10.GL_SMOOTH);
// 黑色背景
gl.glClearColor(0, 0, 0, 0);
// 设置深度缓存
gl.glClearDepthf(1.0f);
// 启用深度测试
gl.glEnable(GL10.GL_DEPTH_TEST);
// 所作深度测试的类型
gl.glDepthFunc(GL10.GL_LEQUAL);
// 告诉系统对透视进行修正
gl.glHint(GL10.GL_PERSPECTIVE_CORRECTION_HINT, GL10.GL_FASTEST);
//初始化圆形数据
for (int i = 0; i < 720; i += 2) {
// x value
vertices[i] = (float) (Math.cos(DegToRad(i)) * 1);
// y value
vertices[i+1] = (float) (Math.sin(DegToRad(i)) * 1);
}
}
}
完整程序见附件
-
本文附件下载:
<li><a href="http://dl.javaeye.com/topics/download/3f20ad00-0257-37ea-8e0a-9690ff535827">FirstOpenGlPrj.rar</a> (41.8 KB)</li>
<br><br>
作者: <a href="http://dyingearth.javaeye.com">dyingearth</a>
<br>
声明: 本文系JavaEye网站发布的原创文章,未经作者书面许可,严禁任何网站转载本文,否则必将追究法律责任!
<br><br>
<span style="color:red">
<a href="http://www.javaeye.com/topic/843106" style="color:red">已有 <strong>1</strong> 人发表回复,猛击->><strong>这里</strong><<-参与讨论</a>
</span>
<br><br><br>
JavaEye推荐