VBA, VB.NET For Creo
Get dimension name and value of specific feature
ToolBOX01
2025. 1. 20. 21:16
반응형
I want to create a code to get the dimension name and value contained in a Feature with a specific name.
▷ Code to connect Creo models
Option Explicit
Public asynconn As New pfcls.CCpfcAsyncConnection
Public conn As pfcls.IpfcAsyncConnection
Public BaseSession As pfcls.IpfcBaseSession
Public model As pfcls.IpfcModel
Public Sub CreoConnt02()
On Error GoTo ErrorHandler '// Setting up an error handler
'// Creo 연결 설정
Set conn = asynconn.Connect(Null, Null, Null, Null)
'// Creo Connection Settings
On Error Resume Next '// Keep code execution going even when an exception occurs
Set BaseSession = conn.Session
If Err.Number <> 0 Then
MsgBox "Failed to import Creo session. Check your connection status." & vbCrLf & _
"Error message: " & Err.Description, vbCritical, "error"
Err.Clear
Exit Sub
End If
'// Get current model
Set model = BaseSession.CurrentModel
If model Is Nothing Then
MsgBox "There are currently no active Creo models", vbInformation, "alarm"
Exit Sub
End If
'// MsgBox "Creo connection and model verification complete", vbInformation, "success"
ErrorHandler:
' ToolkitNotFound Special handling of error messages
If InStr(Err.Description, "XToolkitNotFound") > 0 Then
MsgBox "Make sure Creo is running.", vbCritical, "error"
Exit Sub
End If
End Sub
▷ Code : Get the dimension name and value of a feature
The feature name is "KOREA". Please enter it in capital letters. You can change the name in the code.
- You can get Feature objects with "IpfcModelItem".
- You can get Dimension objects with "IpfcFeature"
Option Explicit
Sub FeatureDimesnions()
On Error GoTo RunError
Application.EnableEvents = False
'// Module Name : CreoVBAStart
Call CreoVBAStart02.CreoConnt02
Dim ModelItemOwner As IpfcModelItemOwner
Dim ModelItem As IpfcModelItem
Dim Feature As IpfcFeature
Dim FeatureName01 As String: FeatureName01 = "korea"
Dim ModelItems As IpfcModelItems
Dim BaseDimension As IpfcBaseDimension
Dim i As Integer
Set ModelItemOwner = model
Set ModelItem = ModelItemOwner.GetItemByName(EpfcModelItemType.EpfcITEM_FEATURE, FeatureName01)
Set Feature = ModelItem
Set ModelItems = Feature.ListSubItems(EpfcModelItemType.EpfcITEM_DIMENSION)
For i = 0 To ModelItems.Count - 1
Set BaseDimension = ModelItems.Item(i)
Debug.Print BaseDimension.Symbol
Debug.Print BaseDimension.DimValue
Next i
MsgBox "I brought all the Dimension names.", vbInformation, "korealionkk@gmail.com"
conn.Disconnect (2)
'// Cleanup
Set asynconn = Nothing
Set conn = Nothing
Set BaseSession = Nothing
Set model = Nothing
RunError:
If Err.Number <> 0 Then
MsgBox "Process Failed: An error occurred." & vbCrLf & _
"Error No: " & CStr(Err.Number) & vbCrLf & _
"Error Description: " & Err.Description & vbCrLf & _
"Error Source: " & Err.Source, vbCritical, "Error"
If Not conn Is Nothing Then
If conn.IsRunning Then
conn.Disconnect (2)
End If
End If
End If
End Sub
Creo | VBA execution results |
by korealionkk@gmail.com