/**
 * 缓冲区工具类
 */
public class BufferUtil {
 /**
  * 将浮点数组转换成字节缓冲区
  */
 public static ByteBuffer arr2ByteBuffer(float[] arr){
  ByteBuffer ibb = ByteBuffer.allocateDirect(arr.length * 4);
  ibb.order(ByteOrder.nativeOrder());
  FloatBuffer fbb = ibb.asFloatBuffer();
  fbb.put(arr);
  ibb.position(0);
  return ibb ;
 }
 
 /**
  * 将list转换成字节缓冲区
  */
 public static ByteBuffer list2ByteBuffer(List<Float> list){
  ByteBuffer ibb = ByteBuffer.allocateDirect(list.size() * 4);
  ibb.order(ByteOrder.nativeOrder());
  FloatBuffer fbb = ibb.asFloatBuffer();
  for(Float f : list){
   fbb.put(f);
  }
  ibb.position(0);
  return ibb ;
 }
}

/**

* 渲染器

*/

public abstract class AbstractMyRenderer implements android.opengl.GLSurfaceView.Renderer

{

private float ratio;

public float xrotate = 0f;//围绕x轴旋转角度

public float yrotate = 0f;//围绕x轴旋转角度

/**

* 1.

*/

public void onSurfaceCreated(GL10 gl, EGLConfig config)

{

//清平色

gl.glClearColor(0f, 0f, 0f, 1f);

//启用顶点缓冲区数组

gl.glEnableClientState(GL10.GL_VERTEX_ARRAY);

}

/**

* 2.

*/

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

//设置视口

gl.glViewport(0, 0, width, height);

ratio = (float)width / (float)height;

//投影矩阵

gl.glMatrixMode(GL10.GL_PROJECTION);

//加载单位矩阵

gl.glLoadIdentity();

//设置平截头体

gl.glFrustumf(-ratio, ratio, -1, 1, 3f, 7f);  }

/**

* 3.

*/

public abstract void onDrawFrame(GL10 gl);

}

**

* 棱锥,正方形

*/

public class MyTriangleConeRenderer extends AbstractMyRenderer{

public void onSurfaceCreated(GL10 gl, EGLConfig config) {

gl.glClearColor(0f, 0f, 0f, 1f);
  //顶点缓冲区
  gl.glEnableClientState(GL10.GL_VERTEX_ARRAY);
  //启用颜色缓冲区
  gl.glEnableClientState(GL10.GL_COLOR_ARRAY);
 }
 
 public void onDrawFrame(GL10 gl) {
  //清除颜色缓冲区和深度缓冲区
  gl.glClear(GL10.GL_COLOR_BUFFER_BIT|GL10.GL_DEPTH_BUFFER_BIT);
  //设置绘图颜色
  gl.glColor4f(1f, 0f, 0f, 1f);
  
  //启用深度测试
  gl.glEnable(GL10.GL_DEPTH_TEST);
  
  //启用表面剔除
  gl.glEnable(GL10.GL_CULL_FACE);
  //指定前面()
  //ccw:counter clock wise-->逆时针
  //cw:clock wise--> 顺时针
  gl.glFrontFace(GL10.GL_CCW);
  //剔除背面
  gl.glCullFace(GL10.GL_BACK);
  
  //GL10.GL_SMOOTH:平滑着色(默认)
  //GL10.GL_FLAT:单调模式
  gl.glShadeModel(GL10.GL_FLAT);
  
  //操作模型视图矩阵
  gl.glMatrixMode(GL10.GL_MODELVIEW);
  gl.glLoadIdentity();
  //设置眼球的参数
  GLU.gluLookAt(gl,0f,0f,5f, 0f, 0f, 0f, 0f,1f,0f);
  
  //旋转角度
  gl.glRotatef(xrotate, 1, 0, 0);
  gl.glRotatef(yrotate, 0, 1, 0);
  
  //计算点坐标
  float r = 0.5f ;//半径
  float x = 0f,y = 0f,z = -0.5f ;
  
  /******************** 锥面 ************************/
  //顶点坐标集合
  List<Float> coordsList = new ArrayList<Float>();
  //添加锥顶点
  coordsList.add(0f);
  coordsList.add(0f);
  coordsList.add(0.5f);
  
  //顶点颜色集合
  List<Float> colorList = new ArrayList<Float>();
  colorList.add(1f);//r
  colorList.add(0f);//g
  colorList.add(0f);//b
  colorList.add(1f);//a
  
  /******************** 锥底 ************************/
  //锥底坐标
  List<Float> coordsConeBottomList = new ArrayList<Float>();
  coordsConeBottomList.add(0f);
  coordsConeBottomList.add(0f);
  coordsConeBottomList.add(-0.5f);
  
  boolean flag = false ;
  //底面
  for(float alpha = 0f ; alpha < Math.PI * 6 ; alpha = (float) (alpha + Math.PI / 8)){
   //锥面
   x = (float) (r * Math.cos(alpha));
   y = (float) (r * Math.sin(alpha));
   coordsList.add(x);
   coordsList.add(y);
   coordsList.add(z);
   
   //锥底坐标
   coordsConeBottomList.add(x);
   coordsConeBottomList.add(y);
   coordsConeBottomList.add(z);
   
   //点颜色值
   if(flag = !flag){
    //黄色
    colorList.add(1f);
    colorList.add(1f);
    colorList.add(0f);
    colorList.add(1f);
   }
   else{
    //红色
    colorList.add(1f);
    colorList.add(0f);
    colorList.add(0f);
    colorList.add(1f);
   }
  }
  //点颜色值
  if(flag = !flag){
   //黄色
   colorList.add(1f);
   colorList.add(1f);
   colorList.add(0f);
   colorList.add(1f);
  }
  else{
   //红色
   colorList.add(1f);
   colorList.add(0f);
   colorList.add(0f);
   colorList.add(1f);
  }
  
  //颜色缓冲区
  ByteBuffer colorBuffer = BufferUtil.list2ByteBuffer(colorList);
  gl.glColorPointer(4, GL10.GL_FLOAT, 0, colorBuffer);
  //绘制锥面
  gl.glVertexPointer(3, GL10.GL_FLOAT, 0, BufferUtil.list2ByteBuffer(coordsList));
  gl.glDrawArrays(GL10.GL_TRIANGLE_FAN, 0, coordsList.size() / 3);
  
  //剔除正面
  gl.glCullFace(GL10.GL_FRONT);
  //绘制锥底
  colorBuffer.position(4);
  gl.glColorPointer(4, GL10.GL_FLOAT, 0, colorBuffer);
  gl.glVertexPointer(3, GL10.GL_FLOAT, 0, BufferUtil.list2ByteBuffer(coordsConeBottomList));
  gl.glDrawArrays(GL10.GL_TRIANGLE_FAN, 0, coordsConeBottomList.size() / 3);
 }
}

//主界面

public class MainActivity extends Activity {

private AbstractMyRenderer render;

private MyGLSurfaceView view;

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

view = new GLSurfaceView(this);

render = new MyTriangleConeRenderer();

view.setRenderer(render);

//GLSurfaceView.RENDERMODE_CONTINUOUSLY:持续渲染(默认)

//GLSurfaceView.RENDERMODE_WHEN_DIRTY:脏渲染,命令渲染

view.setRenderMode(GLSurfaceView.RENDERMODE_WHEN_DIRTY);

setContentView(view);

}

public boolean onKeyDown(int keyCode, KeyEvent event) {

float step = 5f ;

//up

if(keyCode == KeyEvent.KEYCODE_DPAD_UP){

render.xrotate = render.xrotate - step ;

}      else if(keyCode == KeyEvent.KEYCODE_DPAD_DOWN){

render.xrotate = render.xrotate + step ;

}      else if(keyCode == KeyEvent.KEYCODE_DPAD_LEFT){

render.yrotate = render.yrotate + step ;

}      else if(keyCode == KeyEvent.KEYCODE_DPAD_RIGHT){

render.yrotate = render.yrotate - step ;

}

//请求渲染,和脏渲染配合使用

view.requestRender();

return super.onKeyDown(keyCode, event);

}

}

OpenGL绘制棱锥,剔除的更多相关文章

  1. OpenGl 绘制一个立方体

    OpenGl 绘制一个立方体 为了绘制六个正方形,我们为每个正方形指定四个顶点,最终我们需要指定6*4=24个顶点.但是我们知道,一个立方体其实总共只有八个顶点,要指定24次,就意味着每个顶点其实重复 ...

  2. [Modern OpenGL系列(三)]用OpenGL绘制一个三角形

    本文已同步发表在CSDN:http://blog.csdn.net/wenxin2011/article/details/51347008 在上一篇文章中已经介绍了OpenGL窗口的创建.本文接着说如 ...

  3. opengl绘制正弦曲线

    利用opengl绘制正弦曲线 ,见代码: #include <windows.h> //#include <GLUT/glut.h> #include <GL/glut. ...

  4. OpenGL绘制自由落体小球

    OpenGL绘制自由落体小球 一.    程序运行的软硬件环境 本次设计在window10系统下进行,运用C++进行编写,在CodeBlocks环境下使用OpenGL进行设计. 所需环境配置分为2部分 ...

  5. OpenGL绘制简单场景,实现旋转缩放平移和灯光效果

    本项目实现了用OpenGL绘制一个简单场景,包括正方体.球体和网格,实现了物体的旋转.缩放.平移和灯光效果.附有项目完整代码.有具体凝视.适合刚開始学习的人熟悉opengl使用. 开发情况 开发环境V ...

  6. Opengl绘制我们的小屋(二)第一人称漫游

    这章我们先讲第一人称漫游的实现.在openTK里,我们用函数Matrix4.LookAt(caram.Eye,caram.Target,Vector3.UnitY)来放置摄像机,其中三个参数分别与摄像 ...

  7. OPENGL绘制文字

    OPENGL没有提供直接绘制文字的功能,需要借助于操作系统. 用OPENGL绘制文字比较常见的方法是利用显示列表.创建一系列显示列表,每个字符对应一个列表编号.例如,'A'对应列表编号1000+'A' ...

  8. 第一课、OpenGL绘制直线等等

    第一课.OpenGL绘制直线等等 分类: [开发技术]OpenGL 2012-01-18 14:59 5217人阅读 评论(0) 收藏 举报 buffer图形c // //  main.c //  o ...

  9. 46.Qt 使用OpenGL绘制立方体

    main.cpp #include <QApplication> #include <iostream> #include "vowelcube.h" in ...

随机推荐

  1. C#管理控制IIS7的方法

    原文:C#管理控制IIS7的方法 转自 http://www.lob.cn/jq/csyy/7285.shtml 把在找到正确方法前遇到的挫折也拿出来与大家分享,相信不少朋友从iis6到iis7的过渡 ...

  2. Hadoop2.3.0具体安装过程

    前言:       Hadoop实现了一个分布式文件系统(Hadoop Distributed File System),简称HDFS.HDFS有高容错性的特点,并且设计用来部署在低廉的(low-co ...

  3. 设计模式--模板方法 And State模式

    1.模板方法   钩子: 在抽象基类已经有默认的定义,子类选择是否覆盖它 在模板方法模式中,  抽象基类中使用 钩子函数(子类视情况是否覆盖)  来达到控制模板方法中  流程控制的 目的 设计原则: ...

  4. Net 一个请求的处理流程

    Net 一个请求的处理流程   1.浏览器请求 请求-准备环境-->处理请求   2.Aspnet 环境的创建 客户请求 IIS区分静态文件还是动态文件,静态文件直接文件返回,动态文件通过asp ...

  5. jquery中 $ 和 jQuery 及 $() 的差别

    用过jquery的人都知道,jquery有两种使用方法,一种是$,另一种是jQuery,那么这两种方式在使用上有什么差别呢? 答案是这两种使用方法没什么差别,仅仅是别名而已,用$要比jQuery简短一 ...

  6. XML概要

     早在两年前,我一直听说XML,但是,只是没有时间去研究它.也不知道它的作用,花了一些时间最近几天来学习他们的语言.是XML的一些简介希望能对各位同学有所帮助: XML是eXtensible Ma ...

  7. DES加密和解密PHP,Java,ObjectC统一的方法

    原文:DES加密和解密PHP,Java,ObjectC统一的方法 PHP的加解密函数 <?php class DesComponent { var $key = '12345678'; func ...

  8. stl之map容器的原理及应用

    容器的数据结构同样是采用红黑树进行管理,插入的元素健位不允许重复,所使用的节点元素的比较函数,只对元素的健值进行比较,元素的各项数据可通过健值检索出来.map容器是一种关联容器,实现了SortedAs ...

  9. linux_增加用户组_删除用户

    添加账号组 /usr/sbin/groupadd iknow 添加账号 /usr/sbin/useradd  -g iknow -d /home/iknow/ iknow 更改密码 passwd 选项 ...

  10. Swift中文手册 -- The Basics

    原文:Swift中文手册 -- The Basics 基础部分 Swift 是 iOS 和 OS X 应用开发的一门新语言.然而,如果你有 C 或者 Objective-C 开发经验的话,你会发现 S ...