Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  AutoCAD ObjectARX und .NET
  Attribute verschieben

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:  Attribute verschieben (884 mal gelesen)
BerryB
Mitglied


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

Beiträge: 3
Registriert: 29.03.2015

erstellt am: 07. Apr. 2015 10: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

Hallo,

ich versuche mit einer Windows-Anwendung auf Basis VB.NET auf AutoCAD zuzugreifen und in einer DWG-Zeichnung Änderungen durchzuführen.

Bei der Neu-Positionierung eines Attributes komme ich nicht weiter, weil der nachfolgende Code zwar keine Fehlermeldung bringt,
abei leider auch nicht die gewünschte Änderung. In der MSGBOX ist zu sehen, dass die Änderung nicht übernommen wurde.

Was muss ich ändern?

eingefügte Referenzen:
Autodesk.AutoCAD.Interop.dll
Autodesk.AutoCAD.Interop.Common.dll

Code:

Imports Autodesk.AutoCAD.Interop
Imports Autodesk.AutoCAD.Interop.Common

Public Class frmTest

    Private Sub btnTest_Click(sender As Object, e As EventArgs) Handles btnTest.Click

        Dim AcadApp As AcadApplication = CreateObject("AutoCad.Application")

        'warten, bis AutoCAD läuft (neues Zeichnung kann beendet werden)
        On Error Resume Next
        Do
            Err.Number = 0
            AcadApp.ActiveDocument.Close()
        Loop Until Err.Number = 0
        On Error GoTo 0

        'AutoCAD sichtbar machen
        AcadApp.Visible = True

        'DWG öffnen
        AcadApp.Documents.Open("H:\aktuell\CAD\Test.dwg")

        'ModelSpace nach Blockreferenzen im bestimmten Layer mit Attributen suchen
        Dim obj As AcadObject
        Dim attrib
        Dim Punkt(2) As Double
        Dim a As Double

        For Each obj In AcadApp.ActiveDocument.ModelSpace
            If obj.ObjectName = "AcDbBlockReference" And obj.Layer = "456eGERA" Then
                If obj.HasAttributes Then
                    attrib = obj.GetAttributes
                    a = attrib(0).InsertionPoint(0)
                    Punkt(0) = attrib(0).InsertionPoint(0) + 1000
                    Punkt(1) = attrib(0).InsertionPoint(1)
                    Punkt(2) = attrib(0).InsertionPoint(2)
                    attrib(0).InsertionPoint = Punkt
                    MsgBox("alter Wert: " & a & vbCrLf & "neuer Wert:" & attrib(0).InsertionPoint(0))
                    Exit For
                End If
            End If
        Next

        'aktuelles Dokument schließen
        AcadApp.ActiveDocument.Close()
        'AutoCAD beenden
        AcadApp.Quit()
    End Sub

End Class



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

erstellt am: 07. Apr. 2015 13:31    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 BerryB 10 Unities + Antwort hilfreich

... AlignmentPoint mal versucht?

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

BerryB
Mitglied


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

Beiträge: 3
Registriert: 29.03.2015

erstellt am: 07. Apr. 2015 13:50    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

Danke

TextAlignmentPoint heißt die richtige Eigenschaft

so klappt's:

Code:

                If obj.HasAttributes Then
                    attrib = obj.GetAttributes
                    a = attrib(0).TextAlignmentPoint(0)
                    Punkt(0) = attrib(0).TextAlignmentPoint(0) + 1000
                    Punkt(1) = attrib(0).TextAlignmentPoint(1)
                    Punkt(2) = attrib(0).TextAlignmentPoint(2)
                    attrib(0).TextAlignmentPoint = Punkt
                    MsgBox("alter Wert: " & a & vbCrLf & "neuer Wert:" & attrib(0).TextAlignmentPoint(0))
                    Exit For 'Abbruch nach erstem Block mit Attributen
                End If

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