Android瀑布流照片墙实现,体验不规则排列的美感

               

转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/10470797


传统界面的布局方式总是行列分明、坐落有序的,这种布局已是司空见惯,在不知不觉中大家都已经对它产生了审美疲劳。这个时候瀑布流布局的出现,就给人带来了耳目一新的感觉,这种布局虽然看上去貌似毫无规律,但是却有一种说不上来的美感,以至于涌现出了大批的网站和应用纷纷使用这种新颖的布局来设计界面。


记得我在之前已经写过一篇关于如何在Android上实现照片墙功能的文章了,但那个时候是使用的GridView来进行布局的,这种布局方式只适用于“墙”上的每张图片大小都相同的情况,如果图片的大小参差不齐,在GridView中显示就会非常的难看。而使用瀑布流的布局方式就可以很好地解决这个问题,因此今天我们也来赶一下潮流,看看如何在Android上实现瀑布流照片墙的功能。


首先还是讲一下实现原理,瀑布流的布局方式虽然看起来好像排列的很随意,其实它是有很科学的排列规则的。整个界面会根据屏幕的宽度划分成等宽的若干列,由于手机的屏幕不是很大,这里我们就分成三列。每当需要添加一张图片时,会将这张图片的宽度压缩成和列一样宽,再按照同样的压缩比例对图片的高度进行压缩,然后在这三列中找出当前高度最小的一列,将图片添加到这一列中。之后每当需要添加一张新图片时,都去重复上面的操作,就会形成瀑布流格局的照片墙,示意图如下所示。



听我这么说完后,你可能会觉得瀑布流的布局非常简单嘛,只需要使用三个LinearLayout平分整个屏幕宽度,然后动态地addView()进去就好了。确实如此,如果只是为了实现功能的话,就是这么简单。可是别忘了,我们是在手机上进行开发,如果不停地往LinearLayout里添加图片,程序很快就会OOM。因此我们还需要一个合理的方案来对图片资源进行释放,这里仍然是准备使用LruCache算法,对这个算法不熟悉的朋友可以先参考Android高效加载大图、多图方案,有效避免程序OOM 。


下面我们就来开始实现吧,新建一个Android项目,起名叫PhotoWallFallsDemo,并选择4.0的API。


第一个要考虑的问题是,我们到哪儿去收集这些大小参差不齐的图片呢?这里我事先在百度上搜索了很多张风景图片,并且为了保证它们访问的稳定性,我将这些图片都上传到了我的CSDN相册里,因此只要从这里下载图片就可以了。新建一个Images类,将所有相册中图片的网址都配置进去,代码如下所示:

public class Images public final static String[] imageUrls = new String[] {   "https://img-my.csdn.net/uploads/201309/01/1378037235_3453.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037235_7476.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037235_9280.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037234_3539.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037234_6318.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037194_2965.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037193_1687.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037193_1286.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037192_8379.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037178_9374.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037177_1254.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037177_6203.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037152_6352.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037151_9565.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037151_7904.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037148_7104.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037129_8825.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037128_5291.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037128_3531.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037127_1085.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037095_7515.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037094_8001.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037093_7168.jpg",   "https://img-my.csdn.net/uploads/201309/01/1378037091_4950.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949643_6410.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949642_6939.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949630_4505.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949630_4593.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949629_7309.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949629_8247.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949615_1986.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949614_8482.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949614_3743.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949614_4199.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949599_3416.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949599_5269.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949598_7858.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949598_9982.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949578_2770.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949578_8744.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949577_5210.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949577_1998.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949482_8813.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949481_6577.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949480_4490.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949455_6792.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949455_6345.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949442_4553.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949441_8987.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949441_5454.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949454_6367.jpg",   "https://img-my.csdn.net/uploads/201308/31/1377949442_4562.jpg" };}
然后新建一个ImageLoader类,用于方便对图片进行管理,代码如下所示:
public class ImageLoader
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值