我已经将ratingBar颜色设置为
Android的默认蓝色和灰色的不同颜色 – 如果选择了黑色背景和粉红色,我的星星已经成为我的明星.
这是我的主要代码:
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); RatingBar ratingBar = (RatingBar) findViewById(R.id.ratingbar); LayerDrawable layerDrawable2 = (LayerDrawable) ratingBar.getProgressDrawable(); DrawableCompat.setTint(DrawableCompat.wrap(layerDrawable2.getDrawable(0)),ContextCompat.getColor(getApplicationContext(),android.R.color.background_dark)); DrawableCompat.setTint(DrawableCompat.wrap(layerDrawable2.getDrawable(1)),R.color.colorAccent)); // Partial star DrawableCompat.setTint(DrawableCompat.wrap(layerDrawable2.getDrawable(2)),R.color.colorAccent)); ratingBar.setIsIndicator(false); ratingBar.setRating(3.6f); ratingBar.setStepSize(0.1f); ratingBar.invalidate(); ratingBar.setIsIndicator(true); } }
你可以看到,如果我把评级设为3.6,最多可以选择4个.
但是,如果我注释自己的自定义颜色,则ratingBar设置正确,只显示第四颗星的一部分,因为传递给它的值为3.6:
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); RatingBar ratingBar = (RatingBar) findViewById(R.id.ratingbar); /* LayerDrawable layerDrawable2 = (LayerDrawable) ratingBar.getProgressDrawable(); DrawableCompat.setTint(DrawableCompat.wrap(layerDrawable2.getDrawable(0)),R.color.colorAccent));*/ ratingBar.setIsIndicator(false); ratingBar.setRating(3.6f); ratingBar.setStepSize(0.1f); ratingBar.invalidate(); ratingBar.setIsIndicator(true); } }
为什么如果我创建自己的自定义颜色,ratingBar没有正确填充?
我创建了一个小的回购,你可以下载它并在这里测试:https://github.com/Winghin2517/RatingBarTest2
编辑:
FlyingPumba的图书馆显示了我想要实现的一些承诺,但是当屏幕上显示星空背景是白色时,需要一种风格,当用户按下星号时,它将被纯色填满.在我的情况下,我想让它充满绿色.
以下是我能够实现的,但还不够.我改变了星空坐在粉红色的滚动景观背景,所以你可以看到,而不是星星的白色背景,从scrollview背景的粉红色闪耀.对于我的用例,我想要白色的星星坐在一个图像视图的前面,我不想让图像中的图像照亮星星.
此外,我不需要白色笔触,因为我想保持星星的造型简单.
<com.iarcuschin.simpleratingbar.SimpleRatingBar android:id="@+id/ratingBar3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_margin="8dp" app:srb_rating="3.6" app:srb_fillColor="@color/material_greenA700" app:srb_borderColor="@color/material_white" app:srb_starBorderWidth="0" app:srb_pressedFillColor="@color/material_greenA700" app:srb_starSize="30dp" />
解决方法
你在正确的轨道上,你正在尝试.你唯一做错了的是将错误的颜色分配给第二个drawable.
想想第二个可以作为明星的背景,而不是前景.所以部分星需要背景颜色,而不是星星的颜色,即在你的例子中,黑色,而不是粉红色.
以下是修改后的代码,其工作方式如下所述.我稍作重新格式化,以突显所需的变更.
RatingBar ratingBar = (RatingBar) findViewById(R.id.ratingbar); LayerDrawable layerDrawable2 = (LayerDrawable) ratingBar.getProgressDrawable(); // No star DrawableCompat.setTint(DrawableCompat.wrap(layerDrawable2.getDrawable(0)),android.R.color.background_dark)); // Partial star DrawableCompat.setTint(DrawableCompat.wrap(layerDrawable2.getDrawable(1)),// use background_dark instead of colorAccent // R.color.colorAccent)); android.R.color.background_dark)); // Custom star DrawableCompat.setTint(DrawableCompat.wrap(layerDrawable2.getDrawable(2)),R.color.colorAccent));
在许多情况下,另一种做法,也可能更好的方法是在RatingBar上使用适当的样式.
这需要为评分栏设置自定义样式,然后定义该样式使用的图层可绘制来指向您自己的图像或颜色.
我不会进一步细节,因为the actual xml code is shown in Anantham’s answer.