R和B使用这个逻辑时得到错误,我似乎无法找到什么即时做错了,我到底解决办法是我翻转R和B是不擅长的一切,我尝试找出其中的逻辑breakes

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);
    }
 }
}
有帮助吗?

解决方案

我觉得你在一个奇怪的方式去了解这一点;颜色有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);
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top