我已经将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.