하나의 프레임레이아웃 안에 이미지뷰 2개를 위 아래로 셋팅하고


각각의 이미지뷰를 따로따로 확대, 축소 할 수 있도록 onTouch 를 구현하려고 하는데요


이미지뷰 2개의 ScaleType 을 FitXY 로 했는데 확대 축소가 안되더라구요..


그래서 matrix 로 바꿨더니 확대 축소는 되는데 하나의 이미지뷰만 확대 축소가 되네요..


제가 하고싶은 것은 터치점을 구분해서 위, 아래에 배치된 이미지뷰를 각각 따로 확대 축소가 되도록 하고싶은데..


이것저것 다 해보았는데..안되네여..ㅠ 도와주세요..ㅠㅠ 


오늘로서 4일째 삽질입니다..흐흑..ㅠㅠㅠㅠ 


혹시 몰라서 소스도 첨부하겠습니다 ㅠ


아래의 소스는 ontouch 메소드 안에서 2개의 이미지뷰를 ID 값으로 구분해서 

이벤트가 발생하도록 if 문으로 분기를 시켜놨는데 .. 하나의 이미지만 확대 축소가 되네여..ㅠ


public class Testresult extends Activity implements OnTouchListener{

private Bitmap[] mBitmap = new Bitmap[2];

private ImageView iv01;

private ImageView iv02;

private FrameLayout result_frame;

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

Matrix matrix = new Matrix();

Matrix savedMatrix = 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;

// Remember some things for zooming

PointF start = new PointF();

PointF mid = new PointF();

float oldDist = 1f;

ImageView iv ;

@Override

protected void onCreate(Bundle savedInstanceState) {

// TODO Auto-generated method stub

super.onCreate(savedInstanceState);

setContentView(R.layout.testresult);

Log.d("result_test", "in........");

result_frame = (FrameLayout)findViewById(R.id.frameMain);

// sdcard에서 이미지 읽어오기

        mBitmap[0] = BitmapFactory.decodeFile("/sdcard/yun/face.png");       

        mBitmap[1] = BitmapFactory.decodeFile("/sdcard/yun/body.png");

        

        iv01 = (ImageView)findViewById(R.id.imageView1);

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

        

        iv01.setImageBitmap(mBitmap[0]);

        iv02.setImageBitmap(mBitmap[1]);

        result_frame.bringChildToFront(iv01);

        

        iv01.setOnTouchListener(this);

        iv02.setOnTouchListener(this);

}



@Override

public boolean onTouch(View v, MotionEvent event) {

// TODO Auto-generated method stub

ImageView view = (ImageView) v;

// mBitmap = BitmapFactory.decodeResource(null, R.drawable.hair_01);  

// Dump touch event to log

dumpEvent(event);


// Handle touch events here...

if(v.getId()==R.id.imageView1) {

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

case MotionEvent.ACTION_DOWN:

savedMatrix.set(matrix);

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

mode = DRAG;

break;

case MotionEvent.ACTION_POINTER_DOWN:

oldDist = spacing(event);

if (oldDist > 10f) {

savedMatrix.set(matrix);

midPoint(mid, event);

mode = ZOOM;

}

break;

case MotionEvent.ACTION_UP:

case MotionEvent.ACTION_POINTER_UP:

mode = NONE;

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) {

float newDist = spacing(event);

if (newDist > 10f) {

matrix.set(savedMatrix);

float scale = newDist / oldDist;

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

}

}

break;

}

}

else if(v.getId()==R.id.imageView2){

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

case MotionEvent.ACTION_DOWN:

savedMatrix.set(matrix);

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

mode = DRAG;

break;

case MotionEvent.ACTION_POINTER_DOWN:

// 두 손가락 사이에 거리를 계산 

oldDist = spacing(event);

if (oldDist > 10f) {

savedMatrix.set(matrix);

midPoint(mid, event);

mode = ZOOM;

}

break;

case MotionEvent.ACTION_UP:

case MotionEvent.ACTION_POINTER_UP:

mode = NONE;

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) {

float newDist = spacing(event);

if (newDist > 10f) {

matrix.set(savedMatrix);

float scale = newDist / oldDist;

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

}

}

break;

}

}

view.setImageMatrix(matrix);

return true; // indicate event was handled

}

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

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);

}

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

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);

}