У меня есть такой код, чтобы найти все экземпляры шаблона в результирующем изображении.
Image<Gray, Byte> templateImage = new Image<Gray, Byte>(bmpSnip);
Image<Gray, float> imgMatch = sourceImage.MatchTemplate(templateImage, Emgu.CV.CvEnum.TM_TYPE.CV_TM_CCOEFF_NORMED);
и затем циклически проверять свойство imgMatch.Data [,,], если оценка превышает порог(скажем,> 0,75) и поместите маркеры на изображение о совпадении.Но совпадения не имеют никакого смысла, я подозреваю, что я неправильно понимаю координаты.
float[,,] matches = imgMatch.Data;
for (int x = 0; x < matches.GetLength(0); x++)
{
for (int y = 0; y < matches.GetLength(1); y++)
{
double matchScore = matches[x, y, 0];
if (matchScore > 0.75)
{
Rectangle rect = new Rectangle(new Point(x,y), new Size(1, 1));
imgSource.Draw(rect, new Bgr(Color.Blue), 1);
}
}
}
Если я использую MinMax, как показано ниже:
double[] min, max;
Point[] pointMin, pointMax;
imgMatch.MinMax(out min, out max, out pointMin, out pointMax);
и установите маркер (прямоугольник), чтобы выделить совпадение, я получаю очень хороший результат.Так что я уверен, что это связано с определением координат для imgMatch.Data [,,]
Есть идеи, где я ошибаюсь?