2013-04-09 12:41:27 +02:00
|
|
|
|
|
|
|
|
|
(* /*****************************************************************
|
|
|
|
|
// Delphi-OpenCV Demo
|
|
|
|
|
// Copyright (C) 2013 Project Delphi-OpenCV
|
|
|
|
|
// ****************************************************************
|
|
|
|
|
// Contributor:
|
|
|
|
|
// laentir Valetov
|
|
|
|
|
// email:laex@bk.ru
|
|
|
|
|
// ****************************************************************
|
|
|
|
|
// You may retrieve the latest version of this file at the GitHub,
|
|
|
|
|
// located at git://github.com/Laex/Delphi-OpenCV.git
|
|
|
|
|
// ****************************************************************
|
|
|
|
|
// The contents of this file are used with permission, subject to
|
|
|
|
|
// the Mozilla Public License Version 1.1 (the "License"); you may
|
|
|
|
|
// not use this file except in compliance with the License. You may
|
|
|
|
|
// obtain a copy of the License at
|
|
|
|
|
// http://www.mozilla.org/MPL/MPL-1_1Final.html
|
|
|
|
|
//
|
|
|
|
|
// Software distributed under the License is distributed on an
|
|
|
|
|
// "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
|
|
|
|
|
// implied. See the License for the specific language governing
|
|
|
|
|
// rights and limitations under the License.
|
|
|
|
|
******************************************************************* *)
|
2013-04-02 00:17:25 +02:00
|
|
|
|
// JCL_DEBUG_EXPERT_GENERATEJDBG OFF
|
|
|
|
|
// JCL_DEBUG_EXPERT_INSERTJDBG OFF
|
|
|
|
|
// JCL_DEBUG_EXPERT_DELETEMAPFILE OFF
|
|
|
|
|
program cv_Save;
|
|
|
|
|
|
2013-04-09 12:41:27 +02:00
|
|
|
|
{$APPTYPE CONSOLE}
|
|
|
|
|
{$POINTERMATH ON}
|
|
|
|
|
|
2013-04-02 00:17:25 +02:00
|
|
|
|
{$R *.res}
|
|
|
|
|
|
|
|
|
|
uses
|
|
|
|
|
System.SysUtils,
|
2013-04-05 22:58:24 +02:00
|
|
|
|
uLibName in '..\..\..\include\uLibName.pas',
|
|
|
|
|
highgui_c in '..\..\..\include\highgui\highgui_c.pas',
|
2013-04-18 08:34:16 +02:00
|
|
|
|
core_c in '..\..\..\include\core\core_c.pas',
|
|
|
|
|
Core.types_c in '..\..\..\include\core\Core.types_c.pas',
|
2013-04-05 22:58:24 +02:00
|
|
|
|
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',
|
2013-04-18 08:34:16 +02:00
|
|
|
|
Core in '..\..\..\include\core\core.pas'
|
2013-04-05 13:36:47 +02:00
|
|
|
|
;
|
2013-04-02 00:17:25 +02:00
|
|
|
|
|
|
|
|
|
Const
|
|
|
|
|
kernet_filename = 'result\kernel.xml';
|
|
|
|
|
|
|
|
|
|
Var
|
|
|
|
|
kernel: array [0 .. 8] of Single;
|
|
|
|
|
kernel_matrix: TCvMat;
|
|
|
|
|
i: Integer;
|
|
|
|
|
j: Integer;
|
|
|
|
|
matrix: pCvMat;
|
|
|
|
|
ptr: pSingle;
|
|
|
|
|
fs: pCvFileStorage;
|
|
|
|
|
frame_count: Integer;
|
|
|
|
|
s: pCvSeq;
|
|
|
|
|
frame_width: Integer;
|
|
|
|
|
frame_height: Integer;
|
|
|
|
|
color_cvt_matrix: pCvMat;
|
|
|
|
|
|
|
|
|
|
begin
|
|
|
|
|
try
|
2013-04-18 08:34:16 +02:00
|
|
|
|
// <20>ccc<63><63>, c<><63><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2013-04-02 00:17:25 +02:00
|
|
|
|
kernel[0] := 1;
|
|
|
|
|
kernel[1] := 0;
|
|
|
|
|
kernel[2] := 0;
|
|
|
|
|
kernel[3] := 0;
|
|
|
|
|
kernel[4] := 2;
|
|
|
|
|
kernel[5] := 0;
|
|
|
|
|
kernel[6] := 0;
|
|
|
|
|
kernel[7] := 0;
|
|
|
|
|
kernel[8] := 3;
|
2013-04-18 08:34:16 +02:00
|
|
|
|
// c<><63><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2013-04-02 00:17:25 +02:00
|
|
|
|
kernel_matrix := cvMat(3, 3, CV_32FC1, @kernel);
|
2013-04-18 08:34:16 +02:00
|
|
|
|
// c<><63><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> XML-<2D><><EFBFBD><EFBFBD>
|
2013-04-02 00:17:25 +02:00
|
|
|
|
cvSave(kernet_filename, @kernel_matrix);
|
|
|
|
|
// <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> XML-<2D><><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
matrix := pCvMat(cvLoad(kernet_filename));
|
2013-04-18 08:34:16 +02:00
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> c<><63><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
// 1 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: c <20>c<EFBFBD><63><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>c<EFBFBD> CV_MAT_ELEM
|
2013-04-02 00:17:25 +02:00
|
|
|
|
for i := 0 to matrix^.rows - 1 do
|
|
|
|
|
begin
|
|
|
|
|
for j := 0 to matrix^.cols - 1 do
|
2013-04-05 22:58:24 +02:00
|
|
|
|
Write(Format('%.0f ', [pSingle(CV_MAT_ELEM(matrix^, SizeOf(single), i, j))^]));
|
2013-04-02 00:17:25 +02:00
|
|
|
|
Writeln;
|
|
|
|
|
end;
|
|
|
|
|
Writeln;
|
|
|
|
|
|
2013-04-18 08:34:16 +02:00
|
|
|
|
// 2 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: c <20>c<EFBFBD><63><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> cvGet2D()
|
2013-04-02 00:17:25 +02:00
|
|
|
|
// cvGetReal2D() <20><><EFBFBD> CV_64FC1
|
|
|
|
|
for i := 0 to matrix^.rows - 1 do
|
|
|
|
|
begin
|
|
|
|
|
for j := 0 to matrix^.cols - 1 do
|
|
|
|
|
Write(Format('%.0f ', [cvGet2D(matrix, i, j).val[0]]));
|
|
|
|
|
Writeln;
|
|
|
|
|
end;
|
|
|
|
|
Writeln('-----');
|
|
|
|
|
|
2013-04-18 08:34:16 +02:00
|
|
|
|
// 3 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><>c<EFBFBD><63><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2013-04-02 00:17:25 +02:00
|
|
|
|
for i := 0 to matrix^.rows - 1 do
|
|
|
|
|
begin
|
|
|
|
|
ptr := pSingle((Integer(matrix^.data) + i * matrix^.step));
|
|
|
|
|
for j := 0 to matrix^.cols - 1 do
|
|
|
|
|
Write(Format('%.0f ', [ptr[j]]));
|
|
|
|
|
Writeln;
|
|
|
|
|
end;
|
|
|
|
|
Writeln('-----');
|
|
|
|
|
|
2013-04-18 08:34:16 +02:00
|
|
|
|
// <20>c<EFBFBD><63><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><>c<EFBFBD><63>c<EFBFBD>
|
2013-04-02 00:17:25 +02:00
|
|
|
|
cvReleaseMat(matrix);
|
|
|
|
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> XML
|
|
|
|
|
Writeln('Example 3_19 Reading in cfg.xml');
|
|
|
|
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
fs := cvOpenFileStorage('resource\cfg.xml', 0, CV_STORAGE_READ);
|
2013-04-18 08:34:16 +02:00
|
|
|
|
// c<><63><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2013-04-02 00:17:25 +02:00
|
|
|
|
frame_count := cvReadIntByName(fs, 0, 'frame_count', 5 { <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><>-<2D><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> } );
|
|
|
|
|
s := cvGetFileNodeByName(fs, 0, 'frame_size')^.seq;
|
|
|
|
|
frame_width := cvReadInt(pCvFileNode(cvGetSeqElem(s, 0)));
|
|
|
|
|
frame_height := cvReadInt(pCvFileNode(cvGetSeqElem(s, 1)));
|
|
|
|
|
color_cvt_matrix := pCvMat(cvRead(fs, 0));
|
|
|
|
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
WriteLn(Format('frame_count=%d, frame_width=%d, frame_height=%d',[frame_count,frame_width,frame_height]));
|
|
|
|
|
|
|
|
|
|
cvReleaseFileStorage(fs);
|
|
|
|
|
Writeln('Press <Enter>');
|
|
|
|
|
Readln;
|
|
|
|
|
except
|
|
|
|
|
on E: Exception do
|
|
|
|
|
Writeln(E.ClassName, ': ', E.Message);
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
end.
|