zoukankan      html  css  js  c++  java
  • Android图片的缩放效果

    一.概述

    Android 图片要实现:手势滑动,双击变大,多点触控的效果. 其实是有一定难度的,我们需要用Matrix ,GestureDetector 等等需要完成一个复杂的逻辑才能实现,然而今天我要说的并不是这种方法,而是一个第三方库Photoview,它使得完成图片缩放工作只需要3-5行代码就搞定了. 是不是很爽...

    二.使用方法

    github:https://github.com/chrisbanes/PhotoView

    如果用AS需在引入如下库文件(目前是最新的):

    dependencies {
      compile 'com.commit451:PhotoView:1.2.4'
    }
    配置就是这么简单

    三.代码演示

    public class MainActivity extends AppCompatActivity {
        private PhotoView photoView;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            initialize();
            showData();
        }
        private void showData() {
            //加载图片
            Glide.with(this)
                    .load(R.mipmap.temp)
                    .asBitmap()
                    .into(photoView);
        }
        private void initialize() {
            photoView = (PhotoView) findViewById(R.id.photoView);
        }
    }
    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="vertical" android:layout_width="match_parent"
        android:layout_height="match_parent">
    
        <uk.co.senab.photoview.PhotoView
            android:id="@+id/photoView"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </LinearLayout>

    运行效果如下,支持 上下左右拖动,直接 双击变大, 再次双击全屏显示, 再次双击还原 等效果, 支持多点触摸缩放,任意滑动

    上面代码用到了Glide显示图片,所以项目需引入Glide库: 

    compile 'com.github.bumptech.glide:glide:3.6.1'
    关于Glide的详情介绍参考:

  • 相关阅读:
    Linux下Socket编程之地址结构
    矫正Fedora 8中livna源Nvidia驱动托付关连
    Firefox3 RC1颁布各种新特征发扬阐发更平定
    Fedora 8中完全开启compizfusion特效
    编译安置gsopcast SVN版
    Sopcast for linux更新至3.01!
    措置惩罚Fedora 8中的装备权限标题成绩
    vsftp假造用户设置(Ubuntu8.04)
    QQ2008贺岁版 on FedoraBy wine 0.9.58
    vFU NET
  • 原文地址:https://www.cnblogs.com/android-zcq/p/5138330.html
Copyright © 2011-2022 走看看