Get DimXpert Datum Example (VBA)
This example shows how to build a part and get attributes 
 for the following DimXpert annotation:
       * 
  Datum
'---------------------------------------------------------------------------
' Preconditions:
' 1. 
 Open:
' <SolidWorks_install_dir>\samples\tutorial\cosmosfloxpress\ball valve\ball.sldprt.
' 2. 
 Open the DimXpert toolbar from View > Toolbars 
'    (select the first instance 
 of Toolbars on the View menu).
' 3. 
 Click the Add DimXpert datum icon on the DimXpert toolbar.
' 4. 
 Click on the ball of the part.
' 5. 
 Click away from the part to place the datum annotation.
' 6. 
 Click the green check mark to accept the new datum feature.
' 7. 
 Observe the following DimXpert features on the DimXpertManager tab 
'   of 
 the Management Panel:  Sphere1.
' 8. 
 Open an Immediate Window in the IDE.
' 9. 
 Ensure that the latest SolidWorks DimXpert type library is loaded 
'    in Tools 
 > References.
' 10. 
 Ensure that the Microsoft Scripting Runtime library is loaded 
'    in Tools 
 > References.
' 11. 
 Run this macro (F5).
'
' Postconditions:
' 1. The 
 output of this macro is logged in c:\temp\dimXpertInfo.txt.
' 2. Inspect 
 the Immediate Window.
' NOTE: 
 Because these parts are used in a SolidWorks online tutorial, 
' do not save 
 any changes when you close them.
'---------------------------------------------------------------------------
Option Explicit
Dim strs As New Collection
Dim dimXpertPart As dimXpertPart
Sub Main()
    Dim 
 swapp As SldWorks.SldWorks
    Set 
 swapp = Application.SldWorks
 Dim 
 swModelDoc As SldWorks.ModelDoc2
  Set 
 swModelDoc = swapp.ActiveDoc
   If 
 swModelDoc Is Nothing Then
     Exit 
 Sub
   End 
 If
    Dim 
 f As New FileSystemObject
    Dim 
 textStr As TextStream
    Set 
 textStr = f.CreateTextFile("C:\temp\dimXpertInfo.txt", True)
    If 
 textStr Is Nothing Then
        Debug.Print 
 "Error creating temp file."
        Exit 
 Sub
    End 
 If
    
    Call 
 log("Starting DimXpert log...", textStr)
    Call 
 retrieve_info_text(swapp, textStr)
    textStr.Close
End Sub
Private Sub log(text As String, textStr As TextStream)
    Debug.Print 
 text
    textStr.WriteLine 
 (text)
End Sub
Private Sub retrieve_info_text(swapp As SldWorks.SldWorks, 
 textStr As TextStream)
    Dim 
 dimXpertMgr As SldWorks.DimXpertManager
    
    Set 
 dimXpertMgr = swapp.IActiveDoc2.Extension.DimXpertManager(swapp.IActiveDoc2.IGetActiveConfiguration().Name, 
 True)
    Call 
 log("Model: " & swapp.IActiveDoc2.GetPathName, textStr)
    Dim 
 dimXpertPartObj As dimXpertPart
    Set 
 dimXpertPartObj = dimXpertMgr.dimXpertPart
    
    
    Set 
 dimXpertPart = dimXpertPartObj
   
    Dim 
 vAnnotations As Variant
   
    vAnnotations 
 = dimXpertPart.GetAnnotations()
    
    Call 
 log("------------------------", textStr)
    Call 
 log("Annotations...", textStr)
    Call 
 log("------------------------", textStr)
    
    
    Dim 
 annotationTemp As DimXpertAnnotation
    Dim 
 annotationIndex As Long
    For 
 annotationIndex = 0 To UBound(vAnnotations)
        Set 
 annotationTemp = vAnnotations(annotationIndex)
        
        Dim 
 AnnotationDataText As Collection
        
        Set 
 AnnotationDataText = AnnotationData(annotationTemp)
        Dim 
 annotationTextIndex As Long
        For 
 annotationTextIndex = 1 To AnnotationDataText.Count
            Call 
 log(AnnotationDataText(annotationTextIndex), textStr)
        Next
    Next
    
        
End Sub
Public Function AnnotationData(annotation As DimXpertAnnotation) 
 As Collection
    Dim 
 annoType As Long
    
    'general 
 info
    Call 
 GeneralInfo(annotation)
    annoType 
 = annotation.Type
    If 
 annoType = swDimXpertDatum Then
        Call 
 DatumData(annotation)
    
    ElseIf 
 annoType = swDimXpertGeoTol_Position Then
        Call 
 PositionData(annotation)
     
    ElseIf 
 annoType = swDimXpertGeoTol_CompositePosition Then
        Call 
 CompositePositionData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_Symmetry Then
        Call 
 SymmetryData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_Concentricity Then
        Call 
 ConcentricityData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_LineProfile Then
        Call 
 LineProfileData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_CompositeLineProfile Then
        Call 
 CompositeLineProfileData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_SurfaceProfile Then
        Call 
 SurfaceProfileData(annotation)
    
    ElseIf 
 annoType = swDimXpertGeoTol_CompositeSurfaceProfile Then
        Call 
 CompositeSurfaceProfileData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_Angularity Or annoType = swDimXpertGeoTol_Parallelism 
 Or annoType = swDimXpertGeoTol_Perpendicularity Then
        Call 
 OrientationData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_TotalRunout Then
        Call 
 TotalRunoutData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_CircularRunout Then
        Call 
 CircularRunoutData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_Flatness Then
        Call 
 FlatnessData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_Circularity Then
        Call 
 CircularityData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_Cylindricity Then
        Call 
 CylindricityData(annotation)
        
    ElseIf 
 annoType = swDimXpertGeoTol_Straightness Then
        Call 
 StraightnessData(annotation)
    ElseIf 
 annoType = swDimXpertGeoTol_Tangency Then
        Call 
 TangencyData(annotation)
    Else 
    ' 
 any of the dimension tolerance types
        Call 
 DimensionToleranceData(annotation)
    
    End 
 If
    
    
    Set 
 AnnotationData = strs
End Function
Private Sub Clear(strs As Collection)
    Dim 
 n As Long
    strs.Remove 
 (strs.Count)
    If 
 Not strs.Count = 0 Then
        Call 
 Clear(strs)
    End 
 If
End Sub
Private Sub GeneralInfo(annotation As DimXpertAnnotation)
    Dim 
 annoType As String
    Dim 
 modelObj As Object
    Dim 
 modelFeature As SldWorks.feature
    If 
 Not strs.Count = 0 Then
        Call 
 Clear(strs)
    End 
 If
    
    strs.Add 
 ("")
    strs.Add 
 ("Name: " + annotation.Name)
    
    annoType 
 = annotationTypeNameFromObject(annotation)
    strs.Add 
 ("Type: " + annoType)
    strs.Add 
 ("Display Entity: " + DisplayEntity(annotation))
    
    Set 
 modelObj = annotation.GetModelFeature
    Set 
 modelFeature = modelObj
    If 
 Not (modelFeature Is Nothing) Then
        strs.Add 
 ("ModelFeature: " + modelFeature.Name + " (" + modelFeature.GetTypeName2() 
 + ")")
    End 
 If
End Sub
Private Sub DatumData(annotation As DimXpertDatum)
    ' 
 the datum letter
    strs.Add 
 ("")
    strs.Add 
 ("Datum Letter:  " 
 + annotation.Identifier)
    
End Sub
Private Sub PositionData(annotation As DimXpertPositionTolerance)
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 enabled As Boolean, value As Double
    Dim 
 boolstatus As Boolean
    
    strs.Add 
 ("")
    strs.Add 
 ("Position Tolerance Compartment:")
        
    ' 
 the shape of the tolerance zone
    strs.Add 
 ("  Zone 
 Type: " + PositionZoneType(annotation.zoneType))
            
    ' 
 the zone vector if the tolerance zone is planar
    If 
 annotation.zoneType = swDimXpertPositionZoneType_PlanarPosition Then
        boolstatus 
 = annotation.GetPlanarZoneVector(I, J, K)
        strs.Add 
 ("  Direction: 
 " + FormatVector(I, J, K))
    End 
 If
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
                    
    ' 
 the material condition modifer applied to feature
    strs.Add 
 ("  Modifier: 
 " + mcmStr(annotation.modifier))
    
    ' 
 the projected tolerance zone when specified
    boolstatus 
 = annotation.GetProjectedZone(enabled, value)
    Call 
 FormatProjectedZone(enabled, value)
    
    ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
    
End Sub
Private Sub CompositePositionData(annotation As DimXpertCompositePositionTolerance)
    
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 enabled As Boolean, value As Double
    Dim 
 boolstatus As Boolean
    
    strs.Add 
 ("")
    strs.Add 
 ("Composite Position Tolerance Compartment")
        
    ' 
 the shape of the tolerance zone
    strs.Add 
 ("  Zone 
 Type: " + PositionZoneType(annotation.zoneType))
    
    ' 
 the zone vector when the zone is planar
    If 
 annotation.zoneType = swDimXpertPositionZoneType_PlanarPosition Then
        boolstatus 
 = annotation.GetPlanarZoneVector(I, J, K)
        strs.Add 
 ("  Direction: 
 " + FormatVector(I, J, K))
    End 
 If
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
                    
    ' 
 the material condition modifer
    strs.Add 
 ("  Modifier: 
 " + mcmStr(annotation.modifier))
    
    ' 
 the projected tolerance zone when specified
    boolstatus 
 = annotation.GetProjectedZone(enabled, value)
    Call 
 FormatProjectedZone(enabled, value)
    
    ' 
 the datum reference frame for the pattern location
    Call 
 DatumsStr(annotation)
    
    ' 
 the datum reference frame for the feature to feature location
    strs.Add 
 ("Composite datums:")
    strs.Add 
 ("  Repeat 
 Primary: " + IIf(annotation.PrimaryInLowerTier, "True", 
 "False"))
    strs.Add 
 ("  Repeat 
 Secondary: " + IIf(annotation.SecondaryInLowerTier, "True", 
 "False"))
    strs.Add 
 ("  Repeat 
 Tertiary: " + IIf(annotation.TertiaryInLowerTier, "True", 
 "False"))
    
End Sub
Private Sub SymmetryData(annotation As DimXpertSymmetryTolerance)
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 boolstatus As Boolean
    strs.Add 
 ("")
    strs.Add 
 ("Symmetry Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
                    
    ' 
 the material condition modifer applied to feature
    strs.Add 
 ("  Modifier: 
 " + mcmStr(annotation.modifier))
    
    ' 
 the datum reference frame
    strs.Add 
 ("")
    Call 
 DatumsStr(annotation)
    ' 
 the direction of the planar zone
    strs.Add 
 ("")
    boolstatus 
 = annotation.GetZoneDirection(I, J, K)
    strs.Add 
 ("Planar Zone Direction: " + FormatVector(I, J, K))
        
End Sub
Private Sub ConcentricityData(annotation As DimXpertConcentricityTolerance)
                    
    strs.Add 
 ("")
    strs.Add 
 ("Concentricity Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
                    
    ' 
 the material condition modifer applied to feature
    strs.Add 
 ("  Modifier: 
 " + mcmStr(annotation.modifier))
    
    ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
    
End Sub
Private Sub TotalRunoutData(annotation As DimXpertTolerance)
    strs.Add 
 ("")
    strs.Add 
 ("Total Runout Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
    
    ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
    
End Sub
Private Sub CircularRunoutData(annotation As DimXpertTolerance)
    strs.Add 
 ("")
    strs.Add 
 ("Circular Runout Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
    
    ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
    
End Sub
Private Sub LineProfileData(annotation As DimXpertLineProfileTolerance)
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 boolstatus As Boolean
    
    strs.Add 
 ("")
    strs.Add 
 ("Line Profile Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
                    
    ' 
 the outer (outside material) tolerance value
    strs.Add 
 ("  Outer 
 Tolerance: " + FormatDouble(annotation.OuterToleranceValue))
    
    ' 
 the vector normal to the profile zones
    strs.Add 
 ("")
    boolstatus 
 = annotation.GetPlanarZoneVector(I, J, K)
    strs.Add 
 ("Planar Zone Vector: " + FormatVector(I, J, K))
    
   ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
    
End Sub
Private Sub CompositeLineProfileData(annotation As DimXpertCompositeLineProfileTolerance)
    
    strs.Add 
 ("")
    strs.Add 
 ("Composite Line Profile Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
                    
    ' 
 the outer (outside material) tolerance value
    strs.Add 
 ("  Outer 
 Tolerance: " + FormatDouble(annotation.OuterToleranceValue))
    
    ' 
 the vector normal to the profile zones
    strs.Add 
 ("")
    boolstatus 
 = annotation.GetPlanarZoneVector(I, J, K)
    strs.Add 
 ("Planar Zone Vector: " + FormatVector(I, J, K))
    
   ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
    
    ' 
 the datum reference frame for the orientation and form
    strs.Add 
 ("Composite Datums:")
    strs.Add 
 ("  Repeat 
 Primary: " + IIf(annotation.PrimaryInLowerTier, "True", 
 "False"))
    strs.Add 
 ("  Repeat 
 Secondary: " + IIf(annotation.SecondaryInLowerTier, "True", 
 "False"))
    strs.Add 
 ("  Repeat 
 Tertiary: " + IIf(annotation.TertiaryInLowerTier, "True", 
 "False"))
   
End Sub
Private Sub SurfaceProfileData(annotation As DimXpertSurfaceProfileTolerance)
    
    strs.Add 
 ("")
    strs.Add 
 ("Surface Profile Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
                    
    ' 
 the outer (outside material) tolerance value
    strs.Add 
 ("  Outer 
 Tolerance: " + FormatDouble(annotation.OuterToleranceValue))
    
   ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
    
End Sub
Private Sub CompositeSurfaceProfileData(annotation As 
 DimXpertCompositeSurfaceProfileTolerance)
    
    strs.Add 
 ("")
    strs.Add 
 ("Composite Surface Profile Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance 
 Upper Tier: " + FormatDouble(annotation.Tolerance))
                    
    ' 
 the outer tolerance value
    strs.Add 
 ("  Outer 
 Tolerance Upper Tier: " + FormatDouble(annotation.OuterToleranceValue))
    
   ' 
 the datum reference frame for the location
    Call 
 DatumsStr(annotation)
    
    ' 
 the datum reference frame for the orientation and form
    strs.Add 
 ("Composite Datums:")
    strs.Add 
 ("  Repeat 
 Primary: " + IIf(annotation.PrimaryInLowerTier, "True", 
 "False"))
    strs.Add 
 ("  Repeat 
 Secondary: " + IIf(annotation.SecondaryInLowerTier, "True", 
 "False"))
    strs.Add 
 ("  Repeat 
 Tertiary: " + IIf(annotation.TertiaryInLowerTier, "True", 
 "False"))
End Sub
Private Sub OrientationData(annotation As DimXpertOrientationTolerance)
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 enabled As Boolean, value As Double
    Dim 
 annoType As Long
    Dim 
 boolstatus As Boolean
    annoType 
 = annotation.Type
    ' 
 the type or orientation tolerance
    If 
 annoType = swDimXpertGeoTol_Perpendicularity Then
        strs.Add 
 ("Orientation Type:  Perpendicularity")
    ElseIf 
 annoType = swDimXpertGeoTol_Parallelism Then
        strs.Add 
 ("Orientation Type:  Parallelism")
    ElseIf 
 annoType = swDimXpertGeoTol_Angularity Then
        strs.Add 
 ("Orientation Type:  Angularity")
    End 
 If
    
    strs.Add 
 ("")
    strs.Add 
 ("Orientation Tolerance Compartment:")
        
    ' 
 the shape of the tolerance zone
    Select 
 Case annotation.zoneType
    Case 
 swDimXpertOrientationZoneType_Cylindrical
        strs.Add 
 ("  Zone 
 Type: Cylindrical")
    Case 
 swDimXpertOrientationZoneType_Planar
        strs.Add 
 ("  Zone 
 Type: Planar")
        boolstatus 
 = annotation.GetPlanarZoneVector(I, J, K)
        strs.Add 
 ("Planar Zone Vector: " + FormatVector(I, J, K))
    End 
 Select
            
   ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
                    
    'material 
 condition modifer applied to feature
    strs.Add 
 ("  Modifier: 
 " + mcmStr(annotation.modifier))
    
    ' 
 the projected tolerance zone when specified
    boolstatus 
 = annotation.GetProjectedZone(enabled, value)
    Call 
 FormatProjectedZone(enabled, value)
    
    ' 
 is tangent plane
    strs.Add 
 ("  IsTangentPlane: 
 " + IIf(annotation.IsTangentPlane, "True", "False"))
    
    ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
    
End Sub
Private Sub FlatnessData(annotation As DimXpertFlatnessTolerance)
    Dim 
 enabled As Boolean
    Dim 
 length As Double, width As Double
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 boolstatus As Boolean
    
    strs.Add 
 ("")
    strs.Add 
 ("Flatness Tolerance Compartment:")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
    
    ' 
 the per unit area data
    boolstatus 
 = annotation.GetPerUnitArea(enabled, length, width, I, J, K)
    strs.Add 
 ("  Per 
 Unit Area: " + IIf(enabled, "True", "False"))
    If 
 enabled Then
        strs.Add 
 ("  Per 
 Unit Length: " + FormatDouble(length))
        strs.Add 
 ("  Per 
 Unit Width: " + FormatDouble(width))
        strs.Add 
 ("  Per 
 Unit Direction: " + FormatVector(I, J, K))
    End 
 If
    
End Sub
Private Sub CircularityData(annotation As DimXpertTolerance)
    strs.Add 
 ("")
    strs.Add 
 ("Circularity Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
    
End Sub
Private Sub CylindricityData(annotation As DimXpertTolerance)
    strs.Add 
 ("")
    strs.Add 
 ("Cylindricity Tolerance Compartment")
            
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
    
End Sub
Private Sub StraightnessData(annotation As DimXpertStraightnessTolerance)
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 enabled As Boolean
    Dim 
 dist As Double
    Dim 
 boolstatus As Boolean
   'tolerance 
 compartment info
    strs.Add 
 ("")
    strs.Add 
 ("Straightness Tolerance Compartment")
    
    'type 
 or shape of the tolerance zone
    Select 
 Case annotation.zoneType
    Case 
 swDimXpertStraightnessZoneType_Cylindrical
        strs.Add 
 ("  Zone 
 Type: Cylindrical")
    Case 
 swDimXpertStraightnessZoneType_PlanarMedian
        strs.Add 
 ("  Zone 
 Type: Planar Median")
    Case 
 swDimXpertStraightnessZoneType_Surface
        strs.Add 
 ("  Zone 
 Type: Surface Straightness")
        boolstatus 
 = annotation.GetPlanarZoneVector(I, J, K)
        strs.Add 
 ("  Zone 
 Vector: " + FormatVector(I, J, K))
    End 
 Select
    
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
    
    'per 
 unit length
    boolstatus 
 = annotation.GetPerUnitLength(enabled, dist)
    strs.Add 
 ("  Per 
 Unit Length: " + IIf(enabled, "True", "False"))
    If 
 enabled Then
        strs.Add 
 ("  Per 
 Unit Length Distance:  " 
 + FormatDouble(dist))
    End 
 If
    
    ' 
 the material condition modifer
    strs.Add 
 ("  Modifier: 
 " + mcmStr(annotation.modifier))
End Sub
Private Sub ProfileData(annotation As DimXpertTolerance)
    strs.Add 
 ("")
    strs.Add 
 ("Profile Tolerance Compartment")
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
    ' 
 the datum reference frame
    Call 
 DatumsStr(annotation)
End Sub
Private Sub SurfaceFinishData(annotation As DimXpertTolerance)
    strs.Add 
 ("")
    strs.Add 
 ("Surface Finish Tolerance Compartment")
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
End Sub
Private Sub TangencyData(annotation As DimXpertTolerance)
    strs.Add 
 ("")
    strs.Add 
 ("Tangency Tolerance Compartment")
    ' 
 the tolerance value
    strs.Add 
 ("  Tolerance: 
 " + FormatDouble(annotation.Tolerance))
End Sub
Private Sub DimensionToleranceData(annotation As DimXpertDimensionTolerance)
    Dim 
 isAngleType As Boolean
    Dim 
 annoType As Long
    Dim 
 upper As Double, lower As Double
    Dim 
 plus As Double, minus As Double
    Dim 
 boolstatus As Boolean
    annoType 
 = annotation.Type
    
    isAngleType 
 = False
    
    strs.Add 
 ("")
    strs.Add 
 ("Dimension Tolerance Compartment")
    If 
 annoType = swDimXpertDimTol_DistanceBetween Then
        Dim 
 distancebetween As DimXpertDistanceBetweenDimTol
        Set 
 distancebetween = annotation
        Call 
 DistanceBetweenData(distancebetween)
    ElseIf 
 annoType = swDimXpertDimTol_CompositeDistanceBetween Then
        Dim 
 compdistancebetween As DimXpertCompositeDistanceBetweenDimTol
        Set 
 compdistancebetween = annotation
        Call 
 CompositeDistanceBetweenData(compdistancebetween)
    
    ElseIf 
 annoType = swDimXpertDimTol_CounterBore Then
        Dim 
 counterBore As IDimXpertCounterBoreDimTol
        Set 
 counterBore = annotation
        If 
 counterBore.ReferenceFeature Is Nothing Then
             strs.Add 
 ("Reference Feature: NULL")
        Else
            strs.Add 
 ("Reference Feature: " + counterBore.ReferenceFeature.Name)
        End 
 If
        
    ElseIf 
 annoType = swDimXpertDimTol_Depth Then
        Dim 
 depth As IDimXpertDepthDimTol
        Set 
 depth = annotation
        If 
 depth.ReferenceFeature Is Nothing Then
             strs.Add 
 ("Reference Feature: NULL")
        Else
            strs.Add 
 ("Reference Feature: " + depth.ReferenceFeature.Name)
        End 
 If
        
                
    ElseIf 
 annoType = swDimXpertDimTol_CounterSinkDiameter Then
        Dim 
 countersink As IDimXpertCounterSinkDiameterDimTol
        Set 
 countersink = annotation
        If 
 countersink.ReferenceFeature Is Nothing Then
             strs.Add 
 ("Reference Feature: NULL")
        Else
            strs.Add 
 ("Reference Feature: " + countersink.ReferenceFeature.Name)
        End 
 If
        
        
    ElseIf 
 annoType = swDimXpertDimTol_ChamferDimension Then
        
        Select 
 Case annotation.ChamferType
        Case 
 swDimXpertChamferDimensionType_Angle
            strs.Add 
 ("Chamfer Dimension Type: Angle")
            isAngleType 
 = True
        Case 
 swDimXpertChamferDimensionType_LinearDistance1
            strs.Add 
 ("Chamfer Dimension Type: Distance 1")
        Case 
 swDimXpertChamferDimensionType_LinearDistance2
            strs.Add 
 ("Chamfer Dimension Type: Distance 2")
        End 
 Select
        
    ElseIf 
 annoType = swDimXpertDimTol_AngleBetween Then
        isAngleType 
 = True
        Dim 
 angleBetween As IDimXpertAngleBetweenDimTol
        Set 
 angleBetween = annotation
        ' 
 the origin and tolerance feature
        strs.Add 
 ("Origin Feature: " + angleBetween.OriginFeature.Name)
        
        ' 
 is supplement angle
        strs.Add 
 ("Supplement Angle: " + IIf(angleBetween.Supplement, "True", 
 "False"))
                
    ElseIf 
 annoType = swDimXpertDimTol_CounterSinkAngle Then
        isAngleType 
 = True
        Dim 
 countersinkAngle As IDimXpertCounterSinkAngleDimTol
        Set 
 countersinkAngle = annotation
        
        If 
 countersinkAngle.ReferenceFeature Is Nothing Then
             strs.Add 
 ("Reference Feature: NULL")
        Else
            strs.Add 
 ("Reference Feature: " + countersinkAngle.ReferenceFeature.Name)
        End 
 If
        
    
    ElseIf 
 annoType = swDimXpertDimTol_ConeAngle Then
        isAngleType 
 = True
    End 
 If
    
    ' 
 conversion for radians to degrees when dimension type is angle
    Dim 
 dbl As Double
    If 
 isAngleType Then
        dbl 
 = 57.2957795130823
    Else
        dbl 
 = 1#
    End 
 If
    ' 
 the nominal, and upper and lower limits of size of the dimension
    strs.Add 
 ("")
    strs.Add 
 ("Compute Nominal Dimension: " + FormatDouble(annotation.GetNominalValue 
 * dbl))
    boolstatus 
 = annotation.GetUpperAndLowerLimit(upper, lower)
    strs.Add 
 ("Get Upper Limit: " + FormatDouble(upper * dbl))
    strs.Add 
 ("Get Lower Limit: " + FormatDouble(lower * dbl))
    
    ' 
 the upper and lower tolerance value by type
    Select 
 Case annotation.DimensionType
    
    Case 
 swDimXpertDimTolType_BlockTolerance
        strs.Add 
 ("Dimension Type: Block Tolerance")
    
    ' 
 block tolerance
    Case 
 swDimXpertDimTolType_BlockToleranceNoNominal
        Dim 
 blockTols As DimXpertBlockTolerances
        Set 
 blockTols = dimXpertPart.GetBlockTolerances
        
        Select 
 Case blockTols.Type
            Case 
 swDimXpertBlockToleranceType_ASMEInch
                strs.Add 
 ("Dimension Type: Block Tolerance No Nominal")
                If 
 isAngleType Then
                    strs.Add 
 ("Angular Block Tolerance")
                Else
                    strs.Add 
 ("Block Tolerance Decimal Places: " + Format(annotation.BlockToleranceDecimalPlaces, 
 "##,##0"))
                End 
 If
            Case 
 swDimXpertBlockToleranceType_ISO2768
                strs.Add 
 ("Dimension Type: General Tolerance")
        End 
 Select
    
    Case 
 swDimXpertDimTolType_ISOLimitsAndFits
        strs.Add 
 ("Dimension Type: Limits and Fits")
    ' 
 limits and fits tolerance
    Case 
 swDimXpertDimTolType_ISOLimitsAndFitsNoNominal
        strs.Add 
 ("Dimension Type: Limits and Fits No Nominal")
        strs.Add 
 ("Limits and Fits: " + annotation.LimitsAndFitsCode)
    ' 
 limit dimension
    Case 
 swDimXpertDimTolType_LimitDimension
        strs.Add 
 ("Dimension Type: Limit Dimension")
        boolstatus 
 = annotation.GetUpperAndLowerLimit(upper, lower)
        strs.Add 
 ("Get Upper Limit: " + FormatDouble(upper * dbl))
        strs.Add 
 ("Get Lower Limit: " + FormatDouble(lower * dbl))
    Case 
 swDimXpertDimTolType_MAXTolerance
        strs.Add 
 ("Dimension Type: MAXTolerance")
    Case 
 swDimXpertDimTolType_MINTolerance
        strs.Add 
 ("Dimension Type: MINTolerance")
    Case 
 swDimXpertDimTolType_NoTolerance
        strs.Add 
 ("Dimension Type: NoTolerance")
    Case 
 swDimXpertDimTolType_PlusMinusDimension
        strs.Add 
 ("Dimension Type: Plus Minus Dimension")
    
    ' 
 plus and minus dimension
    Case 
 swDimXpertDimTolType_PlusMinusNoNominal
        strs.Add 
 ("Dimension Type: Plus Minus No Nominal")
        boolstatus 
 = annotation.GetPlusAndMinusTolerance(plus, minus)
        strs.Add 
 ("Plus  Tolerance: 
 " + FormatDouble(plus * dbl))
        strs.Add 
 ("Minus Tolerance: " + FormatDouble(minus * dbl))
    
    End 
 Select
        
End Sub
Private Sub DistanceBetweenData(annotation As DimXpertDistanceBetweenDimTol)
    Dim 
 feature As DimXpertFeature
    Dim 
 featureFosUsage As Long
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 boolstatus As Boolean
    ' 
 the origin and tolerance feature along with their feature of size usage 
 (min, max, center)
    boolstatus 
 = annotation.GetOriginFeature(feature, featureFosUsage)
    strs.Add 
 ("")
    strs.Add 
 ("Origin Feature: " + feature.Name + " @ " + FosUsage(featureFosUsage))
    boolstatus 
 = annotation.GetFeature(feature, featureFosUsage)
    strs.Add 
 ("Tolerance Feature: " + feature.Name + " @ " + FosUsage(featureFosUsage))
    
    ' 
 The direction vector
    boolstatus 
 = annotation.GetDirectionVector(I, J, K)
    strs.Add 
 ("")
    strs.Add 
 ("Direction Vector: " + FormatVector(I, J, K))
        
End Sub
Private Sub CompositeDistanceBetweenData(annotation As 
 DimXpertCompositeDistanceBetweenDimTol)
    Dim 
 feature As DimXpertFeature
    Dim 
 featureFosUsage As Long
    Dim 
 plus As Double, minus As Double
    Dim 
 I As Double, J As Double, K As Double
    Dim 
 boolstatus As Boolean
    Dim 
 blockTols As DimXpertBlockTolerances
    
    ' 
 the origin and tolerance feature along with their feature of size usage 
 (min, max, center)
    boolstatus 
 = annotation.GetOriginFeature(feature, featureFosUsage)
    strs.Add 
 ("")
    strs.Add 
 ("Origin Feature: " + feature.Name + " @ " + FosUsage(featureFosUsage))
    boolstatus 
 = annotation.GetFeature(feature, featureFosUsage)
    strs.Add 
 ("Tolerance Feature: " + feature.Name + " @ " + FosUsage(featureFosUsage))
            
    ' 
 the pattern locating feature
    boolstatus 
 = annotation.GetIntraFeature(feature, featureFosUsage)
    strs.Add 
 ("Pattern Locating Feature: " + feature.Name + " @ " 
 + FosUsage(featureFosUsage))
    
    ' 
 The direction vector
    boolstatus 
 = annotation.GetDirectionVector(I, J, K)
    strs.Add 
 ("")
    strs.Add 
 ("Direction Vector: " + FormatVector(I, J, K))
    
    
    ' 
 the upper and lower tolerance value for the pattern location by type
    
    Select 
 Case annotation.DimensionType
    ' 
 plus and minus dimension
    Case 
 swDimXpertDimTolType_PlusMinusNoNominal
        strs.Add 
 ("Pattern Locating Dimension Type:  Plus 
 Minus No Nominal")
        boolstatus 
 = annotation.GetPlusAndMinusToleranceIntraFeature(plus, minus)
        strs.Add 
 ("  Plus 
  Tolerance: 
 " + FormatDouble(plus))
        strs.Add 
 ("  Minus 
 Tolerance: " + FormatDouble(minus))
    ' 
 block tolerance
    Case 
 swDimXpertDimTolType_BlockToleranceNoNominal
      
        Set 
 blockTols = dimXpertPart.GetBlockTolerances
        
        Select 
 Case blockTols.Type
        Case 
 swDimXpertBlockToleranceType_ASMEInch
            strs.Add 
 ("Pattern Locating Dimension Type: Block Tolerance No Nominal")
            strs.Add 
 ("  Block 
 Tolerance Decimal Places: " + Format(annotation.BlockToleranceDecimalPlaces, 
 "##,##0"))
        Case 
 swDimXpertBlockToleranceType_ISO2768
            strs.Add 
 ("Pattern Locating Dimension Type: General Tolerance")
        End 
 Select
    
    End 
 Select
    
    ' 
 the upper and lower tolerance value for the feature to feature location 
 by type
    Select 
 Case annotation.DimensionTypeIntraFeature
    ' 
 plus and minus dimension
    Case 
 swDimXpertDimTolType_PlusMinusNoNominal
        strs.Add 
 ("Feature Locating Dimension Type: Plus Minus No Nominal")
        boolstatus 
 = annotation.GetPlusAndMinusToleranceIntraFeature(plus, minus)
        strs.Add 
 ("  Plus 
  Tolerance: 
 " + FormatDouble(plus))
        strs.Add 
 ("  Minus 
 Tolerance: " + FormatDouble(minus))
    ' 
 block tolerance
    Case 
 swDimXpertDimTolType_BlockToleranceNoNominal
        
        Set 
 blockTols = dimXpertPart.GetBlockTolerances
        Select 
 Case blockTols.Type
        Case 
 swDimXpertBlockToleranceType_ASMEInch
            strs.Add 
 ("Feature locating Dimension Type: Block Tolerance No Nominal")
            strs.Add 
 ("  Block 
 Tolerance Decimal Places: " + Format(annotation.BlockToleranceDecimalPlacesIntraFeature, 
 "##,##0"))
        Case 
 swDimXpertBlockToleranceType_ISO2768
            strs.Add 
 ("Feature locating Dimension Type: General Tolerance")
        End 
 Select
    End 
 Select
    
End Sub
Private Sub DatumsStr(annotation As DimXpertTolerance)
    strs.Add 
 ("")
    strs.Add 
 ("Datums:")
    Call 
 datumStr(annotation.GetPrimaryDatums(), annotation.GetPrimaryDatumModifiers(), 
 "  Primary:")
    Call 
 datumStr(annotation.GetSecondaryDatums(), annotation.GetSecondaryDatumModifiers(), 
 "  Secondary:")
    Call 
 datumStr(annotation.GetTertiaryDatums(), annotation.GetTertiaryDatumModifiers(), 
 "  Tertiary:")
    
End Sub
Private Sub datumStr(dats As Variant, mods As Variant, 
 datumOrder As String)
    Dim 
 I   As 
 Long
    Dim 
 str As String
    Dim 
 mcm As Long
    If 
 IsEmpty(dats) Then
        strs.Add 
 (datumOrder + ": none")
        Exit 
 Sub
    End 
 If
    
    For 
 I = LBound(dats) To UBound(dats)
        mcm 
 = mods(I)
        str 
 = str + "  " 
 + dats(I).Identifier + " @ " + mcmStr(mcm)
    Next 
 I
        
    If 
 StrComp(str, "") > 0 Then
        strs.Add 
 (datumOrder + str)
    Else
        strs.Add 
 (datumOrder + " <none>")
    End 
 If
End Sub
' returns a string containing the height of the projected 
 tolerance zone
Private Sub FormatProjectedZone(enabled As Boolean, height 
 As Double)
    
    If 
 enabled = True Then
        strs.Add 
 ("  Projected 
 Zone:  True")
        strs.Add 
 ("  Zone 
 Height: " + FormatDouble(height))
    Else
        strs.Add 
 ("  Projected 
 Zone:  False")
    End 
 If
    
End Sub
Private Function mcmStr(mcm As Long) As String
    Dim 
 str
    
    Select 
 Case mcm
    Case 
 swDimXpertMCM_LMC
        str 
 = "LMC"
    Case 
 swDimXpertMCM_MMC
        str 
 = "MMC"
    Case 
 swDimXpertMCM_NoMCM
        str 
 = "NoMCM"
    Case 
 swDimXpertMCM_RFS
        str 
 = "RFS"
    End 
 Select
    
    mcmStr 
 = str
End Function
' returns a string containing the type of position tolerance 
 zone used
Private Function PositionZoneType(typ As Long) As String
    Dim 
 str As String
    
    Select 
 Case typ
    Case 
 swDimXpertPositionZoneType_CylindricalPosition
        str 
 = "Cylindrical"
    Case 
 swDimXpertPositionZoneType_PlanarPosition
        str 
 = "Planar"
    Case 
 swDimXpertPositionZoneType_SphericalPosition
        str 
 = "Spherical"
    Case 
 swDimXpertPositionZoneType_Boundary
        str 
 = "Boundary"
    Case 
 swDimXpertPositionZoneType_RadialPositionArc
        str 
 = "RadialPositionArc"
    Case 
 swDimXpertPositionZoneType_RadialPositionPlanar
        str 
 = "RadialPositionPlanar"
    Case 
 Else
        str 
 = "N/A"
    End 
 Select
    
    PositionZoneType 
 = str
End Function
' returns a string containing the names of the SW display 
 entities
Private Function DisplayEntity(annotation As DimXpertAnnotation) 
 As String
    Dim 
 str As String
    Dim 
 dispEnt As Object
    Dim 
 swAnnot As SldWorks.annotation
    
    
    'Set 
 dispEnt = swDimXpert.GetDisplayEntity(annot)
    Set 
 dispEnt = annotation.GetDisplayEntity
    
    If 
 Not dispEnt Is Nothing Then
        If 
 TypeOf dispEnt Is SldWorks.annotation Then
            Set 
 swAnnot = dispEnt
            str 
 = swAnnot.GetName
        End 
 If
    End 
 If
        
    DisplayEntity 
 = str
End Function
' returns a string containing the feature of size usage 
 (min, max, center)
Private Function FosUsage(value As Long) As String
    Dim 
 str
    Select 
 Case value
    Case 
 swDimXpertDistanceFosUsage_Center
        str 
 = "Center"
    Case 
 swDimXpertDistanceFosUsage_MaximumSide
        str 
 = "Max"
    Case 
 swDimXpertDistanceFosUsage_MinimumSide
        str 
 = "Min"
    Case 
 Else
        str 
 = "N/A"
    End 
 Select
    FosUsage 
 = str
End Function
Private Function FormatVector(I As Double, J As Double, 
 K As Double) As String
    Dim 
 str
    str 
 = FormatDouble(I) + ", " + FormatDouble(J) + ", " 
 + FormatDouble(K)
            
    FormatVector 
 = str
End Function
Private Function FormatDouble(value As Double) As String
    Dim 
 str
    
    str 
 = Format(value, "##,##0.0000")
    
    FormatDouble 
 = str
End Function
Private Function RadiansToDegrees(value As Double) As 
 String
    Dim 
 str
    
    str 
 = Format((value * 57.2957795130823), "##,##0.00")
                  
    RadiansToDegrees 
 = str
End Function
Private Function annotationTypeNameFromObject(anno As 
 DimXpertAnnotation) As String
    annotationTypeNameFromObject 
 = annotationTypeNameFromTypeNumber(anno.Type)
End Function
Private Function annotationTypeNameFromTypeNumber(annoTypeIndex 
 As Long) As String
    Select 
 Case annoTypeIndex
    
    Case 
 swDimXpertDimTol_DistanceBetween
        annotationTypeNameFromTypeNumber 
 = "DistanceBetween Dim"
    Case 
 swDimXpertDimTol_CounterBore
        annotationTypeNameFromTypeNumber 
 = "CounterBore Dim"
    Case 
 swDimXpertDimTol_Depth
        annotationTypeNameFromTypeNumber 
 = "Depth Dim"
    Case 
 swDimXpertDimTol_CounterSinkDiameter
        annotationTypeNameFromTypeNumber 
 = "CounterSinkDiameter Dim"
    Case 
 swDimXpertDimTol_ChamferDimension
        annotationTypeNameFromTypeNumber 
 = "ChamferDimension Dim"
    Case 
 swDimXpertDimTol_AngleBetween
        annotationTypeNameFromTypeNumber 
 = "AngleBetween Dim"
    Case 
 swDimXpertDimTol_CounterSinkAngle
        annotationTypeNameFromTypeNumber 
 = "CounterSinkAngle Dim"
    Case 
 swDimXpertDimTol_ConeAngle
        annotationTypeNameFromTypeNumber 
 = "ConeAngle Dim"
    Case 
 swDimXpertDimTol_Diameter
        annotationTypeNameFromTypeNumber 
 = "Diameter Dim"
    Case 
 swDimXpertDimTol_Length
        annotationTypeNameFromTypeNumber 
 = "Length Dim"
    Case 
 swDimXpertDimTol_Radius
        annotationTypeNameFromTypeNumber 
 = "Radius Dim"
    Case 
 swDimXpertDimTol_Width
        annotationTypeNameFromTypeNumber 
 = "Width Dim"
    Case 
 swDimXpertDimTol_CompositeDistanceBetween
        annotationTypeNameFromTypeNumber 
 = "CompositeDistanceBetween Dim"
    Case 
 swDimXpertDatum
        annotationTypeNameFromTypeNumber 
 = "Datum"
    Case 
 swDimXpertGeoTol_Position
        annotationTypeNameFromTypeNumber 
 = "Position Tol"
    Case 
 swDimXpertGeoTol_CompositePosition
        annotationTypeNameFromTypeNumber 
 = "CompositePosition Tol"
    Case 
 swDimXpertGeoTol_Symmetry
        annotationTypeNameFromTypeNumber 
 = "Symmetry Tol"
    Case 
 swDimXpertGeoTol_Concentricity
        annotationTypeNameFromTypeNumber 
 = "Concentricity Tol"
    Case 
 swDimXpertGeoTol_LineProfile
        annotationTypeNameFromTypeNumber 
 = "LineProfile Tol"
    Case 
 swDimXpertGeoTol_CompositeLineProfile
        annotationTypeNameFromTypeNumber 
 = "CompositeLineProfile Tol"
    Case 
 swDimXpertGeoTol_SurfaceProfile
        annotationTypeNameFromTypeNumber 
 = "SurfaceProfile Tol"
    Case 
 swDimXpertGeoTol_CompositeSurfaceProfile
        annotationTypeNameFromTypeNumber 
 = "CompositeSurfaceProfile Tol"
    Case 
 swDimXpertGeoTol_Angularity
        annotationTypeNameFromTypeNumber 
 = "Angularity Tol"
    Case 
 swDimXpertGeoTol_Parallelism
        annotationTypeNameFromTypeNumber 
 = "Parallelism Tol"
    Case 
 swDimXpertGeoTol_Perpendicularity
        annotationTypeNameFromTypeNumber 
 = "Perpendicularity Tol"
    Case 
 swDimXpertGeoTol_TotalRunout
        annotationTypeNameFromTypeNumber 
 = "TotalRunout Tol"
    Case 
 swDimXpertGeoTol_CircularRunout
        annotationTypeNameFromTypeNumber 
 = "CircularRunout Tol"
    Case 
 swDimXpertGeoTol_Flatness
        annotationTypeNameFromTypeNumber 
 = "Flatness Tol"
    Case 
 swDimXpertGeoTol_Circularity
        annotationTypeNameFromTypeNumber 
 = "Circularity Tol"
    Case 
 swDimXpertGeoTol_Cylindricity
        annotationTypeNameFromTypeNumber 
 = "Cylindricity Tol"
    Case 
 swDimXpertGeoTol_Straightness
        annotationTypeNameFromTypeNumber 
 = "Straightness Tol"
    Case 
 swDimXpertGeoTol_Tangency
        annotationTypeNameFromTypeNumber 
 = "Tangency Tol"
    Case 
 Else
        annotationTypeNameFromTypeNumber 
 = "<unknown> " & CStr(annoTypeIndex)
    
    End 
 Select
End Function