我想显示一些十进制数字。尽可能多的需要在WPF中使用独特的画笔。
例如
-1.00 (display in Green and Orange)
0.00 (display in Orange)
1.00 (display in Green)
2.00 (display in Red)
不需要指定的模式。
根据我的情况,RBG很小。
255 * 255 * 255 = 16 581 375
值的颜色必须始终相同。
public Brush GetValueColor(decimal value)
{
//Generate Brush for value
return myBrush;
}
我不知道我的问题有什么问题。只需要一个函数就可以为每个唯一的数字返回一个唯一的画笔。它不会影响数字的外观。
答案 0 :(得分:2)
您总是可以根据value.ToString()中的字节生成LinearGradientBrush
GradientStops
。如果需要,您还可以将LinearGradientBrush
反转回小数值。
GetValueColor
public LinearGradientBrush GetValueColor(decimal value)
{
LinearGradientBrush brush = new LinearGradientBrush();
byte[] byteArray = Encoding.ASCII.GetBytes(value.ToString());
for (int i = 0; i < byteArray.Length; i += 3)
{
byte red = byteArray[i];
byte green = i < byteArray.Length - 1 ? byteArray[i + 1] : (byte)0;
byte blue = i < byteArray.Length - 2 ? byteArray[i + 2] : (byte)0;
brush.GradientStops.Add(
new GradientStop(new Color {A = 255, R = red, G = green, B = blue },
(double)(i+1) / byteArray.Length));
}
return brush;
}
反向:GetColorValue
public decimal GetColorValue(LinearGradientBrush brush)
{
List<byte> byteList = new List<byte>();
foreach (GradientStop gradientStop in brush.GradientStops)
{
byteList.Add(gradientStop.Color.R);
byteList.Add(gradientStop.Color.G);
byteList.Add(gradientStop.Color.B);
}
return Convert.ToDecimal(Encoding.ASCII.GetString(byteList.ToArray()));
}