如何动态地在android中创建可拖动和可调整大小的形状

时间:2012-08-05 12:16:12

标签: android eclipse canvas draggable resize-image

我是Android的新手,我正在创建一个简单的应用程序,我从图库中选择一个图像,在图像上绘制一个矩形,用户可以在图像上的任何位置拖动并重新调整矩形的大小动态。

我的代码直到现在可以从库中加载图像并在图像上绘制一个矩形。但我不知道如何动态地拖动矩形。

public class MainActivity extends Activity   {
private static int RESULT_LOAD_IMAGE = 1;


@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    Button buttonLoadImage = (Button) findViewById(R.id.buttonLoadPicture);
    buttonLoadImage.setOnClickListener(new View.OnClickListener() {

        public void onClick(View arg0) {

            Intent i = new Intent(
                    Intent.ACTION_PICK,
                    android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);

            startActivityForResult(i, RESULT_LOAD_IMAGE);
        }
    });
}



@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    if (requestCode == RESULT_LOAD_IMAGE && resultCode == RESULT_OK && null != data) {
        Uri selectedImage = data.getData();
        String[] filePathColumn = { MediaStore.Images.Media.DATA };

        Cursor cursor = getContentResolver().query(selectedImage,
                filePathColumn, null, null, null);
        cursor.moveToFirst();

        int columnIndex = cursor.getColumnIndex(filePathColumn[0]);
        String picturePath = cursor.getString(columnIndex);
        cursor.close();

        ImageView imageView = (ImageView) findViewById(R.id.imgView);
        Bitmap bMap = BitmapFactory.decodeFile(picturePath);

        bMap = bMap.copy(Bitmap.Config.ARGB_8888 , true);

        float width = imageView.getWidth();
        float height = imageView.getHeight();

        Canvas canvas = new Canvas(bMap);
        Paint paint = new Paint();
        paint.setAntiAlias(true);
        paint.setStyle(Paint.Style.STROKE);
        paint.setStrokeWidth(4);  
        paint.setColor(Color.RED);
        canvas.drawRect(width/2+60, height/2-20, width/2-60, height/2+20, paint);

        imageView.setImageBitmap(bMap);

    }


}

}

Output

我想要的输出类似于上图。红色矩形可以由用户调整大小并拖动,然后保存图像。

1 个答案:

答案 0 :(得分:3)

您需要创建一个表示您绘制的矩形的自定义视图。在onDraw(...)中,您可以设置矩形的Paint及其初始大小。现在的概念是,当它被触及它的角落并被拖动时,当用户从屏幕上抬起他们的手指时,矩形的x和y坐标将改变。我将在Android开发人员指南中向您推荐this,了解如何创建自定义视图。而且this在这里是一个类似的问题帖子,可能会给你一些想法。