美文网首页
自定义RatingBar的一些问题

自定义RatingBar的一些问题

作者: V_boomboom | 来源:发表于2016-07-20 00:22 被阅读652次

    使用Ratingbar做一个完成度的评定显示:
    系统默认的Ratingbar颜色并不合适使用。
    此处需要自定义。
    参考网上一些文章,写一下总结。

    一、设置RatingBar显示的资源图片

    在drawable文件加下新建一个layout-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/star_disable" />
    
        <item
    
            android:id="@android:id/progress"
    
            android:drawable="@drawable/star_enable" />
    
    <--
        <item
    
            android:id="@android:id/secondaryProgress"
    
            android:drawable="@drawable/star_enable" />-->
    </layer-list>
    

    属性说明:此文件用于设置不同的状态下的RatingBar的图片样式

    • background:默认的显示是RatingBar的样式(ps:比如一颗灰色的星星);
    • secondaryProgress:与用户交互式(选中评价等级)时的过度样式,此处因为不与用户做交互因此注释;
    • progress:当选中这的等级的时候RatingBar的样式。

    二、设置需要的RatingBar的样式。

    此处可以设置在Style文件中也可以直接在使用RatingBar时设置。

    (1)设置每一星星的背景:

    android:progressDrawable="@drawable/rating_bar_bg"
    

    ps:此处使用刚刚写的layout-list文件,需注意的是使用的是progressDrawable属性而不是Drawable;drawable设置的是整个RatingBar的背景,而progressDrawable设置的是RatingBar中单个图像不同状态的背景。

    (2)设置时候与用户交互(用户是否可以点击和选中等级,即禁止用户点击RatingBar时修改RatingBar的值)

    android:isIndicator="true"
    <!--为true时不可交互,false时可交互。-->
    

    (3)设置总共的等级总数:

    android:numStars="5"
    

    (4)minHeight和minWidth属性:

    android:minHeight="30px"
    android:minWidth="30px"
    

    PS:此处注意,在自定义RatingBar时使用自己的图片会发现出现拉伸的问题,则将图片的真实大小设置到这两个属性上课解决问题。

    (5)设置显示当前的评价等级:

    设置rating属性来显示。

    相关文章

      网友评论

          本文标题:自定义RatingBar的一些问题

          本文链接:https://www.haomeiwen.com/subject/ffkvjttx.html