欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

android編程之下拉刷新實現(xiàn)方法分析

 更新時間:2015年11月02日 14:13:59   作者:年輕的zhangchang  
這篇文章主要介紹了android編程之下拉刷新實現(xiàn)方法,以實例形式詳細分析了Android編程中針對ListView下拉刷新的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了android編程之下拉刷新實現(xiàn)方法。分享給大家供大家參考,具體如下:

現(xiàn)在android應(yīng)用里面下拉刷新比較多 ,今天自己研究一下相關(guān)的資料

public class MyListView extends ListView implements OnScrollListener {
 private static final String TAG = "listview";
 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;
 // 實際的padding的距離與界面上偏移距離的比例
 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;
 // 用于保證startY的值在一個完整的touch事件中只被記錄一次
 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;
 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("size", "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(TAG, "在down時候記錄當(dāng)前位置‘");
    }
    break;
   case MotionEvent.ACTION_UP:
    if (state != REFRESHING && state != LOADING) {
     if (state == DONE) {
      // 什么都不做
     }
     if (state == PULL_To_REFRESH) {
      state = DONE;
      changeHeaderViewByState();
      Log.v(TAG, "由下拉刷新狀態(tài),到done狀態(tài)");
     }
     if (state == RELEASE_To_REFRESH) {
      state = REFRESHING;
      changeHeaderViewByState();
      onRefresh();
      Log.v(TAG, "由松開刷新狀態(tài),到done狀態(tài)");
     }
    }
    isRecored = false;
    isBack = false;
    break;
   case MotionEvent.ACTION_MOVE:
    int tempY = (int) event.getY();
    if (!isRecored && firstItemIndex == 0) {
     Log.v(TAG, "在move時候記錄下位置");
     isRecored = true;
     startY = tempY;
    }
    if (state != REFRESHING && isRecored && state != LOADING) {
     // 保證在設(shè)置padding的過程中,當(dāng)前的位置一直是在head,否則如果當(dāng)列表超出屏幕的話,當(dāng)在上推的時候,列表會同時進行滾動
     // 可以松手去刷新了
     if (state == RELEASE_To_REFRESH) {
      setSelection(0);
      // 往上推了,推到了屏幕足夠掩蓋head的程度,但是還沒有推到全部掩蓋的地步
      if (((tempY - startY) / RATIO < headContentHeight)
        && (tempY - startY) > 0) {
       state = PULL_To_REFRESH;
       changeHeaderViewByState();
       Log.v(TAG, "由松開刷新狀態(tài)轉(zhuǎn)變到下拉刷新狀態(tài)");
      }
      // 一下子推到頂了
      else if (tempY - startY <= 0) {
       state = DONE;
       changeHeaderViewByState();
       Log.v(TAG, "由松開刷新狀態(tài)轉(zhuǎn)變到done狀態(tài)");
      }
      // 往下拉了,或者還沒有上推到屏幕頂部掩蓋head的地步
      else {
       // 不用進行特別的操作,只用更新paddingTop的值就行了
      }
     }
     // 還沒有到達顯示松開刷新的時候,DONE或者是PULL_To_REFRESH狀態(tài)
     if (state == PULL_To_REFRESH) {
      setSelection(0);
      // 下拉到可以進入RELEASE_TO_REFRESH的狀態(tài)
      if ((tempY - startY) / RATIO >= headContentHeight) {
       state = RELEASE_To_REFRESH;
       isBack = true;
       changeHeaderViewByState();
       Log.v(TAG, "由done或者下拉刷新狀態(tài)轉(zhuǎn)變到松開刷新");
      }
      // 上推到頂了
      else if (tempY - startY <= 0) {
       state = DONE;
       changeHeaderViewByState();
       Log.v(TAG, "由DOne或者下拉刷新狀態(tài)轉(zhuǎn)變到done狀態(tài)");
      }
     }
     // done狀態(tài)下
     if (state == DONE) {
      if (tempY - startY > 0) {
       state = PULL_To_REFRESH;
       changeHeaderViewByState();
      }
     }
     // 更新headView的size
     if (state == PULL_To_REFRESH) {
      headView.setPadding(0, -1 * headContentHeight
        + (tempY - startY) / RATIO, 0, 0);
     }
     // 更新headView的paddingTop
     if (state == RELEASE_To_REFRESH) {
      headView.setPadding(0, (tempY - startY) / RATIO
        - headContentHeight, 0, 0);
     }
    }
    break;
   }
  }
  return super.onTouchEvent(event);
 }
 // 當(dāng)狀態(tài)改變時候,調(diào)用該方法,以更新界面
 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(TAG, "當(dāng)前狀態(tài),松開刷新");
   break;
  case PULL_To_REFRESH:
   progressBar.setVisibility(View.GONE);
   tipsTextview.setVisibility(View.VISIBLE);
   lastUpdatedTextView.setVisibility(View.VISIBLE);
   arrowImageView.clearAnimation();
   arrowImageView.setVisibility(View.VISIBLE);
   // 是由RELEASE_To_REFRESH狀態(tài)轉(zhuǎn)變來的
   if (isBack) {
    isBack = false;
    arrowImageView.clearAnimation();
    arrowImageView.startAnimation(reverseAnimation);
    tipsTextview.setText("下拉刷新");
   } else {
    tipsTextview.setText("下拉刷新");
   }
   Log.v(TAG, "當(dāng)前狀態(tài),下拉刷新");
   break;
  case REFRESHING:
   headView.setPadding(0, 0, 0, 0);
   progressBar.setVisibility(View.VISIBLE);
   arrowImageView.clearAnimation();
   arrowImageView.setVisibility(View.GONE);
   tipsTextview.setText("正在刷新...");
   lastUpdatedTextView.setVisibility(View.VISIBLE);
   Log.v(TAG, "當(dāng)前狀態(tài),正在刷新...");
   break;
  case DONE:
   headView.setPadding(0, -1 * headContentHeight, 0, 0);
   progressBar.setVisibility(View.GONE);
   arrowImageView.clearAnimation();
   arrowImageView.setImageResource(R.drawable.arrow);
   tipsTextview.setText("下拉刷新");
   lastUpdatedTextView.setVisibility(View.VISIBLE);
   Log.v(TAG, "當(dāng)前狀態(tài),done");
   break;
  }
 }
 public void setonRefreshListener(OnRefreshListener refreshListener) {
  this.refreshListener = refreshListener;
  isRefreshable = true;
 }
 public interface OnRefreshListener {
  public void onRefresh();
 }
 public void onRefreshComplete() {
  state = DONE;
  lastUpdatedTextView.setText("最近更新:" + new Date().toLocaleString());
  changeHeaderViewByState();
 }
 private void onRefresh() {
  if (refreshListener != null) {
   refreshListener.onRefresh();
  }
 }
 // 此方法直接照搬自網(wǎng)絡(luò)上的一個下拉刷新的demo,此處是“估計”headView的width以及height
 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) {
  lastUpdatedTextView.setText("最近更新:" + new Date().toLocaleString());
  super.setAdapter(adapter);
 }
}

希望本文所述對大家Android程序設(shè)計有所幫助。

相關(guān)文章

  • Android編程自定義進度條顏色的方法詳解

    Android編程自定義進度條顏色的方法詳解

    這篇文章主要介紹了Android編程自定義進度條顏色的方法,結(jié)合實例形式分析了Android進度條顏色相關(guān)的屬性設(shè)置操作技巧,需要的朋友可以參考下
    2017-09-09
  • android讀取assets中Excel表格并顯示

    android讀取assets中Excel表格并顯示

    這篇文章主要為大家詳細介紹了android讀取assets中Excel表格并顯示的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • 一文詳解無痕埋點在Android中的實現(xiàn)

    一文詳解無痕埋點在Android中的實現(xiàn)

    很多時候因為產(chǎn)品都會要獲取用戶的行為,需要客戶端進行相關(guān)的埋點,下面這篇文章主要給大家介紹了關(guān)于無痕埋點在Android中實現(xiàn)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Android如何繪制發(fā)光效果詳解

    Android如何繪制發(fā)光效果詳解

    這篇文章主要給大家介紹了關(guān)于Android如何繪制發(fā)光效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對各位Android開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Android頭像上傳功能的實現(xiàn)代碼(獲取頭像加剪切)

    Android頭像上傳功能的實現(xiàn)代碼(獲取頭像加剪切)

    最近在做一個頭像上傳的項目,下面小編給大家分享Android頭像上傳功能的實現(xiàn)代碼,需要的的朋友參考下吧
    2017-08-08
  • 深入了解ViewPager2的使用

    深入了解ViewPager2的使用

    這篇文章主要介紹了ViewPager2 使用的相關(guān)資料,幫助大家更好的進行Android開發(fā),感興趣的朋友可以了解下
    2020-12-12
  • Android 更改 Toast 的默認位置方法

    Android 更改 Toast 的默認位置方法

    下面小編就為大家?guī)硪黄狝ndroid 更改 Toast 的默認位置方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • Android使用個推實現(xiàn)三方應(yīng)用的推送功能

    Android使用個推實現(xiàn)三方應(yīng)用的推送功能

    這篇文章主要為大家詳細介紹了Android使用個推實現(xiàn)三方應(yīng)用的推送功能,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Android布局之RelativeLayout相對布局

    Android布局之RelativeLayout相對布局

    RelativeLayout是相對布局控件:以控件之間相對位置或相對父容器位置進行排列,下面通過本文給大家介紹Android布局之RelativeLayout相對布局,涉及到android relativelayout相對布局相關(guān)知識,對android relativelayout相對布局相關(guān)知識,感興趣的朋友一起學(xué)習(xí)吧
    2015-12-12
  • 深入理解Android 5.0中的Toolbar

    深入理解Android 5.0中的Toolbar

    相信大家都有所體會,搜索Toolbar相關(guān)文章滿天飛,但是大都不是很全面,每次要用到的時候又要重頭過濾一遍。而且隨著版本升級很多較早的文章的方法已經(jīng)失效,最近剛好好用到Toolbar,就將相關(guān)配置整理下,方便以后需要的時候或者有需要的朋友們參考學(xué)習(xí)。
    2017-01-01

最新評論