如何在activity时间在运行一步步绘制线条位图
How to draw line bitmap step by step at run time in the activity
我有画线的示例代码。我需要在 运行 时间内逐点画线。但是现在我在执行后只显示了 activity。但是,我需要开始 activity 并逐点显示线。
示例代码
public class MainActivity extends ActionBarActivity {
ImageView drawingImageView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
drawingImageView = (ImageView) this.findViewById(R.id.DrawingImageView);
Bitmap bitmap = Bitmap.createBitmap((int) getWindowManager()
.getDefaultDisplay().getWidth(), (int) getWindowManager()
.getDefaultDisplay().getHeight(), Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
drawingImageView.setImageBitmap(bitmap);
// Line
Paint paint = new Paint();
paint.setColor(Color.rgb(255, 153, 51));
paint.setStrokeWidth(10);
int startx = 50;
int starty = 90;
int endx = 350;
int endy = 90;
while(endx>=startx) {
try {
Thread.sleep(5);
}catch (InterruptedException e){
e.printStackTrace();
}
canvas.drawLine(startx, starty, startx+1, endy, paint);
startx++;
}
}}
XML
<?xml version="1.0" encoding="utf-8"?>
<ImageView android:id="@+id/DrawingImageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
我认为您的视图中添加了线条,但 UI 没有刷新,因此在 Thread.sleep(5) 之后添加下面的线条以刷新 UI
getWindow().getDecorView().findViewById(android.R.id.content).invalidate();
或者你可以使用下面的代码 -
public class ImgDraw extends Activity {
ImageView drawingImageView;
Handler mHandlerAnimation = null;
Runnable mRunnableAnimation = null;
Canvas canvas ;
int startx = 0,starty =0,endx = 0,endy = 0;
Paint paint;
Bitmap bitmap ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_imgdraw);
drawingImageView = (ImageView)findViewById(R.id.DrawingImageView);
DisplayMetrics metrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(metrics);
int width = metrics.widthPixels;
int height = metrics.heightPixels;
bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
canvas = new Canvas(bitmap);
drawingImageView.setImageBitmap(bitmap);
// Line
paint = new Paint();
paint.setColor(Color.rgb(255, 153, 51));
paint.setStrokeWidth(10);
startx = 50;
starty = 90;
endx = 350;
endy = 90;
// canvas.drawLine(startx, starty, startx+1, endy, paint);
ImgAnimation();
}
private void ImgAnimation() {
mHandlerAnimation = new Handler();
mRunnableAnimation = new Runnable() {
public void run() {
if(endx>=startx) {
canvas.drawLine(startx, starty, startx+1, endy, paint);
startx = startx + 10;
getWindow().getDecorView().findViewById(android.R.id.content).invalidate();
}
mHandlerAnimation.postDelayed(this, 80);
}
};
mHandlerAnimation.postDelayed(mRunnableAnimation, 80);
}
}
使用下面的代码在到达 endx 位置时重新启动动画 -
private void ImgAnimation() {
mHandlerAnimation = new Handler();
mRunnableAnimation = new Runnable() {
public void run() {
if(endx>startx)
{
canvas.drawLine(startx, starty, startx+1, endy, paint);
startx = startx + 1;
getWindow().getDecorView().findViewById(android.R.id.content).invalidate();
}
else
{
bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
canvas = new Canvas(bitmap);
drawingImageView.setImageBitmap(bitmap);
startx = 50;
}
mHandlerAnimation.postDelayed(this, 80);
}
};
mHandlerAnimation.postDelayed(mRunnableAnimation, 80);
}
我有画线的示例代码。我需要在 运行 时间内逐点画线。但是现在我在执行后只显示了 activity。但是,我需要开始 activity 并逐点显示线。
示例代码
public class MainActivity extends ActionBarActivity {
ImageView drawingImageView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
drawingImageView = (ImageView) this.findViewById(R.id.DrawingImageView);
Bitmap bitmap = Bitmap.createBitmap((int) getWindowManager()
.getDefaultDisplay().getWidth(), (int) getWindowManager()
.getDefaultDisplay().getHeight(), Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
drawingImageView.setImageBitmap(bitmap);
// Line
Paint paint = new Paint();
paint.setColor(Color.rgb(255, 153, 51));
paint.setStrokeWidth(10);
int startx = 50;
int starty = 90;
int endx = 350;
int endy = 90;
while(endx>=startx) {
try {
Thread.sleep(5);
}catch (InterruptedException e){
e.printStackTrace();
}
canvas.drawLine(startx, starty, startx+1, endy, paint);
startx++;
}
}}
XML
<?xml version="1.0" encoding="utf-8"?>
<ImageView android:id="@+id/DrawingImageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
我认为您的视图中添加了线条,但 UI 没有刷新,因此在 Thread.sleep(5) 之后添加下面的线条以刷新 UI
getWindow().getDecorView().findViewById(android.R.id.content).invalidate();
或者你可以使用下面的代码 -
public class ImgDraw extends Activity {
ImageView drawingImageView;
Handler mHandlerAnimation = null;
Runnable mRunnableAnimation = null;
Canvas canvas ;
int startx = 0,starty =0,endx = 0,endy = 0;
Paint paint;
Bitmap bitmap ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_imgdraw);
drawingImageView = (ImageView)findViewById(R.id.DrawingImageView);
DisplayMetrics metrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(metrics);
int width = metrics.widthPixels;
int height = metrics.heightPixels;
bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
canvas = new Canvas(bitmap);
drawingImageView.setImageBitmap(bitmap);
// Line
paint = new Paint();
paint.setColor(Color.rgb(255, 153, 51));
paint.setStrokeWidth(10);
startx = 50;
starty = 90;
endx = 350;
endy = 90;
// canvas.drawLine(startx, starty, startx+1, endy, paint);
ImgAnimation();
}
private void ImgAnimation() {
mHandlerAnimation = new Handler();
mRunnableAnimation = new Runnable() {
public void run() {
if(endx>=startx) {
canvas.drawLine(startx, starty, startx+1, endy, paint);
startx = startx + 10;
getWindow().getDecorView().findViewById(android.R.id.content).invalidate();
}
mHandlerAnimation.postDelayed(this, 80);
}
};
mHandlerAnimation.postDelayed(mRunnableAnimation, 80);
}
}
使用下面的代码在到达 endx 位置时重新启动动画 -
private void ImgAnimation() {
mHandlerAnimation = new Handler();
mRunnableAnimation = new Runnable() {
public void run() {
if(endx>startx)
{
canvas.drawLine(startx, starty, startx+1, endy, paint);
startx = startx + 1;
getWindow().getDecorView().findViewById(android.R.id.content).invalidate();
}
else
{
bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
canvas = new Canvas(bitmap);
drawingImageView.setImageBitmap(bitmap);
startx = 50;
}
mHandlerAnimation.postDelayed(this, 80);
}
};
mHandlerAnimation.postDelayed(mRunnableAnimation, 80);
}