48

レイアウトにボタン、テキストビューなどが含まれています。レイアウトにピンチ ズームを実装することはできますか?

4

7 に答える 7

44

更新された回答

コードはここにあります: official-doc

時代遅れの回答

あなたに役立つかもしれない次のリンクをチェックしてください

以下のリンクに最適な例が記載されており、要件を満たすようにリファクタリングできます。

  1. ピンチズームジェスチャーの実装

  2. アンドロイドピンチ

  3. GestureDetector.SimpleOnGestureListener

于 2011-03-21T10:04:06.963 に答える
38

Android 2.2+ (api level8) の場合、ScaleGestureDetector を使用できます。

メンバーが必要です:

private ScaleGestureDetector mScaleDetector;

コンストラクター (または onCreate()) に次を追加します。

mScaleDetector = new ScaleGestureDetector(context, new OnScaleGestureListener() {
    @Override
    public void onScaleEnd(ScaleGestureDetector detector) {
    }
    @Override
    public boolean onScaleBegin(ScaleGestureDetector detector) {
        return true;
    }
    @Override
    public boolean onScale(ScaleGestureDetector detector) {
        Log.d(LOG_KEY, "zoom ongoing, scale: " + detector.getScaleFactor());
        return false;
    }
});

onTouchEvent をオーバーライドします。

@Override
public boolean onTouchEvent(MotionEvent event) {
    mScaleDetector.onTouchEvent(event);
    return true;
}

ビューを手動で描画する場合、おそらく onScale() で倍率をメンバーに格納してから、invalidate() を呼び出し、onDraw() で描画するときに倍率を使用します。それ以外の場合は、onScale() でフォント サイズなどを直接変更できます。

于 2012-07-30T13:45:56.980 に答える
16

このチュートリアルTextViewを使用して、 にピンチ ズームを実装しました。結果のコードは次のとおりです。

private GestureDetector gestureDetector;
private View.OnTouchListener gestureListener;

そして onCreate() で:

    // Zoom handlers
    gestureDetector = new GestureDetector(new MyGestureDetector());
    gestureListener = new View.OnTouchListener() {

        // We can be in one of these 2 states
        static final int NONE = 0;
        static final int ZOOM = 1;
        int mode = NONE;

        static final int MIN_FONT_SIZE = 10;
        static final int MAX_FONT_SIZE = 50;

        float oldDist = 1f;

        @Override
        public boolean onTouch(View v, MotionEvent event) {
            TextView textView = (TextView) findViewById(R.id.text);

            switch (event.getAction() & MotionEvent.ACTION_MASK) {
                case MotionEvent.ACTION_POINTER_DOWN:
                    oldDist = spacing(event);
                    Log.d(TAG, "oldDist=" + oldDist);
                    if (oldDist > 10f) {
                       mode = ZOOM;
                       Log.d(TAG, "mode=ZOOM" );
                    }
                    break;
                case MotionEvent.ACTION_POINTER_UP:
                    mode = NONE;
                    break;
                case MotionEvent.ACTION_MOVE:
                    if (mode == ZOOM) {
                        float newDist = spacing(event);
                        // If you want to tweak font scaling, this is the place to go.
                        if (newDist > 10f) {
                            float scale = newDist / oldDist;

                            if (scale > 1) {
                                scale = 1.1f;
                            } else if (scale < 1) {
                                scale = 0.95f;
                            }

                            float currentSize = textView.getTextSize() * scale;
                            if ((currentSize < MAX_FONT_SIZE && currentSize > MIN_FONT_SIZE)
                                    ||(currentSize >= MAX_FONT_SIZE && scale < 1)
                                    || (currentSize <= MIN_FONT_SIZE && scale > 1)) {
                                textView.setTextSize(TypedValue.COMPLEX_UNIT_PX, currentSize);
                            }
                        }
                    }
                    break;
                }
            return false;
        }

マジック定数 1.1 と 0.95 は経験的に選択されました (scaleこの目的で変数を使用すると、私のTextView振る舞いが少し奇妙になりました)。

于 2011-03-21T10:23:35.887 に答える
5

仕事をし、私にとって完璧に機能するこのプロジェクトもあります: https://github.com/chrisbanes/PhotoView

于 2013-02-25T15:52:50.483 に答える
4

ハニカムでは, API レベル 11, 可能です. ピボット ポイントで setScalaX と setScaleY を使用できます
ここで説明しまし
た ビューを完全にズームする
ピンチ ズームして完全に表示します

于 2011-03-24T10:20:08.273 に答える
1

Android 2.1以降をサポートする基本的なピンチズームのプロジェクトを作成しました

ここで入手可能

于 2012-03-10T01:59:26.060 に答える