91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

ViewDragHelper怎么在Android中使用

發布時間:2021-03-29 17:42:59 來源:億速云 閱讀:199 作者:Leah 欄目:移動開發

這篇文章給大家介紹ViewDragHelper怎么在Android中使用,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

初始化操作

 private ViewDragHelper mDrragHelper;
  public SlideViewGroup(@NonNull Context context) {
    this(context,null);
  }

  public SlideViewGroup(@NonNull Context context, @Nullable AttributeSet attrs) {
    this(context, attrs,0);
  }

  public SlideViewGroup(@NonNull Context context, @Nullable AttributeSet attrs, @AttrRes int defStyleAttr) {

    super(context, attrs, defStyleAttr);
    mDrragHelper=ViewDragHelper.create(this,1.0f,mCallback);

  }

mDrragHelper=ViewDragHelper.create(this,1.0f,mCallback);第一個操作表示當前操作的對象,第二個參數為手勢操作敏感度,
第三個參數為我們手勢處理的毀掉接口

我們需要先在view事件分發時把手勢操作交給ViewFragHelper

@Override
  public boolean onInterceptTouchEvent(MotionEvent event) {
    //交給viewdrag去攔截
    //事件分發攔截
    float x=0;
    int action = event.getAction();
    switch(action){
      case MotionEvent.ACTION_DOWN:
        x =event.getX();
        break;
        // return false;
      case MotionEvent.ACTION_MOVE:
        if (STATE==0&getX()-x<0){
          return mDrragHelper.shouldInterceptTouchEvent(event);
        }else if (STATE==1){
          return mDrragHelper.shouldInterceptTouchEvent(event);
        }
        break;
    }
    return false;
  }
//boolean control=true;//控制downx的初始化
  @Override
  public boolean onTouchEvent(MotionEvent event) {
    mDrragHelper.processTouchEvent(event);
    //if (control)
    float downX=0;
    if (event.getAction()==MotionEvent.ACTION_DOWN){
      downX=event.getRawX();
      if (STATE==1){
        //if (event.getRawX()>0&downX<leftWidth-rightViewWidth)
        //close();
        // Toast.makeText(this.getContext(), "leftWidth"+leftWidth+"rawx"+event.getRawX(), Toast.LENGTH_SHORT).show();
      }

    }
    if (event.getAction()==MotionEvent.ACTION_UP){
      //Toast.makeText(this.getContext(), "downx"+downX, Toast.LENGTH_SHORT).show();
      //點擊刪除//&downX>leftWidth-rightViewWidth&downX<leftWidth-rightViewWidth/2
     // Toast.makeText(this.getContext(), "刪除1", Toast.LENGTH_SHORT).show();
      if (STATE==1&event.getRawX()>leftWidth-rightViewWidth&event.getRawX()<leftWidth-rightViewWidth/2){
        // Toast.makeText(this.getContext(), "刪除2", Toast.LENGTH_SHORT).show();
        if (skipListener!=null){
         // Toast.makeText(this.getContext(), "刪除3", Toast.LENGTH_SHORT).show();
          skipListener.onDelete();
        }
        // Toast.makeText(this.getContext(), "刪除", Toast.LENGTH_SHORT).show();
      }
      //點擊刪除&downX>leftWidth-rightViewWidth/2&downX<leftWidth-rightViewWidth
      if (STATE==1&event.getRawX()>leftWidth-rightViewWidth/2&event.getRawX()<leftWidth){
        // Toast.makeText(this.getContext(), "修改", Toast.LENGTH_SHORT).show();
        if (skipListener!=null){
          skipListener.onDefine();
        }
      }
    }
    return true;
  }

重點在這兩句

mDrragHelper.shouldInterceptTouchEvent(event); 
mDrragHelper.processTouchEvent(event);

我們可以在onInterceptTouchEvent決定什么時候把事件交給我們的手勢操作類
然后是回調類

private ViewDragHelper.Callback mCallback=new ViewDragHelper.Callback() {
    @Override
    public boolean tryCaptureView(View child, int pointerId) {
      return child==leftView;
    }

    @Override
    public int clampViewPositionHorizontal(View child, int left, int dx) {
      if (left>=0)
        return 0;
      if (left<-rightViewWidth)
        return -rightViewWidth;

      return left;
    }

    @Override
    public void onViewPositionChanged(View changedView, int left, int top, int dx, int dy) {
      super.onViewPositionChanged(changedView, left, top, dx, dy);
      rightView.layout(leftWidth + left, 0, leftWidth + rightViewWidth, viewHeight);
      /* if (left<0&left>rightViewWidth/2){
      mDrragHelper.smoothSlideViewTo(leftView,left,0);
      mDrragHelper.smoothSlideViewTo(rightView,left,0);
      }*/

      /* if (left>=-(leftWidth+rightViewWidth)) {
        rightView.layout(leftWidth + left, 0, leftWidth + rightViewWidth, viewHeight);
      }
      if (left<-(leftWidth+rightViewWidth)){
        rightView.layout(leftWidth, 0, leftWidth + rightViewWidth, viewHeight);
      }*/

    }

    @Override
    public void onViewReleased(View releasedChild, float xvel, float yvel) {
      super.onViewReleased(releasedChild, xvel, yvel);
      Log.i("left xvel",xvel+"y"+yvel);
      if (xvel<0){
        open();/* mDrragHelper.smoothSlideViewTo(rightView,rightViewWidth/2,0);*/
      }else if (leftView.getLeft()<-rightViewWidth/2)
      {open();}else {
        // Log.i("left open","open");
        close();
      }
    }

    @Override
    public int getViewHorizontalDragRange(View child) {
      return -rightViewWidth;
    }

    @Override
    public void onEdgeTouched(int edgeFlags, int pointerId) {
      super.onEdgeTouched(edgeFlags, pointerId);
    }
  };

tryCaptureView的返回值表示我們允許操作的child
clampViewPositionHorizontal()方法的默認返回值為0,返回值代表水平移動的距離,也就是left值,當返回left值時,我們操作的view就會跟著我們的拖動而移動,當然還有數值方向的方法,如果需要也可以重寫豎直操作的方法
onViewPositionChanged()方法就是當我們移動時就會回調這個方法,此處的left參數就是水平移動返回的left,dx就是水平距離相對變化
onViewRelased()方法就是手指抬起時(釋放)時回調的方法,xvel每秒鐘水平速度速度慢時為0,單位為像素,yvel為每秒鐘豎直方向的速度。速度有正負之分
滑動邊緣:

分為滑動左邊緣還是右邊緣:EDGE_LEFT和EDGE_RIGHT,下面的代碼設置了可以處理滑動左邊緣:

mDragHelper.setEdgeTrackingEnabled(ViewDragHelper.EDGE_LEFT);
假如如上設置,onEdgeTouched方法會在左邊緣滑動的時候被調用,這種情況下一般都是沒有和子view接觸的情況。

@Override
public void onEdgeTouched(int edgeFlags, int pointerId) {
  super.onEdgeTouched(edgeFlags, pointerId);
  Toast.makeText(getContext(), "edgeTouched", Toast.LENGTH_SHORT).show();
}

如果你想在邊緣滑動的時候根據滑動距離移動一個子view,可以通過實現onEdgeDragStarted方法,并在onEdgeDragStarted方法中手動指定要移動的子View

@Override
public void onEdgeDragStarted(int edgeFlags, int pointerId) {
  mDragHelper.captureChildView(mDragView2, pointerId);
}

滑動

手指在當前view的下邊緣就可以滑動

下面看一個我在ontochEvent調用的方法

public void open(){
    if (listener!=null){
      listener.onOpen(this);
    }
    if (mDrragHelper.smoothSlideViewTo(leftView,-rightViewWidth,0))
      ViewCompat.postInvalidateOnAnimation(SlideViewGroup.this);
    STATE=1;
  }

就是平滑滑動,
ViewCompat.postInvalidateOnAnimation(SlideViewGroup.this)
上面那個方法就是刷新布局(重繪操作)
然后會回調次viewgroup的computerScroll

@Override
  public void computeScroll() {
    if (mDrragHelper.continueSettling(true)) {
      ViewCompat.postInvalidateOnAnimation(this);
    }
  }

關于ViewDragHelper怎么在Android中使用就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

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

AI

新安县| 锡林浩特市| 会东县| 明水县| 镇远县| 枣庄市| 阜新市| 托里县| 建始县| 舒兰市| 乃东县| 当涂县| 峨眉山市| 化德县| 方正县| 阿拉善盟| 通辽市| 常德市| 福海县| 嵊泗县| 黎川县| 柞水县| 仲巴县| 广宁县| 延津县| 青州市| 崇仁县| 安化县| 三门峡市| 濉溪县| 花莲市| 波密县| 宾阳县| 友谊县| 宜川县| 资溪县| 灵石县| 奇台县| 伊金霍洛旗| 镇坪县| 舟山市|