做項(xiàng)目的時(shí)候,會(huì)碰到用viewpager + fragments去實(shí)現(xiàn)多頁滑動(dòng)。有些時(shí)候需要完成:界面在滑動(dòng)到一半或是一半以上的時(shí)候,需要把title之類的切換到下一個(gè)頁面。這個(gè)時(shí)候僅僅依賴Viewpager的接口是不能判斷,這里提供一個(gè)方法:判斷viewpager是左滑還是右滑,同時(shí)對(duì)滑過一半的時(shí)候(這個(gè)參數(shù)可以調(diào)),進(jìn)行相關(guān)操作。
//定義兩個(gè)變量,這個(gè)兩個(gè)變量是表示滑動(dòng)時(shí)候,positionOffset 是從大到 //小的變化,還是從小到大的變化。用于在滑動(dòng)時(shí)候,避免多次調(diào)用一個(gè)方法 private boolean isSmallToBig = true; private boolean isBigToSmall = false; //記錄上一次滑動(dòng)的positionOffsetPixels值 private int lastValue = -1; @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { if (positionOffset != 0) { mCurrentPage = position; boolean isLeft = true; if (lastValue >= positionOffsetPixels) { //右滑 isLeft = false; } else if (lastValue < positionOffsetPixels) { //左滑 isLeft = true; } setIndiactorView(positionOffset,isLeft); } lastValue = positionOffsetPixels; } private void setIndiactorView(float positionOffset,boolean isLeft) { //設(shè)定滑動(dòng)的邊界,這里設(shè)置的滑動(dòng)到一半 float radiusOffsetHead = 0.5f; //如果滑動(dòng)小于一半,通過isSmallToBig這個(gè)變量來避免多次調(diào)用 // initIndicatorView 方法 if (positionOffset <= radiusOffsetHead && !isSmallToBig) { initIndicatorView(mCurrentPage); isSmallToBig = true; isBigToSmall = false; } else if (positionOffset > radiusOffsetHead && !isBigToSmall) { //超過一半。如果是左滑,就-1,如果是右滑,就+1 int currnt = isLeft ? mCurrentPage + 1 : mCurrentPage - 1; initIndicatorView(currnt); isBigToSmall = true; isSmallToBig = false; } }以上這篇ViewPager 滑動(dòng)一半的判斷方法以及左滑右滑判斷實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注