Android 中Seekbar详解及简单实例
做到音频播放和音乐播放时,大多数都要用到Seekbar。现在我先简单介绍下Seekbar的几个重要属性。
android:max 设置值的大小 . android:thumb=”@drawable/” 显示的那个可拖动图标,如果没有设置该参数则为系统默认,如果自己需要重新定义,则将自己需要的图标存放在资源目录 /res/drawable下,然后调用即可. android:thumbOffset 拖动图标的偏量值,可以让拖动图标超过bar的长度. android:progress 设置seekbar当前的默认值,范围0到max之间. android:secondaryProgress 用过的迅雷的都知道拖动图标随着当前的播放时间的走动而走动,同时我们也注意到了也有个缓冲看到的进度条,这个属性就是用来设置默认显示的值为多少,范围为0到max. android:progressDrawable 当我们不想使用系统默认的SeekBar时可以自己定义一个,这个资源文件就是用来调用我们自己定义的Seekbar图标的一般是在drawable下建立一个.xml文件s用layer-list来组织这些图标.一般情况下,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的用法基本就这样了,有什么不明白的地方可以提出来。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:Android 可拖动的seekbar自定义进度值Android利用SeekBar实现简单音乐播放器Android自定义SeekBar实现视频播放进度条Android控件之SeekBar的用法总结Android控件SeekBar仿淘宝滑动验证效果Android 动态改变SeekBar进度条颜色与滑块颜色的实例代码Android自定义竖直方向SeekBar多色进度条android之SeekBar控件用法详解Android自定义SeekBar滑动显示数字Android关于SeekBar无法点击到最大值问题解决方法记录(推荐)