mirror of
https://github.com/Laex/Delphi-OpenCV.git
synced 2024-11-16 16:25:53 +01:00
711245f56e
Signed-off-by: Laex <laex@bk.ru>
133 lines
3.9 KiB
ObjectPascal
133 lines
3.9 KiB
ObjectPascal
(* /*****************************************************************
|
|
// 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.
|
|
*******************************************************************
|
|
// Original file:
|
|
// opencv\samples\c\pyramid_segmentation.c
|
|
// *************************************************************** *)
|
|
|
|
// JCL_DEBUG_EXPERT_GENERATEJDBG OFF
|
|
// JCL_DEBUG_EXPERT_INSERTJDBG OFF
|
|
// JCL_DEBUG_EXPERT_DELETEMAPFILE OFF
|
|
program cv_PyrSegmentation;
|
|
|
|
{$APPTYPE CONSOLE}
|
|
{$R *.res}
|
|
|
|
uses
|
|
System.SysUtils,
|
|
highgui_c,
|
|
core_c,
|
|
Core.types_c,
|
|
imgproc_c,
|
|
imgproc.types_c,
|
|
legacy;
|
|
|
|
procedure help;
|
|
begin
|
|
WriteLn('This program demonstrated color pyramid segmentation cvcvPyrSegmentation() which is controlled');
|
|
WriteLn('by two trhesholds which can be manipulated by a trackbar. It can take an image file name or defaults to ''fruits.jpg''');
|
|
WriteLn('Usage :');
|
|
WriteLn('pyaramid_segmentation [image_path_filename -- Defaults to fruits.jpg]');
|
|
end;
|
|
|
|
Var
|
|
image: array [0 .. 1] of pIplImage = (
|
|
nil,
|
|
nil
|
|
);
|
|
image0: pIplImage;
|
|
image1: pIplImage;
|
|
size: TCvSize;
|
|
|
|
w0, h0, i, threshold1, threshold2, l: Integer;
|
|
level: Integer = 4;
|
|
sthreshold1, sthreshold2, l_comp: Integer;
|
|
block_size: Integer = 1000;
|
|
parameter: single;
|
|
threshold, rezult, min_rezult: double;
|
|
filter: Integer = CV_GAUSSIAN_5x5;
|
|
cur_comp, min_comp: pCvConnectedComp;
|
|
comp: pCvSeq;
|
|
storage: pCvMemStorage;
|
|
pt1, pt2: TCvPoint;
|
|
|
|
procedure ON_SEGMENT(a: Integer); cdecl;
|
|
begin
|
|
cvPyrSegmentation(image0, image1, storage, comp, level, threshold1 + 1, threshold2 + 1);
|
|
cvShowImage('Segmentation', image1);
|
|
end;
|
|
|
|
Var
|
|
filename: AnsiString;
|
|
|
|
begin
|
|
try
|
|
help;
|
|
filename := iif(ParamCount = 1, ParamStr(1), 'resource\fruits.jpg');
|
|
image[0] := cvLoadImage(pcvChar(@filename[1]), 1);
|
|
if not Assigned(image[0]) then
|
|
begin
|
|
WriteLn(Format('Cannot load fileimage - %s', [filename]));
|
|
Halt;
|
|
end;
|
|
|
|
cvNamedWindow('Source', 0);
|
|
cvShowImage('Source', image[0]);
|
|
|
|
cvNamedWindow('Segmentation', 0);
|
|
|
|
storage := cvCreateMemStorage(block_size);
|
|
|
|
image[0]^.width := image[0]^.width and (-(1 shl level));
|
|
image[0]^.height := image[0]^.height and (-(1 shl level));
|
|
|
|
image0 := cvCloneImage(image[0]);
|
|
image1 := cvCloneImage(image[0]);
|
|
// segmentation of the color image
|
|
l := 1;
|
|
threshold1 := 255;
|
|
threshold2 := 30;
|
|
|
|
ON_SEGMENT(1);
|
|
|
|
sthreshold1 := cvCreateTrackbar('Threshold1', 'Segmentation', @threshold1, 255, ON_SEGMENT);
|
|
sthreshold2 := cvCreateTrackbar('Threshold2', 'Segmentation', @threshold2, 255, ON_SEGMENT);
|
|
|
|
cvShowImage('Segmentation', image1);
|
|
cvWaitKey(0);
|
|
|
|
cvDestroyWindow('Segmentation');
|
|
cvDestroyWindow('Source');
|
|
|
|
cvReleaseMemStorage(storage);
|
|
|
|
cvReleaseImage(image[0]);
|
|
cvReleaseImage(image0);
|
|
cvReleaseImage(image1);
|
|
|
|
except
|
|
on E: Exception do
|
|
WriteLn(E.ClassName, ': ', E.Message);
|
|
end;
|
|
|
|
end.
|