Aller au contenu

Liste d\'échelles


Patrick_35

Messages recommandés

Bonjour

 

Voici un lisp qui liste les échelles utilisées ou pas dans un dessin

 

(defun c:lste(/ blo doc inu lst txt uti liste_echelles)

 (defun liste_echelles(/ dic ele ent lst obj sel typ)
   (vlax-for blo (vla-get-blocks doc)
     (and (eq (vla-get-isxref blo) :vlax-false)
(vlax-for ent blo
  (and (eq (vla-get-hasextensiondictionary ent) :vlax-true)
    (vlax-for dic (vla-getextensiondictionary ent)
      (and (vlax-property-available-p dic 'name)
	   (eq (vla-get-name dic) "AcDbContextDataManager")
	(vlax-for ele dic
	  (and (eq (vla-get-name ele) "ACDB_ANNOTATIONSCALES")
	    (vlax-for obj ele
	      (setq typ (cdr (assoc 300 (entget (cdr (assoc 340 (entget (vlax-vla-object->ename obj))))))))
	      (or (member typ lst) (setq lst (cons typ lst)))
	    )
	  )
	)
      )
    )
  )
)
     )
   )
   lst
 )

 (setq doc (vla-get-activedocument (vlax-get-acad-object))
lst (liste_echelles)
 )
 (vlax-for ech (setq dic (vla-item (vla-get-dictionaries doc) "ACAD_SCALELIST"))
   (setq txt (cdr (assoc 300 (entget (vlax-vla-object->ename ech)))))
   (if (member txt lst)
     (if uti
(setq uti (strcat uti ", " txt))
(setq uti txt)
     )
     (if inu 
(setq inu (strcat inu ", " txt))
(setq inu txt)
     )
   )
 )
 (if uti
   (princ (strcat "\n\tEchelle(s) annotative utilisée(s) -> " uti))
   (princ "\n\tPas d'échelle annotative d'utilisée.")
 )
 (if inu
   (princ (strcat "\n\tEchelle(s) annotative inutilisée(s) -> " inu))
   (princ "\n\tPas d'échelle annotative d'inutilisée.")
 )
 (princ)
)

 

ps : il reste une ligne à traduire en vl, impossible de trouver comment pour l'instant

 

@+

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

Lien vers le commentaire
Partager sur d’autres sites

Salut,

 

J'avais fait un truc ici (et un autre ), en "pur AutoLISP".

 

Si, pour certains trucs, Visual LISP est incontournable, l'utilisation des listes DXF peut-être parfois plus simple (et je trouve que c'est le cas pour manipuler les dictionnaires) avec des performances équivalentes.

 

De plus, depuis peu, un autre argument pèse en faveur du "pur AutoLISP" : la compatibilité avec AutoCAD sur MAC qui ne connait pas l'interface COM/ActiveX.

Gilles Chanteau - gileCAD - GitHub
Développements sur mesure pour AutoCAD

Lien vers le commentaire
Partager sur d’autres sites

Bonjour,

ma question est peut être bête mais je me lance:

Et la possibilité de purger les échelles non utilisés serait-elle possible ?

 

DAO: AutoCAD(2D & 3D), Covadis

CAO: 3D's MAX, Rhinoceros 3D, REVIT

GeoModeliSation: AutoCAD MEP, RhinoTerrain

Rendu: Vray for Rhino, Keyshot, Lumion

Programmation: Grasshopper, Dynamo, VisualStudio

 

C.V.

Profil LinkedIn

Book

Site web

 

http://nsa37.casimages.com/img/2016/09/26/160926023334168603.jpg

Lien vers le commentaire
Partager sur d’autres sites

Merci lecrabe et gile...

Purgescale.....

DAO: AutoCAD(2D & 3D), Covadis

CAO: 3D's MAX, Rhinoceros 3D, REVIT

GeoModeliSation: AutoCAD MEP, RhinoTerrain

Rendu: Vray for Rhino, Keyshot, Lumion

Programmation: Grasshopper, Dynamo, VisualStudio

 

C.V.

Profil LinkedIn

Book

Site web

 

http://nsa37.casimages.com/img/2016/09/26/160926023334168603.jpg

Lien vers le commentaire
Partager sur d’autres sites

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é