摘要:資源加載完成后,又切換回靜態效果。分別是種,個動畫,個進度條底座。使用,疊加多層效果。定義旋轉效果。定義進度條的樣式。離開頁面時記得關閉動畫小結小結要實現轉圈的效果。主要還是直接操作對象,把動畫加進去。做出更豐富的效果。
某些音樂播放或者視頻播放的界面上,資源還在加載時,進度條的原點(thumb)會顯示一個轉圈的效果。
資源加載完成后,又切換回靜態效果。這個效果增強了用戶體驗。
一般來說有美術人員負責設計和切圖。嘗試實現時,我們可以使用使用drawable,來模擬實現這個轉圈的效果。
為方便管理,可以添加一些尺寸設置
6dp 2dp 20dp 4dp
我們一共要添加4個drawable文件。分別是2種thumb,1個動畫,1個進度條“底座”。
shape_thumb_round_1.xml # 靜態thumblayers_seek_bar_progress_1.xmllayers_thumb_ring_sweep_1.xmlrotate_thumb_1.xml
用solid和stroke做出的圓環效果
這是準備拿來轉圈的thumb。使用layer-list,疊加多層效果。
底部是一個半白色的圓(android:shape="oval"
)。
再疊加上一層圓環(android:shape="ring"
),使用了漸變色,增加動感。
-
-
定義旋轉效果。注意它的drawable
使用了上面定義的layers_thumb_ring_sweep_1.xml。
旋轉參數android:toDegrees
可以根據需求定義。
定義進度條的樣式。這個是“底座”。顏色要和上面的匹配,看起來好看一點。
-
-
-
上面的資源文件準備完畢后。在我們的布局中添加一個SeekBar
android:maxHeight
和android:minHeight
需要設置android:progressDrawable
用前面定義好的“底座”android:thumb
先使用靜態的樣式
由Activity來持有Drawable變量和動畫。例子中使用了dataBinding。
private RotateDrawable mRotateThumbDrawable; // 加載中的thumb,由Activity來持有這個drawableprivate Drawable mSolidThumb;private ObjectAnimator mThumbAnimator; // 控制動畫// ... @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); mBinding = DataBindingUtil.setContentView(this, R.layout.act_seekbar_1);// ... mRotateThumbDrawable = (RotateDrawable) AppCompatResources.getDrawable(getApplicationContext(), R.drawable.rotate_thumb_1); mSolidThumb = AppCompatResources.getDrawable(getApplicationContext(), R.drawable.shape_thumb_round_1); }
Drawable對象由activity直接持有,操作起來比較方便。
改變seekbar的thumb,使用方法setThumb(Drawable thumb)
使用靜態的thumb
mBinding.playSb.setThumb(mSolidThumb);
使用轉圈圈的效果,先setThumb
,并且需要啟動動畫
mBinding.playSb.setThumb(mRotateThumbDrawable);mThumbAnimator = ObjectAnimator.ofInt(mRotateThumbDrawable, "level", 0, 10000);mThumbAnimator.setDuration(1000);mThumbAnimator.setRepeatCount(ValueAnimator.INFINITE);mThumbAnimator.setInterpolator(new LinearInterpolator());mThumbAnimator.start();
效果如下圖
可以在靜態和動態之間相互切換。
離開頁面時記得關閉動畫
@Overrideprotected void onDestroy() { if (null != mThumbAnimator) { mThumbAnimator.cancel(); } super.onDestroy();}
要實現轉圈的效果。主要還是直接操作drawable對象,把動畫加進去。
setThumb(Drawable thumb)
方法接受的是Drawable對象,那么我們的思路就是從控制Drawable這點下手。
全部使用drawable可以達到文中的效果。有條件的也可以使用圖片資源。做出更豐富的效果。
參考:
layer-list
的環形drawable https://stackoverflow.com/questions/30676208/how-to-create-ring-shape-drawable-in-android/30677289更多Android文章可參考 https://an.rustfisher.com/
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/123988.html
摘要:地址中文自定義能改變尺寸顏色滑塊圖片刻度圖片刻度文字和氣泡指示器,當滑動時顯示帶有進度的指示器。給選擇圓角方角默認兩端是圓角,可以設置為方形。滑塊下顯示進度當的類型為時可以設置滑動后滑塊下顯示保留進度。 IndicatorSeekBar showImg(https://segmentfault.com/img/remote/1460000011967195);showImg(https...
摘要:吃飽喝足,兩個人扶著腰走在路上炫腹還是女盆友的提醒說,你不是會小程序嗎,能不能寫一個點贊的小程序來用。哎還真是,我自己擼一個也是闊以的,說不定還能給其他人用。比較適合想要練手小程序和的童鞋全部的代碼還請移步我的歡迎和。 showImg(https://segmentfault.com/img/remote/1460000015245489?w=530&h=153); 發生背景: ???...
閱讀 1573·2021-11-24 09:39
閱讀 1063·2021-11-22 15:11
閱讀 2210·2021-11-19 11:35
閱讀 1639·2021-09-13 10:37
閱讀 2475·2021-09-03 10:47
閱讀 2162·2021-08-30 09:47
閱讀 1643·2021-08-20 09:39
閱讀 2922·2019-08-30 14:13