Lazarus
Home
Help
TinyPortal
Search
Login
Register
Lazarus
»
Forum
»
Free Pascal
»
General
(Moderators:
FPK
,
Tomas Hajny
) »
Get amount of unique colors from picture
Free Pascal
Website
Downloads
Wiki
Documentation
Bugtracker
Mailing List
Lazarus
Website
Downloads (Laz+FPC)
Packages (OPM)
FAQ
Wiki
Documentation (RTL/FCL/LCL)
Bugtracker
CCR Bugs
IRC channel
GIT
Mailing List
Other languages
Foundation
Website
Useful Wiki Links
Project Roadmap
Getting the Source
Screenshots
How to use the forum
About donations (wiki)
Bookstore
Computer Math and Games in Pascal
(preview)
Lazarus Handbook
Search
Advanced search
Recent
insert select from - with...
by
Nicole
[
Today
at 11:39:34 am]
FpDebug breakpoint on "be...
by
YiannisKam
[
Today
at 11:30:25 am]
Database standards OR Am ...
by
TRon
[
Today
at 11:28:02 am]
Access violation when ope...
by
TRon
[
Today
at 11:24:35 am]
How to: create DLL file f...
by
paule32
[
Today
at 11:17:12 am]
Offical launch of the 1 B...
by
Gustavo 'Gus' Carreno
[
Today
at 11:14:40 am]
Registers dialog - regist...
by
Martin_fr
[
Today
at 11:10:13 am]
Forum slow
by
TRon
[
Today
at 10:57:09 am]
HeapTrc not showing line ...
by
Martin_fr
[
Today
at 10:40:33 am]
Step-into the field sette...
by
ginoo
[
Today
at 07:50:24 am]
Does anyone know why thes...
by
TYDQ
[
Today
at 05:24:32 am]
Arabic text, problem on L...
by
Zaher
[
Today
at 03:29:16 am]
InstallAware Using Lazaru...
by
TRon
[
Today
at 02:55:41 am]
Generics - correct syntax
by
Blaazen
[
Today
at 01:57:40 am]
Demoscene The Champs Crac...
by
Gigatron
[
Today
at 01:05:16 am]
How to use the Event Log?
by
n7800
[
Today
at 12:47:25 am]
v3.99 code completion que...
by
440bx
[
Today
at 12:45:55 am]
Access violation when re-...
by
TRon
[April 19, 2024, 11:44:51 pm]
[solved] how to get class...
by
jamie
[April 19, 2024, 11:34:44 pm]
Lazarus for Windows on aa...
by
Wallaby
[April 19, 2024, 10:52:25 pm]
Poll: Watches and Display...
by
440bx
[April 19, 2024, 07:13:51 pm]
Who is Indy mattias?
by
paweld
[April 19, 2024, 04:17:53 pm]
I just released a commerc...
by
BrassGear
[April 19, 2024, 03:17:28 pm]
A fairly simple sound sol...
by
paweld
[April 19, 2024, 01:46:11 pm]
AI, NLP and CAI: Text Gen...
by
Dzandaa
[April 19, 2024, 11:03:26 am]
« previous
next »
Print
Pages: [
1
]
Author
Topic: Get amount of unique colors from picture (Read 2291 times)
lulZghost
Guest
Get amount of unique colors from picture
«
on:
October 16, 2018, 03:34:39 pm »
For my project I need a function way to get the amount of unique colors from a single picture.
My Idea was to make an array of strings, go pixel by pixel, convert the color to string, check if the string already exists and if not add it to the array.
This is my code for it:
Code: Pascal
[Select]
[+]
[-]
private
colorlist
:
array
of
string
;
---------------------------------
function
TFormMain
.
checkColors
(
)
:
integer
;
var
i
,
x
,
y
,
doesexist
:
integer
;
colorstring
:
string
;
begin
for
y
:
=
0
to
image1
.
canvas
.
Height
do
begin
for
x
:
=
0
to
image1
.
canvas
.
Width
do
begin
colorstring
:
=
ColorToString
(
FPColorToTColor
(
image1
.
Canvas
.
Colors
[
x
,
y
]
)
)
;
for
i
:
=
0
to
length
(
colorlist
)
do
begin
doesexist
:
=
0
;
if
colorlist
[
i
]
=
colorstring
then
doesexist
:
=
1
;
end
;
if
doesexist
=
0
then
begin
SetLength
(
colorlist
,
Length
(
colorlist
)
+
1
)
;
colorlist
[
High
(
colorlist
)
]
:
=
colorstring
;
end
;
end
;
end
;
result
:
=
length
(
colorlist
)
;
end
;
SO, apparently this doesn't work, because I get this error
Code: Pascal
[Select]
[+]
[-]
000000010000AC15 668b41e8 mov
-
0x18
(
%rcx
)
,
%ax
I don't get any syntax errors, so somewhere I have another error, but I don't see it. Maybe someone else can spot the logic error in there, because I honestly don't know what the error could be.
Logged
marcov
Administrator
Hero Member
Posts: 11453
FPC developer.
Re: Get amount of unique colors from picture
«
Reply #1 on:
October 16, 2018, 03:35:58 pm »
Code:
[Select]
for i:=0 to length(colorlist) do
Iterates over length(colorlist)+1, is this really what you want?
Also, as a rule, don't convert to string what is not a string.
Logged
Blaazen
Hero Member
Posts: 3239
POKE 54296,15
Re: Get amount of unique colors from picture
«
Reply #2 on:
October 16, 2018, 04:31:36 pm »
I would allocate array with size 256*256*256/8 = 2MB, it will cover RGB values from (0,0,0),(0,0,1)...(255,255,254),(255,255,255) and each bit represents color: 0..not present, 1..present. In the end you can only do sum of "1" bits.
Logged
Lazarus 2.3.0 (rev main-2_3-2863...) FPC 3.3.1 x86_64-linux-qt Chakra, Qt 4.8.7/5.13.2, Plasma 5.17.3
Lazarus 1.8.2 r57369 FPC 3.0.4 i386-win32-win32/win64 Wine 3.21
Try Eye-Candy Controls:
https://sourceforge.net/projects/eccontrols/files/
LemonParty
Jr. Member
Posts: 63
Re: Get amount of unique colors from picture
«
Reply #3 on:
October 19, 2018, 10:57:56 am »
Using strings for such purpouses is ineffective.
Blaazen's idea is really good.
Use
https://www.freepascal.org/docs-html/rtl/system/popcnt.html
to count the number of setted bits.
Logged
Print
Pages: [
1
]
« previous
next »
Lazarus
»
Forum
»
Free Pascal
»
General
(Moderators:
FPK
,
Tomas Hajny
) »
Get amount of unique colors from picture
TinyPortal
© 2005-2018