Android實現(xiàn)仿微信tab高亮icon粘著手的滑動效果
微信的主頁分為3個tab,被選中的tab的tabwidget下面會有一個高亮的長條icon,而當(dāng)切換tab頁面的時候,這個icon不是等到tab切換完成后再出現(xiàn)在當(dāng)前被選中的tab的tabwidget的下面,而是會隨著viewpager滑動頁面的動作也進行滑動,從前一個tabwidget滑到當(dāng)前被選中的tabwidget,像viewpager一樣有一種粘著你的手的效果,體驗很贊。上個圖:
本篇分析如何實現(xiàn)這個效果。
首先基本知識是,實現(xiàn)不同tab頁之間可以滑動切換需要用到TabPageIndicator + ViewPager,其中TabPageIndicator是一個開源控件,ViewPager是android的support.v4包里面的控件。這個實現(xiàn)這里不進行描述,網(wǎng)上有很多的例子。本篇主要實現(xiàn)高亮icon的粘手效果。
先看布局:
<RelativeLayout android:layout_width="match_parent" android:layout_height="@dimen/height_56"> <com.widget.TabPageIndicator android:id="@+id/indicator" android:layout_width="fill_parent" android:layout_height="@dimen/height_56" android:background="@drawable/base_action_bar_bg" /> <ImageView android:id="@+id/highlight_tab_iv" android:layout_height="wrap_content" android:layout_width="90dp" android:background="@drawable/base_tabpager_indicator_selected" android:layout_alignParentBottom="true"/> </RelativeLayout>
如上面的代碼,高亮icon用一個ImageView實現(xiàn),這個ImageView就是那個高亮的長條icon。
然后針對這個ImageView我們需要初始化的時候計算其寬度,保證它的寬度和一個單獨的tabwidget是一樣寬的:
mHlTabIv = (ImageView)findViewById(R.id.highlight_tab_iv); RelativeLayout.LayoutParams mParams = (RelativeLayout.LayoutParams)mHlTabIv.getLayoutParams(); mParams.width = getScreenWidth() / tabCount; mTabViewWidth = mParams.width; mHlTabIv.setLayoutParams(mParams);
然后,要做到這個ImageView粘手的效果,要怎么做呢,其實android3.0之后添加的api就能很簡單的實現(xiàn),3.0之前的就需要用到nineoldandroids這個第三方的開源框架,這個框架的目的就是讓3.0之前的android版本實現(xiàn)android3.0之后的屬性動畫。這個框架的用法和3.0之后的api用法差不多,所以本篇直接用3.0之后的api。
mAnimator = mHlTabIv.animate();
下面是動畫的實現(xiàn)代碼:
mTabPageIndicator.setOnPageChangeListener(new OnPageChangeListener() { @Override public void onPageSelected(int index) { } @Override public void onPageScrolled(int currentPos, float percent, int delta) { if (!mIsScrolling) mAnimator.translationX(mTabViewWidth * currentPos + delta / tabCount).setDuration(50) .setListener(new Animator.AnimatorListener() { @Override public void onAnimationStart(Animator animation) { mIsScrolling = true; } @Override public void onAnimationRepeat(Animator animation) { } @Override public void onAnimationEnd(Animator animation) { mIsScrolling = false; } @Override public void onAnimationCancel(Animator animation) { mIsScrolling = false; } }).start(); } @Override public void onPageScrollStateChanged(int arg0) { } });
如上代碼,只需簡單的幾行代碼就能實現(xiàn)這個順滑的動畫的效果。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
完美解決Android三星手機從圖庫選擇照片旋轉(zhuǎn)問題
這篇文章主要幫助大家完美解決了Android三星手機從圖庫選擇照片旋轉(zhuǎn)問題,很實用的解決小案例,感興趣的小伙伴們可以參考一下2016-04-04Android TextView自定義數(shù)字滾動動畫
這篇文章主要為大家詳細介紹了Android TextView自定義數(shù)字滾動動畫,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04Android簡單修改原有應(yīng)用和添加應(yīng)用的方法
這篇文章主要介紹了Android簡單修改原有應(yīng)用和添加應(yīng)用的方法,涉及Android工程項目中針對源碼的修改及資源文件的編譯等操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-10-10Android編程實現(xiàn)讀取手機聯(lián)系人、撥號、發(fā)送短信及長按菜單操作方法實例小結(jié)
這篇文章主要介紹了Android編程實現(xiàn)讀取手機聯(lián)系人、撥號、發(fā)送短信及長按菜單操作方法,以完整實例形式總結(jié)分析了Android編程實現(xiàn)讀取手機聯(lián)系人、撥號、發(fā)送短信及長按菜單等操作的相關(guān)技巧,需要的朋友可以參考下2015-10-10Android自定義組合控件之自定義下拉刷新和左滑刪除實例代碼
最近做了個項目,其中有項目需求,用到下拉刷新和左滑刪除,網(wǎng)上沒有找到比較理想的解決辦法。下面小編給大家分享我的一個小demo有關(guān)Android自定義組合控件之自定義下拉刷新和左滑刪除實例代碼,需要的朋友參考下2016-04-04