Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  SolidWorks
  (API) Abfrage ob mehr als 1 BG offen

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 SOLIDWORKS
  
Von der Idee zum echten Bauteil: Alles mit einer Plattform - SOLIDWORKS macht es möglich
Autor Thema:  (API) Abfrage ob mehr als 1 BG offen (1575 mal gelesen)
THSEFA
Mitglied
Konstrukteur/CAD-Admin


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

Beiträge: 1141
Registriert: 27.11.2002

SWX 2020 SP5.0 Premium
Windows 10 Pro 64Bit
Citrix VM
Intel(R) XEON(R) Gold 6146 CPU @ 3.20GHz
24 GB Ram<P>Windows 10 Pro 64Bit

erstellt am: 28. Apr. 2011 10:36    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 Allerseits,
ich möchte in einem Makro für Baugruppen am Anfang abfragen, ob mehr als nur diese eine Baugruppe offen ist. Sind mehrere BG´s oder auch Teile auf, soll eine Meldung kommen. Kann mir da jemand mal kurz auf die Sprünge helfen? Ein kurzer Tipp für die Suche in der API-Hilfe würde mir reichen... 

Bei meiner Suche im Forum bin ich auf diesen Thread gestoßen, der entspricht aber nicht ganz dem, was ich suche bzw. habe ich keine Ahnung, wie ich dieses Beispiel für mich anpassen kann.

Schon mal vielen Dank für´s lesen! 

------------------
Viele Grüße, THSEFA 

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

StefanBerlitz
Guter-Geist-Moderator
IT Admin (CAx)



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

Beiträge: 8756
Registriert: 02.03.2000

SunZu sagt:
Analysiere die Vorteile, die
du aus meinem Ratschlag ziehst.
Dann gliedere deine Kräfte
entsprechend und mache dir
außergewöhnliche Taktiken zunutze.

erstellt am: 28. Apr. 2011 10:59    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 THSEFA 10 Unities + Antwort hilfreich

Hallo THSEFA,

das kannst du auf verschiedene Weise lösen, z.B. mit SldWorks::GetDocuments (Beispiel siehe Get Paths of Open Documents), ich hab es hier als Beispiel mit der "klassischen" Traverse über die geöffneten Dokumente gemacht. Du musst nur beachten, dass auch geladenen Komponenten von Baugruppen oder Modelle von Zeichnungen als geöffnet gelten. Dafür den "Umweg"§ über die Sichtbatkeit im Code, je nachdem, ob du alle geöffneten oder nur alle "offenen" Dokumente haben willst  

Code:
Sub main()

    Dim swapp     As Object
    Dim ModelDoc  As Object

    Set swapp = Application.SldWorks
    Set ModelDoc = swapp.GetFirstDocument

    While Not ModelDoc Is Nothing

        ' vollständig geladene Baugruppenkomponenten oder Modelle aus Zeichnungen
        ' zählen als geöffnet, sind aber nicht sichtbar
        ' Also nachschauen, ob das ModelDoc "sichtbar" ist

        If ModelDoc.Visible = True Then
            ' sichtbar, also "geöffnet"
            Debug.Print "Geöffnet und sichtbar: " & ModelDoc.GetPathName
        Else
            Debug.Print "   Geöffnet aber nicht sichtbar: " & ModelDoc.GetPathName
        End If
       
        Set ModelDoc = ModelDoc.GetNext
   
    Wend

End Sub



Du musst also für deinen Fall nur einen Zähler mitlaufen lassen, wie viele der geöffneten Dokumente sichtbar sind und bei mehr als einem eine Warnmeldung bringen.

Ciao,
Stefan

------------------
Inoffizielle deutsche SolidWorks Hilfeseite    http://solidworks.cad.de
Stefans SolidWorks Blog

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

THSEFA
Mitglied
Konstrukteur/CAD-Admin


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

Beiträge: 1141
Registriert: 27.11.2002

SWX 2020 SP5.0 Premium
Windows 10 Pro 64Bit
Citrix VM
Intel(R) XEON(R) Gold 6146 CPU @ 3.20GHz
24 GB Ram<P>Windows 10 Pro 64Bit

erstellt am: 29. Apr. 2011 08:56    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 Stefan für deinen Tipp!

Nachdem ich gestern ein wenig damit rumgespielt habe, ist folgendes rausgekommen:

Code:

Dim swApp As SldWorks.SldWorks
Dim myDwgDoc As SldWorks.ModelDoc2
Dim swDoc As SldWorks.ModelDoc2
Dim Part As Object
Dim ModelDoc2  As Object
Dim filename As String
Dim count As String
Dim DwgPath As String
Dim Pdminfo As String
Dim CloseErrors As Long
Dim CloseWarnings As Long
Dim NumDocsReturned As Long
Dim swAllDocs As EnumDocuments2

Const swDocPART = 1
Const swDocASSEMBLY = 2
Const swDocDRAWING = 3


Set swApp = Application.SldWorks
Set swAllDocs = swApp.EnumDocuments2
Set ModelDoc2 = swApp.GetFirstDocument
Set Model = swApp.GetFirstDocument

' dann war gar kein Dokument geöffnet, wie soll da was funktionieren
If ModelDoc2 Is Nothing Then
MsgBox " Kein Dokument geöffnet! ", vbExclamation
End
End If
count = 0
    While Not ModelDoc2 Is Nothing
        'vollständig geladene Baugruppenkomponenten oder Modelle aus Zeichnungen zählen als geöffnet, sind aber nicht sichtbar
        'Also nachschauen, ob das ModelDoc "sichtbar" ist
        If ModelDoc2.visible = True Then
            'sichtbar, also "geöffnet"
            Debug.Print "Geöffnet und sichtbar: " & ModelDoc2.GetPathName
            'zählt die sichtbaren Dokumente
            count = count + 1
        Else
            'ist nur eines offen, so werden die nicht sichtbaren (z.B. die Teile einer Baugruppe) gezählt
            Debug.Print "Geöffnet aber nicht sichtbar: " & ModelDoc2.GetPathName
        End If

        Set ModelDoc2 = ModelDoc2.GetNext

    Wend
   
    If (count > 1) Then
    MsgBox ("Es sind " + count + " Dokumente in Solidworks geöffnet!") ' , vbOKOnly
    End
    End If

Set ModelDoc2 = swApp.GetFirstDocument
   
    'neue Schleife
    Do
        'vollständig geladene Baugruppenkomponenten oder Modelle aus Zeichnungen zählen als geöffnet, sind aber nicht sichtbar
        ' Also nachschauen, ob das ModelDoc "sichtbar" ist
        If ModelDoc2.visible = True Then
            'sichtbar, also "geöffnet"
            Debug.Print "Geöffnet und sichtbar: " & ModelDoc2.GetPathName
            'wenn Dokument sichtbar, dann raus aus Schleife
            Exit Do
        Else
            Debug.Print "Geöffnet aber nicht sichtbar: " & ModelDoc2.GetPathName
            'End
        End If

        Set ModelDoc2 = ModelDoc2.GetNext

    Loop While Not ModelDoc2 Is Nothing

'wenn keine Assembly aktiv ist wird das Makro wieder beendet
If (ModelDoc2.GetType <> swDocASSEMBLY) Then
MsgBox " Nur für Baugruppen geeignet! ", vbExclamation
End
End If
 
'Dateinamen der Baugruppe holen
filename = Model.GetTitle

*
*
*



Ich finde es zwar ganz schön umständlich, aber es funktioniert.

Nochmals ein herzliches Dankeschön an Stefan!

------------------
Viele Grüße, THSEFA 

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)2024 CAD.de | Impressum | Datenschutz