照着https://github.com/994866755/handsomeYe.seekbar.github.io? 这个老哥的项目搞了一下?
然后关键是onStopTrackingTouch方法没写全啊我去,而且换成圆角图片之后会出现阴影之类的,这个好解决,.xml控件上加就行了
android:splitTrack="false"
完了还有点击阴影我也不想要啊 设置
android:background="@null"
还有替换图片的size也是不规范的,直接设置图片会出现尺寸兼容问题还是做成了layer-list,这部分照着android:thumb的样式写就行了 改一下圆角角度之类,滑动块要圆角的话就这样了
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<!--seekBar背景-->
<!-- <item android:drawable="@android:color/transparent" />-->
<!--seekBar的进度条-->
<item android:id="@android:id/background">
<!--形状-->
<shape android:shape="rectangle">
<!--大小-->
<size android:height="29dp" />
<!--圆角-->
<corners android:radius="25dp" />
</shape>
</item>
<item
android:width="50dp"
android:height="30dp"
android:drawable="@drawable/bg_seekbar_thumb"/>
</layer-list>
最坑的呢是onStopTrackingTouch的方法里
@Override
public void onStopTrackingTouch(SeekBar seekBar) {
if (seekBar.getProgress() != seekBar.getMax()) {
seekBar.setProgress(0);
} else {
// todo 做滑动到最右的操作.
// showMessage("滑动到最右");
sbProgress.setThumb(getResources().getDrawable(R.drawable.bg_seekbar_pass_size));
int measuredWidth = sbProgress.getMeasuredWidth();
int width = sbProgress.getProgressDrawable().getBounds().width();
int paddingRight = sbProgress.getPaddingRight();
//关键是这一行!!!!!如果不这么计算会导致替换的样式只显示一半,其他的方法我都试了 无效。可
//兼容5.1和以上高版本 +6可以酌情改一下 就相当是pddingRight了
sbProgress.setThumbOffset(measuredWidth - width + paddingRight + 6);
sbProgress.setEnabled(false);
}
}
|