私は次のクラスがあります。AndroidのキャンバスSurfaceView黒い画面
public class GameView extends SurfaceView implements SurfaceHolder.Callback {
public static final int WIDTH = 860;
public static final int HEIGHT = 480;
int x = 0;
GameLoop gameLoop;
public GameView(Context context) {
super(context);
getHolder().addCallback(this);
setFocusable(true);
}
public GameView(Context context, AttributeSet attrs) {
super(context, attrs);
getHolder().addCallback(this);
setFocusable(true);
}
public GameView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
getHolder().addCallback(this);
setFocusable(true);
}
@Override
public void surfaceCreated(SurfaceHolder holder) {
//setWillNotDraw(false);
gameLoop = new GameLoop(this);
gameLoop.start();
}
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
}
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
if(canvas != null) {
Paint paint = new Paint();
paint.setColor(Color.WHITE);
canvas.drawRect(x, 0, 200, 200, paint);
canvas.drawRect(200, 200, 400, 400, paint);
Log.v("TEST", "Drawing into canvas");
Log.v("TEST", "x := " + x);
}
}
public void update() {
x += 5;
}
とこのようになりますゲームループ:
public class GameLoop extends Thread {
public static final int REFRESH_TIME = 2;
private static final int LOG_FPS_AFTER_FRAMES = 30;
public static Canvas canvas;
private double averageFPS;
private GameView gameView;
private boolean running;
public GameLoop(GameView gamePanel) {
this.gameView = gamePanel;
}
@Override
public void run() {
super.run();
running = true;
long startTime;
long timeMillis;
long waitTime;
long totalTime = 0;
int frameCount = 0;
long targetTime = 1000*REFRESH_TIME;
while(running) {
startTime = System.nanoTime();
canvas = null;
try {
canvas = gameView.getHolder().lockCanvas();
synchronized (gameView.getHolder()) {
gameView.update();
gameView.draw(canvas);
}
} catch(Exception e) {}
finally {
if(canvas != null) {
try {
gameView.getHolder().unlockCanvasAndPost(canvas);
} catch(Exception e) {}
}
}
timeMillis = (System.nanoTime() - startTime)/1000000;
waitTime = targetTime - timeMillis;
try {
this.sleep(waitTime);
} catch(Exception e) {}
totalTime += System.nanoTime() - startTime;
frameCount++;
if(frameCount == LOG_FPS_AFTER_FRAMES) {
averageFPS = 1000/((totalTime/frameCount)/1000000);
frameCount = 0;
totalTime = 0;
Log.v("FPS", Double.toString(averageFPS));
}
}
}
@Override
public void interrupt() {
super.interrupt();
running = false;
}
public boolean isRunning() {
return running;
}
public void setRunning(boolean value) {
this.running = value;
}
}
OnDrawメソッドは2秒ごとに呼び出されているが画面は黒いままです。どのような問題が起きる可能性がありますか? (私はラインsetWillNotDraw(false)をコメント解除した場合の方法により長方形が一度描かれたが、動いていない)...