| | | Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für Autodesk Produkte |
Autor
|
Thema: Texteinfügen, Einfügeposition (1140 mal gelesen)
|
MartinM Mitglied
Beiträge: 122 Registriert: 27.11.2001
|
erstellt am: 23. Feb. 2005 16:30 <-- editieren / zitieren --> Unities abgeben:
Hallo zusammen, ich möchte mit VBA einen (einzeiligen) Text einfügen. Das besondere dabei: der Text soll am Cursor hängen und dann per Mausklick positioniert werden. Kennt von euch jemand eine Lösung bzw. einen Ansatz hierfür ? Viele Grüsse Martin Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Huebi Mitglied Vermessungsing.
Beiträge: 107 Registriert: 08.01.2004 Intel Core Duo E6750@2.66GHz NVIDIA GeForce 8600 GT AutoCAD 2004, 2007, 2008 AcadMAP 2004 und 2007 Civil 3D 2008 ADT 2009
|
erstellt am: 24. Feb. 2005 08:27 <-- editieren / zitieren --> Unities abgeben: Nur für MartinM
Servus Martin, soweit ich weiß, funktioniert es in VBA nicht, daß man Objekte an den Cursor hängt und dann einfügt. Hierzu gab es schon ein paar Beiträge bei denen es meist um das Einfügen von Blocks (am Cursor) ging (...kannst ja mal in der Suche nachsehen). Was allerdings geht, ist ein nicht gerade eleganter Workaround mit dem SendCommand - Befehl (siehe anhängender Programmcode). Ich erzeuge einen Text und verändere ihn (in diesem Fall die Farbe), um diesen Text im Anschluß in AutoCAD (mit SendCommand) mit dem Befehl "_move" un dem Zusatz "_l" (also vorherige Auswahl) ansprechen zu können. Hier mal ein Schnellschußprogrämmchen... Code: Sub TextSendCommand() Dim Txt As AcadText Dim TxtHoe As Double Dim SysVarName, TxtStr, XStr, YStr As String Dim Pkt As VariantTxtStr = "Hallo" 'Abfragen der aktuellen Textgröße SysVarName = "TEXTSIZE" TxtHoe = ThisDrawing.GetVariable(SysVarName) 'Einfügepunkt per Klick auswählen Pkt = ThisDrawing.Utility.GetPoint(, "Einfügepunkt für Text wählen: ") Set Txt = ThisDrawing.ModelSpace.AddText(TxtStr, Pkt, TxtHoe) 'Durch das Ändern der Farbe Txt.color = acByLayer 'Ermitteln der Startkoordinaten für das Verschieben als String XStr = CStr(Pkt(0)): Mid(XStr, InStr(XStr, ","), 1) = "." YStr = CStr(Pkt(1)): Mid(YStr, InStr(YStr, ","), 1) = "." 'SendCommand für Move mit den Startkoordinaten ThisDrawing.SendCommand "_move" & vbCr & "_l" & vbCr & vbCr & XStr & "," & YStr & vbCr End Sub
Ich hoffe, ich konnte Dir damit ein wenig helfen. Gruß aus München Hübi
------------------ Wissen ist Macht - nix wissen macht nix! Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
MartinM Mitglied
Beiträge: 122 Registriert: 27.11.2001
|
erstellt am: 24. Feb. 2005 12:27 <-- editieren / zitieren --> Unities abgeben:
Hallo Hübi, vielen Dank für deinen Beitrag. Zum einen bestätigt er meine Vermutung, dass es in VBA nicht geht; zum anderen lieferst du mir gleich einen Workaround, an den ich mich jetzt hätte machen müssen. Danke Martin Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
CADmium Moderator Maschinenbaukonstrukteur
Beiträge: 13508 Registriert: 30.11.2003 ACAD 2008 Mechanical
|
erstellt am: 24. Feb. 2005 12:42 <-- editieren / zitieren --> Unities abgeben: Nur für MartinM
es würde schon gehen: in einer Schleife bis Mausklick 0. ab 2. Aufruf : Text löschen 1. Mausposition ermitteln2. und dann Text dort erzeugen 3. zurück zu 0 P.S. in Lisp kann man dazu die Funktion grread auswerten ------------------ - Thomas - "Bei 99% aller Probleme ist die umfassende Beschreibung des Problems bereits mehr als die Hälfte der Lösung desselben."
[Diese Nachricht wurde von CADmium am 24. Feb. 2005 editiert.] Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
MartinM Mitglied
Beiträge: 122 Registriert: 27.11.2001
|
erstellt am: 24. Feb. 2005 13:16 <-- editieren / zitieren --> Unities abgeben:
|
| Anzeige.:
Anzeige: (Infos zum Werbeplatz >>)
|