R和B在使用这个逻辑时出错,我似乎无法找到我做错了什么,我的解决方法到底是我翻转r和b是不是很好并且我试图找到逻辑中断的地方
label1.Text = colorX;显示R = 255,G = 0,B = 0,当它被称为R = 0,G = 0,B = 255,这在哪里失败?
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Runtime.InteropServices;
using System.Text.RegularExpressions;
namespace Color_tool
{
public partial class Form1 : Form
{
Regex rgbInputR;
Regex rgbInputG;
Regex rgbInputB;
int r;
int g;
int b;
string colorX;
[DllImport("gdi32")]
private static extern int GetPixel(IntPtr hdc, int x, int y);
[DllImport("User32")]
private static extern IntPtr GetWindowDC(IntPtr hwnd);
private static readonly IntPtr DesktopDC = GetWindowDC(IntPtr.Zero);
public static System.Drawing.Color GetPixelAtCursor()
{
System.Drawing.Point p = Cursor.Position;
return System.Drawing.Color.FromArgb(GetPixel(DesktopDC, p.X, p.Y));
}
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
button1.BackColor = Color.Black;
}
private void timer1_Tick(object sender, EventArgs e)
{
colorX = GetPixelAtCursor().ToString();
Color backX = GetPixelAtCursor();
this.BackColor = Color.FromArgb(r,g,b);
label1.Text = colorX;
RGB_value();
}
private void button1_Click(object sender, EventArgs e)
{
if (timer1.Enabled == false)
timer1.Enabled = true;
else
timer1.Enabled = false;
}
private void RGB_value()
{
rgbInputR = new Regex(@"(?<=R=)\d{0,3}");
rgbInputG = new Regex(@"(?<=G=)\d{0,3}");
rgbInputB = new Regex(@"(?<=B=)\d{0,3}");
Match R, G, B;
R = rgbInputR.Match(colorX);
G = rgbInputG.Match(colorX);
B = rgbInputB.Match(colorX);
//had to flip the R and B ???
b = int.Parse(R.Groups[0].Value);
g = int.Parse(G.Groups[0].Value);
r = int.Parse(B.Groups[0].Value);
}
}
}
答案 0 :(得分:2)
我认为你会以一种奇怪的方式解决这个问题。 Color可以使用R,G和B属性而不是字符串匹配:
R = colorX.R;
G = colorX.G;
B = colorX.B;
其次,要解决您的问题,GetPixel可能会获得BGR格式的像素而不是RGB。 BGR通常用于位图,你正在谈论的窗口的HDC最有可能以这种格式返回。
修改:来自MSDN文档:
指定显式RGB颜色时, COLORREF值具有以下内容 十六进制形式。 0x00bbggrr
Color.FromArgb()方法需要0xAARRGGBB。你的解决方法很好,虽然在你调用.FromArgb()方法之前正确的解决方法是翻转R和B组件:
int color = GetPixel(...);
return Color.FromArgb(color & 0xFF, color >> 8 & 0xFF, color >> 16);