自定義實現RatingBar

RatingBar是Android中常用的一個組件,但是發現一個問題就是不同系統版本的RatingBar表現的不太一樣

前面的是在Android 2.3版本的表現形式,後面的是在Android 4.0以上版本的表現形式,但是在我們常見的app中一般都要求體驗風格要統一,這就要求我們自定義來實現RatingBar的圖片

首先要找到要用的圖片,其實我們常見的Android圖標在sdk中就可以找到位置是:android-sdk-windows\platforms\android-20\data\res\drawable-hdpi,在這裏我們可以看到所有我們常見的組件的圖片,這樣選取圖片就方便了很多

下面直接上代碼

    <RatingBar
        android:id="@+id/rating"
        style="@style/RatingBar"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:numStars="5"
        android:rating="2" />

    <style name="RatingBar" parent="@android:style/Widget.RatingBar">
        <item name="android:progressDrawable">@drawable/rating_background</item>
    </style>

rating_background.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"
        android:drawable="@drawable/btn_rating_star_off_normal_holo_light">
    </item>
    <item
        android:id="@android:id/progress"
        android:drawable="@drawable/btn_rating_star_on_focused_holo_dark">
    </item>

</layer-list>


這樣就可以使app在不同版本的手機都顯示同樣的效果,如果你願意的話也可以讓圖標是小紅花或小紅旗什麼的,隨意啦。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章