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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
package com.orbekk;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
public class GameView extends SurfaceView implements SurfaceHolder.Callback {
private Logger logger = LoggerFactory.getLogger(getClass());
private GameThread thread;
static class GameThread extends Thread {
private int height = 0;
private int width = 0;
private int posX;
private int posY;
private SurfaceHolder holder;
private Context context;
private Paint paint;
public GameThread(SurfaceHolder holder, Context context) {
this.holder = holder;
this.context = context;
paint = new Paint();
paint.setAntiAlias(true);
paint.setARGB(255, 255, 0, 0);
}
public void setSize(int width, int height) {
synchronized(holder) {
this.width = width;
this.height = height;
}
}
private void doDraw(Canvas c) {
c.drawCircle(100.0f, 50.0f, 20.0f, paint);
}
@Override public void run() {
Canvas c = null;
try {
c = holder.lockCanvas();
synchronized(holder) {
doDraw(c);
}
} finally {
holder.unlockCanvasAndPost(c);
}
}
}
public GameView(Context context) {
super(context);
getHolder().addCallback(this);
thread = new GameThread(getHolder(), context);
}
@Override
protected void onDraw(Canvas canvas) {
Paint paint = new Paint();
paint.setARGB(255, 255, 0, 0);
canvas.drawCircle(50.0f, 50.0f, 50.0f, paint);
}
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width,
int height) {
logger.info("SurfaceChanged(w={}, h={})", width, height);
thread.setSize(width, height);
}
@Override
public void surfaceCreated(SurfaceHolder holder) {
logger.info("SurfaceCreated()");
thread.start();
}
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
logger.info("SurfaceDestroyed()");
// TODO: Stop thread.
}
}
|