Android 中Seekbar詳解及簡單實例
做到音頻播放和音樂播放時,大多數都要用到Seekbar。現在我先簡單介紹下Seekbar的幾個重要屬性。
一般情況下,Seekbar的所有配置是寫在style里的,而不是xml里。下面貼出我的代碼:
<SeekBar android:id="@+id/sb" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="center_vertical" android:max="100" style="@style/Widget.SeekBar.Normal"/>
style的代碼:
<style name="Widget.SeekBar.Normal" parent="@android:style/Widget.SeekBar"> <item name="android:thumbOffset">8dip</item> <item name="android:maxHeight">8dip</item> <item name="android:indeterminateOnly">false</item> <item name="android:indeterminateDrawable">@android:drawable/progress_indeterminate_horizontal</item> <item name="android:progressDrawable">@drawable/po_seekbar</item> <item name="android:minHeight">8dip</item> <item name="android:thumb">@mipmap/cricle</item> </style>
progressdrawable的代碼:
<?xml version="1.0" encoding="utf-8"?><layer-list xmlns:android="http://schemas.android.com/apk/res/android"> <item android:id="@android:id/background"> <shape> <solid android:color="#E6E6E6" /> <stroke android:width="1dp" android:color="#cccccc" /> <corners android:radius="5dp" /> </shape> </item> <item android:id="@android:id/secondaryProgress"> <clip> <shape> <corners android:radius="5dp" /> <solid android:color="#E6E6E6" /> </shape> </clip> </item> <item android:id="@android:id/progress"> <clip> <shape> <corners android:radius="5dp" /> <solid android:color="#7DBF60" /> </shape> </clip> </item></layer-list>
這樣一個Seekbar就解決了。
Seekbar有的監聽,就是你拖動到哪播放到哪(差不多這個意思)。
代碼很簡單:
sb.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { public void onProgressChanged(SeekBar seekBar, int i, boolean b) { int process = seekBar.getProgress(); if (player != null) { player.seekTo(process); } } public void onStartTrackingTouch(SeekBar seekBar) { } public void onStopTrackingTouch(SeekBar seekBar) { } });好了,現在說下可能遇到的情況:
1、Seekbar中間圓圈左右顯示不全。設置thumboffset=0就可以了。
2、Seekbar中間圓圈上下顯示不全。這里你把Seekbar的高度設置成自適應就可以了,當時我還因為這個問題搞了半天(日了狗了)。
Seekbar的用法基本就這樣了,有什么不明白的地方可以提出來。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
新聞熱點
疑難解答