// JCL_DEBUG_EXPERT_GENERATEJDBG OFF // JCL_DEBUG_EXPERT_INSERTJDBG OFF // JCL_DEBUG_EXPERT_DELETEMAPFILE OFF program cvSetImageROI_cvAddWeighted; {$APPTYPE CONSOLE} {$R *.res} uses System.SysUtils, uLibName in '..\..\..\include\uLibName.pas', highgui_c in '..\..\..\include\highgui\highgui_c.pas', core_c in '..\..\..\include\сore\core_c.pas', Core.types_c in '..\..\..\include\сore\Core.types_c.pas', imgproc.types_c in '..\..\..\include\imgproc\imgproc.types_c.pas', imgproc_c in '..\..\..\include\imgproc\imgproc_c.pas', legacy in '..\..\..\include\legacy\legacy.pas', calib3d in '..\..\..\include\calib3d\calib3d.pas', imgproc in '..\..\..\include\imgproc\imgproc.pas', haar in '..\..\..\include\objdetect\haar.pas', objdetect in '..\..\..\include\objdetect\objdetect.pas', tracking in '..\..\..\include\video\tracking.pas', Core in '..\..\..\include\сore\core.pas' ; Const filename_src1 = 'Resource\cat2-mirror.jpg'; filename_src2 = 'Resource\cat2.jpg'; Var image: pIplImage = nil; templ: pIplImage = nil; dst: pIplImage = nil; x, y, width, height: Integer; alpha, beta: Double; begin try image := cvLoadImage(filename_src1); WriteLn(Format('[i] image_src1: %s', [filename_src1])); templ := cvLoadImage(filename_src2); WriteLn(Format('[i] image_src2: %s', [filename_src2])); cvNamedWindow('origianl', CV_WINDOW_AUTOSIZE); cvNamedWindow('template', CV_WINDOW_AUTOSIZE); cvNamedWindow('res', CV_WINDOW_AUTOSIZE); dst := cvCloneImage(templ); // размер шаблона width := templ^.width; height := templ^.height; // оригинал и шаблон cvShowImage('origianl', image); cvShowImage('template', templ); x := 0; y := 0; // задаём весовые коэффициенты alpha := 0.5; beta := 0.5; // устанавливаем область интереса cvSetImageROI(image, cvRect(x, y, width, height)); // взвешенная сумма cvAddWeighted(image, alpha, templ, beta, 0.0, dst); // освобождаем область интереса cvResetImageROI(image); // показываем результат cvShowImage('res', dst); // ждём нажатия клавиши cvWaitKey(0); // освобождаем ресурсы cvReleaseImage(image); cvReleaseImage(templ); cvReleaseImage(dst); cvDestroyAllWindows(); except on E: Exception do Writeln(E.ClassName, ': ', E.Message); end; end.