2014-02-27 33 views
3

我有两个贴纸,我希望两个贴纸都能移动缩放旋转。当我将ontouchlistener添加到两个贴纸时,都会执行这些操作。如何在同一个布局中移动两个贴纸android

这就是我设置监听

ImageView crown = (ImageView) root.findViewById(R.id.crown); 
    crown.setOnTouchListener(this); 

    ImageView crown1 = (ImageView) root.findViewById(R.id.crown1); 
    crown1.setOnTouchListener(this); 

我的布局,这是xml文件

<FrameLayout 
     android:id="@+id/editpic" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_marginBottom="60dp" 
     android:layout_marginTop="40dp" 
     android:background="@drawable/thumb" > 

    <ImageView 
      android:id="@+id/crown" 
      android:layout_width="fill_parent" 
      android:layout_height="fill_parent" 
      android:scaleType="matrix" 
      android:src="@drawable/crown1" > 
     </ImageView> 

     <ImageView 
      android:id="@+id/crown1" 
      android:layout_width="fill_parent" 
      android:layout_height="fill_parent" 
      android:scaleType="matrix" 
      android:src="@drawable/crown2" > 
     </ImageView> 

    </FrameLayout> 

让我知道如果任何人有这个解决方案的代码。

更新:

public boolean onTouch(View v, MotionEvent event) { 
     Log.e(TAG, "onTouch !!"); 
     ImageView view = (ImageView) v; 



     // Handle touch events here... 
     switch (event.getAction() & MotionEvent.ACTION_MASK) { 
     case MotionEvent.ACTION_DOWN: 
      savedMatrix.set(matrix); 
      start.set(event.getX(), event.getY()); 
      mode = DRAG; 
      lastEvent = null; 
      break; 
     case MotionEvent.ACTION_POINTER_DOWN: 
      oldDist = spacing(event); 
      if (oldDist > 10f) { 
       savedMatrix.set(matrix); 
       midPoint(mid, event); 
       mode = ZOOM; 
      } 
      lastEvent = new float[4]; 
      lastEvent[0] = event.getX(0); 
      lastEvent[1] = event.getX(1); 
      lastEvent[2] = event.getY(0); 
      lastEvent[3] = event.getY(1); 
      d = rotation(event); 
      break; 
     case MotionEvent.ACTION_UP: 
     case MotionEvent.ACTION_POINTER_UP: 
      mode = NONE; 
      lastEvent = null; 
      break; 
     case MotionEvent.ACTION_MOVE: 
      if (mode == DRAG) { 
       // ... 
       matrix.set(savedMatrix); 
       matrix.postTranslate(event.getX() - start.x, event.getY() 
         - start.y); 
      } else if (mode == ZOOM && event.getPointerCount() == 2) { 
       float newDist = spacing(event); 
       matrix.set(savedMatrix); 
       if (newDist > 10f) { 
        float scale = newDist/oldDist; 
        matrix.postScale(scale, scale, mid.x, mid.y); 
       } 
       if (lastEvent != null) { 
        newRot = rotation(event); 
        float r = newRot - d; 
        matrix.postRotate(r, view.getMeasuredWidth()/2, 
          view.getMeasuredHeight()/2); 
       } 
      } 
      break; 
     } 

     view.setImageMatrix(matrix); 

     return true; 
    } 

    private float rotation(MotionEvent event) { 
     double delta_x = (event.getX(0) - event.getX(1)); 
     double delta_y = (event.getY(0) - event.getY(1)); 
     double radians = Math.atan2(delta_y, delta_x); 

     return (float) Math.toDegrees(radians); 
    } 

    private float spacing(MotionEvent event) { 
     float x = event.getX(0) - event.getX(1); 
     float y = event.getY(0) - event.getY(1); 
     return FloatMath.sqrt(x * x + y * y); 
    } 

    private void midPoint(PointF point, MotionEvent event) { 
     float x = event.getX(0) + event.getX(1); 
     float y = event.getY(0) + event.getY(1); 
     point.set(x/2, y/2); 
    } 
+0

'onTouch()'的代码在哪里? –

+0

检查更新..我已经添加了代码 –

回答

1

你必须在条件onTouch()方法中添加代码不同viewId

尝试这样

@Override 
public boolean onTouch(View v, MotionEvent event) { 
    // TODO Auto-generated method stub 
    switch (v.getId()) { 

    case R.id.crown: 
     // put code for 1st crown touch 
     break; 
    case R.id.crown1: 
     // put code for 2nd crown touch 
     break; 

    default: 
     break; 
    } 
    return true; 
} 
+0

返回false不工作.. –

+0

我已经给imageview参数作为fillparent,所以只有一个图像做操作..但如果给定包装内容图像不移动在整个布局 –

+0

返回假不工作?意味着? –

0

是的,我知道我该死晚,但认为分享,这样它可以帮助其他人在未来..

如果你想要做移动,调整大小,缩放,旋转,在相同的布局超过2次你可以去android multi-touch controller,它简化了MotionEvent接触点API的有点混乱和不一致。

控制器还支持捏缩放,包括跟踪屏幕坐标和对象坐标之间的转换。

控制器最近更新为支持夹捏旋转,允许您使用屏幕上的两个触摸点在物理上扭曲物体。

控制器可以非常容易地使用单独物体(例如一叠照片)的画布进行操作,每个物体都可以单独用单个触摸点拖动或用捏操作缩放。

相关问题