델파이로 두 사진의 싱크로율을 비교하다
21494 단어 Delphi
procedure
TFrm_test.initList;
var
idx, i, k, x, y, l: integer;
p, fn:
string
;
bmp: TBitmap;
BColor, NowColor: TColor;
begin
p :
=
ExtractFilePath(Application.ExeName);
bmp :
=
TBitmap.Create;
for
i :
=
0
to
9
do
begin
fn :
=
p
+
'
\CodeBmp\
'
+
IntToStr(i)
+
'
.bmp
'
;
if
not
FileExists(fn)
then
Continue;
idx :
=
length(PointRecList);
SetLength(PointRecList, idx
+
1
);
PointRecList[idx].Code :
=
IntToStr(i);
bmp.LoadFromFile(fn);
BColor :
=
bmp.Canvas.Pixels[
0
, bmp.Height
-
1
];
for
x :
=
0
to
bmp.Width
-
1
do
for
y :
=
0
to
bmp.Height
-
1
do
begin
NowColor :
=
bmp.Canvas.Pixels[x, y];
if
NowColor
<>
BColor
then
begin
l :
=
length(PointRecList[idx].PointList);
SetLength(PointRecList[idx].PointList, l
+
1
);
PointRecList[idx].PointList[l].x :
=
x;
PointRecList[idx].PointList[l].y :
=
y;
end
;
end
;
end
;
FreeAndNil(bmp);
//
end
;
function
getCode_Bmp(
const
bmp: TBitmap; strLen: integer;
PointRecList:
array
of
TPointRec):
string
;
var
j, i, l, x, y, x0, xS, beginx: integer;
BColor, NowColor: TColor;
PointList:
array
of
TPoint;
function
getCode:
string
;
var
maxCount, k, m, j, i: integer;
begin
Result :
=
'
?
'
;
if
length(PointList)
<
3
then
exit;
maxCount :
=
0
;
for
i :
=
0
to
high(PointRecList)
do
begin
if
length(PointRecList[i].PointList)
<
3
then
Continue;
m :
=
0
;
for
k :
=
1
to
high(PointList)
do
begin
for
j :
=
1
to
high(PointRecList[i].PointList)
do
if
((PointList[k].x
-
PointList[
0
].x)
=
(PointRecList[i].PointList[j].x
-
PointRecList[i].PointList[
0
].x)
)
and
((PointList[k].y
-
PointList[
0
].y)
=
(PointRecList[i].PointList[j].y
-
PointRecList[i].PointList[
0
].y)
)
then
begin
inc(m);
Break;
end
;
end
;
m :
=
m
*
100
div
(length(PointList)
-
1
);
if
m
>
maxCount
then
begin
Result :
=
PointRecList[i].Code;
maxCount :
=
m;
end
;
end
;
end
;
begin
Result :
=
'
'
;
BColor :
=
bmp.Canvas.Pixels[
0
, bmp.Height
-
1
];
x0 :
=
0
;
xS :
=
bmp.Width
div
strLen;
for
i :
=
0
to
strLen
-
1
do
begin
beginx :
=
x0
+
xS
*
i;
SetLength(PointList,
0
);
for
j :
=
0
to
xS
-
1
do
begin
x :
=
beginx
+
j;
for
y :
=
0
to
bmp.Height
-
1
do
begin
NowColor :
=
bmp.Canvas.Pixels[x, y];
if
NowColor
<>
BColor
then
begin
l :
=
length(PointList);
SetLength(PointList, l
+
1
);
PointList[l].x :
=
x;
PointList[l].y :
=
y;
end
;
end
;
end
;
Result :
=
Result
+
getCode;
end
;
end
;
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
[Delphi] TStringBuilder그리고 꼭 사용해야만 할까? 그림처럼 Heap 영역에 "Hello" 공간을 생성하고 포인팅을 한다. "Hello World" 공간을 새로 생성한 후 포인팅을 하게 된다. 결국 "Hello" 라는 String 객체가 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.