可能重复:
如何快速进行 Alpha 混合?
Alpha 混合 2 种 RGBA(整数)颜色的最快方法是什么?
请注意,要混合的目标颜色始终是不透明的,只有第二种颜色可以具有不同级别的透明度。
我试图在 C 中找到最快的方法,考虑到混合的最终结果颜色必须最终没有透明度,完全不透明(alpha = 0xff)
可能重复:
如何快速进行 Alpha 混合?
Alpha 混合 2 种 RGBA(整数)颜色的最快方法是什么?
请注意,要混合的目标颜色始终是不透明的,只有第二种颜色可以具有不同级别的透明度。
我试图在 C 中找到最快的方法,考虑到混合的最终结果颜色必须最终没有透明度,完全不透明(alpha = 0xff)
int blend(unsigned char result[4], unsigned char fg[4], unsigned char bg[4])
{
unsigned int alpha = fg[3] + 1;
unsigned int inv_alpha = 256 - fg[3];
result[0] = (unsigned char)((alpha * fg[0] + inv_alpha * bg[0]) >> 8);
result[1] = (unsigned char)((alpha * fg[1] + inv_alpha * bg[1]) >> 8);
result[2] = (unsigned char)((alpha * fg[2] + inv_alpha * bg[2]) >> 8);
result[3] = 0xff;
}
我不知道它有多快,但它都是整数。它通过将 alpha(和 inv_alpha)转换为 8.8 定点表示来工作。不用担心 alpha 的最小值为 1。在这种情况下,fg[3] 为 0,这意味着前景是透明的。混合将是 1*fg + 256*bg,这意味着 fg 的所有位都将从结果中移出。
事实上,如果您将 RGBA 打包成 64 位整数,您可以非常快地完成它。然后,您可以使用单个表达式并行计算所有三种结果颜色。