program Weighted2; {$APPTYPE CONSOLE} {$R *.res} uses System.SysUtils, core_c in '..\..\include\сore\core_c.pas', Core.types_c in '..\..\include\сore\Core.types_c.pas', highgui_c in '..\..\include\highgui\highgui_c.pas'; Const filename_src1 = 'cat2-mirror.jpg'; filename_src2 = 'cat2.jpg'; Var image: pIplImage = nil; templ: pIplImage = nil; dst: pIplImage = nil; x, y, width, height: Integer; alpha, beta: Double; begin 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(); end.