android-[譯]兩行代碼搞定ViewPager的過渡動畫

ViewPager自帶了一種默認(rèn)的頁面滑動切換動畫慰丛,但是如果產(chǎn)品想要更炫的滑動效果的時候怎么辦呢渣刷?不要怕,我們可以使用support library PagerTransformer,API11 (Honeycomb) 及以上android版本都支持這個類。
用法很方便防楷,

viewpager.setPageTransformer(false, new ViewPager.PageTransformer() {
    @Override
    public void transformPage(View page, float position) {
        // do transformation here
        }
});

transformPage(View page, float position)方法有兩個參數(shù),page參數(shù)代表當(dāng)前view 或 fragment则涯,position參數(shù)就是它的位置的值复局。滑動的時候粟判,起始page和目標(biāo)page的各自的transformPage()就會被同時觸發(fā)調(diào)用亿昏。一個page的position為0代表它處于中間,為1代表它完全處于右邊档礁,為-1代表它完全處于左邊角钩。

官方文檔是這樣說的,position是一個page相對于屏幕中心的位置呻澜。position的值跟隨用戶滑動page而變化递礼。當(dāng)page填充屏幕完全可見的時候,它的position是0羹幸;page位于屏幕右邊宰衙,它的position是1。兩個page同時滑動到一半的時候睹欲,左邊page的position是-0.5供炼,右邊page的position是0.5一屋。(因為左右是對稱的)所以,為了不考慮正負(fù)值袋哼,我們?nèi)osition的絕對值:

final float normalizedposition = Math.abs(Math.abs(position) - 1);

現(xiàn)在左右兩個page各自有了一個0到1之間的normalizedposition值(左邊在遞減[1,0]冀墨,右邊在遞增[0,1]),怎么用就靠你了涛贯。比如诽嘉,首先,我們可以做一個淡入淡出效果弟翘。

@Override
public void transformPage(View page, float position) {
    final float normalizedposition = Math.abs(Math.abs(position) - 1);
    page.setAlpha(normalizedposition);
}
fade

尺寸大小變化效果:

@Override
public void transformPage(View page, float position) {
final float normalizedposition = Math.abs(Math.abs(position) - 1);
    page.setScaleX(normalizedposition / 2 + 0.5f);
    page.setScaleY(normalizedposition / 2 + 0.5f);
}
scale

最后一個例子是使page沿Z軸方向旋轉(zhuǎn)30度:

@Override
public void transformPage(View page, float position) {
    page.setRotationY(position * -30);
}

上面是一些簡單的例子悦冀,這里官方給了兩個例子。也可以把PagerTransformer和PagerTitleStrip/ PagerTabStrip結(jié)合在一起睛琳。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末盒蟆,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子师骗,更是在濱河造成了極大的恐慌历等,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辟癌,死亡現(xiàn)場離奇詭異寒屯,居然都是意外死亡,警方通過查閱死者的電腦和手機黍少,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進(jìn)店門寡夹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人仍侥,你說我怎么就攤上這事鸳君。” “怎么了或颊?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長囱挑。 經(jīng)常有香客問我,道長平挑,這世上最難降的妖魔是什么游添? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任系草,我火速辦了婚禮,結(jié)果婚禮上唆涝,老公的妹妹穿的比我還像新娘找都。我一直安慰自己,他們只是感情好廊酣,可當(dāng)我...
    茶點故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著晓猛,像睡著了一般戒职。 火紅的嫁衣襯著肌膚如雪帕涌。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天客情,我揣著相機與錄音梭伐,去河邊找鬼。 笑死赂苗,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的败砂。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼吠卷,長吁一口氣:“原來是場噩夢啊……” “哼锡垄!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起祭隔,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤货岭,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后疾渴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體千贯,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年搞坝,在試婚紗的時候發(fā)現(xiàn)自己被綠了搔谴。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,764評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡桩撮,死狀恐怖敦第,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情店量,我是刑警寧澤芜果,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站融师,受9級特大地震影響右钾,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜旱爆,卻給世界環(huán)境...
    茶點故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一舀射、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧怀伦,春花似錦脆烟、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至吴攒,卻和暖如春张抄,著一層夾襖步出監(jiān)牢的瞬間砂蔽,已是汗流浹背洼怔。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留左驾,地道東北人镣隶。 一個月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓极谊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親彻秆。 傳聞我的和親對象是個殘疾皇子摸屠,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,665評論 2 354

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