【发布时间】:2020-09-05 11:11:30
【问题描述】:
我想创建一个自定义的 SeekBar,但是我遇到了这个问题,因为在某些地方进度没有跟随 SeekBar 的拇指(进度值从 0-10 到 90-100)。我相信它会发生,因为我将thumbOffset 设置为 0,以便拇指留在进度条内。我想做一个 iPhone 风格的 SeekBar。
SeekBar 在进度0(正常):
SeekBar 进度 5(不正常):
SeekBar 进度 50(还可以):
SeekBar 进度 90(不正常):
SeekBar 进度 100(正常):
在根据拇指位置绘制进度时,似乎没有考虑thumbOffset。我尝试将thumbOffset 更改为拇指宽度的一半,并使用不同的填充进行各种组合,但没有解决问题。我还尝试了在 SO 上找到的所有其他解决方案。
这是我正在使用的 XML:
SeekBar 定义:
<SeekBar
android:id="@+id/scan_seekbar"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="0.5"
android:max="100"
android:progress="5"
android:progressDrawable="@drawable/bg_seekbar"
android:splitTrack="false"
android:thumbOffset="0dp"
android:thumb="@drawable/seekbar_thumb" />
可绘制bg_seekbar.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 android:shape="rectangle">
<size android:height="48dp"/>
<corners android:radius="25dp"/>
<stroke android:color="@color/semiLightBlue" android:width="1dp"/>
</shape>
</item>
<item android:id="@android:id/progress">
<clip>
<shape android:shape="rectangle">
<corners android:radius="25dp"/>
<size android:height="48dp"/>
<stroke android:color="@color/colorAccent" android:width="1dp"/>
<solid android:color="@color/colorAccent"/>
</shape>
</clip>
</item>
</layer-list>
SeekBar 拇指seekbar_thumb.xml:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item>
<shape android:shape="rectangle">
<solid android:color="@color/colorAccent"/>
<corners android:radius="25dp"/>
<padding android:bottom="8dp" android:top="8dp" android:left="16dp" android:right="16dp" />
</shape>
</item>
<item android:drawable="@drawable/ic_swipe_white" android:gravity="center" android:height="32dp" android:width="44dp"/>
</layer-list>
还有其他人遇到过这个问题吗?
【问题讨论】:
-
我试过 android:thumbOffset="12dp"。它似乎更有用。但我并不是说这是解决方案
-
它不能解决问题,因为我希望拇指在进度 0 和 100 处从
progressDrawable内部开始。使用您的解决方案,它会弹出。
标签: android seekbar android-seekbar seekbar-thumb