Winform 渐变色 调色板
原本想研究一下C#生成热力图,奈何知识点较多(相对于本人来讲),一下子看的有点懵,本着循序渐进的思想,在此记录一个相关功能。
生成一个可以自定义颜色的调色板,效果图:
渐变色图片实际是生成的一张位图,放在了Panel控件中 :
colorPanel.BackgroundImage = colorBitmap;
colorPanel是我的控件名,colorBitmap是位图对象的引用;
代码:
private void CreatePaletteImage()
{List<Color> newColors = new List<Color>();//颜色集合newColors.AddRange(GetGradientColorList(Color.Red, Color.Yellow, 64));newColors.AddRange(GetGradientColorList(Color.Yellow, Color.Green, 64));newColors.AddRange(GetGradientColorList(Color.Green, Color.Blue, 64));newColors.AddRange(GetGradientColorList(Color.Blue, Color.Navy, 64));//颜色调色板展示Bitmap colorBitmap = new Bitmap(colorPanel.Width, colorPanel.Height);//从位图中获得GDI+对象Graphics graphic = Graphics.FromImage(colorBitmap);for (int i = 0; i < 256; i++){SolidBrush solidBrush = new SolidBrush(newColors[i]);Rectangle rectangle = new Rectangle((int)(i * 2), 0, (int)2, colorPanel.Height);graphic.FillRectangle(solidBrush, rectangle);graphic.Save();solidBrush.Dispose();}colorPanel.BackgroundImage = colorBitmap;
}/// <summary>
/// 获得两个颜色之间渐进颜色的集合
/// </summary>
/// <returns>返回颜色集合</returns>
public static List<Color> GetGradientColorList(Color srcColor, Color desColor, int count)
{List<Color> colorFactorList = new List<Color>();int redSpan = desColor.R - srcColor.R;int greenSpan = desColor.G - srcColor.G;int blueSpan = desColor.B - srcColor.B;for (int i = 0; i < count; i++){Color color = Color.FromArgb(srcColor.R + (int)((double)i / count * redSpan),srcColor.G + (int)((double)i / count * greenSpan),srcColor.B + (int)((double)i / count * blueSpan));colorFactorList.Add(color);}return colorFactorList;
}
问:Graphics.FromImage(img);的功能是什么?这样定义后画布与图片的关系到底是怎样的?
答:
就是通过image创建了个画布,就是允许你改变image。你就想象成Graphics就像图片外面一层透明的膜,在膜上画图就相当于在image上画图了。
引用:Graphics - 我是牙牙 - 博客园
C# .Net实现简易灰度图和酷炫HeatMap热力图winform(进阶)_c# 热力图-CSDN博客