您好如何在中设置R G B
值System.Drawing.Color.G
?
这是System.Drawing.Color.G=255;
不允许的,因为它是只读的
Property or indexer 'System.Drawing.Color.G' cannot be assigned toit is read only
我只需要Color
通过分配自定义R G B
值来创建对象
您好如何在中设置R G B
值System.Drawing.Color.G
?
这是System.Drawing.Color.G=255;
不允许的,因为它是只读的
Property or indexer 'System.Drawing.Color.G' cannot be assigned toit is read only
我只需要Color
通过分配自定义R G B
值来创建对象
Answers:
该Color
结构是不可变的(就像所有结构一样),这意味着一旦创建了特定实例,就不能更改其属性的值。
相反,您需要使用所需的属性值创建结构的新实例。由于要使用其分量RGB值创建颜色,因此需要使用FromArgb
方法:
Color myColor = Color.FromArgb(100, 150, 75);
您必须使用Color.FromArgb方法创建新的颜色结构
var newColor = Color.FromArgb(0xCC,0xBB,0xAA);
您可以扩展以仅更改一种颜色分量
static class ColorExtension
{
public static Color ChangeG(Color this color,byte g)
{
return Color.FromArgb(color.A,color.R,g,color.B);
}
}
那么您可以使用以下代码:
yourColor = yourColor.ChangeG(100);
yourColor = Color.FromArgb(yourColor.A,yourColor.R,100,yourColor.B);
。所以很有用
G
是否仅仅是改变,或者它是否还会产生其他效果,在视觉上几乎是不明显的。考虑到Color结构的设计,我认为没有解决此问题的好方法。如果有一个ArgbColor
具有四个暴露的单字节字段的简单结构,以及一个Color
可以隐式转换为该类的类,var temp = myColor.AsArgb(); temp.Green=100; myColor = temp;
则应明确指出,例如,如果它myColor
已被命名为系统颜色...
AsArgb
方法滤除任何此类特征,但Green
将保留未通过该方法滤除的所有其他特征。实际上,如果定义了一种扩展方法以转换为开放字段结构类型,则即使Color
定义了该方法,该方法也可能是可行的,并且可能是做事的最佳方法。
using System;
using System.Drawing;
public struct MyColor
{
private byte a, r, g, b;
public byte A
{
get
{
return this.a;
}
}
public byte R
{
get
{
return this.r;
}
}
public byte G
{
get
{
return this.g;
}
}
public byte B
{
get
{
return this.b;
}
}
public MyColor SetAlpha(byte value)
{
this.a = value;
return this;
}
public MyColor SetRed(byte value)
{
this.r = value;
return this;
}
public MyColor SetGreen(byte value)
{
this.g = value;
return this;
}
public MyColor SetBlue(byte value)
{
this.b = value;
return this;
}
public int ToArgb()
{
return (int)(A << 24) || (int)(R << 16) || (int)(G << 8) || (int)(B);
}
public override string ToString ()
{
return string.Format ("[MyColor: A={0}, R={1}, G={2}, B={3}]", A, R, G, B);
}
public static MyColor FromArgb(byte alpha, byte red, byte green, byte blue)
{
return new MyColor().SetAlpha(alpha).SetRed(red).SetGreen(green).SetBlue(blue);
}
public static MyColor FromArgb(byte red, byte green, byte blue)
{
return MyColor.FromArgb(255, red, green, blue);
}
public static MyColor FromArgb(byte alpha, MyColor baseColor)
{
return MyColor.FromArgb(alpha, baseColor.R, baseColor.G, baseColor.B);
}
public static MyColor FromArgb(int argb)
{
return MyColor.FromArgb(argb & 255, (argb >> 8) & 255, (argb >> 16) & 255, (argb >> 24) & 255);
}
public static implicit operator Color(MyColor myColor)
{
return Color.FromArgb(myColor.ToArgb());
}
public static implicit operator MyColor(Color color)
{
return MyColor.FromArgb(color.ToArgb());
}
}