Преобразование ARBG в RGB с альфа-смешиванием
Скажем, что у нас есть цвет ARGB:
Color argb = Color.FromARGB(127, 69, 12, 255); //Light Urple.
Когда это будет окрашено поверх существующего цвета, цвета будут смешиваться. Поэтому, когда он смешивается с белым, получившийся цвет Color.FromARGB(255, 162, 133, 255);
Решение должно работать следующим образом:
Color blend = Color.White;
Color argb = Color.FromARGB(127, 69, 12, 255); //Light Urple.
Color rgb = ToRGB(argb, blend); //Same as Color.FromARGB(255, 162, 133, 255);
Что такое ToRGB
реализация?
Ответы
Ответ 1
Он называется alpha blending.
В psuedocode, если цвет фона (blend) всегда имеет 255 альфа. Также предполагается, что альфа составляет 0-255.
alpha=argb.alpha()
r = (alpha/255)*argb.r() + (1 - alpha/255)*blend.r()
g = (alpha/255)*argb.g() + (1 - alpha/255)*blend.g()
b = (alpha/255)*argb.b() + (1 - alpha/255)*blend.b()
Примечание: вам, вероятно, нужно быть немного осторожным в вопросах математики и округления с плавающей точкой/в зависимости от языка. Соответственно литые промежуточные продукты
Отредактировано для добавления:
Если у вас нет цвета фона с альфой 255, алгебра становится намного сложнее. Я сделал это раньше, и это интересное упражнение осталось для читателя (если вам действительно нужно знать, задайте другой вопрос:).
Другими словами, какой цвет C смешивается с каким-то фоном так же, как смешивание A, а затем смешивание B. Это похоже на вычисление A + B (что не совпадает с B + A).
Ответ 2
Я знаю, что это старый поток, но я хочу добавить это:
Public Shared Function AlphaBlend(ByVal ForeGround As Color, ByVal BackGround As Color) As Color
If ForeGround.A = 0 Then Return BackGround
If BackGround.A = 0 Then Return ForeGround
If ForeGround.A = 255 Then Return ForeGround
Dim Alpha As Integer = CInt(ForeGround.A) + 1
Dim B As Integer = Alpha * ForeGround.B + (255 - Alpha) * BackGround.B >> 8
Dim G As Integer = Alpha * ForeGround.G + (255 - Alpha) * BackGround.G >> 8
Dim R As Integer = Alpha * ForeGround.R + (255 - Alpha) * BackGround.R >> 8
Dim A As Integer = ForeGround.A
If BackGround.A = 255 Then A = 255
If A > 255 Then A = 255
If R > 255 Then R = 255
If G > 255 Then G = 255
If B > 255 Then B = 255
Return Color.FromArgb(Math.Abs(A), Math.Abs(R), Math.Abs(G), Math.Abs(B))
End Function
public static Color AlphaBlend(Color ForeGround, Color BackGround)
{
if (ForeGround.A == 0)
return BackGround;
if (BackGround.A == 0)
return ForeGround;
if (ForeGround.A == 255)
return ForeGround;
int Alpha = Convert.ToInt32(ForeGround.A) + 1;
int B = Alpha * ForeGround.B + (255 - Alpha) * BackGround.B >> 8;
int G = Alpha * ForeGround.G + (255 - Alpha) * BackGround.G >> 8;
int R = Alpha * ForeGround.R + (255 - Alpha) * BackGround.R >> 8;
int A = ForeGround.A;
if (BackGround.A == 255)
A = 255;
if (A > 255)
A = 255;
if (R > 255)
R = 255;
if (G > 255)
G = 255;
if (B > 255)
B = 255;
return Color.FromArgb(Math.Abs(A), Math.Abs(R), Math.Abs(G), Math.Abs(B));
}
Ответ 3
если вам не нужно знать эту предварительную визуализацию, вы всегда можете использовать метод win32 для winpixel, я считаю.
Примечание: ввод текста на iPhone в середине Миссури без доступа inet. Посмотрите реальный пример win32 и посмотрите, есть ли эквивалент .net.
Если кто-то заботится и не хочет использовать (отличный) ответ выше, вы можете получить значение цвета пикселя в .Net по этой ссылке Пример MSDN