Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  Rund um AutoCAD
  LISP - Fläche und Länge berechnen

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:  LISP - Fläche und Länge berechnen (1878 mal gelesen)
SNOOP_69
Mitglied
Konstrukteur - Innenausbau


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

Beiträge: 539
Registriert: 25.01.2006

Hardware:
- Lenovo-W540
Software:
- Win10 Pro 64bit
- Autocad 2018-2023 (Vollversion+LT)
- BricsCad
- DraftSight
- SolidWorks 2017-2022
- SWOOD 2019
- MasterCAM 2018-2022

erstellt am: 07. Jul. 2017 10:00    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,
kann mir jemand bei folgendem Lisp helfen?
Ich würde gerne zusätzlich zur Gesamtfläche (dieser Teil funktioniert sehr gut)...

Code:
(defun C:fla_ber ()
  (setq clay (getvar "clayer")
echo (getvar "cmdecho")
)
; Eingabe
  (princ "\n Polylinien wählen <Enter für alle Polylinien>: ")
  (setq ss (ssget '((0 . "LWPOLYLINE")
    (70 . 1)
  )
  )
  )
  (if (not ss)
    (progn
      (initget "Alle Layer Objekt")
      (setq ant
    (getkword
      "\n Alle, auf aktuellen Layer oder auf Objekt layer: [Alle/Layer/Objekt]: "
    )
      )
      (cond
((= ant "Alle")
(setq ss (ssget "X"
'((0 . "LWPOLYLINE")
  (70 . 1)
  )
  )
)
)
((= ant "Layer")
(setq ss (ssget "X"
(list
  '(0 . "LWPOLYLINE")
  '(70 . 1)
  (cons 8 (getvar "clayer"))
  )
  )
)
)
((= ant "Objekt")
(setvar
  "clayer"
  (cdr (assoc 8 (entget (car (entsel "\n Objekt wählen: ")))))
)
(setq ss (ssget "X"
(list
  '(0 . "LWPOLYLINE")
  '(70 . 1)
  (cons 8 (getvar "clayer"))
  )
  )
)
)
      )
    )
  )
; Berechnung
  (if (not ss)
    (princ "\n Keine Polylinien gefunden!")
    (progn
      (setq fläche 0
    z -1
      )
      (repeat (sslength ss)
(setq obj  (ssname ss (setq z (1+ z)))
      data (entget obj)
)
; Schwerpunkt berechnen
(setq plist (apply
      'append
      (mapcar
'(lambda (x)
  (if (= 10 (car x))
    (list (cdr x))
  )
)
data
      )
    )
      pk    (list (/ (apply '+ (mapcar 'car plist)) (length plist))
  (/ (apply '+ (mapcar 'cadr plist)) (length plist))
    )
)
(command "_area" "Objekt" obj)
; Text setzen
(entmake (list
  '(0 . "TEXT")
  (cons 1 (strcat (rtos (getvar "area") 2 2) "m²"))
  (cons 8 (getvar "clayer"))
  (cons 10 pk)
  (cons 40 (getvar "textsize"))
  '(50 . 0.0)
)
)
(setq fläche (+ fläche (getvar "area")))
      )
      (entmake
(list
  '(0 . "TEXT")
  (cons 1 (strcat "Gesamtfläche: " (rtos fläche 2 2) "mm²"))
  (cons 8 (getvar "clayer"))
  (cons 10 (getpoint "\nEinfügungspunkt angeben: "))
  (cons 40 (getvar "textsize"))
  '(50 . 0.0)
)
      )
    )
  )
  (setvar "clayer" clay)
  (setvar "cmdecho" echo)
  (princ (strcat "\n* Gesamtfläche beträgt: " (rtos fläche 2 2) "m²"))
  (princ)
)

...noch die Gesamtlänge mit ausgeben lassen. Die Texte/Werte sollten dann einfach untereinander eingefügt werden.
Leider bekomme ich es nicht hin...

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

CADwiesel
Moderator
CAD4FM UG




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

Beiträge: 1968
Registriert: 05.09.2000

AutoCAD, Bricscad
Wir machen das Mögliche unmöglich

erstellt am: 07. Jul. 2017 10:21    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 SNOOP_69 10 Unities + Antwort hilfreich

Code:
(defun C:fla_ber ( / clay echo ss ant fläche z laength obj data plist pk )
  (vl-load-com)
  (setq clay (getvar "clayer")
        echo (getvar "cmdecho")
        ) ;_ end of setq
                                        ; Eingabe
  (princ "\n Polylinien wählen <Enter für alle Polylinien>: ")
  (setq ss (ssget '((0 . "LWPOLYLINE")
                    (70 . 1)
                    )
                  ) ;_ end of ssget
        ) ;_ end of setq
  (if (not ss)
    (progn
      (initget "Alle Layer Objekt")
      (setq ant
            (getkword
              "\n Alle, auf aktuellen Layer oder auf Objekt layer: [Alle/Layer/Objekt]: "
              ) ;_ end of getkword
            ) ;_ end of setq
      (cond
        ((= ant "Alle")
        (setq ss (ssget "X"
                        '((0 . "LWPOLYLINE")
                          (70 . 1)
                          )
                        ) ;_ end of ssget
              ) ;_ end of setq
        )
        ((= ant "Layer")
        (setq ss (ssget "X"
                        (list
                          '(0 . "LWPOLYLINE")
                          '(70 . 1)
                          (cons 8 (getvar "clayer"))
                          ) ;_ end of list
                        ) ;_ end of ssget
              ) ;_ end of setq
        )
        ((= ant "Objekt")
        (setvar
          "clayer"
          (cdr (assoc 8 (entget (car (entsel "\n Objekt wählen: ")))))
          ) ;_ end of setvar
        (setq ss (ssget "X"
                        (list
                          '(0 . "LWPOLYLINE")
                          '(70 . 1)
                          (cons 8 (getvar "clayer"))
                          ) ;_ end of list
                        ) ;_ end of ssget
              ) ;_ end of setq
        )
        ) ;_ end of cond
      ) ;_ end of progn
    ) ;_ end of if
                                        ; Berechnung
  (if (not ss)
    (princ "\n Keine Polylinien gefunden!")
    (progn
      (setq fläche 0
            laength 0
            z -1
            ) ;_ end of setq
      (repeat (sslength ss)
        (setq obj  (ssname ss (setq z (1+ z)))
              data (entget obj)
              ) ;_ end of setq
                                        ; Schwerpunkt berechnen
        (setq plist (apply
                      'append
                      (mapcar
                        '(lambda (x)
                          (if (= 10 (car x))
                            (list (cdr x))
                            ) ;_ end of if
                          ) ;_ end of lambda
                        data
                        ) ;_ end of mapcar
                      ) ;_ end of apply
              pk    (list (/ (apply '+ (mapcar 'car plist)) (length plist))
                          (/ (apply '+ (mapcar 'cadr plist)) (length plist))
                          ) ;_ end of list
              ) ;_ end of setq
        (command "_area" "Objekt" obj)
                                        ; Text setzen
        (entmake (list
                  '(0 . "TEXT")
                  (cons 1 (strcat (rtos (getvar "area") 2 2) "m²"))
                  (cons 8 (getvar "clayer"))
                  (cons 10 pk)
                  (cons 40 (getvar "textsize"))
                  '(50 . 0.0)
                  ) ;_ end of list
                ) ;_ end of entmake
        (entmake (list
                  '(0 . "TEXT")
                  (cons 1 (strcat (rtos (vla-get-length (vlax-ename->vla-object obj)) 2 2) "m"))
                  (cons 8 (getvar "clayer"))
                  (cons 10 (list (car pk)(-(cadr pk)(getvar "textsize"))0.0))
                  (cons 40 (getvar "textsize"))
                  '(50 . 0.0)
                  ) ;_ end of list
                )
        (setq laength(+ laength(vla-get-length (vlax-ename->vla-object obj))))
        (setq fläche (+ fläche (getvar "area")))
        ) ;_ end of repeat
      (entmake
        (list
          '(0 . "TEXT")
          (cons 1 (strcat "Gesamtfläche: " (rtos fläche 2 2) "mm²"))
          (cons 8 (getvar "clayer"))
          (cons 10 (setq txtpt(getpoint "\nEinfügungspunkt angeben: ")))
          (cons 40 (getvar "textsize"))
          '(50 . 0.0)
          ) ;_ end of list
        ) ;_ end of entmake
      (entmake
        (list
          '(0 . "TEXT")
          (cons 1 (strcat "Gesamtlänge: " (rtos laength 2 2) "m"))
          (cons 8 (getvar "clayer"))
          (cons 10 (list (car txtpt)(-(cadr txtpt)(getvar "textsize"))0.0))
          (cons 40 (getvar "textsize"))
          '(50 . 0.0)
          ) ;_ end of list
        )
      ) ;_ end of progn
    ) ;_ end of if
  (setvar "clayer" clay)
  (setvar "cmdecho" echo)
  (princ
    (strcat "\n* Gesamtfläche beträgt: " (rtos fläche 2 2) "m²")
    ) ;_ end of princ
  (princ)
  ) ;_ end of defun

------------------
Gruß
CADwiesel
Besucht uns im CHAT

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

SNOOP_69
Mitglied
Konstrukteur - Innenausbau


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

Beiträge: 539
Registriert: 25.01.2006

Hardware:
- Lenovo-W540
Software:
- Win10 Pro 64bit
- Autocad 2018-2023 (Vollversion+LT)
- BricsCad
- DraftSight
- SolidWorks 2017-2022
- SWOOD 2019
- MasterCAM 2018-2022

erstellt am: 07. Jul. 2017 11:46    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

Läuft perfekt! Vielen Dank!

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