Aller au contenu

Messages recommandés

Posté(e)

Bonjour

 

j'écris actuellement un lisp suite à une demande de mes collègues et je bute sur un point !

Je cherche à compter certains blocs présents dans mon plan.

 

Dans ma boucle (vlax-for Element ...) j'ai écrit ceci :

 

(setq blkName (vla-get-name Element))
(setq dxfblk (cons 2 blkName))
(setq Ensa (ssget "_X" (cons '(0 . "INSERT") (list dxfblk))))
 (if
   (/= Ensa nil)
   (progn
     (setq IntNbrElement (sslength Ensa))
   )
   (setq IntNbrElement 0)
 )

 

Le problème c'est qu'il ne compte que les blocs insérés directement et pas les blocs imbriqués dans d'autres blocs.

Je sais qu'il faut utiliser une fonction récursive mais je n'y arrive pas...

 

Si quelqu'un pouvait m'aider ! :)

 

Merci d'avance

PIRO Charles

Developpeur Revit, RV/RA - Formateur Revit

PIRO CIE

Posté(e)

bonjour

 

(defun c:comptebloc ( / ADoc ss n monbloc Imb)

(vl-load-com)
(setq ADoc (vla-get-activedocument (vlax-get-acad-object)))

(setq ss (ssget "_X" '((0 . "INSERT")(410 . "MODEL"))))
(setq n 0)
(vlax-for monbloc (vla-get-ActiveSelectionSet ADoc)
 	(if (setq Imb (Imbriquebloc monbloc 0))
	(setq n (+ n Imb))
)
 	(setq n (1+ n))
)
 (princ n)(princ)
)


(defun Imbriquebloc ( bloc compte / Inbloc)
(vlax-for Imbloc (vla-item (vla-get-blocks ADoc)(vla-get-name bloc))
	(if (eq (vla-get-objectname Imbloc) "AcDbBlockReference")
		(progn
			(if (setq Imb(Imbriquebloc Imbloc 0))
				(setq compte (+ compte Imb))
			)
		  	(setq compte (1+ compte))
		)
	)
)
)

 

Quelque chose comme ça?

 

edit : petite erreur!

C'est en forgeant que l'on devient forgerons.

Et c'est en sciant que Léonard DeVinci!

Posté(e)

Salut

 

Ou encore

 

(setq lst nil)

(defun Imbriquebloc ( bloc / tab Inbloc)
       (vlax-for Imbloc (vla-item (vla-get-blocks ADoc)(vla-get-name bloc))
               (if (eq (vla-get-objectname Imbloc) "AcDbBlockReference")
                       (setq tab (cons (Imbriquebloc Imbloc) tab))
               )
       )
(setq lst (cons (vla-get-name bloc) tab))
)

 

@+

Les Lisps de Patrick

Le but n'est pas toujours placé pour être atteint, mais pour servir de point de mire.

Joseph Joubert, 1754-1824

Posté(e)

@ alala et Patrick_35 : Merci, ça fonctionne parfaitement.

 

@Gile : Merci pour le rappel ! j'avais oublié ce post qui pourtant est super intéressant. Tes fonctions résolvent bien des problèmes. Merci beaucoup ;) .

PIRO Charles

Developpeur Revit, RV/RA - Formateur Revit

PIRO CIE

Créer un compte ou se connecter pour commenter

Vous devez être membre afin de pouvoir déposer un commentaire

Créer un compte

Créez un compte sur notre communauté. C’est facile !

Créer un nouveau compte

Se connecter

Vous avez déjà un compte ? Connectez-vous ici.

Connectez-vous maintenant
×
×
  • Créer...

Information importante

Nous avons placé des cookies sur votre appareil pour aider à améliorer ce site. Vous pouvez choisir d’ajuster vos paramètres de cookie, sinon nous supposerons que vous êtes d’accord pour continuer. Politique de confidentialité