【问题标题】:requestRender doesn't seem to render (opengl-es android)requestRender 似乎没有渲染(opengl-es android)
【发布时间】:2011-12-01 17:53:02
【问题描述】:

我有一个在线程中运行的游戏循环,我的问题是

mGLSurfaceView.requestRender();

因空指针异常而崩溃。我的 onSurfaceCreated 方法中有一个日志标签,它证明表面已创建(至少我认为),所以这不是问题。

我认为问题在于 requestRender 需要一个非静态引用。当我尝试调用另一个方法的非静态引用时,它反而在该行上崩溃了。所以我只能假设线程对非静态对象不太友好。我也无法对 requestRender 进行静态引用(这将是一个明显的解决方案)。

这是我的游戏循环线程

import android.util.Log;

public class GameLoop extends Thread {

    private MyGLSurfaceView myGLSurfaceView;
    private final static int maxFPS = 30;
    private final static int maxFrameSkips = 5;
    private final static int framePeriod = 1000 / maxFPS;

    public static boolean running;
    public final static String TAG = "input";

@Override
public void run() {
    running = LaunchActivity.getRunning();
    long beginTime;
    long timeDiff;
    int sleepTime;
    int framesSkipped;


    sleepTime = 0;
    while (running) {
        running = LaunchActivity.getRunning();
        Log.d(TAG, "gameRunning");
        beginTime = System.currentTimeMillis();
        framesSkipped = 0;
            // notice the static reference here
        GameLogic.update();
        Log.d(TAG, "updated");
            // not static here
        myGLSurfaceView.requestRender();
        Log.d(TAG, "rendered");
        timeDiff = System.currentTimeMillis() - beginTime;
        sleepTime = (int)(framePeriod - timeDiff);

        if (sleepTime > 0) {
            try{
                Thread.sleep(sleepTime);
                Log.d(TAG, "sleeping" + String.valueOf(sleepTime));
            }catch(InterruptedException e){}
        }

        while(sleepTime < 0 && framesSkipped < maxFrameSkips){
            GameLogic.update();
            sleepTime += framePeriod;
            framesSkipped++;
            Log.d(TAG, "Frames Skipped");
        }




}
}


}

这是我的表面创建方法(我认为这可能是问题的一部分)

@Override
public void onSurfaceCreated(GL10 gl, EGLConfig config) {
    gl.glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
    gl.glShadeModel(GL10.GL_SMOOTH);
    gl.glClearDepthf(1.0f);
    gl.glEnable(GL10.GL_DEPTH_TEST);
    gl.glDepthFunc(GL10.GL_LEQUAL);
    gl.glHint(GL10.GL_PERSPECTIVE_CORRECTION_HINT, GL10.GL_NICEST);
    Log.d(TAG, "SurfaceCreated");

}

哦,顺便说一句,我正在使用

glOrthof

投影

堆栈跟踪

10-05 20:26:44.694: ERROR/AndroidRuntime(18276): FATAL EXCEPTION: Thread-11
10-05 20:26:44.694: ERROR/AndroidRuntime(18276): java.lang.NullPointerException
10-05 20:26:44.694: ERROR/AndroidRuntime(18276):     at basicmelon.games.androidgamething.GameLoop.run(GameLoop.java:33)
10-05 20:26:44.694: ERROR/AndroidRuntime(18276):     at java.lang.Thread.run(Thread.java:1096)

日志标签

10-05 20:28:23.077: DEBUG/input(18923): GLSurfaceViewed
10-05 20:28:23.116: DEBUG/input(18923): Created
10-05 20:28:23.116: DEBUG/input(18923): Resumed
10-05 20:28:23.124: DEBUG/input(18923): gameRunning
10-05 20:28:23.132: DEBUG/input(18923): Updated
10-05 20:28:23.210: DEBUG/input(18923): Paused

【问题讨论】:

  • 您能否包含异常的堆栈跟踪和显示您的日志消息的日志输出?
  • @P.T.刚刚意识到 SurfaceCreated 日志标签从未被调用(对于我的表面创建正确而言如此之多),我在游戏循环代码中修改了一些(从对 MyGLSurfaceView 的引用中删除了 = new GLSurfaceView

标签: android multithreading opengl-es render game-loop


【解决方案1】:

您永远不会创建 MyGLSurfaceView 对象。您必须将此行放在 while 循环之前的某个位置:

myGLSurfaceView = new MyGLSurfaceView();

【讨论】:

  • 关于我应该在方括号之间放什么的任何建议 =P
  • 尝试:myGLSurfaceView = new MyGLSurfaceView(this);也许你应该阅读你正在使用的类的文档^^
  • 在我的 LaunchActivity 中找到了这一行并将变量带过来 ^_^ 非常感谢
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-02-10
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-06-09
相关资源
最近更新 更多