Android OpenGLは、画面の半分のみをレンダリングします
-
28-09-2019 - |
質問
私はOpenGLアプリケーションの例に従っていますが、なぜこのことが起こっているのかわかりません...
GlsurfaceViewがあり、対応するレンダラーが三角形を描いています。しかし、画面上のビュー全体を取得する代わりに、私は上半分だけを持っています。また、写真で見ることができるように複製されています。 Nexus Oneを使用しています
XML:
<?xml version="1.0" encoding="utf-8"?>
<com.forgottenprojects.geoturista.DrawingLayer
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/drawing"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
/>
アクティビティはマニフェストでこれを持っています:
android:theme="@android:style/Theme.NoTitleBar.Fullscreen"
DrawingLayerクラス:
public class DrawingLayer extends GLSurfaceView {
private TriangleRenderer renderer;
private Context context;
public DrawingLayer(Context context, AttributeSet attrs) {
super(context, attrs);
init(context);
}
public DrawingLayer(Context context) {
super(context);
init(context);
}
private void init(Context c)
{
this.context = c;
setEGLConfigChooser(false);
this.renderer = new TriangleRenderer(c);
setRenderer(renderer);
setRenderMode(GLSurfaceView.RENDERMODE_CONTINUOUSLY);
getHolder().setFormat(PixelFormat.TRANSLUCENT);
}
}
トライアングルレンダラー(そのほとんどがApress Pro Android2ブックから)
public class TriangleRenderer implements Renderer {
private final static int VERTS = 3;
private FloatBuffer mFVertexBuffer;
private ShortBuffer mIndexBuffer;
TriangleRenderer(Context context)
{
ByteBuffer vbb = ByteBuffer.allocateDirect(VERTS * 3 * 4);
vbb.order(ByteOrder.nativeOrder());
mFVertexBuffer = vbb.asFloatBuffer();
ByteBuffer ibb = ByteBuffer.allocateDirect(VERTS * 2);
ibb.order(ByteOrder.nativeOrder());
mIndexBuffer = ibb.asShortBuffer();
float[] coords = {
-0.5f, -0.5f, 0, // (x1,y1,z1)
0.5f, -0.5f, 0,
0.0f, 0.5f, 0
};
for (int i = 0; i < VERTS; i++) {
for(int j = 0; j < 3; j++) {
mFVertexBuffer.put(coords[i*3+j]);
}
}
short[] myIndecesArray = {0,1,2};
for (int i=0;i<3;i++)
{
mIndexBuffer.put(myIndecesArray[i]);
}
mFVertexBuffer.position(0);
mIndexBuffer.position(0);
}
protected void draw(GL10 gl)
{
gl.glColor4f(1.0f, 0, 0, 0.5f);
gl.glVertexPointer(3, GL10.GL_FLOAT, 0, mFVertexBuffer);
gl.glDrawElements(GL10.GL_TRIANGLES, VERTS,
GL10.GL_UNSIGNED_SHORT, mIndexBuffer);
}
@Override
public void onSurfaceCreated(GL10 gl, EGLConfig config) {
gl.glDisable(GL10.GL_DITHER);
gl.glHint(GL10.GL_PERSPECTIVE_CORRECTION_HINT, GL10.GL_FASTEST);
gl.glClearColor(0.5f, 0.5f, 0.5f, 1.0f);
gl.glShadeModel(GL10.GL_SMOOTH);
gl.glEnable(GL10.GL_DEPTH_TEST);
}
@Override
public void onDrawFrame(GL10 gl) {
gl.glDisable(GL10.GL_DITHER);
gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT);
gl.glClearColor(1.0f, 0.5f, 0.7f, 1.0f);
gl.glMatrixMode(GL10.GL_MODELVIEW);
gl.glLoadIdentity();
GLU.gluLookAt(gl, 0, 0, -5, 0f, 0f, 0f, 0f, 1f, 0f);
gl.glEnableClientState(GL10.GL_VERTEX_ARRAY);
draw(gl);
}
@Override
public void onSurfaceChanged(GL10 gl, int width, int height) {
gl.glViewport(0, 0, width, height);
gl.glMatrixMode(GL10.GL_PROJECTION);
float ratio = (float)width / (float)height;
gl.glLoadIdentity();
gl.glFrustumf(-ratio, ratio, -1, 1, 3, 7);
}
}
前もって感謝します!
解決
EGLディスプレイの構成が間違っているようです。
他のヒント
それは一緒に働いた
setEGLConfigChooser(8,8,8,8,4,4);
しかし、私はその背後に透明性を適用する方法がわかりません(カメラビューのある別のSurfaceViewがあるため)
Pierre-Antoineの応答にコメントを追加しますが、まだ適切なレベルの評判はありません。
彼が言及しているように、問題はEGLディスプレイの構成が間違っていることです。
この問題に遭遇したとき、私が遭遇したEGLディスプレイの構成の問題は、構成のリストを反復するときに、私が持っているよりもリストのさらに1つを選択することです。
私の具体的な例(Sony Xperia X10をAndroid 2.3を実行している)で、私は持っていたEGL構成を選択していました EGL_SAMPLES
4と EGL_SAMPLE_BUFFERS
1に設定します。設定コードを変更したときに、「以前の」構成intを選択するようになります。 EGL_SAMPLES
1と EGL_SAMPLE_BUFFERS
0に設定すると、半ブラック画面がなくなり、適切なレンダリングがありました。