Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/66.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Android View类线程在第二次迭代的循环中停止_Java_Android - Fatal编程技术网

Java Android View类线程在第二次迭代的循环中停止

Java Android View类线程在第二次迭代的循环中停止,java,android,Java,Android,这是视图类: public class Ball extends View implements Runnable { public Ball(Context context) { super(context); ActionBar.LayoutParams lp = new ActionBar.LayoutParams(500, 200); //setY(100); this.setLayoutParams(lp);

这是视图类:

public class Ball extends View implements Runnable {


    public Ball(Context context) {
        super(context);
        ActionBar.LayoutParams lp = new ActionBar.LayoutParams(500, 200);
        //setY(100);
        this.setLayoutParams(lp);
        Log.d("test", "Ball created");
        Thread t = new Thread(this);

        t.start();
    }


    public void run() {

        try {



           while (!Thread.currentThread().isInterrupted()) {

                float y = getY();

                Log.d("test", "first y: " + y);
               Log.d("test", "LINE --- LINE");
                y = y + 30;
               Log.d("test", "setting y: " + y);
                setY(y);

               Log.d("test", "before sleep");
                Thread.currentThread().sleep(1000);
               Log.d("test", "after sleep");
            }
        }
        catch(Throwable e)
        {
            Log.d("error", e.getMessage());
        }

    }

    @Override
    protected void onDraw(Canvas canvas) {

        Log.d("test", "onDraw called");
        super.onDraw(canvas);
        int x = getWidth();
        int y = getHeight();
        int radius;
        radius = 100;
        Paint paint = new Paint();
        paint.setStyle(Paint.Style.FILL);
        paint.setColor(Color.WHITE);
        canvas.drawPaint(paint);
        // Use Color.parseColor to define HTML colors
        paint.setColor(Color.parseColor("#FF0000"));

        canvas.drawRect(0, 0, this.getWidth(), this.getHeight(), paint);
        paint.setColor(Color.parseColor("#CD5C5C"));
        canvas.drawCircle(0 + radius, 0 + radius, radius, paint);
        Log.d("test", "onDraw Ended");
    }

}
在循环内部的run方法中,如果我将其更改为:

y = y;
甚至:

y = 30; //or any other number
线程继续工作,但如果代码为:

y = y + 30; // or any other number
然后在执行setY(y)之后的第二次迭代(我不知道为什么是第2次迭代)中,它停止了,没有抛出错误,我无法找到原因,有人能找到一些关于这可能是什么原因的线索吗


我只想让球每秒改变y位置

为动画目的更新数据是一种非常奇怪的方式。有这样的内置方法:
postInvalidateDelayed

@Override protected void onDraw(Canvas canvas) {
    //calculate data
    //animate it
    postInvalidateDelayed(1000 / 30);//request drawing 30 frames per second.  
}

哇,这真的很有效,但还是不知道为什么我的代码不起作用,不管怎样,谢谢