Aller au contenu

décaler les textes chevauchés de profils covadis


Messages recommandés

Posté(e)

Bonjour, vous voulez en finir avec les superpositions de textes des profils covadis ou autopiste mais sans perdre d'informations, voici un petit lisp qui décale les textes chevauchés autant que nécessaire.

 

(DEFUN C:DECTEXT()
;pour décaler les textes chevauchés de profils covadis
;par F.Brosseau SARL PROJSUR le 18/02/2010
 (setq n 0 sel (ssget "X" '((0 . "TEXT"))))
 (repeat (sslength sel)
   (if (> n 0) (setq xo x yo y ))
   (setq entname(ssname sel n)
     	  ent (entget entname)
	  x (car(cdr(assoc 10 ent)))
	  y (cadr(cdr(assoc 10 ent)))
	  n (+ n 1)
   )
   (if (and (> n 1) (< (- xo x) (cdr (assoc 40 ent))) (= yo y)) (progn
	(setq x (- xo (* 2 (cdr (assoc 40 ent)))) pt (list x y 0))
	(entmake (list '(0 . "TEXT")
			'(100 . "AcDbEntity")
			'(100 . "AcDbText")
			(assoc 1 ent)
			(assoc 7 ent)
			(assoc 8 ent)
			(cons  10 pt)
			(cons  11 pt)
			(assoc 40 ent)
			(cons  50 1.570796)
			(cons  71 0)
			(cons  72 0)
			(cons  73 2)
			)
	)
	(entdel entname)
   ))
 )
 (setq ss nil)
 (PRINC)) 

 

Voilà, il est brut de décoffrage mais fonctionne bien pour moi, ainsi les profils sont enfin lisibles.

 

Bonne journée.[Edité le 18/2/2010 par fredbross]

Posté(e)

Bonjour à toutes et tous,

 

En effet efficace !

 

Seul pb, il ne garde pas la couleur des textes imposées dans le fichier de paramétrages,..

 

De plus, est-il possible de réduire un peu l'espacement entre les textes ainsi décalés ?

 

Avant =>

 

http://free0.hiboox.com/images/0710/5ff076476c06e79f2c9e97f0fb0f0ec8.jpg

 

 

Après =>

 

http://free0.hiboox.com/images/0710/654d58657a760332fb0f5c352de9443f.jpg

 

 

Civil 3D 2025 - COVADIS_18.3b

https://www.linkedin...3%ABt-95313341/

Posté(e)

Salut

l'idée est bonne mais il faudrait peut etre pouvoir faire une selection, sinon on ne maitrise pas les modifications. Si tu as un gros fichier ....

Il faudrait, soit agir sur une selection de calque, soit donner une zone à traiter.

A suivre

 

Posté(e)

Bonsoir Fred

 

bien vu ce lisp

 

l'inconveniant c'est que dans certains cas le texte décales n'est plus du tout sous le sommet concerne

 

a savoir qu'une nouveauté dans ce sens est en cours de prepartion,qui permettra de choisir sur le profil type les points a coter obligatoirement,ceux qui ne doivent jamais l'être .en ce cas ceux qui doivent absolument aparaitre et qui se superpose seront décales en automatique.

 

En attendant cette nouveauté,ton lisp va dépanner pas mal de monde

 

cordialement

 

question: c'est quoi la SARL projsur ???

Thierry Garré

 

Géorail-Covadis-Autopiste-Autocad-Autocad Map-Infraworks 360- Navisworks -Recap

Posté(e)

Voilà le lisp modifier pour conserver les couleurs et pour pouvoir sélectionner les textes par fenêtre ou autre.

 

(DEFUN C:DT()
;pour décaler les textes chevauchés de profils covadis
;par F.Brosseau SARL PROJSUR le 18/02/2010
 (command "annuler" "D")
 (setq n 0 sel (ssget '((0 . "TEXT"))))
 (repeat (sslength sel)
   (if (> n 0) (setq xo x yo y ))
   (setq entname(ssname sel n)
     	  ent (entget entname)
	  x (car(cdr(assoc 10 ent)))
	  y (cadr(cdr(assoc 10 ent)))
	  n (+ n 1)
   )
   (if (and (> n 1) (< (- xo x) (cdr (assoc 40 ent))) (= yo y)) (progn
	(setq x (- xo (* 2 (cdr (assoc 40 ent)))) pt (list x y 0))
	(entmake (list '(0 . "TEXT")
			'(100 . "AcDbEntity")
			'(100 . "AcDbText")
			(assoc 1 ent)
			(assoc 7 ent)
			(assoc 8 ent)
		        (assoc 62 ent)
			(cons  10 pt)
			(cons  11 pt)
			(assoc 40 ent)
			(cons  50 1.570796)
			(cons  71 0)
			(cons  72 0)
			(cons  73 2)
			)
	)
	(entdel entname)
   ))
 )
 (setq ss nil)
 (command "annuler" "F")
 (PRINC))

 

Voilà, bon week-end.

Posté(e)

Bonsoir Lili2006,

 

Tout d'abord Merci fred ;) alors cette nouvelle Société comment va t elle ?

 

(defun C:ct ()
;pour décaler les textes chevauchés de profils covadis
;par F.Brosseau SARL PROJSUR le 18/02/2010
 (command "annuler" "D")
 (setq n 0 sel (ssget '((0 . "TEXT"))))
 (repeat (sslength sel)
   (if (> n 0) (setq xo x yo y ))
   (setq entname(ssname sel n)
     	  ent (entget entname)
	  x (car(cdr(assoc 10 ent)))
	  y (cadr(cdr(assoc 10 ent)))
	  n (+ n 1)
   )
   (if (and (> n 1) (		(setq x (- xo (*  [surligneur]1.65 [/surligneur]  (cdr (assoc 40 ent)))) pt (list x y 0))
	(entmake (list '(0 . "TEXT")
			'(100 . "AcDbEntity")
			'(100 . "AcDbText")
			(assoc 1 ent)
			(assoc 7 ent)
			(assoc 8 ent)
		        (assoc 62 ent)
			(cons  10 pt)
			(cons  11 pt)
			(assoc 40 ent)
			(cons  50 1.570796)
			(cons  71 0)
			(cons  72 0)
			(cons  73 2)
			)
	)
	(entdel entname)
   ))
 )
 (setq ss nil)
 (command "annuler" "F")
 (PRINC)) 

 

Voici le code de fred corrigé. Autrement pour jouer avec le décalage il faut modifier la valeur surlignée en jaune

 

Cordialement,

 

LAurent

Posté(e)

Content de savoir que cela sera utile à d'autres.

 

Thierry, je t'ai répondu en MP, quant à Laurent, oui ça roule, je commence à être sollicité mais suis toujours pris sur le chantier du tram de Montpellier et pour longtemps encore je pense.

 

Bonne journée à tous.

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é