在很多应用中我们都会看到很多通过进度来变化背景的颜色,比如像清理手机垃圾的一些软件在扫描垃圾的同时缓慢的改变背景颜色,原理是这样的先获得开始和结束颜色的2进制值求出他们三颜色的差值再计算每变化一刻进度变化的颜色值.代码如下:
//自定义View 根据进度改变view的背景颜色
public void setBackgroundColor(int progress) {//通过对比要变化开始的颜色和结束的颜色的差值来计算颜色的变化
//从蓝色变化到橘黄色(progress 0到1)
float h = 24F + progress * 194F / 100;
float s = Math.min(0.82F, 0.82F - progress * 0.08F / 100);
float v = Math.min(0.85F, 0.85F + progress * 0.19F / 100);
super.setBackgroundColor(DateUtil.hsb2rgb(h, s, v));
}
public void setProgress(int progress) {//从蓝色变化到红色
float h = 218F + progress * 145F / 100;
float s = 0.74F;
float v = Math.min(0.88F, 0.66F + progress * 0.275F / 100);
super.setBackgroundColor(DateUtil.hsb2rgb(h, s, v));
}
//颜色2进制算法
public static int hsb2rgb(float h, float s, float v) {
h = h % 360;
assert Float.compare(h, 0.0f) >= 0 && Float.compare(h, 360.0f) <= 0;
assert Float.compare(s, 0.0f) >= 0 && Float.compare(s, 1.0f) <= 0;
assert Float.compare(v, 0.0f) >= 0 && Float.compare(v, 1.0f) <= 0;
float r = 0, g = 0, b = 0;
int i = (int) ((h / 60) % 6);
float f = (h / 60) - i;
float p = v * (1 - s);
float q = v * (1 - f * s);
float t = v * (1 - (1 - f) * s);
switch (i) {
case 0:
r = v;
g = t;
b = p;
break;
case 1:
r = q;
g = v;
b = p;
break;
case 2:
r = p;
g = v;
b = t;
break;
case 3:
r = p;
g = q;
b = v;
break;
case 4:
r = t;
g = p;
b = v;
break;
case 5:
r = v;
g = p;
b = q;
break;
default:
break;
}
return Color.argb(0xFF, (int) (r * 255.0), (int) (g * 255.0),
(int) (b * 255.0));
}