问题样式评分栏
Posted
技术标签:
【中文标题】问题样式评分栏【英文标题】:Issue styling Rating bar 【发布时间】:2016-06-01 02:25:00 【问题描述】:我在设置评分栏时遇到问题
这是截图
我想减小评分栏的大小。我知道我可以使用小样式来使它们变小,但这太小了。我可以做一些中等风格的吗?。
这是我的 xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_
android:layout_
android:background="#ffffff">
<LinearLayout
android:layout_
android:layout_
android:background="#F0EEEF">
<TextView
android:layout_
android:layout_
android:text="RATE OUR SERVICES"
android:gravity="center"
android:textColor="@color/textColor"
android:textStyle="bold"/>
</LinearLayout>
<TextView
android:layout_
android:layout_
android:text="By Quality"
android:layout_gravity="center_horizontal"
android:layout_marginTop="20dp"/>
<RatingBar
android:theme="@style/RatingBar"
android:layout_
android:layout_
android:layout_gravity="center_horizontal"
android:layout_marginTop="5dp"
android:numStars="5"
android:isIndicator="false" />
<TextView
android:layout_
android:layout_
android:text="By Services"
android:layout_gravity="center_horizontal"
android:layout_marginTop="10dp"/>
<RatingBar
android:theme="@style/RatingBar"
android:layout_
android:layout_
android:layout_gravity="center_horizontal"
android:layout_marginTop="5dp"
android:numStars="5"
android:isIndicator="false" />
<TextView
android:layout_
android:layout_
android:text="By Time"
android:layout_gravity="center_horizontal"
android:layout_marginTop="10dp"/>
<RatingBar
android:theme="@style/RatingBar"
android:layout_
android:layout_
android:layout_gravity="center_horizontal"
android:layout_marginTop="5dp"
android:numStars="5"
android:isIndicator="false" />
<TextView
android:layout_
android:layout_
android:text="Overall Rating"
android:layout_gravity="center_horizontal"
android:layout_marginTop="10dp"/>
<RatingBar
android:theme="@style/RatingBar"
android:layout_
android:layout_
android:layout_gravity="center_horizontal"
android:layout_marginTop="5dp"
android:numStars="5"
android:isIndicator="false" />
</LinearLayout>
【问题讨论】:
代替 wrap_content 为 layout_widht 和 layout_height,将你想要的尺寸放在 dp 中。 (例如 layout_width 为 150dp) 在 dp 中给出高度宽度时,评分栏会被裁剪 我认为 RatingBar 太静态了.....见这里:***.com/questions/2874537/… 【参考方案1】:您可以使用自定义 RatingBar。以下是代码 1.在drawable中创建一个文件custom_ratingbar.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/star_empty" />
<item android:id="@android:id/secondaryProgress"
android:drawable="@drawable/star_empty" />
<item android:id="@android:id/progress"
android:drawable="@drawable/star_full" />
</layer-list>
然后在您的 RatingBar 中使用以下内容:-
<RatingBar
android:id="@+id/ratingBar"
android:layout_
android:layout_
android:layout_gravity="center_horizontal"
android:progressDrawable="@drawable/custom_ratingbar"
android:numStars="5"
android:stepSize="0.2"
android:rating="3.0" />
【讨论】:
【参考方案2】:您可以为 ratingbar 创建自定义样式以使其具有合适的大小:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="foodRatingBar" parent="@android:style/Widget.RatingBar">
<item name="android:minHeight">48dip</item> <!-- your desired size -->
<item name="android:maxHeight">48dip</item> <!-- your desired size -->
</style>
</resources>
然后在您的评分栏上使用此样式。 还有更具体的教程:http://kozyr.zydako.net/2010/05/23/pretty-ratingbar/。
【讨论】:
【参考方案3】:我制作了一个自定义评分栏,可能会对您有所帮助:SimpleRatingBar。
它的特点:
完全正常工作android:layout_width
:可以设置为wrap_content
、match_parent
或abritary dp。
任意数量的星星。
任意步长。
星星的大小可以精确控制或通过设置最大大小来控制。
可自定义颜色(星星的边框、填充和背景)。
可自定义的星号间距。
可自定义的星星边框宽度。
允许设置 OnRatingBarChangeListener
星形填充可以设置为从左到右或从右到左开始(支持 RTL 语言)。
AnimationBuilder 集成在视图中,可通过动画以编程方式设置评分。
Here is a preview of it.
您可以在jcenter
或Maven Central
中找到它。所以在你的 build.gradle
文件中添加你的依赖项:
compile 'com.iarcuschin:simpleratingbar:0.1.+'
希望对你有用。
【讨论】:
这个项目已经结束了,下次一定会试一试以上是关于问题样式评分栏的主要内容,如果未能解决你的问题,请参考以下文章