我试过 Jonny Piazzi 写的方法。但它不能正常工作。
所以我在下面写了我自己的一个:
private static Color GetColorByOffset(GradientStopCollection collection, double offset)
{
GradientStop[] stops = collection.OrderBy(x => x.Offset).ToArray();
if (offset <= 0) return stops[0].Color;
if (offset >= 1) return stops[stops.Length - 1].Color;
GradientStop left = stops[0], right = null;
foreach (GradientStop stop in stops)
{
if (stop.Offset >= offset)
{
right = stop;
break;
}
left = stop;
}
Debug.Assert(right != null);
offset = Math.Round((offset - left.Offset)/(right.Offset - left.Offset), 2);
byte a = (byte) ((right.Color.A - left.Color.A)*offset + left.Color.A);
byte r = (byte) ((right.Color.R - left.Color.R)*offset + left.Color.R);
byte g = (byte) ((right.Color.G - left.Color.G)*offset + left.Color.G);
byte b = (byte) ((right.Color.B - left.Color.B)*offset + left.Color.B);
return Color.FromArgb(a, r, g, b);
}
我希望这个对你有用!
我在下面的 xaml 代码中使用了此方法,以将指定的数字显示为热图位置。
<LinearGradientBrush x:Key="CountBrush" StartPoint="0 0" EndPoint="1 0">
<GradientStop Offset="0.00" Color="ForestGreen"/>
<GradientStop Offset="0.50" Color="Yellow"/>
<GradientStop Offset="1.00" Color="OrangeRed"/>
</LinearGradientBrush>
<local:Int32ToColorConverter x:Key="CountToColorConverter" Min="0" Max="200" LinearBrush="{StaticResource CountBrush}"/>