Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  CATIA V5 Programmierung
  Produktstruktur nach Partnamen durchsuchen und im 1. Part mittels Geoset abbilden.

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
Autor Thema:  Produktstruktur nach Partnamen durchsuchen und im 1. Part mittels Geoset abbilden. (992 mal gelesen)
Beny
Mitglied
Konstrukteur - Standardisierung


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

Beiträge: 36
Registriert: 15.11.2010

erstellt am: 14. Jul. 2011 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 Leute,


Ich bin gerade dabei ein Makro zu schreiben, aber ich komme irgendwie nicht mehr weiter.

Die Ausgangssituation:

der User hat ein Product geöffnet und startet das makro. Innerhalb des Produktes gibt es eine unterschiedliche Part und Productstruktur auf mehreren Produktebenen.

Das Makro soll nun durch das Produkt des Users laufen und auf der 1. Produktebene von allen Parts den Namen des Hauptkörpers auslesen und mir im 1. Part des Produktes (STRG-Part) ein Geometrisches Set mit dem Namen anlegen lassen.

Dazu hab ich schonmal was ausgearbeitet.

- aber ich bekomme für jedes Objekt immer ein Produkt angezeigt (wenn ich Typename durchführen lasse) ob wohl es ein Part ist.
- wie bekomme ich es hin das das 1. part im Produkt als Part deklariert wird? (damit man später die Struktur abbilden lassen kann?)


vielen dank schonmal für eure Hilfe.

lg beny


Anbei der Code:

Sub Test()

'Deklarieren und Setzen der Objecte

Dim DocS As Documents
Set DocS = CATIA.Documents

Dim UserProductDocument As ProductDocument
Set UserProductDocument = CATIA.ActiveDocument

Dim UserProduct As Products
Set UserProduct = UserProductDocument.Product

Dim STRGPartProduct  As Product
Set STRGPartProduct = UserProductDocument.Product.Products.Item(1)

Dim Partanzahl As Long
Partanzahl = UserProduct.Count

MsgBox "TestMessage: In dem geöffneten Product existieren___  " & Partanzahl & "  ___Komponenten"
MsgBox "TestMessage: Der Name des 1. Parts (STRG-Part) ist___  " & STRGPartProduct.name

Dim Objct As Object
Set Objct = STRGPartProduct

Dim STRGPart As Part

Dim AktuellesPart As Product

Dim Objectname As String

'Schleife welche alle Objecte des Products durchgeht und von allen Parts den Hauptkörper ausliest und im STRG-Part (1.Part im Product) eine bestimmte struktur anlegt.
        Dim I As Long
        For I = 1 To Partanzahl

            Set AktuellesPart = UserProductDocument.Product.Products.Item(I)
           
           
            MsgBox "TestMessage: Typename des__    " & I & "  .Objects des Products ist ein__  " & TypeName(AktuellesPart)
            'es werden immer nur Producte als Typename angezeigt? aber es sind doch parts?

           
            If TypeName(AktuellesPart) <> "Part" Then
                'Hier wird normal weitergemacht und jedes Document was kein Part ist übersprungen ohne änderung
            Else


               
                Objectname = InStr(1, Objectname, UserProductDocument.Product.PartNumber, vbTextCompare) - 1
                MsgBox Objectname
               
                Select Case Objectname
               
                    Case "STRG"
                             
                    Case "DMU"
                   
                   
                Case Else

                    'Anlegen der Einfuegestruktur
                    '-------[HybridBody] #Name des jeweiligen Parts (Nummer I) unter dem Product
                            Dim GSHBS_Partname As HybridBodies
                            Set GSHBS_Partname = STRGPart.HybrirdBodies
                            Dim GSHB_Partname As HybridBody
                            Set GSHB_Partname = GSHBS_Partname.Add()
                            GSHB_Partname.name = GSHBS_Partname
                            STRGPart.InWorkObject = GSHB_Partname
                        STRGPart.Update
                            'GSHBS_Partname = GeometrischesSetHybridBodieS_Partname
                            'GSHB_Partname = GeometrischesSetHybridBody_Partname
                   
                   
                    '-------[HybridBody] Hilfselemente
                            Dim GSHBS_HEPN As HybridBodies
                            Set GSHBS_HEPN = GSHB_Partname.HybridBodies
                            Dim GSHB_HEPN As HybridBody
                            Set GSHB_HEPN = GSHBS_HEPN.Add()
                            GSHB_HEPN.name = "Hilfselemente"
                            STRGPart.InWorkObject = GSHB_HEPN
                        STRGPart.Update
                            'GSHBS_HEPN = GeometrischesSetS_Hilfselemente Partname
                            'GSHB_HEPN = GeometrischesSet_Hilfselemente Partname
                   
                   
                    '-------[HybridBody] Positionsebenen
                            Dim GSHBS_Poseb As HybridBodies
                            Set GSHBS_Poseb = GSHB_Partname.HybridBodies
                            Dim GSHB_Poseb As HybridBody
                            Set GSHB_Poseb = GSHBS_Poseb.Add()
                            GSHB_Poseb.name = "Positionsebenen"
                            STRGPart.InWorkObject = GSHB_Poseb
                        STRGPart.Update
                            'GSHBS_Poseb = GeometrischesSet_Positionsebenen
                            'GSHB_Poseb = GeometrischesSet_Positionsebenen
           

                End Select
           
            End If
       
        Next

End Sub

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

bgrittmann
Moderator
Konstrukteur


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

Beiträge: 11780
Registriert: 30.11.2006

CATIA V5R19

erstellt am: 14. Jul. 2011 12:58    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 Beny 10 Unities + Antwort hilfreich

Servus

Zu deinen Fragen:
- aber ich bekomme für jedes Objekt immer ein Produkt angezeigt (wenn ich Typename durchführen lasse) ob wohl es ein Part ist.
Das Part ist immer in ein Produkt verpackt, also solltest du mit STRGPartProduct.Part auf das Part zugreifen können.

- wie bekomme ich es hin das das 1. part im Produkt als Part deklariert wird? (damit man später die Struktur abbilden lassen kann?)

Siehe 1. Antwort.zB
Set STRGPartProduct = UserProductDocument.Product.Products.Item(1).Part

Gruß
Bernd

------------------
Warum einfach, wenn es auch kompliziert geht.

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