導航:首頁 > 操作系統 > androidratingbar圖片

androidratingbar圖片

發布時間:2023-04-05 23:47:08

A. android自定義RatingBar(星級評分控制項)

RatingBar是基於SeekBar(拖動條)和ProgressBar(狀態條)的擴展,用星形來顯示等級評定!

RatingBar實現的效果圖:

      看著自定義的樣式遠遠比Android自帶的樣式好看多了,用戶體驗度遠遠提升,下面我們就來實現該控制項:

  定義根據圖片自定一個RatingBar的背景條,和圖片放到同一個目錄下面

     five_rating_bar.xml

backgroud:是用來填充背景圖片的,和進度條非常類似,當我們設置最高評分時(android:numStars),系統就會根據我們的設置,來畫出以星星為單位的背景(假如android:numStars="5",就會畫出5顆灰色的星星)

progress:是用來在背景圖片基礎上進行填充的指示屬性(和進度條類似,第一進度位置)

secondaryProgress:同progress一樣屬於第二進度位置(如果不定義這個,進度條拖動,每次就畫出一整顆星星(亮),第二進度(暗)沒有覆蓋掉第一進度之後的位置,從左往右是拖不出來N.5顆星星的,這樣評分效果就不完整)

    style.xml

      提取樣式屬於個人習慣,這里可以不提取出來,可以寫在布局文件中,這里RatingBar的樣式是通過style來切換的。

    通過 parent屬性來選擇繼承的父類,我們這里繼承RatingBar類。

    重新定義 progressDrawable屬性(RatingBar的背景條)

    maxHeight和minHeight可以根據我們圖片像素或者其他參考值來設定。

在我們需要用到RatingBar的xml配置文件裡面添加RatingBar控制項。

     main.xml

android:isIndicator              RatingBar是否是一個指示器(用戶無法進行更改)

android:numStars               顯示的星型數量,必須是一個整形值,像「100」。

android:rating                    默認的評分,必須是浮點類型,像「1.2」。

android:stepSize                 評分的步長,必須是浮點類型,像「1.2」。

就這么簡單,我們自定義屬於自己的RatingBar,星級評分控制項!

B. 為什麼android控制項中的ratingbar的圖片換成點9文件之後就變成一個星星了那

拉太大了 小點。。

C. android 自定義ratingbar怎麼變成這樣

把自定義局簡圖片從hdpi移動到mdpi中 , 系統會按照不同的文件,採取不同的壓縮方式,解決方法就是這么的簡單液臘粗鬧鎮。

D. android ratingbar怎麼設置半個星

RatingBar是基於SeekBar(拖動條)和ProgressBar(狀態條)的擴展,用星形來顯示等級評定,在使用默認RatingBar時,用戶可以通過觸摸/拖動/按鍵(比如遙控器)來設置評分,RatingBar自帶有兩種模式,一個小風格ratingBarStyleSmall,大風格為ratingBarStyleIndicator,大的只適合做指示,不適用與用戶交互。


黃色星形為自定義RatingBar
小綠色為自帶的ratingBarStyleSmall
大綠色為自帶的ratingBarStyleIndicator

通過設置style="XXXXXXXXXXXXX"進行設置切換(比如:style="?android:attr/ratingBarStyleIndicator")

自定義RatingBar需要注意的地方

一般情況下,系統自帶的RatingBar是遠遠無法滿足開發需求的,我們根據圖片自定一個RatingBar,在開始實現自定義RatingBar之前,順帶說一下res目錄下圖片放置目錄的區別:

在android sdk 1.5版本之前res目錄下面只有一個drawable一個目錄,在android sdk 1.6版本以後就出現了三個目錄,分別是drawable-hdpi、drawable-ldpi、drawable-mdpi、drawable-xhdpi,
(1)drawable-hdpi裡面存放高解析度的圖片,如WVGA(480x800),FWVGA(480x854)
(2)drawable-mdpi裡面存放中等解析度的圖片,如HVGA(320x480)
(3)drawable-ldpi裡面存放低解析度的圖片,如QVGA(240x320)
(4)drawable-xhdpi裡面存放超大解析度的圖片,至少960dp x 720dp
由於我們自定義實現的RatingBar裡面使用到的星形圖片解析度比較低,所以一般情況下,我們把圖片放到drawable-mdpi或者drawable-ldpi裡面。

自定義RatingBar的實現過程

首先,根據圖片自定一個RatingBar的背景條,和圖片放到同一個目錄下面(比如drawable-mdpi),room_rating_bar.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/star1"></item> <span></span>

<item android:id="@+android:id/secondaryProgress"

android:drawable="@drawable/star1"></item>

<item android:id="@+android:id/progress"

android:drawable="@drawable/star2"></item>

</layer-list>

backgroud:是用來填充背景圖片的,和進度條非常類似,當我們設置最高評分時(android:numStars),系統就會根據我們的設置,來畫出以星星為單位的背景(假如android:numStars="5",就會畫出5顆灰色的星星)
progress:是用來在背景圖片基礎上進行填充的指示屬性(和進度條類似,第一進度位置)
secondaryProgress:同progress一樣屬於第二進度位置(如果不定義這個,進度條拖動,每次就畫出一整顆星星(亮),第二進度(暗)沒有覆蓋掉第一進度之後的位置,從左往右是拖不出來N.5顆星星的,這樣評分效果就不完整)

其次,通過開始介紹,我們知道RatingBar的樣式是通過style來切換的,在android中,我們可以通過在styles.xml文件中通過設置style屬性,來繼承我們需要自定控制項類型,如下styles.xml

?


<?xml version="1.0" encoding="utf-8"?>

<resources>

<style name="roomRatingBar" parent="@android:style/Widget.RatingBar">

<item name="android:progressDrawable">@drawable/room_rating_bar</item>

<item name="android:minHeight">16dp</item>

<item name="android:maxHeight">16dp</item>

</style>

</resources>

通過parent屬性來選擇繼承的父類,我們這里繼承RatingBar類。
重新定義progressDrawable屬性(RatingBar的背景條,和我們在首先裡面介紹的那樣)
maxHeight和minHeight可以根據我們圖片像素或者其他參考值來設定。

最後,在我們需要用到RatingBar的xml配置文件裡面添加RatingBar控制項。
main.xml

?

<RatingBar

android:id="@+id/room_ratingbar"

style="@style/roomRatingBar"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:numStars="5"

android:rating="4"

android:layout_marginLeft="10dp" >

</RatingBar>

E. android中如何改變ratingbar 顏色

首先我們在styles.xml寫入一個樣式:
<?xml version="1.0" encoding="utf-8"?>

<resources>

<style name="foodRatingBar" parent="@android:style/Widget.RatingBar">

<item name="android:progressDrawable">@drawable/food_ratingbar_full</item>

<item name="android:minHeight">48dip</item>

<茄鍵判item name="android:maxHeight">48dip</item>

</style>

</resources>

<?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/food_ratingbar_full_empty" />

<item android:id="@+android:id/secondaryProgress"

android:drawable="顫改@drawable/food_ratingbar_full_empty" />

<item android:id="@+android:id/progress"

android:drawable="@drawable/food_ratingbar_full_filled" />

亮態</layer-list>

food_ratingbar_full_empty是代表沒有選中圖片效果,food_ratingbar_full_filled選中圖片效果。
最後將style放入RatingBar中,即可實現你的圖片效果:

<RatingBar android:id="@+id/my_rating_bar"
style="@style/foodRatingBar" />

閱讀全文

與androidratingbar圖片相關的資料

熱點內容
把文件夾設鎖 瀏覽:570
命令行語句 瀏覽:218
企友3e財務如何連接伺服器 瀏覽:984
華為手機如何刪除卸載app殘留數據 瀏覽:543
rpm的命令作用 瀏覽:365
如何查看網站的伺服器時間 瀏覽:850
編譯局和人民出版社 瀏覽:652
java泛型extends 瀏覽:326
頭條程序員教學 瀏覽:772
安卓合並什麼意思 瀏覽:530
linux在光碟引導 瀏覽:537
imap伺服器地址怎麼查 瀏覽:654
作曲教程pdf 瀏覽:506
pr怎麼壓縮文件大小 瀏覽:863
查看oracle字元集命令 瀏覽:179
鋰電池增加密度 瀏覽:661
linux用戶密碼忘記 瀏覽:242
gb壓縮天然氣 瀏覽:635
圖片拼接不壓縮app 瀏覽:670
我的世界如何編程 瀏覽:86