时间:2021-05-20
ImageView设置手指滑动缩放效果,具体实现步骤大家通过本文学习下吧!
实现步骤
1, imageview设置scaletype为 android:scaleType=”matrix”
2, 设置imageview的setOnTouchListener,重写里面的代码
3, 新建一个matrix,
matrix.postScale(scale,scale,缩放中心,缩放中心); image.setImageMatrix(matrix);这样image的大小就会改变了.
需要注意的几点是 imageview一定要设置scaletype为matrix,否则图片不能进行缩放.而且Bitmap也可以通过Matrix改变大小.
也可以用自定义控件imageview,重写里面的onTouchEvent,本文就是用的自定义控件得到方式实现的.
代码
自定义控件的代码,主要是重写的onTouchEvent的代码
package com.test.administrator.imageviewscale;import android.content.Context;import android.graphics.Matrix;import android.graphics.PointF;import android.renderscript.Float2;import android.renderscript.Float4;import android.util.AttributeSet;import android.util.FloatMath;import android.view.MotionEvent;import android.widget.ImageView;/** * Created by Administrator on 2016/3/21. */public class MyImageView extends ImageView {private PointF centerPoint;private float firstdistance;private Matrix matrix;public MyImageView(Context context) {super(context);initParams();}private void initParams() {matrix = new Matrix();setImageMatrix(matrix);}public MyImageView(Context context, AttributeSet attrs) {super(context, attrs);initParams();}public MyImageView(Context context, AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);initParams();}@Overridepublic boolean onTouchEvent(MotionEvent event) {int count = event.getPointerCount();if(count == 1){switch (event.getAction()){case MotionEvent.ACTION_DOWN:System.out.println("actiondown 1----");break;case MotionEvent.ACTION_MOVE:System.out.println("actionmove 1----");break;case MotionEvent.ACTION_UP:System.out.println("actionup 1----");break;default:break;}}else if(count == 2){switch (event.getAction()&MotionEvent.ACTION_MASK){case MotionEvent.ACTION_POINTER_DOWN: firstdistance = getDistance(event);centerPoint = getCenterPoint(event);System.out.println("actiondown 2===");break;case MotionEvent.ACTION_MOVE:float distance = getDistance(event);float scale = distance / firstdistance;matrix.postScale(scale,scale,centerPoint.x,centerPoint.y);setImageMatrix(matrix);System.out.println(scale + "====");firstdistance = distance;System.out.println("actionmove 2===");break;case MotionEvent.ACTION_UP:break;default:break;}}return true;}/** * 获取两个点的中心点坐标 * @param event */private PointF getCenterPoint(MotionEvent event) {PointF point = new PointF();point.x = (event.getX()+event.getX(1))/2;point.y = (event.getY()+event.getY(1))/2;return point;}/** * 两根手指时手指间的距离 * @param event */private float getDistance(MotionEvent event) {float x1 = event.getX();float y1 = event.getY();float x2 = event.getX(1);float y2 = event.getY(1);float distance = (float) Math.sqrt((x1 - x2)*(x1 - x2)+(y1 - y2)*(y1- y2));return distance;}}imageview的代码
<com.test.administrator.imageviewscale.MyImageViewandroid:id="@+id/iv"android:layout_width="match_parent"android:layout_height="match_parent"android:focusable="true"android:clickable="true"android:scaleType="matrix" android:src="@drawable/qq" />总结
以上所述是小编给大家介绍的Android通过ImageView设置手指滑动控件缩放,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了Android自定义星星可滑动评分控件的具体方法,供大家参考,具体内容如下此控件通过线性布局结合ImageView来实现。具有展示分数,滑动
概述:通过自定义ImageView控件,在xml布局里面调用自定的组件实现图片的缩放。/***自定义的ImageView控制,可对图片进行多点触控缩放和拖动**
为什么要对Android中的图片进行采样缩放呢?是为了更加高效的加载Bitmap。假设通过imageView来显示图片,很多时候ImageView并没有图片的原
本文实例讲述了Android开发之imageView图片按比例缩放的实现方法。分享给大家供大家参考,具体如下:android:scaleType可控制图片的缩放
本文实例讲述了Android控件之ImageView用法。分享给大家供大家参考。具体如下:ImageView控件是一个图片控件,负责显示图片。以下模拟手机图片查