将做工程过程比较常用的代码段做个记录,如下代码内容是关于Android系统上拉刷新功能的实现的代码,应该是对小伙伴有较大用处。
public class MyListView extends ListView implements OnScrollListener {
private LinearLayout hearderLayout;
private ImageView arrowImageView;
private ProgressBar progressBar;
private TextView tipsTextview;
private TextView lastUpdatedTime;
private int headContentHeight;
private int headContentWidth;
private RotateAnimation animation;
private RotateAnimation reverseAnimation;
private int firstItemIndex;
private OnRefreshListener refreshListener;
public MyListView (Context context) {
super(context);
init(context);
}
public MyListView (Context context, AttributeSet attrs) {
super(context, attrs);
init(context);
}
private void init(Context context) {
LayoutInflater inflater = LayoutInflater.from(context);
hearderLayout = (LinearLayout) inflater.inflate(R.layout.list_view_header, null);
arrowImageView = (ImageView) hearderLayout.findViewById(R.id.head_arrowImageView);
progressBar = (ProgressBar) hearderLayout.findViewById(R.id.head_progressBar);
tipsTextview = (TextView) hearderLayout.findViewById(R.id.head_tipsTextView);
lastUpdatedTime = (TextView) hearderLayout.findViewById(R.id.head_lastUpdatedTextView);
this.measureView(hearderLayout);
headContentHeight = hearderLayout.getMeasuredHeight();
headContentWidth = hearderLayout.getMeasuredWidth();
hearderLayout.invalidate();
Log.e("sys", "width:" + headContentWidth + " height:" + headContentHeight);
addHeaderView(hearderLayout, null, false);
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);
refreshStatus = DONE;
}
@Override
public void onScroll(AbsListView arg0, int firstVisiableItem, int arg2, int arg3) {
firstItemIndex = firstVisiableItem;
}
@Override
public void onScrollStateChanged(AbsListView arg0, int arg1) {
}
private int startY = 0;
@Override
public boolean onTouchEvent(MotionEvent event) {
if (firstItemIndex == 0 && isRefreshable) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
if (!isStartRefreshEvent) {
isStartRefreshEvent = true;
startY = (int) event.getY();
}
break;
case MotionEvent.ACTION_MOVE:
int tempY = (int) event.getY();
int scrollY = (tempY - startY) / RATIO;
Log.i("sys", "拉开方向 " + scrollY);
if (!isStartRefreshEvent) {
isStartRefreshEvent = true;
startY = tempY;
} else if (isStartRefreshEvent && refreshStatus != LOADING) {
if (refreshStatus == RELEASE_To_REFRESH) {
setSelection(0);
if (scrollY < headContentHeight && scrollY > 0) {
refreshStatus = HIDE_To_REFRESH;
this.changeHeaderView();
}
else if (scrollY <= 0) {
refreshStatus = DONE;
this.changeHeaderView();
}
}
if (refreshStatus == HIDE_To_REFRESH) {
setSelection(0);
if (scrollY > headContentHeight) {
refreshStatus = RELEASE_To_REFRESH;
this.changeHeaderView();
}
else if (scrollY <= 0) {
refreshStatus = DONE;
this.changeHeaderView();
}
}
if (refreshStatus == DONE) {
if (scrollY > 0) {
refreshStatus = HIDE_To_REFRESH;
this.changeHeaderView();
}
}
if (refreshStatus == HIDE_To_REFRESH) {
}
if (refreshStatus == RELEASE_To_REFRESH) {
hearderLayout.setPadding(0, scrollY - headContentHeight, 0, 0);
}
}
break;
case MotionEvent.ACTION_UP:
if (refreshStatus != LOADING) {
if (refreshStatus == DONE) {
}
if (refreshStatus == HIDE_To_REFRESH) {
refreshStatus = DONE;
this.changeHeaderView();
}
if (refreshStatus == RELEASE_To_REFRESH) {
refreshStatus = LOADING;
this.changeHeaderView();
onRefresh();
}
}
isStartRefreshEvent = false;
break;
}
}
return super.onTouchEvent(event);
}
private void changeHeaderView() {
switch (refreshStatus) {
case RELEASE_To_REFRESH:
arrowImageView.setVisibility(View.VISIBLE);
progressBar.setVisibility(View.GONE);
tipsTextview.setVisibility(View.VISIBLE);
lastUpdatedTime.setVisibility(View.VISIBLE);
arrowImageView.clearAnimation();
arrowImageView.startAnimation(animation);
tipsTextview.setText("松开刷新");
break;
case HIDE_To_REFRESH:
progressBar.setVisibility(View.GONE);
tipsTextview.setVisibility(View.VISIBLE);
lastUpdatedTime.setVisibility(View.VISIBLE);
arrowImageView.setVisibility(View.VISIBLE);
arrowImageView.clearAnimation();
arrowImageView.startAnimation(reverseAnimation);
tipsTextview.setText("下拉刷新");
break;
case LOADING:
hearderLayout.setPadding(0, 0, 0, 0);
progressBar.setVisibility(View.VISIBLE);
arrowImageView.clearAnimation();
arrowImageView.setVisibility(View.GONE);
tipsTextview.setText("正在刷新...");
lastUpdatedTime.setVisibility(View.VISIBLE);
break;
case DONE:
progressBar.setVisibility(View.GONE);
arrowImageView.clearAnimation();
tipsTextview.setText("下拉刷新");
lastUpdatedTime.setVisibility(View.VISIBLE);
break;
}
}
public void setonRefreshListener(OnRefreshListener refreshListener) {
this.refreshListener = refreshListener;
isRefreshable = true;
}
public interface OnRefreshListener {
public void onRefresh();
}
public void onRefreshFinished() {
refreshStatus = DONE;
DateFormat format = new SimpleDateFormat("yyyy年MM月dd日 HH:mm");
String date = format.format(new Date());
lastUpdatedTime.setText("最近更新:" + date);
changeHeaderView();
}
private void onRefresh() {
if (refreshListener != null) {
refreshListener.onRefresh();
}
}
private void measureView(View child) {
ViewGroup.LayoutParams p = child.getLayoutParams();
if (p == null) {
p = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
}
int childWidthSpec = ViewGroup.getChildMeasureSpec(0, 0 + 0, p.width);
int lpHeight = p.height;
int childHeightSpec;
if (lpHeight > 0) {
childHeightSpec = MeasureSpec.makeMeasureSpec(lpHeight, MeasureSpec.EXACTLY);
} else {
childHeightSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED);
}
child.measure(childWidthSpec, childHeightSpec);
}
public void setAdapter(BaseAdapter adapter) {
DateFormat format = new SimpleDateFormat("yyyy年MM月dd日 HH:mm");
String date = format.format(new Date());
lastUpdatedTime.setText("最近更新:" + date);
super.setAdapter(adapter);
}
}
layout:
<?xml version="1.0" encoding="utf-8"?>android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="#ffffff" >
<!-- 内容 -->
<RelativeLayout
android:id="@+id/head_contentLayout"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:paddingLeft="30dip" >
<!-- 箭头图像、进度条 -->
<FrameLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_centerVertical="true" >
<!-- 箭头 -->
<ImageView
android:id="@+id/head_arrowImageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/arrow"
android:layout_gravity="center" />
<!-- 进度条,style集合了一个anim -->
<ProgressBar
android:id="@+id/head_progressBar"
style="@style/wait_anim"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:visibility="gone" />
</FrameLayout>
<!-- 提示、最近更新 -->
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:gravity="center_horizontal"
android:orientation="vertical" >
<!-- 提示 -->
<TextView
android:id="@+id/head_tipsTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="下拉刷新"
android:textSize="15dp" />
<!-- 最近更新 -->
<TextView
android:id="@+id/head_lastUpdatedTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="上次更新"
android:textSize="12dp" />
</LinearLayout>
</RelativeLayout>
Activity中关键代码:
mListView.setonRefreshListener(new OnRefreshListener() {
public void onRefresh() {
new AsyncTask<Void, Void, Void>() {
protected Void doInBackground(Void… params) {
try {
Thread.sleep(3000);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
@Override
protected void onPostExecute(Void result) {
adapter.notifyDataSetChanged();
mListView.onRefreshFinished();
}
}.execute(null);
}
});