借助 Google 提供的材料组件库版本 1.2.0,您可以使用 Slider 组件。
只需添加您的布局:
<LinearLayout
android:layout_height="wrap_content"
android:clipChildren="false"
android:clipToPadding="false"
...>
<com.google.android.material.slider.Slider
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
app:labelBehavior="withinBounds"
android:value="7"
android:valueFrom="0"
android:valueTo="10"
.../>
</LinearLayout>
您可以使用这些属性自定义颜色:
<com.google.android.material.slider.Slider
app:activeTrackColor="@color/primaryDarkColor"
app:inactiveTrackColor="@color/primaryLightColor"
app:thumbColor="@color/primaryDarkColor"
.../>
或者您可以使用带有materialThemeOverlay 属性的自定义样式覆盖默认颜色:
<com.google.android.material.slider.Slider
style="@style/Custom_Slider_Style"
与:
<style name="Custom_Slider_Style" parent="Widget.MaterialComponents.Slider">
<item name="materialThemeOverlay">@style/slider_overlay</item>
</style>
<style name="slider_overlay">
<item name="colorPrimary">@color/...</item>
<item name="colorOnPrimary">@color/...</item>
</style>
或在布局中使用android:theme attr:
<com.google.android.material.slider.Slider
android:theme="@style/slider_overlay"
../>
例子:
如果您想自定义 工具提示 形状,您可以使用 labelStyle 属性:
<com.google.android.material.slider.Slider
app:labelStyle="@style/tooltip"
与:
<style name="tooltip" parent="Widget.MaterialComponents.Tooltip">
<item name="shapeAppearanceOverlay">@style/tooltipShOverylay</item>
<item name="backgroundTint">@color/....</item>
</style>
<style name="tooltipShOverylay">
<item name="cornerSize">50%</item>
</style>