我是android的新手,所以我不知道这个问题是否是基本的。
我想每N秒在画布上绘制一个圆圈。
寻找教程,我成功在画布上绘制了一个圆。但是随后出现了问题。 如何删除以前绘制的圆圈。
我的操作方式可能不好,实际上,我只是画了另一个圆圈(但是白色)。这意味着,每次迭代我都会绘制一个白色圆圈,以擦除前一个圆圈。然后是蓝色的新圆圈。
在第一次迭代中它是完美的工作方式...但是一旦我在已经绘制了圆的地方开始绘制圆...事情就开始错误了...就像再次绘制一些先前删除的圈子再次出现。
我真的不知道该怎么解释。
您可以看到执行这种和平代码会发生什么情况。
我的游戏活动启动器
public class GameActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Float max = new Float(200.42);
ArrayList<Float> liste_test = new ArrayList<Float>();
liste_test.add(new Float(36.8));
liste_test.add(new Float(147.8));
liste_test.add(new Float(97.8));
liste_test.add(new Float(max));
liste_test.add(new Float(10));
setContentView(new ExampleSurfaceView(this,liste_test,max));
}
}
我的ExampleSurfaceView我使用列表中的“标准化”数据绘制圆。
public class ExampleSurfaceView extends SurfaceView implements SurfaceHolder.Callback {
// Le holder
SurfaceHolder mSurfaceHolder;
// Le thread dans lequel le dessin se fera
DrawingThread mThread;
int oldPosition_x;
int oldPosition_y;
ArrayList<Integer> valeurs_capteurs;
int nb_valeurs;
public ExampleSurfaceView (Context context,ArrayList<Float> donees_capteur, Float max) {
super(context);
this.valeurs_capteurs=normalise(donees_capteur,max);
this.nb_valeurs=this.valeurs_capteurs.size();
mSurfaceHolder = getHolder();
mSurfaceHolder.addCallback(this);
mThread = new DrawingThread();
}
//pour récupérer des données uniforme peu importe le capteur
public ArrayList<Integer> normalise(ArrayList<Float> donnees, Float max){
valeurs_capteurs = new ArrayList<Integer>();
for (Float donnee : donnees) {
int donnee_normalized= (int)((donnee/max)*100);
valeurs_capteurs.add(donnee_normalized);
}
return valeurs_capteurs;
}
protected void onDraw(Canvas canvas,int nb) {
//dessinez ici
super.onDraw(canvas);
Paint paint = new Paint();
paint.setStyle(Paint.Style.FILL);
int index = nb%(nb_valeurs-1);
System.out.println(index);
//On calcule une position à partir des données du capteur
int circlePositionX = 60+this.valeurs_capteurs.get(index);
int circlePositionY = 60+this.valeurs_capteurs.get(index);
//initialisation au premier draw
if(nb==0){
oldPosition_x=circlePositionX;
oldPosition_y=circlePositionY;
}
//effacer l'andien cercle
paint.setColor(Color.WHITE);
canvas.drawCircle(oldPosition_x,oldPosition_y, 50,paint);
System.out.println("Erase in "+oldPosition_x+" - "+oldPosition_y);
oldPosition_x=circlePositionX;
oldPosition_y=circlePositionY;
//dessiner le nouveau cercle
paint.setColor(Color.BLUE);
canvas.drawCircle(circlePositionX, circlePositionY, 50,paint);
System.out.println("Draw in "+circlePositionX+" - "+circlePositionY);
}
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
// Que faire quand le surface change ? (L'utilisateur tourne son téléphone par exemple)
}
@Override
public void surfaceCreated(SurfaceHolder holder) {
mThread.keepDrawing = true;
mThread.start();
}
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
mThread.keepDrawing = false;
boolean joined = false;
while (!joined) {
try {
mThread.join();
joined = true;
} catch (InterruptedException e) {}
}
}
private class DrawingThread extends Thread {
// Utilisé pour arrêter le dessin quand il le faut
boolean keepDrawing = true;
@SuppressLint("WrongCall")
@Override
public void run() {
int nb=0;
while (keepDrawing) {
Canvas canvas = null;
try {
// On récupère le canvas pour dessiner dessus
canvas = mSurfaceHolder.lockCanvas();
// On s'assure qu'aucun autre thread n'accède au holder
synchronized (mSurfaceHolder) {
// Et on dessine
onDraw(canvas,nb);
nb+=1;
}
} finally {
// Notre dessin fini, on relâche le Canvas pour que le dessin s'affiche
if (canvas != null)
mSurfaceHolder.unlockCanvasAndPost(canvas);
}
try {
Thread.sleep(2000);
} catch (InterruptedException e) {}
}
}
}
}
当我查看打印件时,数据似乎是逻辑的,我擦除并打印到了合适的位置...但是仍然存在问题...显然我做错了,但是我可以经过多次搜索后,才知道是什么。感谢您的协助。