应用黑白显示
- 范例
- 代码
- 原理
- ColorMatrix转换原理
- 测试setSaturation(0),效果是黑白化
- 测试 setYUV2RGB YUV to RGB
- 反转
- 去色效果
- 代码
督促自己学习总结,特用文章的形式记录下来,共同进步
特殊日期应用页面需要黑白显示,是很多应用必须满足工信部的要求,也成为一般新闻类,娱乐类app的基本功能
范例
先看两张图
代码
在activity中拿到Window中的DecorVIew
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
if (getSP().getBoolean(KEY_TYPE, false)) {
val mPaint = Paint()
val cm = ColorMatrix()
cm.setSaturation(0F)
mPaint.colorFilter = ColorMatrixColorFilter(cm)
window.decorView.setLayerType(View.LAYER_TYPE_SOFTWARE, mPaint)
}
}在实际应用中KEY_TYPE的取值可以通过拉取服务器配置或者根据日期判断,达到项目要求
原理
android提供了颜色转化类ColorMatrix
* 4x5 matrix for transforming the color and alpha components of a Bitmap.
* The matrix can be passed as single array, and is treated as follows:
*
* <pre>
* [ a, b, c, d, e,
* f, g, h, i, j,
* k, l, m, n, o,
* p, q, r, s, t ]</pre>
提供一个4x5的矩阵,就是一个长度为20的数组* <p>
* When applied to a color <code>[R, G, B, A]</code>, the resulting color
* is computed as:
* </p>
*
* <pre>
* R’ = a*R + b*G + c*B + d*A + e;
* G’ = f*R + g*G + h*B + i*A + j;
* B’ = k*R + l*G + m*B + n*A + o;
* A’ = p*R + q*G + r*B + s*A + t;</pre>
*
* <p>
* That resulting color <code>[R’, G’, B’, A’]</code>
* then has each channel clamped to the <code>0</code> to <code>255</code>
* range.
* </p>
一个颜色值ARGB通过数组计算得到转化后的ARGBColorMatrix转换原理
转换后的颜色为:
计算结果:
nR = (a*R + b*G + c*B + d*A + e)&0xff
nG = (f*R + g*G + h*B + i*A + j)&0xff
nB = (k*R + l*G + m*B + n*A + o)&0xff
nA = (p*R + q*G + r*B + s*A + t)&0xff测试setSaturation(0),效果是黑白化
测试 setSaturation(0) [0.213, 0.715, 0.072, 0.0, 0.0, 0.213, 0.715, 0.072, 0.0, 0.0, 0.213, 0.715, 0.072, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0] --- start
BLACK 转换前 [a=255,r=0,g=0,b=0] 转换后 [a=255,r=0,g=0,b=0]
BLUE 转换前 [a=255,r=0,g=0,b=255] 转换后 [a=255,r=18,g=18,b=18]
RED 转换前 [a=255,r=255,g=0,b=0] 转换后 [a=255,r=54,g=54,b=54]
GREEN 转换前 [a=255,r=0,g=255,b=0] 转换后 [a=255,r=182,g=182,b=182]
YELLOW 转换前 [a=255,r=255,g=255,b=0] 转换后 [a=255,r=236,g=236,b=236]
MAGENTA 转换前 [a=255,r=255,g=0,b=255] 转换后 [a=255,r=72,g=72,b=72]
ORANGE 转换前 [a=255,r=255,g=200,b=0] 转换后 [a=255,r=197,g=197,b=197]
PINK 转换前 [a=255,r=255,g=175,b=175] 转换后 [a=255,r=192,g=192,b=192]展示效果:

测试 setYUV2RGB YUV to RGB
测试 setYUV2RGB [1.0, 0.0, 1.402, 0.0, 0.0, 1.0, -0.34414, -0.71414, 0.0, 0.0, 1.0, 1.772, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0] --- start
BLACK 转换前 [a=255,r=0,g=0,b=0] 转换后 [a=255,r=0,g=0,b=0]
BLUE 转换前 [a=255,r=0,g=0,b=255] 转换后 [a=255,r=101,g=74,b=0]
RED 转换前 [a=255,r=255,g=0,b=0] 转换后 [a=255,r=255,g=255,b=255]
GREEN 转换前 [a=255,r=0,g=255,b=0] 转换后 [a=255,r=0,g=169,b=195]
YELLOW 转换前 [a=255,r=255,g=255,b=0] 转换后 [a=255,r=255,g=167,b=194]
MAGENTA 转换前 [a=255,r=255,g=0,b=255] 转换后 [a=255,r=100,g=72,b=255]
ORANGE 转换前 [a=255,r=255,g=200,b=0] 转换后 [a=255,r=255,g=186,b=97]
PINK 转换前 [a=255,r=255,g=175,b=175] 转换后 [a=255,r=244,g=69,b=53]展示效果:

反转
BLACK 转换前 [a=255,r=0,g=0,b=0] 转换后 [a=255,r=0,g=0,b=0]
BLUE 转换前 [a=255,r=0,g=0,b=255] 转换后 [a=255,r=0,g=0,b=1]
RED 转换前 [a=255,r=255,g=0,b=0] 转换后 [a=255,r=1,g=0,b=0]
GREEN 转换前 [a=255,r=0,g=255,b=0] 转换后 [a=255,r=0,g=1,b=0]
YELLOW 转换前 [a=255,r=255,g=255,b=0] 转换后 [a=255,r=1,g=1,b=0]
MAGENTA 转换前 [a=255,r=255,g=0,b=255] 转换后 [a=255,r=1,g=0,b=1]
ORANGE 转换前 [a=255,r=255,g=200,b=0] 转换后 [a=255,r=1,g=56,b=0]
PINK 转换前 [a=255,r=255,g=175,b=175] 转换后 [a=255,r=1,g=81,b=81]
去色效果
BLACK 转换前 [a=255,r=0,g=0,b=0] 转换后 [a=1,r=255,g=255,b=255]
BLUE 转换前 [a=255,r=0,g=0,b=255] 转换后 [a=1,r=125,g=125,b=125]
RED 转换前 [a=255,r=255,g=0,b=0] 转换后 [a=1,r=125,g=125,b=125]
GREEN 转换前 [a=255,r=0,g=255,b=0] 转换后 [a=1,r=125,g=125,b=125]
YELLOW 转换前 [a=255,r=255,g=255,b=0] 转换后 [a=1,r=252,g=252,b=252]
MAGENTA 转换前 [a=255,r=255,g=0,b=255] 转换后 [a=1,r=252,g=252,b=252]
ORANGE 转换前 [a=255,r=255,g=200,b=0] 转换后 [a=1,r=169,g=169,b=169]
PINK 转换前 [a=255,r=255,g=175,b=175] 转换后 [a=1,r=138,g=138,b=138]
还有很多颜色转换的功能,这里就不一一列举了,实际根据工作中的需要选择合适转换


















