项目开发中,有一个这样的需求:
在个人主页里会有12张图片的背景墙。这12张图片由服务器返回,会不定时刷新。
第一种方案
起初,自己的实现思路是:xml直接定义12个ImageView,然后在接收到图片路径后,再进行异步加载。
显然,这种方法是肯定可以的,但是却显得不“优雅”。而且后续可能会对这整个背景墙有个缩放的动画之类的,那么再实现起来便会比较复杂了。
第二种方案
之后,我想到了GridView,显然也是可以的,在得到图片路径后传入到Adapter中即可。比起方案一稍微“优雅”些,但是也是很难将这个背景墙当成一个整体,进行将来可能会添加的动画特效需求。
第三种方案
最后,我想到,既然要当成一整个整体,那么自定义View或许是个不错的办法。
思路
思路是这样的:
- 首先ImageView展示初始图片;
- 下载图片;
- 所有图片下载完成后刷新View,显示下载的图片墙。
下面上代码。
代码
自定义ImageView:
1 | public class JointImageView extends ImageView { |
布局文件中使用:
1 | <com.android.widget.JointImageView |
项目中使用的Universal-Image-Loader三方库进行图片的加载。
下载图片的异步任务代码:
1 | private class BitmapLoaderTask extends AsyncTask<String[], Integer, List<Bitmap>> { |
通过方案三,在实现当下需求的同时,也可以作为一个单独的View,在将来拓展可能的缩放等特效动画。
但是也有一个缺点:必须所有的图片下载完毕才进行刷新。
当然,也可以将刷新策略调整成下载一张刷新一次,这个就得看具体的需求了。
题外话
对于图片中的阴影效果,我们可以采用alpha背景来实现。也可以通过色彩矩阵在绘制的时候进行调整。
通过alpha背景实现很简单,在FrameLayout上遮罩一个View,alpha设置成相应的值即可。
1 | <View |
通过色彩矩阵就得不停的调整了。
1 | // 生成色彩矩阵 |