Viewpager頂部滑動(dòng)

我們都會遇到這樣的需求就是下方ViewPager 上方一個(gè)導(dǎo)航 導(dǎo)航文字底下還會有個(gè)滑動(dòng)線兄朋。如果是手寫實(shí)現(xiàn)的話 肯定是基于 onpagescroll 方法 來改變滑動(dòng)線的leftmargin 實(shí)現(xiàn)滑動(dòng)線的滑動(dòng)谱姓。

所以下面我就直接分析

我先把核心部分代碼貼出來 然后再給大家分析下為什么這么寫

[html]view plaincopy

viewPager.setOnPageChangeListener(new?ViewPager.OnPageChangeListener()?{

@Override

public?void?onPageScrolled(int?position,?float?offset,?int?positionOffsetPixels)?{

LayoutParamslp=?(LayoutParams)?line

.getLayoutParams();

intlength=tabNames.length;

if(currentIndex==position){

lp.leftMargin=?(int)?(offset?*?(screenWidth?*?1.0?/?length)

+?currentIndex

*?(screenWidth?/?length));

}else?if(currentIndex>position){

lp.leftMargin=?(int)?(-(1?-?offset)

*?(screenWidth?*?1.0?/?length)

+?currentIndex

*?(screenWidth?/?length));

}

line.setLayoutParams(lp);

}

@Override

public?void?onPageSelected(int?position)?{

currentIndex=position;

}

@Override

public?void?onPageScrollStateChanged(int?state)?{

}

});

首先我會分析給大家聽 onPageScrolled 的過程中 position 和 currentindex 的變化

currentindex 每次記錄當(dāng)前頁面的位置 姻蚓。 position 是這里的position不是 onPageSelected的position

由于滑動(dòng)式currentindex 首先是不變的熏矿。 當(dāng)滑動(dòng)超過一半時(shí) currentindex

就會變, 而position會根據(jù)滑動(dòng)方向 泄朴, 當(dāng) 往左滑動(dòng)時(shí) 馬上會減一 蔬顾, 當(dāng)往右滑動(dòng)時(shí)會 先不變。

然后當(dāng)viewpager頁面停止后他才會判斷頁面是否劃過去了 劃過去就加 一 沒有就不變昭齐。

所以 currentindex 永遠(yuǎn)是大于或者等于position的

offset 是一個(gè)小數(shù)從0 變化到1 ?如果從左到右 是 0-1 ?從右到左是 1-0尿招;

基于這個(gè)分析 從左往右 滑動(dòng)時(shí) ?假設(shè)從第0個(gè)頁面滑到 第1個(gè)頁面

首先是 currentindex 與 position 相等。 然后超過一半時(shí) currentindex>posiiton

······(1)當(dāng)currentindex =position 時(shí) 改變 滑動(dòng)線的leftmargin

lp.leftMargin = (int) (offset * (screenWidth * 1.0 / length)

+ currentIndex *(screenWidth / length));

length代表 幾個(gè)tab ?屏幕寬度除以tab個(gè)數(shù)表示每個(gè)滑動(dòng)線的寬度。

這時(shí) 滑動(dòng)線的左側(cè)leftmargin 初始值 肯定是 currentindex*這個(gè)寬度的就谜。

那么當(dāng)變化時(shí)我們就基于這個(gè)初始值 進(jìn)行改變

用寬度*offset 這時(shí)offset 是0-1 的變化 怪蔑。肯定是增長 就是滑動(dòng)線 在往右移動(dòng)

那么當(dāng) 滑動(dòng)過一半時(shí) ?currentindex 變成了 1

(2)currentIndex>position

lp.leftMargin = (int) (-(1 - offset)* (screenWidth * 1.0 / length)

+ currentIndex * (screenWidth / length));

這時(shí) cunrrentindex 增加了一個(gè)丧荐。所以這時(shí)*寬度 相當(dāng)于我們最終 leftmargin 的距離缆瓣。然而我們還沒有到達(dá)

最終的位置 我們剛過一半兒 那我們在往最終位置變化時(shí)offset 是趨近于1 的 而若想要這個(gè)過程leftmargin 在增長

我們就用 1-offset 這個(gè)值是趨近于 0的 那么 ? ? ?(int) (-(1 - offset)* (screenWidth * 1.0 / length) ?計(jì)算的就是我們離最終位置到底差了多少。虹统。

用最終位置 ? ? ? ? currentIndex*(screenWidth / length)); ? 減去上面的就是當(dāng)前位置

這里有些饒 大家多讀讀 多思考下 弓坞。 其實(shí)難點(diǎn)就在這里。

從右往左分析 我就不寫了车荔。 就是一樣的思路昼丑。大家可以自行分析分析。就是利用這個(gè)就可以實(shí)現(xiàn)頂部滑動(dòng)線夸赫。。咖城,

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末茬腿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子宜雀,更是在濱河造成了極大的恐慌切平,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辐董,死亡現(xiàn)場離奇詭異悴品,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)简烘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進(jìn)店門苔严,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人孤澎,你說我怎么就攤上這事届氢。” “怎么了覆旭?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵退子,是天一觀的道長。 經(jīng)常有香客問我型将,道長寂祥,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任七兜,我火速辦了婚禮丸凭,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己贮乳,他們只是感情好忧换,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著向拆,像睡著了一般亚茬。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上浓恳,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天刹缝,我揣著相機(jī)與錄音,去河邊找鬼颈将。 笑死梢夯,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的晴圾。 我是一名探鬼主播颂砸,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼死姚!你這毒婦竟也來了人乓?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤都毒,失蹤者是張志新(化名)和其女友劉穎色罚,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體账劲,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡戳护,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了瀑焦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片腌且。...
    茶點(diǎn)故事閱讀 39,727評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖榛瓮,靈堂內(nèi)的尸體忽然破棺而出切蟋,到底是詐尸還是另有隱情,我是刑警寧澤榆芦,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布柄粹,位于F島的核電站,受9級特大地震影響匆绣,放射性物質(zhì)發(fā)生泄漏驻右。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一崎淳、第九天 我趴在偏房一處隱蔽的房頂上張望堪夭。 院中可真熱鬧,春花似錦、人聲如沸森爽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽爬迟。三九已至橘蜜,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間付呕,已是汗流浹背计福。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留徽职,地道東北人象颖。 一個(gè)月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像姆钉,于是被迫代替她去往敵國和親说订。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容