Android原声RatingBar的星星大小只能设置成3种固定模式,且外观难看。所以实际项目中都会对其样式进行修改,适配应用主题。
1.设计星星切图
由产品和美工完成,建议大小 48px 或 84px。
2.设置进度条样式
在drawable文件夹下新建一个layer-list修改进度条的背景图资源
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@android:id/background"
android:drawable="@drawable/icon_star_bg" />
<item
android:id="@android:id/secondaryProgress"
android:drawable="@drawable/icon_star_bg" />
<item
android:id="@android:id/progress"
android:drawable="@drawable/icon_star_check" />
</layer-list>
3.设置进度条样式
在styles.xml下新建样式,引用上一步设置的layer-list
<style name="RatingBarStyle" parent="@android:style/Widget.RatingBar">
<item name="android:progressDrawable">@drawable/rating_bar</item>
<item name="android:numColumns">5</item>
</style>
4.修改布局中的RatingBar样式
<RatingBar
android:id="@+id/rating_bar"
style="@style/RatingBarStyle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:isIndicator="true"
android:maxHeight="20dp"
android:minHeight="20dp"
android:rating="3"
android:stepSize="1" />
主要注意的属性如下:
- isIndicator:是否只用于展示(true不可点击修改星星数量)
- stepSize:最小单位(推荐 0.5 或 1 )
- rating:单位数量(基于stepSize)
- minHeight 与 maxHeight 共同限制控件大小