android多点触控代码,在Android中使用多点触控旋转和缩放

我想在多点触摸事件中旋转和缩放图像,

我能够拖动,缩放图像,但我无法理解图像的旋转.

我面临问题所以请尽快帮助我.

我的代码在那里

public class Touch extends Activity implements OnTouchListener {

private static final String TAG = "Touch";

// These matrices will be used to move and zoom image

Matrix matrix = new Matrix();

Matrix matrix1 = new Matrix();

Matrix savedMatrix = new Matrix();

Matrix savedMatrix2 = new Matrix();

// We can be in one of these 3 states

static final int NONE = 0;

static final int DRAG = 1;

static final int ZOOM = 2;

int mode = NONE;

float oldscale =0;

// Remember some things for zooming

PointF start = new PointF();

PointF mid = new PointF();

float oldDist = 1f;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

ImageView view = (ImageView) findViewById(R.id.imageView2);

view.setOnTouchListener(this);

ImageView view1 = (ImageView) findViewById(R.id.imageView2);

view1.setOnTouchListener(this);

// ...

// Work around a Cupcake bug

matrix.setTranslate(1f, 1f);

matrix1.setTranslate(1f, 1f);

view.setImageMatrix(matrix);

view1.setImageMatrix(matrix1);

}

@Override

public boolean onTouch(View v, MotionEvent rawEvent) {

WrapMotionEvent event = WrapMotionEvent.wrap(rawEvent);

// ...

ImageView view = (ImageView) v;

// Dump touch event to log

dumpEvent(event);

// Handle touch events here...

double r = Math.atan2(event.getX() - 400 / 2,

400 / 2 - event.getY());

int rotation = (int) Math.toDegrees(r);

float newRot = new Float(rotation);

switch (event.getAction() & MotionEvent.ACTION_MASK) {

case MotionEvent.ACTION_DOWN:

savedMatrix.set(matrix);

start.set(event.getX(), event.getY());

Log.d(TAG, "mode=DRAG");

mode = DRAG;

break;

case MotionEvent.ACTION_POINTER_DOWN:

oldDist = spacing(event);

Log.d(TAG, "oldDist=" + oldDist);

if (oldDist > 10f) {

savedMatrix.set(matrix);

midPoint(mid, event);

mode = ZOOM;

Log.d(TAG, "mode=ZOOM");

}

break;

case MotionEvent.ACTION_UP:

case MotionEvent.ACTION_POINTER_UP:

mode = NONE;

Log.d(TAG, "mode=NONE");

break;

case MotionEvent.ACTION_MOVE:

matrix.postRotate(15);

if (mode == DRAG) {

// ...

matrix.set(savedMatrix);

matrix.postTranslate(event.getX() - start.x,

event.getY() - start.y);

}

else if (mode == ZOOM) {

float newDist = spacing(event);

Log.d(TAG, "newDist=" + newDist);

if (newDist > 10f) {

matrix.set(savedMatrix);

float scale = newDist / oldDist;

matrix.postScale(scale, scale, mid.x, mid.y);

Log.e("scale | mid.x | mid.y", scale + " " +mid.x + " " + mid.y);

}

}

break;

}

view.setImageMatrix(matrix);

return true; // indicate event was handled

}

/** Show an event in the LogCat view, for debugging */

private void dumpEvent(WrapMotionEvent event) {

// ...

String names[] = { "DOWN", "UP", "MOVE", "CANCEL", "OUTSIDE",

"POINTER_DOWN", "POINTER_UP", "7?", "8?", "9?" };

StringBuilder sb = new StringBuilder();

int action = event.getAction();

int actionCode = action & MotionEvent.ACTION_MASK;

sb.append("event ACTION_").append(names[actionCode]);

if (actionCode == MotionEvent.ACTION_POINTER_DOWN

|| actionCode == MotionEvent.ACTION_POINTER_UP) {

sb.append("(pid ").append(

action >> MotionEvent.ACTION_POINTER_ID_SHIFT);

sb.append(")");

}

sb.append("[");

for (int i = 0; i < event.getPointerCount(); i++) {

sb.append("#").append(i);

sb.append("(pid ").append(event.getPointerId(i));

sb.append(")=").append((int) event.getX(i));

sb.append(",").append((int) event.getY(i));

if (i + 1 < event.getPointerCount())

sb.append(";");

}

sb.append("]");

Log.d(TAG, sb.toString());

}

/** Determine the space between the first two fingers */

private float spacing(WrapMotionEvent event) {

// ...

float x = event.getX(0) - event.getX(1);

float y = event.getY(0) - event.getY(1);

return FloatMath.sqrt(x * x + y * y);

}

/** Calculate the mid point of the first two fingers */

private void midPoint(PointF point, WrapMotionEvent event) {

// ...

float x = event.getX(0) + event.getX(1);

float y = event.getY(0) + event.getY(1);

point.set(x / 2, y / 2);

}

}

所以请为我提供这个问题的确切解决方案.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值