レイアウトにボタン、テキストビューなどが含まれています。レイアウトにピンチ ズームを実装することはできますか?
7 に答える
更新された回答
コードはここにあります: official-doc
時代遅れの回答
あなたに役立つかもしれない次のリンクをチェックしてください
以下のリンクに最適な例が記載されており、要件を満たすようにリファクタリングできます。
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() でフォント サイズなどを直接変更できます。
このチュートリアル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
振る舞いが少し奇妙になりました)。
仕事をし、私にとって完璧に機能するこのプロジェクトもあります: https://github.com/chrisbanes/PhotoView
ハニカムでは, API レベル 11, 可能です. ピボット ポイントで setScalaX と setScaleY を使用できます
ここで説明しまし
た ビューを完全にズームする
ピンチ ズームして完全に表示します
Android 2.1以降をサポートする基本的なピンチズームのプロジェクトを作成しました
ここで入手可能