这是我第一次在CSDN上发表博客,11年注册过CSDN,不过基本都是copy他人的资源。在这里发现很多牛人,也学到很多知识,近来不忙,常常思绪万千,其中不乏关于Android开发的想法。
我认为优秀的程序员应该是想方设法让自己越来越懒,或者让团队更闲,这样就有更多时间去学习新的知识,或者去发展自己的爱好。这样就要求代码的封装要好,灵活,易用,健壮,这个是好的代码最基本的特点,什么叫极简?就是只要聊聊几行代码,就能实现一个复杂的功能,而且不用担心美观和性能的问题。
MultiPhotoContainer是一个图片选择容器,适用于发布动态,意见反馈,发布需求等,图库展示页面是在github上lovetuzitong/MultiImageSelector基础上做的,MultiImageSelector这个开源库非常不错,打开一个图片选择页面,选择完获得回调的图片路径,比如:
Intent intent = new Intent(this, MultiImageSelectorActivity.class);
intent.putExtra(MultiImageSelectorActivity.EXTRA_SHOW_CAMERA, true);//是否展示拍照图片
intent.putExtra(MultiImageSelectorActivity.EXTRA_SELECT_COUNT, 1);//最多选取几张
intent.putExtra(MultiImageSelectorActivity.EXTRA_SELECT_MODE, MultiImageSelectorActivity.MODE_SINGLE);//单选
startActivityForResult(intent, FeedBackActivity.REQUEST_IMAGE);
这样通过
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == REQUEST_IMAGE) {
if (resultCode == RESULT_OK) {
List<String> path = data.getStringArrayListExtra(MultiImageSelectorActivity.EXTRA_RESULT);
}
}
}
就能拿到图片路径
看起来是很方便,但事实上我们好要做不少事,首先要顶一个ViewGroup,然后一个一个addView,展示方式有可能是水平也可能是GridView的网格类型,而且还要删除,浏览,长按抖动等效果,还是要一堆代码啊!居于这个问题,MultiPhotoContainer可以马上搞定!
先说说MultiPhotoContainer的功能吧,当前的为版本1.0,后续会优化和扩展
#Version 1.0
1,可以修改加号按钮,删除按钮的图片,图片的圆角半径
2,可以自定义布局样式,是水平滑动还是以GridView的形式展示
3,可以自定义图片的间距,左右间距和上下间距
4,有长按抖动效果
5,有图片交换功能(待续)
6,有图片浏览功能
如何用呢,往下看(Android Studio)
将multiphoto_container.aar复制到libs下
build.gradle配置
//加入
repositories {
flatDir {
dirs'libs'
}
}
dependencies {
compile 'com.squareup.picasso:picasso:2.4.0'
compile(name:'multiphoto_container', ext:'aar')
}
attrs.xml
中可修改参数 <declare-styleable name="MultiPhotoSelectContainer">
<!-- 图片显示垂直间距 -->
<attr name="multiPhoto_vertical_margin" format="dimension" />
<!-- 图片显示水平间距 -->
<attr name="multiPhoto_horizontal_margin" format="dimension" />
<!-- 相对于屏幕左边距 -->
<attr name="multiPhoto_page_margin_left" format="dimension" />
<!-- 相对于屏幕右边距 -->
<attr name="multiPhoto_page_margin_right" format="dimension" />
<!-- 图片显示最大个数,默认9个 -->
<attr name="multiPhoto_count" format="integer" />
<!-- 图片显示列数,默认5列 -->
<attr name="multiPhoto_colomns" format="integer" />
<!-- 图片显示大小,可自动适配,确保显示全 -->
<attr name="multiPhoto_photo_size" format="dimension" />
<!-- 图片显示圆角半径 -->
<attr name="multiPhoto_photo_radius" format="dimension" />
<!-- 删除按钮替换资源ID -->
<attr name="multiPhoto_delete_resId" format="reference" />
<!-- 增加按钮替换资源ID -->
<attr name="multiPhoto_add_resId" format="reference" />
</declare-styleable>
引用
<com.multiphoto.select.MultiPhotoSelectContainer
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/multiphoto_container_select"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/usercenter_operation_gridview"
android:clipChildren="false"
app:multiPhoto_horizontal_margin="5dp"
app:multiPhoto_page_margin_left="15dp"
app:multiPhoto_page_margin_right="15dp"
app:multiPhoto_photo_size="60dp"
/>
Source中可修改
1 setCompressKbSize //图片大小上限 默认2000KB
2 setCurrentLayoutType //设置布局样式,LayoutType_Horizontal(水平)LayoutType_Vertical(网格)
目标
public ArrayList<String> getPhotoList();//得到图片路径列表
有没发现这个容器的好处是符合业务逻辑,压缩图片处理,而且使用起来非常方便,对于要发布动态,意见反馈的需求,是不是分分钟搞定?
先来张截图给大家看下效果
代码资源下载链接:
http://download.csdn.net/detail/rocketlong/9597914