精品专区-精品自拍9-精品自拍三级乱伦-精品自拍视频-精品自拍视频曝光-精品自拍小视频

網站建設資訊

NEWS

網站建設資訊

android中怎么利用Scroller實現過渡滑動效果

本篇文章給大家分享的是有關android中怎么利用Scroller實現過渡滑動效果,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創新互聯公司是一家專業提供昂昂溪企業網站建設,專注與網站制作、成都網站制作、H5技術、小程序制作等業務。10年已為昂昂溪眾多企業、政府機構等服務。創新互聯專業網站制作公司優惠進行中。

主要介紹一下Scroller這個類,它可以實現過渡滑動的效果,使滑動看起來不是那么生硬,當然它用大量的重繪來實現,invalidate();通過源碼看:

看構造方法

/**   * Create a Scroller with the default duration and interpolator.   */  public Scroller(Context context) {    this(context, null);  }  /**   * Create a Scroller with the specified interpolator. If the interpolator is   * null, the default (viscous) interpolator will be used. "Flywheel" behavior will   * be in effect for apps targeting Honeycomb or newer.   */  public Scroller(Context context, Interpolator interpolator) {    this(context, interpolator,        context.getApplicationInfo().targetSdkVersion >= Build.VERSION_CODES.HONEYCOMB);  }  /**   * Create a Scroller with the specified interpolator. If the interpolator is   * null, the default (viscous) interpolator will be used. Specify whether or   * not to support progressive "flywheel" behavior in flinging.   */  public Scroller(Context context, Interpolator interpolator, boolean flywheel) {    mFinished = true;    if (interpolator == null) {      mInterpolator = new ViscousFluidInterpolator();    } else {      mInterpolator = interpolator;    }    mPpi = context.getResources().getDisplayMetrics().density * 160.0f;    mDeceleration = computeDeceleration(ViewConfiguration.getScrollFriction());    mFlywheel = flywheel;    mPhysicalCoeff = computeDeceleration(0.84f); // look and feel tuning  }

我們用默認的就行,傳個context就行了,其他的什么差值器,先不管了

然后調用startScroll,傳遞我們歧視滑動位置和滑動的偏移量,還有可選的默認持續時間,默認為250毫秒這個方法是用來賦值的,接下來會調用invalidate()進行重新繪制,然后就會onDraw(),這時候會調用computeScroll()這個方法,我們重寫這個方法,computeScrollOffset()是判斷動畫有沒有結束的一個方法,沒結束的時候,我們根據滑動的偏移位置進行移動也就是scrollto到scroller的當前位置,再次調用invalidate(),由此無數的重回進行拼接形成了平滑的滑動

/**   * Call this when you want to know the new location. If it returns true,   * the animation is not yet finished.   */  public boolean computeScrollOffset() {    if (mFinished) {      return false;    }    int timePassed = (int)(AnimationUtils.currentAnimationTimeMillis() - mStartTime);    if (timePassed < mDuration) {      switch (mMode) {      case SCROLL_MODE:        final float x = mInterpolator.getInterpolation(timePassed * mDurationReciprocal);        mCurrX = mStartX + Math.round(x * mDeltaX);        mCurrY = mStartY + Math.round(x * mDeltaY);        break;      case FLING_MODE:        final float t = (float) timePassed / mDuration;        final int index = (int) (NB_SAMPLES * t);        float distanceCoef = 1.f;        float velocityCoef = 0.f;        if (index < NB_SAMPLES) {          final float t_inf = (float) index / NB_SAMPLES;          final float t_sup = (float) (index + 1) / NB_SAMPLES;          final float d_inf = SPLINE_POSITION[index];          final float d_sup = SPLINE_POSITION[index + 1];          velocityCoef = (d_sup - d_inf) / (t_sup - t_inf);          distanceCoef = d_inf + (t - t_inf) * velocityCoef;        }        mCurrVelocity = velocityCoef * mDistance / mDuration * 1000.0f;        mCurrX = mStartX + Math.round(distanceCoef * (mFinalX - mStartX));        // Pin to mMinX <= mCurrX <= mMaxX        mCurrX = Math.min(mCurrX, mMaxX);        mCurrX = Math.max(mCurrX, mMinX);        mCurrY = mStartY + Math.round(distanceCoef * (mFinalY - mStartY));        // Pin to mMinY <= mCurrY <= mMaxY        mCurrY = Math.min(mCurrY, mMaxY);        mCurrY = Math.max(mCurrY, mMinY);        if (mCurrX == mFinalX && mCurrY == mFinalY) {          mFinished = true;        }        break;      }    }    else {      mCurrX = mFinalX;      mCurrY = mFinalY;      mFinished = true;    }    return true;  }

public void startScroll(int startX, int startY, int dx, int dy) {    startScroll(startX, startY, dx, dy, DEFAULT_DURATION);  } public void startScroll(int startX, int startY, int dx, int dy, int duration) {    mMode = SCROLL_MODE;    mFinished = false;    mDuration = duration;    mStartTime = AnimationUtils.currentAnimationTimeMillis();    mStartX = startX;    mStartY = startY;    mFinalX = startX + dx;    mFinalY = startY + dy;    mDeltaX = dx;    mDeltaY = dy;    mDurationReciprocal = 1.0f / (float) mDuration;  }

public class MoveFreeView extends View{  private int movedX;  private int movedY;  private Scroller mScroller;  public MoveFreeView(Context context) {    super(context);  }  public MoveFreeView(Context context, @Nullable AttributeSet attrs) {    super(context, attrs);    mScroller = new Scroller(context);  }  public MoveFreeView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {    super(context, attrs, defStyleAttr);  }  @Override  public boolean onTouchEvent(MotionEvent event) {    //獲取觸摸點到邊界坐標    int x = (int) event.getX();    int y = (int) event.getY();    switch (event.getAction()){      case MotionEvent.ACTION_DOWN:        movedX = x;        movedY = y;        break;      case MotionEvent.ACTION_MOVE:        int offsetX = x-movedX;        int offsetY = y-movedY;        layout(getLeft()+offsetX,getTop()+offsetY,getRight()+offsetX,getBottom()+offsetY);        break;    }    return super.onTouchEvent(event);  }  //供外界調用通過傳遞x,y的的滑動距離  public void smoothScrollTo(int destinyX,int destinyY){    //向右側,下方滑動,請傳遞負值    int scrollX = getScrollX();    int scrollY = getScrollY();    int delta = destinyX - scrollX;    int deltaY = destinyY - scrollY;    mScroller.startScroll(scrollX,scrollY,delta,deltaY,5000);    invalidate();  }  @Override  public void computeScroll() {    super.computeScroll();    //true則表示滑動未結束    if (mScroller.computeScrollOffset()){      ((View) getParent()).scrollTo(mScroller.getCurrX(),mScroller.getCurrY());      invalidate();    }  }}

private MoveFreeView button;  @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);    button = (MoveFreeView) findViewById(R.id.custon);    button.smoothScrollTo(-400,-300);    //    button.startAnimation(AnimationUtils.loadAnimation(this,R.anim.translate));//    ObjectAnimator animtor1 = ObjectAnimator.ofFloat(button, "translationX", 0, 300);//    ObjectAnimator animtor2 = ObjectAnimator.ofFloat(button, "translationY", 0, 300);//    ObjectAnimator animator3 = ObjectAnimator.ofFloat(button,"rotationX",0.0f,360f);//    ObjectAnimator animator4 = ObjectAnimator.ofFloat(button,"scaleX",1.5f,0.5f);//    AnimatorSet set= new AnimatorSet();//    set.setDuration(5000);//    set.playTogether(animtor1,animtor2,animator3,animator4);//    set.addListener(new Animator.AnimatorListener() {//      @Override//      public void onAnimationStart(Animator animator) {////      }////      @Override//      public void onAnimationEnd(Animator animator) {//        //動畫結束時做一些事情//      }////      @Override//      public void onAnimationCancel(Animator animator) {////      }////      @Override//      public void onAnimationRepeat(Animator animator) {////      }//    });//    set.start();  }}

以上就是android中怎么利用Scroller實現過渡滑動效果,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創新互聯行業資訊頻道。


名稱欄目:android中怎么利用Scroller實現過渡滑動效果
鏈接分享:http://m.jcarcd.cn/article/pidgge.html
主站蜘蛛池模板: 国产夜夜爽 | 国产区精品视频 | www.日本高清| 午夜国产一级 | 午夜一级高清免费看 | 午夜福利体验 | 精品国产人成亚 | 成人精品第一区国产 | 日韩欧美在线不卡 | 成人区http| 另类专区国产在 | 成人精品妖精视频在 | 97成人免费视频 | 日本α片 | 九九九国产视频 | 国产在线观看h尤 | 91成人抖音 | 果冻传媒老狼一卡 | 日本黄页网站 | 殴美在线观看乱操 | 成人一区视频入口 | 97干色| 果冻剧精品传媒入口 | 日韩欧美中 | 绿巨人视频污app | 国产精品激情自拍 | 乱理伦片免费观看 | 91精品福利在 | 国产在线拍偷 | 欧美日韩网 | 成人亚洲欧美 | 福利写真影院 | www精品网站| 日本乱理| 国产性爱自拍视频 | 国产理论影院 | 日本一本免费一二区 | www.黄| 韩剧大全免费观看 | 国产理论片高清 | 国产片高清不卡 |