juju_30 Posté(e) le 22 septembre 2010 Posté(e) le 22 septembre 2010 Bonjour, je souhaiterais obtenir la liste des calques (et leurs états) d'UNE présentation au préalablement choisit, le probleme est que je n'est jamais travaillé sur la manipulation des presentations ou de l'espace objet. si quelqu'un pourrai me donner quelque indication à suivre. merci
Patrick_35 Posté(e) le 22 septembre 2010 Posté(e) le 22 septembre 2010 Salut Dans une fenêtre de présentation, les calques qui sont gelés sont dans les xdatas de la fenêtreExemple(mapcar '(lambda(x)(cdr (assoc 2 (entget (cdr x))))) (vl-remove-if-not '(lambda(x)(eq (car x) 331)) (entget (car (entsel))))) @+ Les Lisps de PatrickLe but n'est pas toujours placé pour être atteint, mais pour servir de point de mire.Joseph Joubert, 1754-1824
juju_30 Posté(e) le 22 septembre 2010 Auteur Posté(e) le 22 septembre 2010 bonjour patrick je viens d'essayer la ligne de code que tu ma fournie mais je ne comprend pas trop le principe, par exemple pourquoi faut-il que je selectionne qqe chose (???) pour obtenir une liste de calques.est-ce que se serai trop te demander de me donner qqe renseignements sur les étapes de ta ligne de code pour que j'y vois un peu plus clair (ma variable x est toujours = à nil). merci
bonuscad Posté(e) le 22 septembre 2010 Posté(e) le 22 septembre 2010 Je ne vais pas répondre entièrement à la question. pourquoi faut-il que je selectionne qqe chose (???) Il te faut sélectionner une fenêtre dans l'EP pour laquelle tu veux connaitre l'état des calques.Ici la ligne code de Patrick_35 te retourne la liste des calques gelés pour la fenêtre sélectionnée. Tu peux avoir des difficultés pour sélectionner une fenêtre si celle-ci est de type polygonale.Dans se cas il vaut mieux remplacer:(car (entsel))par(ssname (ssget "_:S" '((0 . "VIEWPORT"))) 0) ma variable x est toujours = à nil) normale car cette variable est déclarée comme argument en locale dans la fonction (lambda) Choisissez un travail que vous aimez et vous n'aurez pas à travailler un seul jour de votre vie. - Confucius
juju_30 Posté(e) le 22 septembre 2010 Auteur Posté(e) le 22 septembre 2010 Merci c'est deja un peu plus clair je vais essayer de me debrouiller pour la suite.
Patrick_35 Posté(e) le 22 septembre 2010 Posté(e) le 22 septembre 2010 Ah oui, on va reprendre dès le début.On va rechercher la liste des calques, qu'importe que l'on soit en EO ou EP Pour afficher la liste des calques (xref compris) (defun liste_calques(/ lay lst) (setq lay (tblnext "layer" T)) (while lay (setq lst (cons (cdr (assoc 2 lay)) lst) lay (tblnext "layer") ) ) (reverse lst) ) Pour afficher la liste des calques sans les xrefs (defun liste_calques(/ lay lst) (setq lay (tblnext "layer" T)) (while lay (if (zerop (logand (cdr (assoc 70 lay)) 16)) (setq lst (cons (cdr (assoc 2 lay)) lst)) ) (setq lay (tblnext "layer")) ) (reverse lst) ) Cette ligne de code est pour déterminer les calques qui sont gelés dans une fenêtre de présentation (d'où la sélection pour l'exemple)(mapcar '(lambda(x)(cdr (assoc 2 (entget (cdr x))))) (vl-remove-if-not '(lambda(x)(eq (car x) 331)) (entget (car (entsel)))))Je vais faire la traduction de la ligne de code On sélectionne une fenêtre (setq sel (entget (car (entsel)))) L'instruction suivante (setq lst (vl-remove-if-not '(lambda(x)(eq (car x) 331)) sel)) Pourrait se traduire (foreach ent sel (if (eq (car ent) 331) (setq lst (cons ent lst)) ) ) Et celle-ci (mapcar '(lambda(x)(cdr (assoc 2 (entget (cdr x))))) lst) Pourrait se traduire (foreach ent lst (setq tab (cons (cdr (assoc 2 (entget (cdr ent)))) tab)) ) ps : Bonus vient de passer ;) @+ Les Lisps de PatrickLe but n'est pas toujours placé pour être atteint, mais pour servir de point de mire.Joseph Joubert, 1754-1824
juju_30 Posté(e) le 22 septembre 2010 Auteur Posté(e) le 22 septembre 2010 j'avoue que les "traductions" sont plus compréhensible. je n'ai pas trop l'habitude de travailler avec les "VLA-objet"...en tout cas merci pour votre aide (bonus et patrick)
Patrick_35 Posté(e) le 22 septembre 2010 Posté(e) le 22 septembre 2010 Pas de chance, pour rester compréhensible, pas de vla ;) Donc, en vla (vla-getxdata (vlax-ename->vla-object (car (entsel))) "" 'code 'lst) (mapcar '(lambda(x) (vlax-variant-value (cdr x)) ) (vl-remove-if-not '(lambda(x) (eq (car x) 1003) ) (mapcar 'cons (vlax-safearray->list code) (vlax-safearray->list lst) ) ) ) @+ Les Lisps de PatrickLe but n'est pas toujours placé pour être atteint, mais pour servir de point de mire.Joseph Joubert, 1754-1824
Messages recommandés
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 compteSe connecter
Vous avez déjà un compte ? Connectez-vous ici.
Connectez-vous maintenant