Супер. Я кстати заходил на эту тему, когда искал. Но видимо не сильно присмотрелся к решению. Спасибо.
Только я чуток видоизменил код. Потому что у меня к механизму не привязано.
Здесь выводятся все констрейнты из корневого продукта и входящие в них элементы и парты.
- Код: Выделить всё
Sub CATMain()
Dim productDocument1 As ProductDocument
Set productDocument1 = CATIA.ActiveDocument
Dim selection1 As Selection
Set selection1 = productDocument1.Selection
Dim cc As Constraint
Dim Data As String
Dim InsN As String
Dim MyName As String
Dim MyFatherName As String
Dim MyProduct As Product
Dim MyPart As Part
Dim MyElemF As AnyObject
Dim MyElem As Reference
Dim Str As String
On Error Resume Next
For j = 1 To productDocument1.Product.Connections("CATIAConstraints").Count
Set cc = productDocument1.Product.Connections("CATIAConstraints").Item(j)
Str = Str + cc.Name + Chr(13)
For k = 1 To 3
Err.Clear
Set MyElem = cc.GetConstraintElement(k)
If Err.Number <> 0 Then
Err.Clear
Exit For
End If
InsN = Left(Right(MyElem.DisplayName, Len(MyElem.DisplayName) - InStr(MyElem.DisplayName, "/")), _
InStr(Right(MyElem.DisplayName, Len(MyElem.DisplayName) - InStr(MyElem.DisplayName, "/")), "/") - 1)
selection1.Clear
Call selection1.Add(MyElem)
MyFatherName = Left(Right(CATIA.StatusBar, Len(CATIA.StatusBar) - InStr(CATIA.StatusBar, "/")), _
InStr(Right(CATIA.StatusBar, Len(CATIA.StatusBar) - InStr(CATIA.StatusBar, "/")), "/") - 1)
MyName = Left(CATIA.StatusBar, InStr(CATIA.StatusBar, "/") - 1)
Set MyProduct = productDocument1.Product.Products.Item(InsN)
Set MyPart = MyProduct.ReferenceProduct.Parent.Part
'Set MyElemF = MyPart.FindObjectByName(MyFatherName)
Str = Str + MyProduct.PartNumber + " " + MyElem.DisplayName + " " + MyPart.Name + Chr(13)
Next
Next
MsgBox Str
End Sub