mirror of
https://github.com/Laex/Delphi-OpenCV.git
synced 2024-11-16 16:25:53 +01:00
105 lines
2.9 KiB
ObjectPascal
105 lines
2.9 KiB
ObjectPascal
|
{$APPTYPE CONSOLE}
|
|||
|
{$POINTERMATH ON}
|
|||
|
// JCL_DEBUG_EXPERT_GENERATEJDBG OFF
|
|||
|
// JCL_DEBUG_EXPERT_INSERTJDBG OFF
|
|||
|
// JCL_DEBUG_EXPERT_DELETEMAPFILE OFF
|
|||
|
program fback_c;
|
|||
|
|
|||
|
{$R *.res}
|
|||
|
|
|||
|
uses
|
|||
|
System.SysUtils,
|
|||
|
uLibName in '..\..\..\include\uLibName.pas',
|
|||
|
highgui_c in '..\..\..\include\highgui\highgui_c.pas',
|
|||
|
core_c in '..\..\..\include\<5C>ore\core_c.pas',
|
|||
|
Core.types_c in '..\..\..\include\<5C>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\<5C>ore\core.pas';
|
|||
|
|
|||
|
procedure drawOptFlowMap(const flow: pCvMat; cflowmap: pCvMat; step: Integer; scale: double; color: TCvScalar);
|
|||
|
Var
|
|||
|
x, y: Integer;
|
|||
|
fxy: TCvPoint2D32f;
|
|||
|
begin
|
|||
|
y := 0;
|
|||
|
While y < cflowmap^.rows do
|
|||
|
begin
|
|||
|
x := 0;
|
|||
|
while x < cflowmap^.cols do
|
|||
|
begin
|
|||
|
fxy := pCvPoint2D32f(CV_MAT_ELEM(flow^, SizeOf(TCvPoint2D32f), y, x))^;
|
|||
|
cvLine(cflowmap, cvPoint(x, y), cvPoint(cvRound(x + fxy.x), cvRound(y + fxy.y)), color, 1, 8, 0);
|
|||
|
cvCircle(cflowmap, cvPoint(x, y), 2, color, -1, 8, 0);
|
|||
|
x := x + step;
|
|||
|
end;
|
|||
|
y := y + step;
|
|||
|
end;
|
|||
|
end;
|
|||
|
|
|||
|
Var
|
|||
|
capture: pCvCapture;
|
|||
|
prevgray: pCvMat = nil;
|
|||
|
gray: pCvMat = nil;
|
|||
|
flow: pCvMat = nil;
|
|||
|
cflow: pCvMat = nil;
|
|||
|
firstFrame: boolean;
|
|||
|
frame: pIplImage;
|
|||
|
temp: pCvMat;
|
|||
|
|
|||
|
begin
|
|||
|
try
|
|||
|
Writeln(' This program demonstrate dense Farneback optical flow');
|
|||
|
Writeln('It read from camera 0, and shows how to use and display dense Franeback optical flow');
|
|||
|
Writeln('Usage: ');
|
|||
|
Writeln('fback_c ');
|
|||
|
|
|||
|
capture := cvCreateCameraCapture(0);
|
|||
|
Assert(Assigned(capture));
|
|||
|
|
|||
|
cvNamedWindow('flow', 1);
|
|||
|
while true do
|
|||
|
begin
|
|||
|
firstFrame := Assigned(gray);
|
|||
|
|
|||
|
frame := cvQueryFrame(capture);
|
|||
|
Assert(Assigned(frame));
|
|||
|
|
|||
|
if not Assigned(gray) then
|
|||
|
begin
|
|||
|
gray := cvCreateMat(frame^.height, frame^.width, CV_8UC1);
|
|||
|
prevgray := cvCreateMat(gray^.rows, gray^.cols, gray^._type);
|
|||
|
flow := cvCreateMat(gray^.rows, gray^.cols, CV_32FC2);
|
|||
|
cflow := cvCreateMat(gray^.rows, gray^.cols, CV_8UC3);
|
|||
|
end;
|
|||
|
cvCvtColor(frame, gray, CV_BGR2GRAY);
|
|||
|
|
|||
|
if firstFrame then
|
|||
|
begin
|
|||
|
cvCalcOpticalFlowFarneback(prevgray, gray, flow, 0.5, 3, 15, 3, 5, 1.2, 0);
|
|||
|
cvCvtColor(prevgray, cflow, CV_GRAY2BGR);
|
|||
|
drawOptFlowMap(flow, cflow, 16, 1.5, CV_RGB(0, 255, 0));
|
|||
|
cvShowImage('flow', cflow);
|
|||
|
end;
|
|||
|
|
|||
|
if (cvWaitKey(10) = 27) then
|
|||
|
break;
|
|||
|
|
|||
|
CV_SWAP(prevgray, gray, temp);
|
|||
|
|
|||
|
end;
|
|||
|
cvReleaseCapture(capture);
|
|||
|
|
|||
|
except
|
|||
|
on E: Exception do
|
|||
|
Writeln(E.ClassName, ': ', E.Message);
|
|||
|
end;
|
|||
|
|
|||
|
end.
|