自定义RatingBar的背景图片

通过在/res/drawable下创建layer-list可以实现图片的分层效果,同样我们可以根据该特点自定义RatingBar的背景图片.

RatingBar有3种背景状态,即:不亮,半亮,全亮.分别可以用3张图片来代替.

系统默认的效果图是这样的:


是一个大大的图片.占了布局的很大的一块地方.而如果我们要实现下图的效果图的话,就需要自定义背景图了.


自定义custom_ratingbar.xml文件

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!--自定义ratingbar的背景图-->
    <!--不亮-->
    <item
        android:id="@android:id/background"
        android:drawable="@drawable/rating_small_empty" />
    <!--半亮-->
    <item
        android:id="@android:id/secondaryProgress"
        android:drawable="@drawable/rating_small_half" />
    <!--全亮-->
    <item
        android:id="@android:id/progress"
        android:drawable="@drawable/rating_small_full" />
</layer-list>

创建好layer-list后,如何在布局文件中引入呢.通过android:progressDrawable="@drawable/custom_ratingbar"引入即可.

如下:

<RatingBar
                android:id="@+id/id_rb_star"
                android:layout_width="wrap_content"
                android:layout_height="15dp"
                android:layout_below="@id/id_tv_name"
                android:layout_marginTop="3dp"
                android:layout_toRightOf="@+id/id_iv_icon"
                android:progressDrawable="@drawable/custom_ratingbar"
                android:isIndicator="true"
                android:rating="3.5" />

注意:

1.这里还需要设置android:layout_height,写死一个高度.如果不写死的话,虽然图片已经变小了,但是RatingBar的高度还是系统默认的高度.

2.android:isIndicator="true"需要设置,true表示:用户不能点击星星,只能用来看,false表示可以点击且处于抢占焦点的状态,默认就是false.如果只是想让用户观看,则设置为true.


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值