我正在寻找一个转换它们的公式.
我知道转换一般的透明度
alpha * new(1 – alpha)* old
我有:
Color A : RGB( 85,113,135 ) Color B : RGB( 43,169,225 )
颜色A具有90%的不透明度,并且位于颜色B的顶部,从而产生
Color C : RGB( 65,119,145 )
我的问题是,它如何获得Color C?如果我将Color B替换为另一件事,我该如何获得Color C?
这是另一个例子,相同的基色:
Color A : RGB( 85,135 ) Color B : RGB( 45,67,82 ) -------- Color C : RGB( 65,109,131 )
这些是用图像完成的工作示例 – 我现在正在尝试计算剩余的颜色C,以便我可以指定背景颜色.
更新,请参阅接受的答案.上面例子中的红色很奇怪 – 接受的答案有所有颜色的正确公式,我在Photoshop中测试过.
解决方法
您的公式似乎正是您的示例中使用的公式,按组件计算并向上舍入.
R_c:=上限(R_a * alpha)上限(R_b *(1 – alpha))
G_c := ceiling(G_a * alpha) + ceiling (G_b * (1 - alpha)) B_c := ceiling(B_a * alpha) + ceiling (B_b * (1 - alpha))
但是,奇怪的是,R组件似乎不符合规则.我倾向于想知道为什么.