您的位置:首页 > 其它

【coder-pig教程学习笔记2】SeekBar

2015-11-21 15:58 141 查看
1.SeekBar是ProgressBar的子类,可使用ProgressBar的属性,自带有android:thumb属性(用于自定义滑块)

2.SeekBar的常用属性(代码实现时使用setXxx方法):

android:max=”100” //滑动条的最大值
android:progress=”60” //滑动条的当前值
android:secondaryProgress=”70” //二级滑动条的进度
android:thumb = “@mipmap/sb_icon” //滑块的drawable


3.SeekBar事件监听

mSeekBar.setOnSeekBarChangeListener(new SeekBar.onSeekBarChangeListener(){
//里面需要重写三个方法
@Override
public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser){
//进度发生改变时会触发
}

@Override
public void onStartTrackingTouch(SeekBar seekBar){
//按住SeekBar时会触发
}

@Override
public void onStopTrackingTouch(SeekBar seekBar){
//放开SeekBar时会触发
}

});


4.SeekBar的简单自定义

a.滑块的自定义在drawable目录下创建对应的xml文件,利用selector自动选择不同状态下对应的样式,例如sb_thumb.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:drawable="@mipmap/seekbar_thumb_pressed"/>
<item android:state_pressed="false" android:drawable="@mipmap/seekbar_thumb_normal"/>
</selector>


b.条形栏的自定义在drawable目录下创建对应的xml文件,利用layer-list,例如sb_bar.xml

<?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="#FFFFD042" />
</shape>
</item>
<item android:id="@android:id/secondaryProgress">
<clip>
<shape>
<solid android:color="#FFFFFFFF" />
</shape>
</clip>
</item>
<item android:id="@android:id/progress">
<clip>
<shape>
<solid android:color="#FF96E85D" />
</shape>
</clip>
</item>
</layer-list>


c.在布局文件中引入SeekBar后,对progressDrawable和thumb进行设置

<SeekBar
android:id="@+id/sb_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:maxHeight="5.0dp"
android:minHeight="5.0dp"
android:progressDrawable="@drawable/sb_bar"
android:thumb="@drawable/sb_thumb"/>


感谢coder-pig分享教程
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: