package com.laohuai.appdemo.customui.ui;
import java.util.Date;
import com.laohuai.appdemo.customui.R;
import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.LinearInterpolator;
import android.view.animation.RotateAnimation;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.ProgressBar;
import android.widget.TextView;
public class MyListView extends ListView implements OnScrollListener {
private final static int RELEASE_To_REFRESH = 0;
private final static int PULL_To_REFRESH = 1;
//正在刷新
private final static int REFRESHING = 2;
//刷新完成
private final static int DONE = 3;
private final static int LOADING = 4;
private final static int RATIO = 3;
private LayoutInflater inflater;
private LinearLayout headView;
private TextView tipsTextview;
private TextView lastUpdatedTextView;
private ImageView arrowImageView;
private ProgressBar progressBar;
private RotateAnimation animation;
private RotateAnimation reverseAnimation;
private boolean isRecored;
private int headContentWidth;
private int headContentHeight;
private int startY;
private int firstItemIndex;
private int state;
private boolean isBack;
private OnRefreshListener refreshListener;
private boolean isRefreshable;
int i=1;
public MyListView(Context context) {
super(context);
init(context);
}
public MyListView(Context context, AttributeSet attrs) {
super(context, attrs);
init(context);
}
private void init(Context context) {
setCacheColorHint(context.getResources().getColor(R.color.transparent));
inflater = LayoutInflater.from(context);
headView = (LinearLayout) inflater.inflate(R.layout.head, null);
arrowImageView = (ImageView) headView.findViewById(R.id.head_arrowImageView);
arrowImageView.setMinimumWidth(70);
arrowImageView.setMinimumHeight(50);
progressBar = (ProgressBar) headView.findViewById(R.id.head_progressBar);
tipsTextview = (TextView) headView.findViewById(R.id.head_tipsTextView);
lastUpdatedTextView = (TextView) headView.findViewById(R.id.head_lastUpdatedTextView);
measureView(headView);
headContentHeight = headView.getMeasuredHeight();
headContentWidth = headView.getMeasuredWidth();
headView.setPadding(0, -1 * headContentHeight, 0, 0);
headView.invalidate();
Log.v("@@@@@@", "width:" + headContentWidth + " height:"+ headContentHeight);
addHeaderView(headView, null, false);
setOnScrollListener(this);
animation = new RotateAnimation(0, -180,RotateAnimation.RELATIVE_TO_SELF, 0.5f,
RotateAnimation.RELATIVE_TO_SELF, 0.5f);
animation.setInterpolator(new LinearInterpolator());
animation.setDuration(250);
animation.setFillAfter(true);
reverseAnimation = new RotateAnimation(-180, 0,RotateAnimation.RELATIVE_TO_SELF, 0.5f,
RotateAnimation.RELATIVE_TO_SELF, 0.5f);
reverseAnimation.setInterpolator(new LinearInterpolator());
reverseAnimation.setDuration(200);
reverseAnimation.setFillAfter(true);
state = DONE;
isRefreshable = false;
}
public void onScroll(AbsListView arg0, int firstVisiableItem, int arg2,
int arg3) {
firstItemIndex = firstVisiableItem;
}
public void onScrollStateChanged(AbsListView arg0, int arg1) {
}
public boolean onTouchEvent(MotionEvent event) {
if (isRefreshable) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
if (firstItemIndex == 0 && !isRecored) {
isRecored = true;
startY = (int) event.getY();
Log.v("@@@@@@", "ACTION_DOWN 这是第 "+i+++"步" +1 );
}
break;
case MotionEvent.ACTION_UP:
if (state != REFRESHING && state != LOADING) {
if (state == DONE) {
}
if (state == PULL_To_REFRESH) {
state = DONE;
Log.v("@@@@@@", "ACTION_UP PULL_To_REFRESH and changeHeaderViewByState()" +
" 这是第 "+i+++"步前"+2 );
changeHeaderViewByState();
Log.v("@@@@@@", "ACTION_UP PULL_To_REFRESH and changeHeaderViewByState() " +
"这是第 "+i+++"步后"+2 );
}
if (state == RELEASE_To_REFRESH) {
state = REFRESHING;
Log.v("@@@@@@", "ACTION_UP RELEASE_To_REFRESH changeHeaderViewByState() " +
"这是第 "+i+++"步" +3);
changeHeaderViewByState();
onRefresh();
Log.v("@@@@@@", "ACTION_UP RELEASE_To_REFRESH changeHeaderViewByState()" +
" 这是第 "+i+++"步" +3);
}
}
isRecored = false;
isBack = false;
break;
case MotionEvent.ACTION_MOVE:
int tempY = (int) event.getY();
if (!isRecored && firstItemIndex == 0) {
isRecored = true;
startY = tempY;
Log.v("@@@@@@", "ACTION_MOVE 这是第 "+i+++"步" +4);
}
if (state != REFRESHING && isRecored && state != LOADING) {
if (state == RELEASE_To_REFRESH) {
setSelection(0);
if (((tempY - startY) / RATIO < headContentHeight)
&& (tempY - startY) > 0) {
state = PULL_To_REFRESH;
changeHeaderViewByState();
Log.v("@@@@@@", "changeHeaderViewByState() 这是第 "+i+++"步"+5 );
}
else if (tempY - startY <= 0) {
state = DONE;
changeHeaderViewByState();
Log.v("@@@@@@", "ACTION_MOVE RELEASE_To_REFRESH 2 changeHeaderViewByState " +
"这是第 "+i+++"步" +6);
}
}
if (state == PULL_To_REFRESH) {
setSelection(0);
if ((tempY - startY) / RATIO >= headContentHeight) {
state = RELEASE_To_REFRESH;
isBack = true;
Log.v("@@@@@@", "changeHeaderViewByState " +
"这是第 "+i+++"步前"+7 );
changeHeaderViewByState();
Log.v("@@@@@@", "changeHeaderViewByState " +
"这是第 "+i+++"步后"+7 );
}
else if (tempY - startY <= 0) {
state = DONE;
changeHeaderViewByState();
Log.v("@@@@@@", "ACTION_MOVE changeHeaderViewByState PULL_To_REFRESH 2" +
" 这是第 "+i+++"步" +8);
}
}
if (state == DONE) {
if (tempY - startY > 0) {
state = PULL_To_REFRESH;
Log.v("@@@@@@", "ACTION_MOVE DONE changeHeaderViewByState " +
"这是第 "+i+++"步前" +9);
changeHeaderViewByState();
Log.v("@@@@@@", "ACTION_MOVE DONE changeHeaderViewByState " +
"这是第 "+i+++"步后" +9);
}
}
if (state == PULL_To_REFRESH) {
headView.setPadding(0, -1 * headContentHeight+(tempY - startY) / RATIO, 0, 0);
Log.v("@@@@@@", -1 * headContentHeight+(tempY - startY) / RATIO+
"ACTION_MOVE PULL_To_REFRESH 3 这是第 "+i+++"步"+10 );
}
if (state == RELEASE_To_REFRESH) {
headView.setPadding(0, (tempY - startY) / RATIO- headContentHeight, 0, 0);
Log.v("@@@@@@", "ACTION_MOVE PULL_To_REFRESH 4 这是第 "+i+++"步" +11);
}
}
break;
}
}
return super.onTouchEvent(event);
}
private void changeHeaderViewByState() {
switch (state) {
case RELEASE_To_REFRESH:
arrowImageView.setVisibility(View.VISIBLE);
progressBar.setVisibility(View.GONE);
tipsTextview.setVisibility(View.VISIBLE);
lastUpdatedTextView.setVisibility(View.VISIBLE);
arrowImageView.clearAnimation();
arrowImageView.startAnimation(animation);
tipsTextview.setText("请释放 刷新");
Log.v("@@@@@@", "RELEASE_To_REFRESH 这是第 "+i+++"步"+12 +"请释放 刷新" );
break;
case PULL_To_REFRESH:
progressBar.setVisibility(View.GONE);
tipsTextview.setVisibility(View.VISIBLE);
lastUpdatedTextView.setVisibility(View.VISIBLE);
没有合适的资源?快使用搜索试试~ 我知道了~
【Android应用源码】下拉刷新.zip

共41个文件
class:13个
png:8个
xml:5个

0 下载量 79 浏览量
2025-07-30
09:28:55
上传
评论
收藏 137KB ZIP 举报
温馨提示
资源说明: 1:本资料仅用作交流学习参考,请切勿用于商业用途。 2:一套精品实用安卓应用APP源码资源,无论是入门练手还是项目复用都超实用,省去重复开发时间,让开发少走弯路!
资源推荐
资源详情
资源评论






















收起资源包目录










































































共 41 条
- 1
资源评论


fanxbl957
- 粉丝: 8439
上传资源 快速赚钱
我的内容管理 展开
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助


最新资源
- 基于Comsol的热电效应多物理场仿真:温度场与电流场耦合计算模型
- 非线性不确定性多智能体系统的固定时间事件触发一致性控制策略及其MATLAB实现 MATLAB
- 锂离子电池恒流恒压充电Simulink仿真模型解析及电路结构详解 - CCCV控制系统
- PFC2D5.0离散元法在热力耦合岩石热损伤模拟中的应用及案例代码解析
- PFC裂纹密度云图分析:全面解读裂纹与裂缝的分布密度 · PFC 实战版
- 基于MATLAB的直斜齿轮啮合刚度计算方法及其工程应用 完整版
- 基于MATLAB2018b及以上版本的自适应虚拟阻抗下垂控制(Droop)双机并联系统模型构建及运行曲线研究 · 自适应虚拟阻抗
- COMSOL电化学沉积与催化仿真:枝晶生长及多模式沉积模型解析
- COMSOL结合BIC技术:能带计算、Q因子分析与远场偏振投影的操作指南 · BIC 精选版
- PFC2D模拟活动门试验:土拱效应下的应力分析与Python自动生成等值线云图的研究
- 定向声波发生器设计:基于MATLAB与COMSOL的单元结构、阵列优化及折射率测量 遗传算法
- COMSOL仿真超表面复现技术:多级分解通用方案及其应用
- 岩土工程中FLAC3D与PFC3D耦合模拟隧道开挖:位移连续性与地表沉降规律研究 · 岩土工程 v1.2
- 磁共振成像MRI序列Bloch方程模拟器的matlab实现
- VSG在不平衡电网电压工况下的控制:正负序电网电压、电流分离与电压电流双环控制的实施 v3.0
- 三相电压型虚拟同步发电机(VSG)离网仿真模型研究:包含双闭环控制、虚拟阻抗与预同步切换机制探索的Matlab仿真实现
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈



安全验证
文档复制为VIP权益,开通VIP直接复制
