begin process at 2008 08 20 15:25:08
1 228 895 membres
260 nouveaux aujourd'hui
14 259 membres club

Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum.
Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : remplissage de polygones [ Algorithme / Autre ] (barbichette)

remplissage de polygones le 19/11/2006 14:10:47

barbichette
Membre Club
Bonjour à tous.
Je cherche un algo pour remplir un polygone concave ou convexe sans utiliser le GDI.
J'ai donc une liste de points quelconques, et je veux savoir si un point du plan est dans ou en dehors du polygone.

Les méthodes classiques comme le scanline ne fonctionnent a priori pas puisqu'il faud un poly convexe. sniff...

Quelqu'un aurait une idée, une astuce, un site, quelque chose.. je ne asis pas
Je suis désespéré, je trouve rien sur Internet...

Barbichette

Re : remplissage de polygones le 19/11/2006 14:21:20

cirec
Membre Club
(Admin CS)
Salut,

FloodFill peut être ?

procedure FloodFill(X, Y: Integer; Color: TColor; FillStyle: TFillStyle);

Utilisez la méthode FloodFill pour remplir une zone, pas nécessairement rectangulaire, de l'image avec la valeur de Brush. Les limites de la région à remplir sont déterminées en se déplaçant dans toutes les directions à partir du point (X,Y) jusqu'à ce qu'une limite de couleur impliquant le paramètre Color soit rencontrée.

Le paramètre FillStyle détermine le style de remplissage, c'est-à-dire le type de modification de couleur qui définit les limites. Il peut prendre une des valeurs suivantes.
 
@+
Cirec


Re : remplissage de polygones le 19/11/2006 14:26:12

barbichette
Membre Club
le problème, c'est que je ne dessine pas dans un canvas, et je ne veux pas utiliser le GDI.
Car, c'est dans un cas bien particulier.
Il me faud plus un algo qu'une fonction toute faite.

Merci quand même



Re : remplissage de polygones le 19/11/2006 14:39:03

cirec
Membre Club
(Admin CS)
le fait de ne pas dessiner dans un Canvas n'est pas un problème pour utiliser TCanvas
mais comme tu ne veux pas utiliser le GDI ...
sinon il y a ça :
http://www.delphifr.com/codes/COMMENT-REMPLIR-POLYGONE-SANS-UTILISER-GDI-WINDOWS_39053.aspx

Mais on ne sait pas ce qu'il y a dedans ...
l'auteur utilise une DLL mais ne donne pas la source de cette dernière !!!!

 
@+
Cirec


Re : remplissage de polygones le 19/11/2006 14:56:58

Guillemouze
Réponse acceptée !
sinon la solution manuelle : tu cree une droite querlconque qui passe par ton point, et tu regarde les intersections avec les cotes de ton poly qui sont des points t pas des segments. si le nombre d'intersections avant et apres ton poly sont impaires, alors le pointest dans le polygone.

Re : remplissage de polygones le 19/11/2006 15:16:16

cirec
Membre Club
(Admin CS)
Dans ce cas il est plus simple de transformer le poly en Région et de tester le point avec :

If PtInRegion(RGN: HRGN; X, Y: Integer) Then ...

et pour accelerer le mouvement rien ne t'empêche d'utiliser ScanLine

ce qui au final, a mon avis, serat bien plus rapide .

 
@+
Cirec


Re : remplissage de polygones le 20/11/2006 11:00:24

barbichette
Membre Club
Merci bien pour le systeme de région. Je vais voir ça.
Par contre, Guillemouze, j'ai pas bien suivi ton explication. Mais ça m'intéresse quand même...
les intersections avec les cotes de ton poly qui sont des points t pas des segments
Là, pas bien compris
Tu pourrais être un peu plus explicite..

Merci

Re : remplissage de polygones le 20/11/2006 16:39:25

cirec
Membre Club
(Admin CS)
PS: il existe aussi une fonction dans Windows.pas qui porte le même nom (FloodFill) et qui n'est pas relié a un canvas :

{$EXTERNALSYM FloodFill}
function FloodFill(DC: HDC; nXStart, nYStart: Integer; crFill: COLORREF): BOOL; stdcall;

je suppose que tu as au moins un HDC

Sinon si tu optes pour la méthode de région il existe aussi ceci :
{$EXTERNALSYM FillRgn}
function FillRgn(DC: HDC; hrgn: HRGN; hbr: HBRUSH): BOOL; stdcall;

elle fonctionne aussi avec un HDC et un HBR qui au final offre bien plus de possibilitées :
remplire la région,  selon un motif, une image, une couleur


 
@+
Cirec


Re : remplissage de polygones le 22/11/2006 00:08:20

barbichette
Membre Club
bon, j'ai trouvé mon bonheur et je l'ai adapté en pascal :

http://www.delphifr.com/code.aspx?ID=40419

merci a tous

barbichette


Classé sous : polygones, remplissage, polygone, convexe

Participer à cet échange

Pub



Appels d'offres

CalendriCode

Août 2008
LMMJVSD
    123
45678910
11121314151617
18192021222324
25262728293031

Téléchargements

Logiciels à télécharger sur le même thème :

Boutique

Boutique de goodies CodeS-SourceS