android 手势缩放图片框架

   //图片手势放大
    第一个ImageViewTouch 只支持图片放大和缩小位置不会变动
    compile 'it.sephiroth.android.library.imagezoom:imagezoom:+'

    第二个PhotoView 可以拖动 缩放 图片旋转 但是无法设置图片默认大小
    compile 'com.bm.photoview:library:1.4.1'

    
  在ViewPager中的代码  代码不多自己看
**
 * Created by Administrator on 2016/10/17.
 */
public class ImagePagerAdapter extends PagerAdapter {
    List<String> imageUrls;
    Activity context;
    private ImageView imageView;

    public ImagePagerAdapter(Context context, List<String> imageUrls) {
        this.context = (Activity) context;
        this.imageUrls = imageUrls;
    }

    @Override
    public int getCount() {
        return imageUrls.size();
    }

    @Override
    public boolean isViewFromObject(View view, Object object) {

        return view == object;
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView((View) object);
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
//        imageView = new ImageView(context);
        //不带旋转只能缩放不带回弹
//        imageView = new ImageViewTouch(context,null);
//        PhotoView photoView = new PhotoView(context);
        // 启用图片缩放功能
//        photoView.enable();

        LayoutInflater inflater = LayoutInflater.from(context);
        View view = inflater.inflate(R.layout.big_image_layout, null);
        //可以旋转图片,可以缩放图片,有弹性
        PhotoView photoView = (PhotoView) view.findViewById(R.id.big_image_photoview);
        photoView.enable();

        ImageLoader.getInstance().displayImage(imageUrls.get(position), photoView);
//        Picasso.with(context).load(imageUrls.get(position)).into(imageView);
        container.addView(photoView);
        photoView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                context.finish();
            }
        });
        return photoView;
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Android 应用程序中实现手势缩放图片,您可以使用 Android 框架提供的 GestureDetector 和 ScaleGestureDetector 类。下面是一些实现步骤: 1. 在布局文件中添加一个 ImageView,用于显示图片。 2. 在 Activity 中获取 ImageView 的引用,并创建 GestureDetector 和 ScaleGestureDetector 对象。 3. 在 ImageView 上注册触摸事件监听器,并在监听器中处理手势事件。具体来说,您需要实现以下方法: a. onTouchEvent(MotionEvent event):在此方法中,您需要将 MotionEvent 对象传递给 GestureDetector 和 ScaleGestureDetector 对象,并根据手势类型调用相应的方法。 b. onDown(MotionEvent event):在此方法中,您需要返回 true,以指示您要处理后续的事件。 c. onScroll(MotionEvent event1, MotionEvent event2, float distanceX, float distanceY):在此方法中,您需要计算手势滑动的距离,并将其应用于 ImageView 的 Matrix 变换矩阵中,以实现平移效果。 d. onScale(ScaleGestureDetector detector):在此方法中,您需要获取手势缩放的比例因子,并将其应用于 ImageView 的 Matrix 变换矩阵中,以实现缩放效果。 e. onScaleBegin(ScaleGestureDetector detector):在此方法中,您需要返回 true,以指示您要处理后续的事件。 f. onScaleEnd(ScaleGestureDetector detector):在此方法中,您可以执行任何必要的清理操作。 4. 最后,您需要在 Activity 的 onCreate() 方法中启用 ImageView 的手势支持。具体来说,您需要调用以下方法: a. setClickable(true):启用 ImageView 的点击事件。 b. setScaleType(ImageView.ScaleType.MATRIX):设置 ImageView 的缩放类型为 Matrix。 c. setOnTouchListener(listener):为 ImageView 注册触摸事件监听器。 以上是手势缩放图片的基本实现步骤,您可以根据自己的需求进行相应的修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值