中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android怎么實現仿QQ好友詳情頁下拉頂部圖片縮放效果

發布時間:2022-04-13 15:59:29 來源:億速云 閱讀:211 作者:iii 欄目:編程語言

本篇內容主要講解“Android怎么實現仿QQ好友詳情頁下拉頂部圖片縮放效果”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Android怎么實現仿QQ好友詳情頁下拉頂部圖片縮放效果”吧!

效果圖

Android怎么實現仿QQ好友詳情頁下拉頂部圖片縮放效果

效果分析

1 向下滑動,頭部的圖片隨著手指滑動不斷變大
2 向上滑動,不斷的向上移動圖片,直到圖片不可見
3 當頂部圖片不可見時,向上滑動,滑動ListView

實現思路

1 由于這個View分上下兩部分,垂直排列,可以通過繼承LinearLayout實現::自定義一個DragImageView,該View繼承LinearLayout

public DragImageView(Context context, AttributeSet attrs) {
 super(context, attrs);
 // 默認該View垂直排列
 setOrientation(LinearLayout.VERTICAL);
 // 用于配合處理該View的慣性滑動
 mScroller = new OverScroller(context);
 mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
 mMaximumVelocity = ViewConfiguration.get(context)
    .getScaledMaximumFlingVelocity();
 mMinimumVelocity = ViewConfiguration.get(context)
    .getScaledMinimumFlingVelocity();
 }

2 onMeasure中設置內容視圖的高度

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
 super.onMeasure(widthMeasureSpec, heightMeasureSpec);
 LayoutParams params = (LayoutParams) getChildAt(1).getLayoutParams();
 // 頭部可以全部隱藏,所以內容視圖的高度即為該控件的高度
 params.height = getMeasuredHeight();
}

3 設置ImageView的ScaleType屬性

@Override
protected void onFinishInflate() {
 super.onFinishInflate();
 imageView = (ImageView) getChildAt(0);
 // 隨著手指滑動,圖片不斷放大(寬高都大于或者等于ImageView的大小),并居中顯示:
 // 根據上邊的分析,CENTER_CROP:可以使用均衡的縮放圖像(保持圖像原始比例),使圖片的兩個坐標(寬、高)都大于等于 相應的視圖坐標(負的內邊距),圖像則位于視圖的中央
 imageView.setScaleType(ScaleType.CENTER_CROP);
 listView = (ListView) getChildAt(1);
}

4 事件攔截

@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
 if (ev.getAction() == MotionEvent.ACTION_DOWN) {
  downX = (int) ev.getX();
  downY = (int) ev.getY();
 }
 if (ev.getAction() == MotionEvent.ACTION_MOVE) {
  int currentX = (int) ev.getX();
  int currentY = (int) ev.getY();
  // 確保是垂直滑動
  if (Math.abs(currentY - downY) > Math.abs(currentX - downX)) {
   View childView = listView.getChildAt(listView
     .getFirstVisiblePosition());
   // 有兩種情況需要攔截:
   // 1 圖片沒有完全隱藏
   // 2 圖片完全隱藏,但是向下滑動,并且ListView滑動到頂部
   if (getScrollY() != imageHeight
     || (getScrollY() == imageHeight && currentY - downY > 0
       && childView != null && childView.getTop() == 0)) {
    initVelocityTrackerIfNotExists();
    mVelocityTracker.addMovement(ev);
    return true;
   }
  }

 }
 if (ev.getAction() == MotionEvent.ACTION_UP) {
  recycleVelocityTracker();
 }
 return super.onInterceptTouchEvent(ev);
}

5 onTouchEvent的ACTION_MOVE處理

if (ev.getAction() == MotionEvent.ACTION_MOVE) {
  int currentX = (int) ev.getX();
  int currentY = (int) ev.getY();
  int deltyX = currentX - downX;
  int deltyY = currentY - downY;
  if (Math.abs(deltyY) > Math.abs(deltyX)) {
   if (deltyY > 0) {
    if (getScrollY() > 0) {
     if (getScrollY() - deltyY < 0) {
      scrollBy(0, -getScrollY());
      return true;
     }
     // 當圖片沒有完全顯示,并且向下滑動時,繼續整個view使圖片可見
     scrollBy(0, -deltyY);
    } else {
    // 當圖片完全顯示,并且向下滑動時,則不斷的放大圖片(通過改變ImageView)的高度
     LayoutParams layoutParams = (LayoutParams) getChildAt(0)
       .getLayoutParams();
     layoutParams.height = layoutParams.height + deltyY / 2;
     getChildAt(0).setLayoutParams(layoutParams);
    }
   } else {
   // 當圖片還處于放大狀態,并且向上滑動時,繼續不斷的縮小圖片的高度,使圖片縮小
    if (getChildAt(1).getTop() > imageHeight) {
     LayoutParams layoutParams = (LayoutParams) getChildAt(0)
       .getLayoutParams();
     layoutParams.height = layoutParams.height + deltyY / 2;
     getChildAt(0).setLayoutParams(layoutParams);
    } else {
    // 當圖片處于正常狀態,并且向上滑動時,移動整個View,縮小圖片的可見范圍
     if (getScrollY() - deltyY > imageHeight) {
      scrollBy(0, imageHeight - getScrollY());
      return true;
     }
     scrollBy(0, -deltyY);
    }
   }
   downY = currentY;
   downX = currentX;
   return true;
  }
 }

5 onTouchEvent的ACTION_UP處理

if (ev.getAction() == MotionEvent.ACTION_UP) {
 // 當圖片處于放大狀態時松手,使圖片緩慢的縮回到原來的狀態
 if (getChildAt(1).getTop() > imageHeight) {
  isAnimating = true;
  ValueAnimator valueAnimator = ValueAnimator.ofInt(getChildAt(1)
    .getTop(), imageHeight);
  valueAnimator.setDuration(300);
  valueAnimator.addUpdateListener(new AnimatorUpdateListener() {
   @Override
   public void onAnimationUpdate(ValueAnimator animation) {
    int value = (Integer) animation.getAnimatedValue();
    LayoutParams layoutParams = (LayoutParams) getChildAt(0)
      .getLayoutParams();
    layoutParams.height = value;
    getChildAt(0).setLayoutParams(layoutParams);
   }
  });
  valueAnimator.addListener(new AnimatorListenerAdapter() {
   @Override
   public void onAnimationEnd(Animator animation) {
    super.onAnimationEnd(animation);
    isAnimating = false;
   }
  });
  valueAnimator.start();
 }
 // 當現在圖片處于正常狀態,并且圖片沒有完全隱藏,并且松手時滑動的速度大于可慣性滑動的最小值,讓View產生慣性滑動效果
 if (getChildAt(1).getTop() == imageHeight
   && getScrollY() != imageHeight) {
  mVelocityTracker.computeCurrentVelocity(1000, mMaximumVelocity);
  int velocityY = (int) mVelocityTracker.getYVelocity();
  if (Math.abs(velocityY) > mMinimumVelocity) {
   fling(-velocityY);
  }
  recycleVelocityTracker();
 }

到此,相信大家對“Android怎么實現仿QQ好友詳情頁下拉頂部圖片縮放效果”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

通江县| 万年县| 报价| 松溪县| 华亭县| 西盟| 荥阳市| 黄陵县| 安塞县| 眉山市| 禹城市| 德兴市| 内黄县| 资溪县| 丰原市| 甘谷县| 郸城县| 无为县| 金沙县| 宁波市| 玉龙| 额尔古纳市| 体育| 郸城县| 仁怀市| 宝清县| 仙游县| 来宾市| 丘北县| 天水市| 长岛县| 太康县| 广东省| 高唐县| 长海县| 辽阳县| 彭阳县| 收藏| 龙州县| 宁德市| 滦南县|