Aller au contenu

Renommer bloc


philous2

Messages recommandés

Salut,

 

As tu bien chargé ton lisp ?

 

Sinon : tappes "appload" et va le chercher dans "contenu au demarrage". Ou alors pour l'essayer, tu glisses le fichier lisp sur ton écran autocad.

 

ensuite, tu choisis un bloc, tu fais clic droit... et voilà...

 

A+++

"La ligne droite est le plus court chemin entre deux points, à condition que les deux points soient bien en face l'un de l'autre" P. Desproges.

Lien vers le commentaire
Partager sur d’autres sites

Ben...

 

Une fois ton lisp chargé.

 

Tu cliques sur un bloc, puis tu fais clic-droit, et là t'as un message.

 

Ne passe pas par le ligne de commande. Que par clic-droit !

"La ligne droite est le plus court chemin entre deux points, à condition que les deux points soient bien en face l'un de l'autre" P. Desproges.

Lien vers le commentaire
Partager sur d’autres sites

Invité ingoenius

ici une routine modifiée ca fonctionne en selectionnant le bloc avant ou pas et affiche une boite de dialogue dan laquelle mettre le nouveau nom de bloc

 

;; InputBox (gile)
;; Ouvre une boite de dialogue pour récupérer une valeur
;; sous forme de chaine de caractère
;;
;; Arguments
;; tous les arguments sont de chaines de caractère (ou "")
;; box : titre de la boite de dialogue
;; msg : message d'invite
;; val : valeur par défaut
;;
;; Retour
;; une chaine ("" si annulation)

(defun InputBox (box msg val / subr temp file dcl_id ret)

;; Retour chariot automatique à 50 caractères
(defun subr (str / pos)
(if (and
(< 50 (strlen str))
(setq pos (vl-string-position 32 (substr str 1 50) nil T))
)
(strcat ":text_part{label=\""
(substr str 1 pos)
"\";}"
(subr (substr str (+ 2 pos)))
)
(strcat ":text_part{label=\"" str "\";}")
)
)

;; Créer un fichier DCL temporaire
(setq temp (vl-filename-mktemp "Tmp.dcl")
file (open temp "w")
ret ""
)

;; Ecrire le fichier
(write-line
(strcat
"InputBox:dialog{key=\"box\";initial_focus=\"val\";spacer;:paragraph{"
(subr msg)
"}spacer;:edit_box{key=\"val\";edit_width=54;allow_accept=true;}
spacer;ok_cancel;}"
)
file
)
(close file)

;; Ouvrir la boite de dialogue
(setq dcl_id (load_dialog temp))
(if (not (new_dialog "InputBox" dcl_id))
(exit)
)
(set_tile "box" box)
(set_tile "val" val)
(action_tile
"accept"
"(setq ret (get_tile \"val\")) (done_dialog)"
)
(start_dialog)
(unload_dialog dcl_id)

;;Supprimer le fichier
(vl-file-delete temp)
ret
)

(defun c:BB ();rinomina i blocchi 
(setq OBJ (ssgetfirst))
(setq old_BLOCCO (cadr OBJ));estrai la selezione

(if	(= old_BLOCCO nil)	;se nulla é selezionato  
(setq BLOCCO (car (entsel "\nSelect block ")))
(setq BLOCCO (ssname old_BLOCCO 0))	
)	

(setq old_DatiB (entget BLOCCO))(= (cdr (assoc 0 old_DatiB)) "INSERT")
(setq Test (cdr(assoc 2 old_DatiB))) 		;metto qui il vecchio nome del blocco
;(setq New_N (getstring T "\nNew Name? "))

(setq New_N   (inputbox "Rename Block" Test "new name")) ;cambiare qui la dcl dialog 
(null (tblsearch "BLOCK" New_N))
(vl-cmdf "_.rename" "_b" (cdr (assoc 2 old_DatiB)) New_N)
 
(princ)
)



;----------------------------------------------------------------------------


(defun c:SB () ;scala tutti i blocchi uguali a quello selezionato
 
 
  (SETQ CMDE (GETVAR "cmdecho"))
  (SETVAR "CMDECHO" 0)
  (setq n 0 )
  (command "_undo" "_m")

(setq Obj (car (entsel "\nSeleziona un oggetto\n ")))
(setq DatiB (entget Obj))
(setq InsObj(cdr (assoc 10 DatiB)));punto inserzione blocco 
 
;(setq P (getvar "lastpoint"))  
(setq LayObj (cdr (assoc 8 DatiB)))						;recupera il layer del'oggetto selezionato
(setq NameObj (cdr (assoc 2 DatiB)))						;recupera il nome del blocco selezionato
(setq ssLayBloc (ssget "x" (list(cons 8 LayObj)(cons 2 NameObj))))		;crea il set di selezione degli oggetti sul layer scelto NLAY   

;(command "_move" ssLayBloc "" InsObj  pause  "")  
 
(setq js ssLayBloc)
  (initget 1)
  (setq ech (getstring "/Reference :"))
  (if (or (= ech "R") (= ech "r"))
     (progn
        (setq long_ref (getreal "Longueur de reference <1>:")) 
        (if (= nil long_ref) (setq long_ref 1.0000000))
        (initget (+ 1 2 4))
        (setq long_new (getreal "Nouvelle Longueur:"))
     )
  )
  (repeat (sslength js)
     (setq ent (ssname js n))
     (SETQ PT1 (cdr (assoc 10 (entget ent))))
     (if (or (= ech "R") (= ech "r"))
        (command "_SCALE" ent "" pt1 "r" long_ref long_new)
        (command "_SCALE" ent "" pt1 ech)
     )
     (setq n (1+ n))
     (IF (= (/ n 5.00) (/ n 5)) (prompt "."))
  );repeat
  (SETVAR "CMDECHO" CMDE)
  (terpri)
);

;----------------------------------------------------------------------------



(defun c:RB ( / n js ent pt1 ang);ruota tutti i blocchi con nome uguale al selezionato 
  (SETQ CMDE (GETVAR "cmdecho"))
  (SETVAR "CMDECHO" 0)
  (setq n 0 )
  (command "_undo" "_m")

(setq Obj (car (entsel "\nSeleziona un oggetto\n ")))
(setq DatiB (entget Obj))
(setq InsObj(cdr (assoc 10 DatiB)));punto inserzione blocco 
 
;(setq P (getvar "lastpoint"))  
(setq LayObj (cdr (assoc 8 DatiB)))						;recupera il layer del'oggetto selezionato
(setq NameObj (cdr (assoc 2 DatiB)))						;recupera il nome del blocco selezionato
(setq ssLayBloc (ssget "x" (list(cons 8 LayObj)(cons 2 NameObj))))		;crea il set di selezione degli oggetti sul layer scelto NLAY   

(setq js ssLayBloc)
 
  (setq ang (getreal "Angle de rotation:")) 
  (repeat (sslength js)
     (setq ent (ssname js n))
     (SETQ PT1 (cdr (assoc 10 (entget ent))))
     (command "_rotate" ent "" pt1 ang)
     (setq n (1+ n))
     (IF (= (/ n 50.00) (/ n 50)) (prompt "."))
  );repeat
  (SETVAR "CMDECHO" CMDE)
  (terpri)
 )

;-----------------------------


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é