我的布局包含了按钮、文本视图等元素。是否可以在我的布局中实现双指缩放功能?
对于Android 2.2+(API level 8),您可以使用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;
}
如果您手动绘制View,则在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
表现出奇怪的行为)。
MyGestureDetector()
类。 - PraveenkumarMyGestureDetector()
在这里不相关;由于声明GestureDetector(GestureDetector.OnGestureListener listener)
,我们得出结论它是GestureDetector.OnGestureListener
的误称子类。而该类检测到的事件与缩放无关。 - 18446744073709551615MyGestureDetector
未定义,代码中的其他内容也是如此,例如spacing
,TAG
等。 - Alex我有一个非常好的开源库可以做到这一点。它是一个四个手势库,带有开箱即用的平移缩放设置。你可以在这里找到它:https://bitbucket.org/warwick/hacergestov3 或者你可以在这里下载演示应用程序:https://play.google.com/store/apps/details?id=com.WarwickWestonWright.HacerGestoV3Demo 这是一个纯画布库,因此它可以在几乎任何情况下使用。 希望这可以帮到你。