[英]C# Code takes to long to run. Is there a way to make it finish quicker?
[英]Make this simple c# image searching code quicker?
我正在掃描屏幕以使用下面的代碼單擊按鈕。
我傳入了兩個位圖,一個是按鈕的圖片,另一個是屏幕截圖。
無論如何我可以加快這種基本方法的速度嗎?
private PositionToClick IsInCapture(Bitmap searchFor, Bitmap searchIn)
{
for (int x = 0; x < searchIn.Width; x++)
{
for (int y = 0; y < searchIn.Height; y++)
{
bool invalid = false;
int k = x, l = y;
for (int a = 0; a < searchFor.Width; a++)
{
l = y;
for (int b = 0; b < searchFor.Height; b++)
{
if (searchFor.GetPixel(a, b) != searchIn.GetPixel(k, l))
{
invalid = true;
break;
}
else
l++;
}
if (invalid)
break;
else
k++;
}
if (!invalid)
return new PositionToClick() { X = x, Y = y, found = true };
}
}
return new PositionToClick();
}
您可以先將位圖轉換為字節數組,然后再比較這些數組。 此外,您可以通過減去您正在搜索的圖像的寬度和高度來限制您的搜索區域。 我沒有測試下面的代碼,這只是我的意思的說明。
private PositionToClick IsInCapture(Bitmap searchFor, Bitmap searchIn)
{
var searchForArray = ImageToByte2(searchFor);
var searchInArray = ImageToByte2(searchIn);
for (int x = 0; x <= searchIn.Width - searchFor.Width; x++)
{
for (int y = 0; y <= searchIn.Height - searchFor.Height; y++)
{
bool invalid = false;
int k = x, l = y;
for (int a = 0; a < searchFor.Width; a++)
{
l = y;
for (int b = 0; b < searchFor.Height; b++)
{
var pixelFor = searchForArray[a * searchFor.Width + b];
var pixelIn = searchInArray[k + searchIn.Width + l];
if (pixelIn != pixelFor)
{
invalid = true;
break;
}
else
l++;
}
if (invalid)
break;
else
k++;
}
if (!invalid)
return new PositionToClick() { X = x, Y = y, found = true };
}
}
return new PositionToClick();
}
public static byte[] ImageToByte2(Image img)
{
using (var stream = new MemoryStream())
{
img.Save(stream, System.Drawing.Imaging.ImageFormat.Png);
return stream.ToArray();
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.