blob: b9e2ca6134f85f0bb9a6f40a01b77385681158ff (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
package com.sun.opengl.impl;
import javax.media.opengl.*;
import javax.media.opengl.sub.*;
import javax.media.opengl.sub.fixed.*;
import java.nio.*;
public class GLFixedArrayHandler implements GLArrayHandler {
private GLArrayDataEditable ad;
public GLFixedArrayHandler(GLArrayDataEditable ad) {
this.ad = ad;
}
protected final void passArrayPointer(GLPointerIf gl) {
switch(ad.getIndex()) {
case GLPointerIf.GL_VERTEX_ARRAY:
gl.glVertexPointer(ad);
break;
case GLPointerIf.GL_NORMAL_ARRAY:
gl.glNormalPointer(ad);
break;
case GLPointerIf.GL_COLOR_ARRAY:
gl.glColorPointer(ad);
break;
case GLPointerIf.GL_TEXTURE_COORD_ARRAY:
gl.glTexCoordPointer(ad);
break;
default:
throw new GLException("invalid glArrayIndex: "+ad.getIndex()+":\n\t"+ad);
}
}
public void enableBuffer(GL gl, boolean enable) {
GLPointerIf glp = GLFixedFuncUtil.getGLFixedFuncIf(gl);
if(enable) {
glp.glEnableClientState(ad.getIndex());
Buffer buffer = ad.getBuffer();
if(ad.isVBO()) {
// always bind and refresh the VBO mgr,
// in case more than one gl*Pointer objects are in use
gl.glBindBuffer(GL.GL_ARRAY_BUFFER, ad.getVBOName());
if(!ad.isBufferWritten()) {
if(null!=buffer) {
gl.glBufferData(GL.GL_ARRAY_BUFFER, buffer.limit() * ad.getComponentSize(), buffer, ad.getBufferUsage());
}
ad.setBufferWritten(true);
}
passArrayPointer(glp);
} else if(null!=buffer) {
passArrayPointer(glp);
ad.setBufferWritten(true);
}
} else {
if(ad.isVBO()) {
gl.glBindBuffer(GL.GL_ARRAY_BUFFER, 0);
}
glp.glDisableClientState(ad.getIndex());
}
}
}
|