banniere

Le portail francophone de la géomatique


Toujours pas inscrit ? Mot de passe oublié ?
Nom d'utilisateur    Mot de passe              Toujours pas inscrit ?   Mot de passe oublié ?

Annonce

Rencontres QGIS 2025

L'appel à participation est ouvert jusqu'au 19 janvier 2025!

#1 Tue 14 March 2017 17:20

A48
Participant occasionnel
Date d'inscription: 23 Feb 2017
Messages: 10

[MAP] COPY_OD.lsp et Copie des propriétés

Bonjour,

Je travaille sur la mise en place d'un SIG pour l’assainissement d'une commune sous AutoCAD MAP 2017, j'utilise beaucoup la commande COPY_OD.lsp et copie des propriétés d'AutoCAD  (calque, couleur, type de ligne,...) (commande corresprop sous AutoCAD).

Pour un gain de temps, je souhaiterai exécuter ces 2 commandes en même temps.
Est-ce que quelqu'un pourrait m'expliquer comment modifier le Lisp de COPY_OD pour faire simultanément les 2 actions ?

Merci d'avance, A.

Hors ligne

 

#2 Tue 21 March 2017 13:18

yoann
Participant actif
Lieu: Grenoble
Date d'inscription: 19 Sep 2005
Messages: 120

Re: [MAP] COPY_OD.lsp et Copie des propriétés

Bonjour,

Je me permets de remonter ce post car cette demande m'intéresse aussi... J'utilise aussi beaucoup COPY_OD.lsp et c'est vrai je j'enchaine aussi avec une copie des propriétés, comme A48.

Ces fonctions pourraient d'ailleurs être ajoutées à l'excellent développement d'Olivier (Mapshowod et Mqselect). D'ailleurs cette dll est-elle mise à jour ? J'ai une version "ObjectDataCS19.dll". On se demande pourquoi Autodesk n'intègre pas ce genre de fonctions en natif dans MAP !!!!

Merci d'avance et bonne journée.

Yoz

Hors ligne

 

#3 Wed 22 March 2017 17:21

bruno v.
Participant actif
Date d'inscription: 22 Mar 2010
Messages: 89

Re: [MAP] COPY_OD.lsp et Copie des propriétés

Bonjour,

Le fichier COPY_OD.LSP comportant un copyrigth, je ne vais pas publier le code en entier.
Vous allez vous même assumer les modifications dans le fichier original.

après la ligne 234 (à la fin de la boucle while), vous allez insérer le bloc de code suivant

Code:

            (setq
              dxf_source (entget source_obj)
              dxf_target (entget target_obj)
            )
            (foreach n '(8 62 6 48 370 39 420)
              (cond
                ((assoc n dxf_target)
                  (if (assoc n dxf_source)
                    (setq dxf_target (subst (assoc n dxf_source) (assoc n dxf_target) dxf_target))
                    (if (eq n 420)
                      (setq dxf_target (vl-remove (assoc n dxf_target) dxf_target))
                      (setq dxf_target
                        (subst
                          (cond
                            ((eq n 62) '(62 . 256))
                            ((eq n 6) '(6 . "BYLAYER"))
                            ((eq n 48) '(48 . 1.0))
                            ((eq n 39) '(39 . 0.0))
                            ((eq n 370) '(370 . -1))
                            (T (assoc n dxf_target))
                          )
                          (assoc n dxf_target)
                          dxf_target
                        )
                      )
                    )
                  )
                )
                (T
                  (if (assoc n dxf_source) (setq dxf_target (append dxf_target (list (assoc n dxf_source)))))
                )
              )
            )
            (entmod dxf_target)

Il serait bien de déclarer en locale les nouvelles variables utilisées, donc (ligne 121)

Code:

(defun COPY_DATA (
  source_obj
  target_obj
  overwrite                   ; overwrite flag
  / 
  ct        ct2 
  cttemp    fld 
  fldnme    fldnamelist 
  fldtyp    fldtypelist
  len       numrec 
  OK        tbl 
  tbllist   tbldef 
  tblstr    val 
  vallist 
  )

deviendra

Code:

(defun COPY_DATA (
  source_obj
  target_obj
  overwrite                   ; overwrite flag
  / 
  ct        ct2 
  cttemp    fld 
  fldnme    fldnamelist 
  fldtyp    fldtypelist
  len       numrec 
  OK        tbl 
  tbllist   tbldef 
  tblstr    val 
  vallist 
  dxf_source
  dxf_target
  )

Je ne saurais être responsable d'un mauvais fonctionnement, c'est à vos risques et périls. (Je n'ai testé que sommairement)
Conseil: Sauvegardez vos modifications dans un nouveau fichier, par exemple My_copy_od.lsp et chargez celui-ci. L'ancien restera dispo...

Hors ligne

 

#4 Tue 18 April 2017 15:33

yoann
Participant actif
Lieu: Grenoble
Date d'inscription: 19 Sep 2005
Messages: 120

Re: [MAP] COPY_OD.lsp et Copie des propriétés

Merci Bruno smile

Hors ligne

 

#5 Sat 29 July 2017 08:45

Patrice
JeSuisCharlie
Date d'inscription: 16 Sep 2005
Messages: 4794

Re: [MAP] COPY_OD.lsp et Copie des propriétés

Hello

Merci Bruno !

Qq routines sur les ODs de MAP ici :
https://georezo.net/forum/viewtopic.php?id=44248

GeoBye, Pat

------ PS: les champs OD (Object Data) de type Character/Caractere sont limites a 132 caraceteres ------


(Autodesk Expert Elite Team)

Hors ligne

 

#6 Thu 27 December 2018 16:22

erizk79
Juste Inscrit !
Date d'inscription: 27 Dec 2018
Messages: 1

Re: [MAP] COPY_OD.lsp et Copie des propriétés

bjr,

s'il vous plait quelq'un peut-il m'aider à modifier le Lisp Copy_OD,  je souhaite qu'il change la couleur du but lors de l'ajout des informations. je ne suis pas un developeur.

merci.

Hors ligne

 

#7 Thu 10 January 2019 12:00

bruno v.
Participant actif
Date d'inscription: 22 Mar 2010
Messages: 89

Re: [MAP] COPY_OD.lsp et Copie des propriétés

erizk79 a écrit:

bjr,

s'il vous plait quelq'un peut-il m'aider à modifier le Lisp Copy_OD,  je souhaite qu'il change la couleur du but lors de l'ajout des informations. je ne suis pas un developeur.

merci.


Bonjour,

Essayes avec cette copie modifiée.

Code:

;;;---------------------------------------------------------------------------;
;;;
;;;    COPY_OD.LSP
;;;
;;;    (C) Copyright 1998 by Autodesk, Inc.
;;;
;;;    Permission to use, copy, modify, and distribute this software
;;;    for any purpose and without fee is hereby granted, provided
;;;    that the above copyright notice appears in all copies and
;;;    that both that copyright notice and the limited warranty and
;;;    restricted rights notice below appear in all supporting
;;;    documentation.
;;;
;;;    AUTODESK PROVIDES THIS PROGRAM "AS IS" AND WITH ALL FAULTS.
;;;    AUTODESK SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTY OF
;;;    MERCHANTABILITY OR FITNESS FOR A PARTICULAR USE.  AUTODESK, INC.
;;;    DOES NOT WARRANT THAT THE OPERATION OF THE PROGRAM WILL BE
;;;    UNINTERRUPTED OR ERROR FREE.
;;;
;;;    Use, duplication, or disclosure by the U.S. Government is subject to
;;;    restrictions set forth in FAR 52.227-19 (Commercial Computer
;;;    Software - Restricted Rights) and DFAR 252.227-7013(c)(1)(ii)
;;;    (Rights in Technical Data and Computer Software), as applicable.
;;;
;;;    July 1996
;;; 
;;;---------------------------------------------------------------------------;
;;;
;;;    DESCRIPTION
;;;
;;;    Copy object data from one object to a set of other objects. If the
;;;    object data to be copied already exists on the target object the
;;;    options to not copy, copy once and copy all are presented.
;;;
;;;    Careful, it is possible to corrupt existing topological data
;;;    using this routine.
;;;
;;;---------------------------------------------------------------------------;

;;;****************************************************************************
;;; Function: C:COPY_OD
;;;
;;; Main routine for copying object data from an object to
;;; a selection set of object. 
;;;
;;;
(defun C:COPY_OD ( 
  /
  source_obj                 ; source object
  target_obj                 ; target object
  target_ss                  ; target selection set
  ct                         ; count
  len                        ; length
  overwrite                  ; overwrite flag
  error                      ; old error function
  od_color
  )
  
  (setq error *error*)
  ;;
  ;; Define error handler
  ;;
  (defun *error* (msg)
    (alert msg)
    (setq *error* error)
    (exit)
  )
  
  ;;
  ;; Input the source object to copy data from
  ;;
  (princ "\nSelect SOURCE object: ")
  (setq source_obj (car (entsel)))
  (if (null source_obj)
    (prompt "\nNo source object selected.")
    (progn
      ;;
      ;; If the object has object data attached process it
      ;;
      (if (null (ade_odgettables source_obj))
        (princ "\nSelected object contains no object data.")
        (progn
          (princ "\n\nSelect TARGET objects: ")
          (setq target_ss (ssget))
          (if (null target_ss)
            (prompt "\nNo target object selected.")
            (progn
              (setq len (sslength target_ss))
              (setq ct 0)
              (princ "\nCopying object data...")
              (while (< ct len)
                (setq target_obj (ssname target_ss ct))
                (redraw target_obj 3)
                (setq ct (+ ct 1))
                (setq overwrite (COPY_DATA source_obj target_obj overwrite))
                (if (not od_color) (setq od_color (car (acad_truecolordlg (if (assoc 62 (entget target_obj)) (assoc 62 (entget target_obj)) '(62 . 256)) T))))
                (redraw target_obj 4)
                (if (assoc 62 (entget target_obj))
                  (entmod (subst od_color (assoc 62 (entget target_obj)) (entget target_obj)))
                  (entmod (append (entget target_obj) (list od_color)))
                )
              )
            )
          );if
        )
      );if
    )
  );if   
  
  (setq *error* error)                                ;restore error handler
  
  (prompt "\nProcessing completed.")
  (princ)
  
);C:COPY_OD

;;;****************************************************************************
;;; Function: C:COPY_DATA
;;;
;;; Copy object data from the source object to the target object.
;;;
;;; If the data is already found to exist on a target object, the 
;;; user is prompted what to do. Either to replace it only on the 
;;; target, for all objects in  the selection set, or to skip it.
;;;
;;;
(defun COPY_DATA (
  source_obj
  target_obj
  overwrite                   ; overwrite flag
  / 
  ct        ct2 
  cttemp    fld 
  fldnme    fldnamelist 
  fldtyp    fldtypelist
  len       numrec 
  OK        tbl 
  tbllist   tbldef 
  tblstr    val 
  vallist 
  dxf_source
  dxf_target
  )

  ;; 
  ;; access all OD tables from source object
  ;;
  (if (setq tbllist (ade_odgettables source_obj))
    (progn
      ;;
      ;; for each table on source object
      ;;
      (foreach tbl tbllist
         (prompt (strcat "\nProcessing source table " tbl "."))
         ;;
         ;; determine if target object has object
         ;; data records for current table
         ;;
         (setq OK nil)
         (setq numrec (ade_odrecordqty target_obj tbl))
         ;;
         ;; If the table is found on object ask what to do
         ;;
         (if (and (> numrec 0) (/= overwrite "All"))
           (progn
             (initget "All Yes No")
             (setq overwrite (getkword "\nOverwrite existing record(s) on target? (All/Yes/No) <All>: "))
             (if (null overwrite)
               (setq overwrite "All")
             )
           )
         )
         (if (or (= overwrite "All") 
                 (= overwrite "Yes")
                 (= numrec 0)
             )
            (setq OK T)
         )
         ;;
         ;; delete all existing records on target 
         ;; object if overwrite flag is set
         ;;
         (if (and (> numrec 0)
                  (or (= overwrite "Yes")(= overwrite "All"))
             )
           (progn
             (setq ct 0)
             (while (< ct numrec)
               (ade_oddelrecord target_obj tbl ct)
               (setq ct (+ ct 1))
             )
           ) 
         )
         (if OK
           (progn
            ;;
            ;; build list of field names
            ;;
            (setq tbldef (ade_odtabledefn tbl))
            (setq tblstr (cdr (nth 2 tbldef)))
            (setq fldnamelist ())
            (setq fldtypelist ())
            (foreach fld tblstr
              (setq fldnme (cdr (nth 0 fld)))
              (setq fldtyp (cdr (nth 2 fld)))
              (setq fldnamelist (append fldnamelist (list fldnme)))
              (setq fldtypelist (append fldtypelist (list fldtyp)))
            )
            ;;
            ;; for each record on source object 
            ;;
            (setq numrec (ade_odrecordqty source_obj tbl))
            (setq ct 0)
            (while (< ct numrec)
              ;;
              ;; build list of values
              ;;
              (setq cttemp 0)
              (setq vallist ())
              (foreach fld fldnamelist
                (setq typ (nth cttemp fldtypelist))
                (setq cttemp (+ cttemp 1))
                (setq val (ade_odgetfield source_obj tbl fld ct))
                (if (= typ "Integer")(setq val (fix val)))
                (setq vallist (append vallist (list val)))
              )
              ;;
              ;; add a record to target object
              ;;
              (ade_odaddrecord target_obj tbl)
              ;;
              ;; populate target record with values from source record
              ;;
              (setq ct2 0)
              (while (< ct2 (length vallist))
                (setq val (nth ct2 vallist))
                (setq fld (nth ct2 fldnamelist))
                (setq ct2 (+ ct2 1))
                (ade_odsetfield target_obj tbl fld ct val)
              )
              (setq ct (+ ct 1))
            );while
            (setq
              dxf_source (entget source_obj)
              dxf_target (entget target_obj)
            )
            (foreach n '(8 62 63 6 48 370 39 420 421)
              (cond
                ((assoc n dxf_target)
                  (if (assoc n dxf_source)
                    (setq dxf_target (subst (assoc n dxf_source) (assoc n dxf_target) dxf_target))
                    (if (or (eq n 420) (eq n 421))
                      (setq dxf_target (vl-remove (assoc n dxf_target) dxf_target))
                      (setq dxf_target
                        (subst
                          (cond
                            ((eq n 62) '(62 . 256))
                            ((eq n 63) '(63 . 256))
                            ((eq n 6) '(6 . "BYLAYER"))
                            ((eq n 48) '(48 . 1.0))
                            ((eq n 39) '(39 . 0.0))
                            ((eq n 370) '(370 . -1))
                            (T (assoc n dxf_target))
                          )
                          (assoc n dxf_target)
                          dxf_target
                        )
                      )
                    )
                  )
                )
                (T
                  (if (assoc n dxf_source) (setq dxf_target (append dxf_target (list (assoc n dxf_source)))))
                )
              )
            )
            (entmod dxf_target)
          )
        );if
      );foreach
    )
  );if
  
  ;;
  ;; Return overwrite status so it can 
  ;; be passed back in for the next object.
  ;; 
  overwrite
   
);COPY_DATA

(prompt "\nType: COPY_OD to copy object data.")
(princ)

Hors ligne

 

Pied de page des forums

Powered by FluxBB