您的位置:首页 > 产品设计 > UI/UE

Android UI开发第二十二篇——android 瀑布流图片实现

2013-06-05 10:16 295 查看
自pinterest使用了瀑布流展示图片后,有很多应用开始使用瀑布流的方式,像蘑菇街,美丽说。这里的瀑布流实现使用了开源代码。





layout:

<?xml version="1.0" encoding="utf-8"?>
<com.dodowaterfall.LazyScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/waterfall_scroll"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scrollbars="vertical" >

<LinearLayout
android:id="@+id/waterfall_container"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@android:color/white" >
</LinearLayout>

</com.dodowaterfall.LazyScrollView>


整个瀑布流用的是ScrollView的子类LazyScrollView。这个LazyScrollView中设置了一个监听器接口,用来监听ScrollView执行的不同阶段。接口如下:

public interface OnScrollListener {
void onBottom();

void onTop();

void onScroll();

void onAutoScroll(int l, int t, int oldl, int oldt);
}


对于每一幅图,都用一个ImageView的子类FlowView来表示。为了不阻塞UI线程,图片加载和图片更新都分别用不同的线程来做。这两个线程都在FlowView中。FlowView提供了加载和更新的接口给Activity调用。瀑布流实例的主Activity是MainActivity,常量都保存在Constants类中,方便维护。

瀑布流最重要的是图片的内存回收机制,防止发生内存溢出的情况(OOM)。

参考:

https://github.com/dodola/android_waterfall

http://developer.android.com/training/displaying-bitmaps/process-bitmap.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐