码迷,mamicode.com
首页 > 移动开发 > 详细

Android 实现瀑布流的两种思路

时间:2017-02-18 12:17:37      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:touch事件   and   near   水平   控件   lin   url   出图   scrollby   

瀑布流怎么样我就不多介绍了。下面说说我想到的两个方法。
方法一,控件的叠加:
ScrollView+LinearLayout。在ScrollView里面加一个水平方向的LinearLayout,在水平Layout里面加几个竖直方向的LinearLayout,然后根据滑动情况去加载和回收Bitmap,甚至可以回收ImageView(回收Bitmap的同时remove掉ImageView,加载Bitmap的同时addView,需要把握好View的位置),思路较好实现。

 

方法二,自定义ViewGroup:
加载图片时,记住图片信息(宽,高,url等),并计算出图片应该摆放的位置,在ViewGroup添加ImageView用于展示图片,这时实现ViewGroup的onLayout方法,在onLayout方法里面根据计算的图片位置信息来调用imageView.layout()方法。图片排列好后,需要自己去处理滑动,在Ontouch事件里面去使用ScrollBy/ScrollTo来实现滑动的效果,同时可以在ACTION_UP里面去处理滑动回弹fling的效果。这里需要注意的是ViewGroup默认不去拦截Touch事件。这里需要重写onInterceptTouchEvent方法,让其返回true来拦截Touch事件。

Android 实现瀑布流的两种思路

标签:touch事件   and   near   水平   控件   lin   url   出图   scrollby   

原文地址:http://www.cnblogs.com/ProtectedDream/p/6412658.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!