閲覧いただき、ありがとうございます。
今現在、Androidアプリの勉強をしております。
1画面に2つのカスタムビューを重ねて配置し、それぞれに違う画像を表示しております。
ピンチイン・ピンチアウトによって、2つの画像が一緒に拡大・縮小されるようにしたいのですが、今のコードのままだと、片方しか拡大・縮小されません。
どうすれば実装できるか、教えていただけませんでしょうか?
よろしくお願いいたします。
lang
1import android.content.Context; 2import android.graphics.Bitmap; 3import android.graphics.BitmapFactory; 4import android.graphics.Canvas; 5import android.util.AttributeSet; 6import android.util.Log; 7import android.view.MotionEvent; 8import android.view.ScaleGestureDetector; 9import android.view.View; 10import java.io.InputStream; 11 12public class ZoomFrameStr extends View { 13private Bitmap mBitmap; 14private ScaleGestureDetector mScaleDetector; 15private float mScaleFactor = 1.0f; 16 17public ZoomFrameStr(Context context, AttributeSet attrs){ 18super(context, attrs); 19 20try { 21InputStream is = getResources().getAssets() 22.open("str.png"); 23mBitmap = BitmapFactory.decodeStream(is); 24} catch (Exception e) { 25 26} 27mScaleDetector = new ScaleGestureDetector(context, 28new ScaleGestureDetector.SimpleOnScaleGestureListener() { 29@Override 30public boolean onScale(ScaleGestureDetector detector) { 31mScaleFactor *= detector.getScaleFactor(); 32invalidate(); 33return true; 34} 35}); 36} 37 38protected void onDraw(Canvas canvas) { 39canvas.save(); 40canvas.scale(mScaleFactor, mScaleFactor); 41canvas.drawBitmap(mBitmap, 0, 0, null); 42canvas.restore(); 43} 44 45@Override 46public boolean onTouchEvent(MotionEvent ev) { 47mScaleDetector.onTouchEvent(ev); 48return true; 49} 50} 51 52class ZoomFrameImg extends View { 53 54private Bitmap bitmapImg; 55private ScaleGestureDetector scaleDetectorImg; 56private float scaleFactorImg = 1.0f; 57 58public ZoomFrameImg(Context context, AttributeSet attrs){ 59super(context, attrs); 60 61try { 62InputStream is = getResources().getAssets() 63.open("img.png"); 64bitmapImg = BitmapFactory.decodeStream(is); 65} catch (Exception e) { 66 67} 68 69scaleDetectorImg = new ScaleGestureDetector(context, 70new ScaleGestureDetector.SimpleOnScaleGestureListener() { 71@Override 72public boolean onScale(ScaleGestureDetector detector) { 73scaleFactorImg *= detector.getScaleFactor(); 74invalidate(); 75return true; 76} 77}); 78 79} 80 81protected void onDraw(Canvas canvas) { 82canvas.save(); 83canvas.scale(scaleFactorImg, scaleFactorImg); 84 85int canvasX = canvas.getWidth(); 86int canvasY = canvas.getHeight(); 87int bitmapX = bitmapImg.getWidth(); 88int bitmapY = bitmapImg.getHeight(); 89canvas.drawBitmap(bitmapImg, canvasX-bitmapX, canvasY-bitmapY, null); 90canvas.restore(); 91 92 93} 94 95@Override 96public boolean onTouchEvent(MotionEvent ev) { 97scaleDetectorImg.onTouchEvent(ev); 98return true; 99} 100}
あなたの回答
tips
プレビュー