| |
| Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für SOLIDWORKS |
| |
| Beyond SOLIDWORKS - Wie Dassault Systèmes Ihre Business-Hürden aus dem Weg räumt |
Autor
|
Thema: Koordinaten Mausklick auslesen VBA (448 mal gelesen)
|
Conrad Mitglied Dipl.-Ing. (FH)
Beiträge: 280 Registriert: 20.12.2002 Windows 10 SolidWorks 2018/Sp5.0 Intel(R) XEON(R) CPU E5-1620v4 @ 3.49Ghz 32 GB RAM 64-Bit proALPHA Client for Open Enterprise Server 2 SP4 (IR10) Linux basierte file server
|
erstellt am: 29. Jun. 2021 13:33 <-- editieren / zitieren --> Unities abgeben:
Hallo, wie kann ich mit VBA, die Kordinaten eines Mausklickes auf einer Zeichnung auslesen. Zur Info: Dies soll in einem Makro verwendet werden: Makro läuft an, wartet auf den Klick, liest die Kordinatem des Klicks aus und verarbeitet diese weiter: ------------------ Grüße aus dem Allgäu Conrad
Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Christian_W Ehrenmitglied V.I.P. h.c. Konstrukteur (Dipl-Ing)
Beiträge: 3189 Registriert: 04.04.2001 CSWP 12/2015<P>SWX2021sp5 Win10/11 (SWX2016, SWX2012) proAlpha6.2e00/calinkV9 (Tactonworks) (Medusa7, NesCAD2010, solidEdge19)
|
erstellt am: 29. Jun. 2021 15:45 <-- editieren / zitieren --> Unities abgeben: Nur für Conrad
Hallo, ich hab mal die Koordinaten verwendet, wo man vor dem Makroaufruf auf das leere Blatt geklickt hat und an die Stelle dann einen Block platziert. Dann darf man aber nicht irgendwas anderes damit gewählt haben, deshalb die if-Abfragen. Vielleicht kannst du mit dem Ansatz etwas anfangen, oder es kommt jemand mit einer besseren Lösung
Code:
Set SelectionMgr = MyDoc.SelectionManager If (SelectionMgr.GetSelectedObjectCount <> 0) Then If (SelectionMgr.GetSelectedObjectType(1) = 19) Then 'Vorher ins Blatt geklickt - alles klar vSelPt = SelectionMgr.GetSelectionPoint2(1, -1) BlockPosition(0) = vSelPt(0) BlockPosition(1) = vSelPt(1) Else 'Irgend etwas anderes erwischt MyDoc.ClearSelection2 True End If Else 'Oder gar nicht geklickt? MyDoc.ClearSelection2 True End If
Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Micha1985 Mitglied Technischer Zeichner
Beiträge: 24 Registriert: 30.06.2021 Intel(R) XEON(R) CPU E5-1620v4 @ 3.49Ghz 32 GB RAM 64-Bit Windows 10 SolidWorks 2018/SP5.0 proALPHA6.2e00 / CA-Link V9.0
|
erstellt am: 30. Jun. 2021 08:44 <-- editieren / zitieren --> Unities abgeben: Nur für Conrad
Hallo Christian! Besten Dank schon mal für den Code Ich bin ein Kollege von Conrad und arbeite gerade an demselben Thema. Leider scheint es mit .getselectionpoint2 nicht zu funktionieren, egal wie ich die Variablen deklariere bekomme ich immer eine "Typen unverträglich"-Meldung oder ähnliches. Die Solidworks-API-Hilfe ist in dem Fall auch nicht besonders hilfreich, da dort die Variable je nach Beispiel unterschiedlich deklariert wird (mal als Object, mal als Variant-Array) und keines davon in meinem Fall zu funktionieren scheint. Vielleicht wird .getselectionpoint2 ja in Modell und Zeichnung unterschiedlich angesteuert, oder funktioniert in der Zeichnung überhaupt nicht... bin etwas ratlos. Falls noch jemand eine zündende Idee hat, das wäre mein Wunsch-Ablauf: -Benutzer aktiviert das Makro -Makro läuft bis zu einem gewissen Punkt und wartet dann auf Benutzereingabe -Benutzer klickt auf eine bestimmte Stelle auf der Zeichnung (kann das Blatt sein, oder auch eine Ansicht... mir gehts nur um die Koordinaten des Mausklicks) -Der Klick ist für das Makro das Signal um weiterzulaufen, die X- und Y-Koordinaten werden in 2 Variablen gespeichert um danach damit arbeiten zu können Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Christian_W Ehrenmitglied V.I.P. h.c. Konstrukteur (Dipl-Ing)
Beiträge: 3189 Registriert: 04.04.2001 CSWP 12/2015<P>SWX2021sp5 Win10/11 (SWX2016, SWX2012) proAlpha6.2e00/calinkV9 (Tactonworks) (Medusa7, NesCAD2010, solidEdge19)
|
erstellt am: 30. Jun. 2021 09:57 <-- editieren / zitieren --> Unities abgeben: Nur für Conrad
Hi, also mein makro läuft auf einer Zeichnung, allerdings starte ich das ganze Makro erst nach dem Klick. Problem war, dass man in einen leeren Blattbereich klicken musste, damit das funktioniert. Ich glaub, es gibt sonst Koordinaten mit Bezug auf eine Ansicht oder so (wenn ich mich recht entsinne). Für das einfügen mit MakeSketchBlockFromFile brauchte ich dann auch noch einen "MathPoint". Hier noch ein paar puzzle-Teile
Code: dim vSelPt as Variant dim BlockPosition(2) as Double dim MyPoint As SldWorks.MathPoint Dim swMathUtil As SldWorks.MathUtility Set swMathUtil = swApp.GetMathUtility Set MyPoint = swMathUtil.CreatePoint((BlockPosition))
Dann musst du nur noch herausfinden, dass Blockposition(2) = 0 ist.
Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Micha1985 Mitglied Technischer Zeichner
Beiträge: 24 Registriert: 30.06.2021 Intel(R) XEON(R) CPU E5-1620v4 @ 3.49Ghz 32 GB RAM 64-Bit Windows 10 SolidWorks 2018/SP5.0 proALPHA6.2e00 / CA-Link V9.0
|
erstellt am: 30. Jun. 2021 11:11 <-- editieren / zitieren --> Unities abgeben: Nur für Conrad
Super, habs mal auf meine Bedürfnisse zurechtgebastelt und hat funktioniert! Vielen vielen Dank, manchmal steht man einfach auf dem Schlauch Ist übrigens egal ob man eine Ansicht oder den leeren Blattbereich anklickt, Solid bezieht die Koordinaten wohl immer auf seinen gedachten Nullpunkt im linken unteren Eck der Zeichnung! Kommt mir in dem Fall auch entgegen. Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |