opengl中的Floatbuffer和IntBuffer与java中数据的存储方式不同的解决方法,编辑一个自己的BufferUtil工具类
2016-09-18 14:28
489 查看
android OpenGL ES的书中使用了下面代码:
1)创建三个顶点
private IntBuffer triggerBuffer = IntBuffer.wrap(new int[]{
0,one,0,
-one,-one,0,
one,-one,0,
});
2)然后使用triggerBuffer 画顶点
例如:gl.glVertexPointer(3, GL10.GL_FIXED, 0,triggerBuffer );
经常会出现:Must use a native order direct Buffer的错误。
/*
* OpenGL 是一个非常底层的画图接口,它所使用的缓冲区存储结构是和我们的 java 程序中不相同的。
* Java 是大端字节序(BigEdian),而 OpenGL 所需要的数据是小端字节序(LittleEdian)。
* 所以,我们在将 Java 的缓冲区转化为 OpenGL 可用的缓冲区时需要作一些工作。建立buff的方法如下
* */
为了解决这个问题我们可以创建一个工具类:
PS:创建一个长度为length的Floatbuffer时候,存储方式为opengl的存储方式,在每次调用put加入点后position都会加1,因此加入点后在绘图时候将position重置为0
1)创建三个顶点
private IntBuffer triggerBuffer = IntBuffer.wrap(new int[]{
0,one,0,
-one,-one,0,
one,-one,0,
});
2)然后使用triggerBuffer 画顶点
例如:gl.glVertexPointer(3, GL10.GL_FIXED, 0,triggerBuffer );
经常会出现:Must use a native order direct Buffer的错误。
/*
* OpenGL 是一个非常底层的画图接口,它所使用的缓冲区存储结构是和我们的 java 程序中不相同的。
* Java 是大端字节序(BigEdian),而 OpenGL 所需要的数据是小端字节序(LittleEdian)。
* 所以,我们在将 Java 的缓冲区转化为 OpenGL 可用的缓冲区时需要作一些工作。建立buff的方法如下
* */
为了解决这个问题我们可以创建一个工具类:
import java.nio.ByteBuffer; import java.nio.ByteOrder; import java.nio.FloatBuffer; import java.nio.IntBuffer; /** * Created by lenovo on 2016/9/6. */ public class BufferUtil { public static FloatBuffer floatToBuffer(float[] a) { //先初始化buffer,数组的长度*4,因为一个float占4个字节 ByteBuffer mbb = ByteBuffer.allocateDirect(a.length * 4); //数组排序用nativeOrder,根据本地的排列顺序,指定存储方式,是1. Little endian(小头):将低序字节存储在起始地址 // 2. Big endian(大头):将高序字节存储在起始地址 mbb.order(ByteOrder.nativeOrder()); FloatBuffer mBuffer = mbb.asFloatBuffer(); mBuffer.put(a); mBuffer.position(0); return mBuffer; } // 将数组a转化为intbuffer public static IntBuffer intToBuffer(int[] a) { //先初始化buffer,数组的长度*4,因为一个float占4个字节 ByteBuffer mbb = ByteBuffer.allocateDirect(a.length * 4); //数组排序用nativeOrder mbb.order(ByteOrder.nativeOrder()); IntBuffer mBuffer2 = mbb.asIntBuffer(); mBuffer2.put(a); mBuffer2.position(0); return mBuffer2; } //创建一个长度为length的Floatbuffer,存储方式为opengl的存储方式,在每次调用put加入点后position都会加1,因此加入点后在绘图时候将position重置为0 public static FloatBuffer getFloatBuffer(int length) { ByteBuffer mbb = ByteBuffer.allocateDirect(length * 4); mbb.order(ByteOrder.nativeOrder()); FloatBuffer mBuffer = mbb.asFloatBuffer(); mBuffer.position(0); return mBuffer; } public static IntBuffer getIntBuffer(int length) { ByteBuffer mbb = ByteBuffer.allocateDirect(length * 4); mbb.order(ByteOrder.nativeOrder()); IntBuffer mBuffer = mbb.asIntBuffer(); mBuffer.position(0); return mBuffer; } }
PS:创建一个长度为length的Floatbuffer时候,存储方式为opengl的存储方式,在每次调用put加入点后position都会加1,因此加入点后在绘图时候将position重置为0
相关文章推荐
- 用类名做方法的返回值类型 在学习Java的初始阶段,很多同学使用基本数据类型定义变量和引用类型定义变量以及使用类名做方法的返回值类型常常不知所以。今天我以自己的解读方式和个人的理解作一个简单的解释,和
- WindowsMobile(Winform)开发中的数据存储(解决在不同的Form中要调用对方的方法或者使用对方的数据问题)
- 存储 磁盘大于2TB 大数据存储一个盘 解决方法
- AE多用户同时编辑同一个版本数据的解决方法
- 求 float数据在内存中的存储方法 的 java PHP C/C++ 程序
- json数据与JAVA数据的转换 jsonJavaBean.netApache 自己编写了一个工具类,处理页面提交json格式数据到后台,再进行处理成JAVA对象数据 1、DTO:Data T
- 在一个程序中需要用到全局变量(在多个class之间共享数据),请问如何定义具有这种功能的变量?或者是否有其他的方法解决多个class之间的数据共享(尽量简单实现)。 首先应该明确 Java中没有全局变
- datalist 的用法。也是增删改查,但是比较智能。用数据绑定的方式,可以有不同的显示方法,下面是对一个表的增删改查的参考代码
- Java后台使用get方式远程跨域请求,返回数据为中文乱码解决方法
- 打印同样一个数据,竟然出现不同的结果,解决方法。
- Java—float数据在内存中的存储方法
- 打印同样一个数据,竟然出现不同的结果,解决方法。
- Java与php共享Memcached存储数据中的问题与解决方法
- java不同数据类型在内存中的存储方式
- Nand Flash数据存储方式和数据读写方法!
- [转]java不同容器不同操作系统下中文问题解决方法
- float 数据的存储方式
- sharepoint中无法在"数据表中编辑"的原因和解决方法
- float数据在内存中的存储方法
- 同一个用户在不同页面共享数据的常用方法