PhotoPicker
Introduction: 微信 ui 版的 PhotoPicker,最大程度地简化使用.
Tags:
图片选择-注: 此项目已转移至本人主账号下:在那里继续更新
注: 图片选择/拍照->裁剪->压缩 整个流程的操作已经串起到下面的库中
本项目 fork 自photoPicker
参考微信的图片选择 ui,对原项目 photoPicker 进行改写。
标题栏:去除难用的 toolbar,改成自定义的 titlebar。高度 44dp,标题居中,颜色引用 activity 主题设置 colorPrimary.可以自己设置.
底部弹出框:原项目两边有间距,现改成铺满屏幕宽度弹出
默认图片更改成黑灰色背景,让滑动时图片闪动不会那么突兀
图片 item 再加一层蒙版,未选择状态时,由中间向上下浅黑透明渐变,选择状态下,颜色变黑。
选择框: 未选状态下由原来的不透明变成透明,选中状态时图标颜色使用微信的绿色。
demo apk:见项目根目录下 demo.apk
更新:
1.0.1: 将图片选择后显示的组件封装了一下,提供了最简化使用的 api 该组件既可以用于图片选择后的显示,也可以用于单纯的多图显示,只要设置类型就行
1.0.2
单纯显示图片时,由原来的 4 列改成 3 列
修复图片预览时删到最后一张时的数组角标越界 bug
效果图
文件夹切换:底部弹窗
图片预览:
封装好的图片显示组件:(上方是图片选择,下面是只显示图片的组件)
Usage
gradle
Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
Step 2. Add the dependency
dependencies {
compile 'com.github.glassLake:PhotoPicker:1.0.3'
}
使用完全封装好的组件
xml:
<me.iwf.photopicker.widget.MultiPickResultView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/recycler_view"/>
选择图片并显示图片:
recyclerView = (MultiPickResultView) findViewById(R.id.recycler_view);
recyclerView.init(this,MultiPickResultView.ACTION_SELECT,null);
//onActivityResult 里一行代码回调
recyclerView.onActivityResult(requestCode,resultCode,data);
只显示图片
//可以初始化时传入地址
recyclerViewShowOnly.init(this,MultiPickResultView.ACTION_ONLY_SHOW,pathslook);
//也可以后续设置地址:
recyclerViewShowOnly.showPics(pathslook);
不使用显示组件,只使用选择图片的功能
Pick Photo
PhotoPickUtils.startPick(Activity context,boolean showGif,int photoCount,ArrayList<String> photos)
onActivityResult
@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
PhotoPickUtils.onActivityResult(requestCode, resultCode, data, new PhotoPickUtils.PickHandler() {
@Override
public void onPickSuccess(ArrayList<String> photos) {//已经预先做了 null 或 size 为 0 的判断
}
@Override
public void onPickFail(String error) {
Toast.makeText(MainActivity.this,error,Toast.LENGTH_LONG).show();
}
@Override
public void onCancle() {
Toast.makeText(MainActivity.this,"取消选择",Toast.LENGTH_LONG).show();
}
});
manifest
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<application
...
>
...
<activity android:name="me.iwf.photopicker.PhotoPickerActivity"
android:theme="@style/customTheme"
/>
<activity android:name="me.iwf.photopicker.PhotoPagerActivity"
android:theme="@style/customTheme"/>
</application>
</manifest>
Custom style
<style name="customTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="colorPrimary">#FFA500</item>//标题栏背景色
<item name="colorPrimaryDark">#CCa500</item>
</style>
Proguard
# Glide
-keep public class * implements com.bumptech.glide.module.GlideModule
-keep public enum com.bumptech.glide.load.resource.bitmap.ImageHeaderParser$** {
**[] $VALUES;
public *;
}
# nineoldandroids
-keep interface com.nineoldandroids.view.** { *; }
-dontwarn com.nineoldandroids.**
-keep class com.nineoldandroids.** { *; }
# support-v7-appcompat
-keep public class android.support.v7.widget.** { *; }
-keep public class android.support.v7.internal.widget.** { *; }
-keep public class android.support.v7.internal.view.menu.** { *; }
-keep public class * extends android.support.v4.view.ActionProvider {
public <init>(android.content.Context);
}
# support-design
-dontwarn android.support.design.**
-keep class android.support.design.** { *; }
-keep interface android.support.design.** { *; }
-keep public class android.support.design.R$* { *; }