1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Android強化月間 - Androidアプリ開発の知見を共有しよう -

RatingBarの画像をカスタマイズする方法

Last updated at Posted at 2023-10-01

はじめに

RatingBarは評価に使われるツールです
ユーザーに商品の評価などをしてもらうときに便利な機能ですね
image.png

色のカスタマイズなどは容易なのですが、たまに星の画像(形)を変更してほしいという依頼がありします
というわけでカスタマイズ方法の紹介です
ただし、修正方法は公式推奨の変更方法がないので、あまり推奨はできません
RatingBarは元々OSバージョンやユーザー設定によってバグが起きやすいの機能なので変更したくないというのが本音・・
今回はなるべくバグが起きない、且つ、簡単な方法を紹介します(大手サービスでしばらく運用していますが今のところ問題は起きていません)

調べたやり方

参考サイト:
RatingBarの画像を変更してみる
https://korsakov.hatenadiary.org/entry/20120317/1331975422
RatingBar の星の色を黄金に変更する
https://note.com/countablepad/n/n8df4e66f08c0

ネットを調べてみるとあまり情報がありませんでした・・
数少ないものを参考にさせていただくとStyleを作成して、そこにレイアウトファイルを作成して設定、レイアウトファイルに画像を設定するというやり方が見つかりました

fragment.xml

<RatingBar 
    style="@style/MyRating"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>

style.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="MyRating" parent="@android:style/Widget.RatingBar">
        <item name="android:progressDrawable">@drawable/rating</item>
        <item name="android:indeterminateDrawable">@drawable/rating</item>
        <item name="android:minHeight">38dip</item>
        <item name="android:maxHeight">38dip</item>
        <item name="android:thumb">@null</item>
        <item name="android:isIndicator">true</item>
    </style>
</resources>

rating.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/star01" />
    <item android:id="@+android:id/secondaryProgress" 
        android:drawable="@drawable/star02" />
    <item android:id="@+android:id/progress" 
        android:drawable="@drawable/star03" />
</layer-list>

あとは画像ファイルを星が空の時、星が半分の時、星がフルの時と3パターン用意します(star01,02,03)
もちろんこの方法でも変更可能です

考えたやり方

上記の設定をみると独自Styleの親はstyle/Widget.RatingBarですが、それでいいの?という疑問が出てきました
実際には環境に合わせてStyleが変わるようなので、依頼内容が既存と同じ動き、サイズでとなるとちょっと心配です
コードを見てみるとSDK内のStyleが実際には使われているようです
そこでprogressDrawableの設定だけ直接fragment.xmlに設定すれば既存のStyleが使用されるからより安全なのでは?という考えにたどり着きました
また設定も上記の方法より楽です!
(調べたところindeterminateDrawableなどの設定は不要のようです)

fragment.xml

    <RatingBar
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:progressDrawable="@drawable/MyRatingStar" />

MyRatingStar.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/rating_empty" />
    <item
        android:id="@android:id/secondaryProgress"
        android:drawable="@drawable/rating_half" />
    <item
        android:id="@android:id/progress"
        android:drawable="@drawable/rating_full" />
</layer-list>

あとは画像を3つ用意するだけですが、ここで問題になるのが画像サイズです
画像サイズを間違えると一部かけてしまったり、余白が既存と変わってしまいます
余白は好みによって変えて良いと思いますがなるべく既存に合わせた方が安全だと思います

調べてみると
/Users/{user_name]/Library/Android/sdk/platforms/android-32/data/res/value/styles_material.xml
が採用されていて、
/Users/{user_name]/Library/Android/sdk/platforms/android-32/data/res
をみるとstar画像が複数サイズありました
検証してみるとic_star_black_48dp.png,ic_star_half_black_48dp.png
が実際に使われているのと同サイズのようです(empty画像はalphaとtintを変えて使用しています)
これらはマテリアルデザインが採用されているか?どのSDKを使用しているか?などによって変わってくると思うので、お使いの環境から適切な画像を調べる必要がありそうです
(fragment.xmlのRatingBarの使用クラスを調べる)

今回の画像サイズはこちら

フォルダ pixel * pixel
mdpi 48 * 48
hdpi 72 * 72
xhdpi 96 * 96
xxhdpi 144 * 144
xxxhdpi 192 * 192

結果がこちら!!(余白までちゃんと合わせてないですが・・)
image.png

Tips

empty画像を用意するのが面倒な場合は、fullの画像のalphaやtintを設定して色を薄くしたり変えてしまうことも可能です

MyRatingStar.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" />
        <bitmap
            android:alpha="0.5"
            android:src="@drawable/rating_empty"
            android:tint="?attr/colorControlNormal" />
    </item>
    <item
        android:id="@android:id/secondaryProgress"
        android:drawable="@drawable/rating_half" />
    <item
        android:id="@android:id/progress"
        android:drawable="@drawable/rating_full" />
</layer-list>
1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?