Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  Lisp
  Elemente innerhalb eines Kreises auswählen

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:  Elemente innerhalb eines Kreises auswählen (1224 mal gelesen)
schmiedbert
Mitglied


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

Beiträge: 1
Registriert: 19.06.2017

erstellt am: 19. Jun. 2017 11:02    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

Ein herzliches Grüßgott von meiner Seite!

Ich bin auf der Suche nach Hilfe!

Ich habe bereits ein lisp gebaut unter Verwendung der LeeMac BoundingBox-Routine, um einen Kreis um das Zentrum eines (oder mehrerer) ausgewählter Objekte/s zu erstellen:

(defun c:circ ( / s l )
    (and (setq s (ssget "_:L"))
        (setq l (LM:ssboundingbox s))
        (command "circle" s ""
            "_non"  (apply 'mapcar (cons '(lambda ( a b ) (/ (+ a b) 2.0)) l))
            20
        )
    )
    (princ)
)

;; Selection Set Bounding Box  -  Lee Mac
;; Returns a list of the lower-left and upper-right WCS coordinates of a
;; rectangular frame bounding all objects in a supplied selection set.
;; s - [sel] Selection set for which to return bounding box

(defun LM:ssboundingbox ( s / a b i m n o )
    (repeat (setq i (sslength s))
        (if
            (and
                (setq o (vlax-ename->vla-object (ssname s (setq i (1- i)))))
                (vlax-method-applicable-p o 'getboundingbox)
                (not (vl-catch-all-error-p (vl-catch-all-apply 'vla-getboundingbox (list o 'a 'b))))
            )
            (setq m (cons (vlax-safearray->list a) m)
                  n (cons (vlax-safearray->list b) n)
            )
        )
    )
    (if (and m n)
        (mapcar '(lambda ( a b ) (apply 'mapcar (cons a b))) '(min max) (list m n))
    )
)

(vl-load-com) (princ)

Meine Frage ist nun: Wie kann ich alle Elemente auswählen, die innerhalb dieses Kreises liegen?

Konkret werde ich im späteren Verlauf den radius des Kreises von 0 weg hochiterieren, so lange, bis ich 2 linien und einen Kreis vollständig umschlossen habe!

Vielen Dank im Voraus und liebe Grüße!

Norbert

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

Brischke
Moderator
CAD on demand GmbH




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

Beiträge: 4171
Registriert: 17.05.2001

AutoCAD 20XX, defun-tools (d-tools.eu)

erstellt am: 19. Jun. 2017 11:14    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 schmiedbert 10 Unities + Antwort hilfreich

Zitat:
Original erstellt von schmiedbert:
...Meine Frage ist nun: Wie kann ich alle Elemente auswählen, die innerhalb dieses Kreises liegen?...

Ich denke, das wirst du über eine Selection-WindowPolygon realisieren müssen.
Das Polygon kann nur Liniensegmente enthalten, weshalb du die Polygonkoordinaten entsprechend des Kreisradius und Mittelpunkts berechnen musst. Die Genauigkeit bestimmst du mit der Teilung, wie du die Polygonkorrdinaten vom Kreis ableitest. (1Grad, 10 Grad)

Grüße!
Holger

------------------
Holger Brischke
CAD on demand GmbH
Individuelle Lösungen von Heute auf Morgen.


defun-tools Das Download-Portal für AutoCAD-Zusatzprogramme!


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

VMichl
Mitglied



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

Beiträge: 211
Registriert: 04.01.2001

erstellt am: 19. Jun. 2017 12:12    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 schmiedbert 10 Unities + Antwort hilfreich

Das Kreis müssen Sie aufteilen aber es ist schon da im WPS:
http://www.cadforum.cz/cadforum_en/qaID.asp?tip=5697

V.Michl, www.cadstudio.cz

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

joern bosse
Ehrenmitglied
Dipl.-Ing. Vermessung


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

Beiträge: 1734
Registriert: 11.10.2004

Window 10
ACAD 2021
CIVIL 2021
BricsCAD V14-V22
Intel(R) Core(TM)i5-8250U CPU @ 1.60GHz 1.80 GHz
16.0GB RAM
NVIDIA GeForce GTX 1050<P>

erstellt am: 19. Jun. 2017 12:29    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 schmiedbert 10 Unities + Antwort hilfreich

Hallo Norbert,
hier nochmal ein Beispiel zum Segmentieren eines Kreises (in diesem Fall wird einfach eine Polylinie erstellt):
Code:

(defun JB_KreisSegmente (p radius n / LISTE PISEKTOR PIWERT)
  (setq piSektor (/(* 2.0 pi)n)
piWert 0.0)

  (repeat n
    (setq liste (cons(list (cons 10 (reverse(cdr(reverse(polar p piWert radius)))))
      (cons 40  0.0)
      (cons 41  0.0)
      (cons 42  0.0))liste)
  piWert (+ piWert piSektor)))
 
  (entmake (apply 'append(list(list '(0 . "LWPOLYLINE")
    '(100 . "AcDbEntity")
    '(67 . 0)
    '(410 . "Model")
    (cons 8 "0")
    '(100 . "AcDbPolyline")
    (cons 90 n)
    '(70 . 1)
    '(43 . 0.0)
    '(38 . 0.0)
    '(39 . 0.0))
      (apply 'append
      (reverse liste))
      (list
'(210 0.0 0.0 1.0)))))
  )


(defun c:test ( / P PR R)
  (if (and
(setq p (getpoint "\nMittelpunkt wählen:"))
(setq pr (getpoint p "\nPunkt für Radius:"))
(setq r (distance p pr))
(setq p (trans p 1 0)))
    (JB_KreisSegmente  p r 24))
  (princ))


------------------
viele Grüße

Jörn
http://www.bosse-engineering.com

Liniensignaturen Youtube

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