Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  Lisp
  3d länge

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
  
Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für Autodesk Produkte
Autor Thema:  3d länge (605 mal gelesen)
nebuCADnezzar
Mitglied



Sehen Sie sich das Profil von nebuCADnezzar an!   Senden Sie eine Private Message an nebuCADnezzar  Schreiben Sie einen Gästebucheintrag für nebuCADnezzar

Beiträge: 262
Registriert: 17.10.2007

AutoCAD 2019
Inventor 2019
64 bit Win 10
Intel I7 10610U 1.8 GHz
Quadro P520
32 GB Ram

erstellt am: 06. Feb. 2013 11:43    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hallo zusammen.

Ich bin gerade drann n paar alte LISP's ins neue ACAD 2013 anzupassen. Eins davon macht mir gerade etwas schwierigkeiten (naja meine LISP skills waren schonmal besser...)

Code:
(defun C:3dlength ()
  (setq LENGTH 0)
  (setq C nil)
  (setq PT2 nil)
  (setq ENAME (car (entsel "\n3d Polyline: ")))
  (setq E (entget ENAME))
  (if (= (cdr (assoc 0 E)) "POLYLINE")
      (progn
        (if (= (logand (cdr (assoc 70 E)) 1) 1)
            (setq C 1)
        )
        (setq T C)
        (setq ENAME (entnext ENAME))
        (setq E (entget ENAME))
        (while (/= (cdr (assoc 0 E)) "SEQEND")
            (if (= (logand (cdr (assoc 70 E)) 16) 0)
                (progn
                    (setq PT1 (cdr (assoc 10 E)))
                    (cond ((= T 1) (setq PT0 PT1) (setq T nil)))
                    (cond ((not PT2) (setq PT2 PT1)))
                    (setq LENGTH (+ LENGTH (distance PT1 PT2)))
                    (setq PT2 PT1)
                )
            )
            (setq ENAME (entnext ENAME))
            (setq E (entget ENAME))
        )
        (if (= C 1)
            (setq LENGTH (+ LENGTH (distance PT1 PT0)))
        )
        (princ "\nLaenge :")
        (princ LENGTH)
        (princ)
      )
      (princ "\nKeine 3d Polylinie")
  )
)

Kapiert hab ich wohl das "LENGTH" ein bereits definierter begriff ist den ich nich einfach so überschreiben kann. Das zu ersetzen durch "länge" hat aber nicht geklappt... (ja manchmal funktioniert sowas wenn man sonst nicht weiss was man tut  )

hab auch ein zwei alternativen gefunden, leider macht "gesla" keine 3d polys
http://ww3.cad.de/foren/ubb/Forum54/HTML/003000.shtml

und dies hier nimmt alles in der Zeichnung vorhandene, piken wäre schön...
http://ww3.cad.de/foren/ubb/Forum145/HTML/000033.shtml

Schöne Grüsse
nebu

------------------
...glaubst das ist luft die du gerade atmest? in diesem raum...

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

cadplayer
Ehrenmitglied
CADniker


Sehen Sie sich das Profil von cadplayer an!   Senden Sie eine Private Message an cadplayer  Schreiben Sie einen Gästebucheintrag für cadplayer

Beiträge: 1832
Registriert: 28.04.2009

erstellt am: 06. Feb. 2013 13:11    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für nebuCADnezzar 10 Unities + Antwort hilfreich

So was ist echt uralt 
Warum nicht ein wenig aufpeppeln mit ActiveX

Code:

(defun c:length ()
  (if (setq ent (entsel "\nSelect a length object "))
    (progn
      (setq obj (vlax-ename->vla-object (car ent)))
      (if (vlax-property-available-p obj 'Length)
        (princ
          (strcat "\nLength: " (rtos (vla-get-length obj)2 2))
          )
        (princ "\nObject has no length property ")
        )
      )
    )
  (princ)
  )
     

------------------
Gruss Dirk


http://cadplayerlounge.blogspot.se

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

nebuCADnezzar
Mitglied



Sehen Sie sich das Profil von nebuCADnezzar an!   Senden Sie eine Private Message an nebuCADnezzar  Schreiben Sie einen Gästebucheintrag für nebuCADnezzar

Beiträge: 262
Registriert: 17.10.2007

AutoCAD 2019
Inventor 2019
64 bit Win 10
Intel I7 10610U 1.8 GHz
Quadro P520
32 GB Ram

erstellt am: 06. Feb. 2013 13:42    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hallo Dirk

Ich habs gerade hinbekommen (mit meiner tausche LENGTH und so mal auf gut glück aus...)
und apropos alt hier mal der gesammte code... :-)

Code:
; berechnet die laenge einer 3d polylinie
; by JD 1995
;----------------------------------------------------------

(defun C:3dlange ()
  (setq lange 0)
  (setq C nil)
  (setq PT2 nil)
  (setq ENAME (car (entsel "\n3d Polyline: ")))
  (setq E (entget ENAME))
  (if (= (cdr (assoc 0 E)) "POLYLINE")
      (progn
        (if (= (logand (cdr (assoc 70 E)) 1) 1)
            (setq C 1)
        )
        (setq TT C)
        (setq ENAME (entnext ENAME))
        (setq E (entget ENAME))
        (while (/= (cdr (assoc 0 E)) "SEQEND")
            (if (= (logand (cdr (assoc 70 E)) 16) 0)
                (progn
                    (setq PT1 (cdr (assoc 10 E)))
                    (cond ((= TT 1) (setq PT0 PT1) (setq TT nil)))
                    (cond ((not PT2) (setq PT2 PT1)))
                    (setq lange (+ lange (distance PT1 PT2)))
                    (setq PT2 PT1)
                )
            )
            (setq ENAME (entnext ENAME))
            (setq E (entget ENAME))
        )
        (if (= C 1)
            (setq lange (+ lange (distance PT1 PT0)))
        )
        (princ "\nLaenge :")
        (princ lange)
        (princ)
      )
      (princ "\nKeine 3d Polylinie")
  )
)


Aber hab mich entschlossen deine neuere Variante zu nehmen...!
vielen Dank!

------------------
...glaubst das ist luft die du gerade atmest? in diesem raum...

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2023 CAD.de | Impressum | Datenschutz