实例介绍
【实例简介】瀑布流,实例,一个非常简单好用的,自定义的list view实现的
【实例截图】
【核心代码】
package com.itheima.photofalls57;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import android.content.Context;
import android.graphics.Bitmap;
import android.os.AsyncTask;
import android.os.Handler;
import android.os.Message;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.widget.ImageView;
import android.widget.ImageView.ScaleType;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.Toast;
public class MyScrollView extends ScrollView implements OnTouchListener {
private static int PAGE_SIZE = 20;
private int page = 0;
// 是否为第一次加载
private boolean isOnceLoad;
private ImageLoader mImageLoader;
// 每列的宽度
private int columnWidth;
// 三个linearlayout
private LinearLayout firstColumn;
private LinearLayout secondColumn;
private LinearLayout thirdColumn;
// 三列linearlayout的高度
private int firstColumnHeight;
private int secondColumnHeight;
private int thirdColumnHeight;
private static int scrollViewHeight;
private static View ll_container;
private static int scrollHeight;
//正在执行的异步线程集合
private static Set<LoadImageTask> taskCollections;
//imageview放置的集合
private List<ImageView> imageviewList = new ArrayList<ImageView>();
public MyScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
mImageLoader = ImageLoader.getInstance(context);
taskCollections = new HashSet<MyScrollView.LoadImageTask>();
setOnTouchListener(this);
}
@Override
protected void onLayout(boolean changed, int l, int t, int r, int b) {
super.onLayout(changed, l, t, r, b);
if (!isOnceLoad) {
firstColumn = (LinearLayout) findViewById(R.id.first_colum);
secondColumn = (LinearLayout) findViewById(R.id.second_colum);
thirdColumn = (LinearLayout) findViewById(R.id.third_colum);
columnWidth = firstColumn.getWidth();
//scrollview的高度,也就是屏幕高度
scrollViewHeight = getHeight();
//直接子布局的高度
ll_container = getChildAt(0);
isOnceLoad = true;
loadMoreImages();
}
}
private void loadMoreImages() {
// 进行分页加载
int startIndex = page * PAGE_SIZE;// 0 * 20 = 0
int endIndex = (page 1) * PAGE_SIZE;// 1* 20 = 20
// 如果开始的位置小于图片的总数,那么就进行加载
if (startIndex <= Images.imageUrls.length) {
Toast.makeText(getContext(), "loading...", 0).show();
if (endIndex > Images.imageUrls.length) {
endIndex = Images.imageUrls.length;
}
for (int i = startIndex; i < endIndex; i ) {
// 进行加载
String imageUrl = Images.imageUrls[i];
// 开一个异步线程 AsyncTask
LoadImageTask task = new LoadImageTask();
taskCollections.add(task);
task.execute(imageUrl);
}
// 每加载一次,页数就增加
page ;
} else {
Toast.makeText(getContext(), "no more picture...", 0).show();
}
}
class LoadImageTask extends AsyncTask<String, Void, Bitmap> {
String url;
ImageView mImageView;
public LoadImageTask(ImageView imageView) {
this.mImageView = imageView;
}
public LoadImageTask() {
}
// 在子线程里执行
@Override
protected Bitmap doInBackground(String... params) {
// 加载图片bitmap
url = params[0];
// 涉及三级缓存 先从内存里取,再从本地缓存里拿,最后是网络加载
Bitmap bitmap = mImageLoader.loadImage(url, columnWidth);
return bitmap;
}
// 在子线程执行完之后执行(UI线程)
@Override
protected void onPostExecute(Bitmap bitmap) {
super.onPostExecute(bitmap);
// 显示到界面上
if (bitmap != null) {
// 为了更加精确,我们展示高度重新计算一次
double ratio = bitmap.getWidth() / (columnWidth * 1.0);
int scaleHeight = (int) (bitmap.getHeight() / ratio);
if(mImageView != null){
mImageView.setImageBitmap(bitmap);
}else{
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
columnWidth, scaleHeight);
ImageView imageView = new ImageView(getContext());
imageView.setLayoutParams(params);
imageView.setImageBitmap(bitmap);
imageView.setScaleType(ScaleType.FIT_XY);
imageView.setPadding(5, 5, 5, 5);
imageView.setTag(R.string.image_url, url);
// 要加入到最短的线性布局中
findShortestLinearLayout(scaleHeight,imageView).addView(imageView);
//放置到集合中
imageviewList.add(imageView);
}
}
taskCollections.remove(this);
}
//找到最短的那一列,顺便记录下每张imageview的头部和底部坐标
private LinearLayout findShortestLinearLayout(int imageHeight,ImageView imageView) {
if (firstColumnHeight <= secondColumnHeight) {
if (firstColumnHeight <= thirdColumnHeight) {
imageView.setTag(R.string.image_top, firstColumnHeight);
firstColumnHeight = imageHeight;
imageView.setTag(R.string.image_bottom, firstColumnHeight);
return firstColumn;
} else {
imageView.setTag(R.string.image_top, thirdColumnHeight);
thirdColumnHeight = imageHeight;
imageView.setTag(R.string.image_bottom, thirdColumnHeight);
return thirdColumn;
}
} else {
if (secondColumnHeight <= thirdColumnHeight) {
imageView.setTag(R.string.image_top, secondColumnHeight);
secondColumnHeight = imageHeight;
imageView.setTag(R.string.image_bottom, secondColumnHeight);
return secondColumn;
} else {
imageView.setTag(R.string.image_top, thirdColumnHeight);
thirdColumnHeight = imageHeight;
imageView.setTag(R.string.image_bottom, thirdColumnHeight);
return thirdColumn;
}
}
}
}
@Override
public boolean onTouch(View v, MotionEvent event) {
// 当滑动停止并且滑动最底部的时候,进行加载更多
if (event.getAction() == MotionEvent.ACTION_UP) {
// 由于滑动惯性,手指抬起时不一定是滑动停止时
Message message = new Message();
message.obj = this;
handler.sendMessageDelayed(message, 5);
}
// return true的话,scrollview滑动事件失效
return false;
}
private static Handler handler = new Handler() {
public void handleMessage(android.os.Message msg) {
MyScrollView myScrollView = (MyScrollView) msg.obj;
int scrollY = myScrollView.getScrollY();
if(scrollHeight == scrollY){
//滑动停止了
//为了用户体验,当所有正在加载的任务停止时候,加载
if(scrollViewHeight scrollY >= ll_container.getHeight() && taskCollections.size() == 0 ){
myScrollView.loadMoreImages();
}
//是否在屏幕内,不是的话,设置一张默认的图片,是的话显示原图
myScrollView.checkVisible();
}else{
scrollHeight = scrollY;
Message message = handler.obtainMessage();
message.obj = myScrollView;
handler.sendMessageDelayed(message, 5);
}
};
};
public void checkVisible(){
//1.遍历所有图片
for(int i=0; i< imageviewList.size();i ){
//2.判断是否在屏幕内
ImageView imageView = imageviewList.get(i);
int top = (Integer) imageView.getTag(R.string.image_top);
int bottom = (Integer) imageView.getTag(R.string.image_bottom);
//可见的部分
if(bottom > getScrollY() && top < getScrollY() scrollViewHeight){
//三级缓存
String imageUrl = (String) imageView.getTag(R.string.image_url);
Bitmap bitmap = mImageLoader.getMemoryCache(imageUrl);
if(bitmap != null){
imageView.setImageBitmap(bitmap);
}else{
LoadImageTask task = new LoadImageTask(imageView);
task.execute(imageUrl);
}
}else{
imageView.setImageResource(R.drawable.empty_photo);
}
}
}
}
好例子网口号:伸出你的我的手 — 分享!
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明


网友评论
我要评论