Kalasalbin
Mechanical
- Jul 3, 2018
- 4
Hello. I'm new to this forum and need som help with programming a macro in Catia. What the macro does is that it splits a beam so that the middle part is left and then measures the clearence between surrounding components. My problem is that I can't predict which number my new split will have so that the following measurements wont work. If anyone can help me to insert some code that will rename my split into something of my choosing I would really appreciate it. I will highlight where the split is made in the code where I also want the renaming of the split feature. Thanks!
Language="VBSCRIPT"
Sub CATMain()
Set partDocument1 = CATIA.ActiveDocument
Set part1 = partDocument1.Part
Set hybridBodies1 = part1.HybridBodies
Set hybridBody1 = hybridBodies1.Item("check")
Set sketches1 = hybridBody1.HybridSketches
Set reference1 = part1.CreateReferenceFromName("Selection_RSurFaceBrpAxis_00;3);None);Cf11));Axis_00;Z0;G6284)")
Set sketch1 = sketches1.Add(reference1)
Dim arrayOfVariantOfDouble1(8)
arrayOfVariantOfDouble1(0) = 2756.976947
arrayOfVariantOfDouble1(1) = -880.902000
arrayOfVariantOfDouble1(2) = 1075.486315
arrayOfVariantOfDouble1(3) = 0.366938
arrayOfVariantOfDouble1(4) = 0.000000
arrayOfVariantOfDouble1(5) = 0.930245
arrayOfVariantOfDouble1(6) = -0.928970
arrayOfVariantOfDouble1(7) = -0.052336
arrayOfVariantOfDouble1(8) = 0.366435
sketch1.SetAbsoluteAxisData arrayOfVariantOfDouble1
part1.InWorkObject = sketch1
Set factory2D1 = sketch1.OpenEdition()
Set geometricElements1 = sketch1.GeometricElements
Set axis2D1 = geometricElements1.Item("AbsoluteAxis")
Set line2D1 = axis2D1.GetItem("HDirection")
line2D1.ReportName = 1
Set line2D2 = axis2D1.GetItem("VDirection")
line2D2.ReportName = 2
Set point2D1 = factory2D1.CreatePoint(-67.145811, 281.008170)
point2D1.ReportName = 3
Set point2D2 = factory2D1.CreatePoint(75.628087, 281.008170)
point2D2.ReportName = 4
Set line2D3 = factory2D1.CreateLine(-67.145811, 281.008170, 75.628087, 281.008170)
line2D3.ReportName = 5
line2D3.StartPoint = point2D1
line2D3.EndPoint = point2D2
Set point2D3 = factory2D1.CreatePoint(75.628087, -233.073526)
point2D3.ReportName = 6
Set line2D4 = factory2D1.CreateLine(75.628087, 281.008170, 75.628087, -233.073526)
line2D4.ReportName = 7
line2D4.EndPoint = point2D2
line2D4.StartPoint = point2D3
Set point2D4 = factory2D1.CreatePoint(-67.145811, -233.073526)
point2D4.ReportName = 8
Set line2D5 = factory2D1.CreateLine(75.628087, -233.073526, -67.145811, -233.073526)
line2D5.ReportName = 9
line2D5.StartPoint = point2D3
line2D5.EndPoint = point2D4
Set line2D6 = factory2D1.CreateLine(-67.145811, -233.073526, -67.145811, 281.008170)
line2D6.ReportName = 10
line2D6.EndPoint = point2D4
line2D6.StartPoint = point2D1
Set constraints1 = sketch1.Constraints
Set reference2 = part1.CreateReferenceFromObject(line2D3)
Set reference3 = part1.CreateReferenceFromObject(line2D1)
Set constraint1 = constraints1.AddBiEltCst(catCstTypeHorizontality, reference2, reference3)
constraint1.Mode = catCstModeDrivingDimension
Set reference4 = part1.CreateReferenceFromObject(line2D5)
Set reference5 = part1.CreateReferenceFromObject(line2D1)
Set constraint2 = constraints1.AddBiEltCst(catCstTypeHorizontality, reference4, reference5)
constraint2.Mode = catCstModeDrivingDimension
Set reference6 = part1.CreateReferenceFromObject(line2D4)
Set reference7 = part1.CreateReferenceFromObject(line2D2)
Set constraint3 = constraints1.AddBiEltCst(catCstTypeVerticality, reference6, reference7)
constraint3.Mode = catCstModeDrivingDimension
Set reference8 = part1.CreateReferenceFromObject(line2D6)
Set reference9 = part1.CreateReferenceFromObject(line2D2)
Set constraint4 = constraints1.AddBiEltCst(catCstTypeVerticality, reference8, reference9)
constraint4.Mode = catCstModeDrivingDimension
sketch1.CloseEdition
part1.InWorkObject = hybridBody1
part1.Update
Set hybridShapeFactory1 = part1.HybridShapeFactory
Set hybridShapeDirection1 = hybridShapeFactory1.AddNewDirectionByCoord(0.000000, 0.000000, 0.000000)
Set reference10 = part1.CreateReferenceFromObject(sketch1)
Set hybridShapeExtrude1 = hybridShapeFactory1.AddNewExtrude(reference10, -150.000000, -168.000000, hybridShapeDirection1)
hybridShapeExtrude1.SymmetricalExtension = 0
hybridBody1.AppendHybridShape hybridShapeExtrude1
part1.InWorkObject = hybridShapeExtrude1
part1.Update
Set bodies1 = part1.Bodies
Set body1 = bodies1.Item("PartBody")
Set shapes1 = body1.Shapes
Set reference11 = shapes1.Item("beam_solid")
Set reference12 = part1.CreateReferenceFromObject(hybridShapeExtrude1)
[highlight #FCE94F]Set hybridShapeSplit1 = hybridShapeFactory1.AddNewHybridSplit(reference11, reference12, -1)
hybridShapeFactory1.GSMVisibility reference11, 0
hybridShapeSplit1.ExtrapolationType = 1
hybridBody1.AppendHybridShape hybridShapeSplit1
part1.InWorkObject = hybridShapeSplit1[/highlight]
part1.Update
part1.Update
Set selection1 = partDocument1.Selection
Set visPropertySet1 = selection1.VisProperties
Set hybridShapes1 = hybridShapeExtrude1.Parent
Dim bSTR1
bSTR1 = hybridShapeExtrude1.Name
selection1.Add hybridShapeExtrude1
Set visPropertySet1 = visPropertySet1.Parent
Dim bSTR2
bSTR2 = visPropertySet1.Name
Dim bSTR3
bSTR3 = visPropertySet1.Name
visPropertySet1.SetShow 1
selection1.Clear
Set selection2 = partDocument1.Selection
Set visPropertySet2 = selection2.VisProperties
Set sketches1 = sketch1.Parent
Dim bSTR4
bSTR4 = sketch1.Name
selection2.Add sketch1
Set visPropertySet2 = visPropertySet2.Parent
Dim bSTR5
bSTR5 = visPropertySet2.Name
Dim bSTR6
bSTR6 = visPropertySet2.Name
visPropertySet2.SetShow 1
selection2.Clear
Set selection3 = partDocument1.Selection
Set visPropertySet3 = selection3.VisProperties
Set thickSurface1 = shapes1.Item("beam_solid")
Set shapes1 = thickSurface1.Parent
Dim bSTR7
bSTR7 = thickSurface1.Name
selection3.Add thickSurface1
Set visPropertySet3 = visPropertySet3.Parent
Dim bSTR8
bSTR8 = visPropertySet3.Name
Dim bSTR9
bSTR9 = visPropertySet3.Name
visPropertySet3.SetShow 1
selection3.Clear
Set selection4 = partDocument1.Selection
Set visPropertySet4 = selection4.VisProperties
Set axisSystems1 = part1.AxisSystems
Set axisSystem1 = axisSystems1.Item("Axis_00")
Set axisSystems1 = axisSystem1.Parent
Dim bSTR10
bSTR10 = axisSystem1.Name
selection4.Add axisSystem1
Set visPropertySet4 = visPropertySet4.Parent
Dim bSTR11
bSTR11 = visPropertySet4.Name
Dim bSTR12
bSTR12 = visPropertySet4.Name
visPropertySet4.SetShow 1
selection4.Clear
Set specsAndGeomWindow1 = CATIA.ActiveWindow
Set viewer3D1 = specsAndGeomWindow1.ActiveViewer
Set viewpoint3D1 = viewer3D1.Viewpoint3D
Set parameters1 = part1.Parameters
Set length1 = parameters1.CreateDimension("", "LENGTH", 0.000000)
Set relations1 = part1.Relations
Set formula1 = relations1.CreateFormula("Formula.2921", "", length1, "distance(check\Split.55 ,check\window )")
formula1.Rename "Formula.2921"
Set parameters2 = part1.Parameters
Set length2 = parameters2.CreateDimension("", "LENGTH", 0.000000)
Set relations2 = part1.Relations
Set formula2 = relations2.CreateFormula("Formula.2922", "", length2, "distance(check\Split.55 ,check\door ) ")
formula2.Rename "Formula.2922"
Set parameters3 = part1.Parameters
Set length3 = parameters3.CreateDimension("", "LENGTH", 0.000000)
Set relations3 = part1.Relations
Set formula3 = relations3.CreateFormula("Formula.2923", "", length3, "distance(check\Split.55 ,check\brackets ) ")
formula3.Rename "Formula.2923"
length3.Rename "beam_brackets"
length2.Rename "beam_door"
length1.Rename "beam_window"
part1.Update
End Sub
Language="VBSCRIPT"
Sub CATMain()
Set partDocument1 = CATIA.ActiveDocument
Set part1 = partDocument1.Part
Set hybridBodies1 = part1.HybridBodies
Set hybridBody1 = hybridBodies1.Item("check")
Set sketches1 = hybridBody1.HybridSketches
Set reference1 = part1.CreateReferenceFromName("Selection_RSurFaceBrpAxis_00;3);None);Cf11));Axis_00;Z0;G6284)")
Set sketch1 = sketches1.Add(reference1)
Dim arrayOfVariantOfDouble1(8)
arrayOfVariantOfDouble1(0) = 2756.976947
arrayOfVariantOfDouble1(1) = -880.902000
arrayOfVariantOfDouble1(2) = 1075.486315
arrayOfVariantOfDouble1(3) = 0.366938
arrayOfVariantOfDouble1(4) = 0.000000
arrayOfVariantOfDouble1(5) = 0.930245
arrayOfVariantOfDouble1(6) = -0.928970
arrayOfVariantOfDouble1(7) = -0.052336
arrayOfVariantOfDouble1(8) = 0.366435
sketch1.SetAbsoluteAxisData arrayOfVariantOfDouble1
part1.InWorkObject = sketch1
Set factory2D1 = sketch1.OpenEdition()
Set geometricElements1 = sketch1.GeometricElements
Set axis2D1 = geometricElements1.Item("AbsoluteAxis")
Set line2D1 = axis2D1.GetItem("HDirection")
line2D1.ReportName = 1
Set line2D2 = axis2D1.GetItem("VDirection")
line2D2.ReportName = 2
Set point2D1 = factory2D1.CreatePoint(-67.145811, 281.008170)
point2D1.ReportName = 3
Set point2D2 = factory2D1.CreatePoint(75.628087, 281.008170)
point2D2.ReportName = 4
Set line2D3 = factory2D1.CreateLine(-67.145811, 281.008170, 75.628087, 281.008170)
line2D3.ReportName = 5
line2D3.StartPoint = point2D1
line2D3.EndPoint = point2D2
Set point2D3 = factory2D1.CreatePoint(75.628087, -233.073526)
point2D3.ReportName = 6
Set line2D4 = factory2D1.CreateLine(75.628087, 281.008170, 75.628087, -233.073526)
line2D4.ReportName = 7
line2D4.EndPoint = point2D2
line2D4.StartPoint = point2D3
Set point2D4 = factory2D1.CreatePoint(-67.145811, -233.073526)
point2D4.ReportName = 8
Set line2D5 = factory2D1.CreateLine(75.628087, -233.073526, -67.145811, -233.073526)
line2D5.ReportName = 9
line2D5.StartPoint = point2D3
line2D5.EndPoint = point2D4
Set line2D6 = factory2D1.CreateLine(-67.145811, -233.073526, -67.145811, 281.008170)
line2D6.ReportName = 10
line2D6.EndPoint = point2D4
line2D6.StartPoint = point2D1
Set constraints1 = sketch1.Constraints
Set reference2 = part1.CreateReferenceFromObject(line2D3)
Set reference3 = part1.CreateReferenceFromObject(line2D1)
Set constraint1 = constraints1.AddBiEltCst(catCstTypeHorizontality, reference2, reference3)
constraint1.Mode = catCstModeDrivingDimension
Set reference4 = part1.CreateReferenceFromObject(line2D5)
Set reference5 = part1.CreateReferenceFromObject(line2D1)
Set constraint2 = constraints1.AddBiEltCst(catCstTypeHorizontality, reference4, reference5)
constraint2.Mode = catCstModeDrivingDimension
Set reference6 = part1.CreateReferenceFromObject(line2D4)
Set reference7 = part1.CreateReferenceFromObject(line2D2)
Set constraint3 = constraints1.AddBiEltCst(catCstTypeVerticality, reference6, reference7)
constraint3.Mode = catCstModeDrivingDimension
Set reference8 = part1.CreateReferenceFromObject(line2D6)
Set reference9 = part1.CreateReferenceFromObject(line2D2)
Set constraint4 = constraints1.AddBiEltCst(catCstTypeVerticality, reference8, reference9)
constraint4.Mode = catCstModeDrivingDimension
sketch1.CloseEdition
part1.InWorkObject = hybridBody1
part1.Update
Set hybridShapeFactory1 = part1.HybridShapeFactory
Set hybridShapeDirection1 = hybridShapeFactory1.AddNewDirectionByCoord(0.000000, 0.000000, 0.000000)
Set reference10 = part1.CreateReferenceFromObject(sketch1)
Set hybridShapeExtrude1 = hybridShapeFactory1.AddNewExtrude(reference10, -150.000000, -168.000000, hybridShapeDirection1)
hybridShapeExtrude1.SymmetricalExtension = 0
hybridBody1.AppendHybridShape hybridShapeExtrude1
part1.InWorkObject = hybridShapeExtrude1
part1.Update
Set bodies1 = part1.Bodies
Set body1 = bodies1.Item("PartBody")
Set shapes1 = body1.Shapes
Set reference11 = shapes1.Item("beam_solid")
Set reference12 = part1.CreateReferenceFromObject(hybridShapeExtrude1)
[highlight #FCE94F]Set hybridShapeSplit1 = hybridShapeFactory1.AddNewHybridSplit(reference11, reference12, -1)
hybridShapeFactory1.GSMVisibility reference11, 0
hybridShapeSplit1.ExtrapolationType = 1
hybridBody1.AppendHybridShape hybridShapeSplit1
part1.InWorkObject = hybridShapeSplit1[/highlight]
part1.Update
part1.Update
Set selection1 = partDocument1.Selection
Set visPropertySet1 = selection1.VisProperties
Set hybridShapes1 = hybridShapeExtrude1.Parent
Dim bSTR1
bSTR1 = hybridShapeExtrude1.Name
selection1.Add hybridShapeExtrude1
Set visPropertySet1 = visPropertySet1.Parent
Dim bSTR2
bSTR2 = visPropertySet1.Name
Dim bSTR3
bSTR3 = visPropertySet1.Name
visPropertySet1.SetShow 1
selection1.Clear
Set selection2 = partDocument1.Selection
Set visPropertySet2 = selection2.VisProperties
Set sketches1 = sketch1.Parent
Dim bSTR4
bSTR4 = sketch1.Name
selection2.Add sketch1
Set visPropertySet2 = visPropertySet2.Parent
Dim bSTR5
bSTR5 = visPropertySet2.Name
Dim bSTR6
bSTR6 = visPropertySet2.Name
visPropertySet2.SetShow 1
selection2.Clear
Set selection3 = partDocument1.Selection
Set visPropertySet3 = selection3.VisProperties
Set thickSurface1 = shapes1.Item("beam_solid")
Set shapes1 = thickSurface1.Parent
Dim bSTR7
bSTR7 = thickSurface1.Name
selection3.Add thickSurface1
Set visPropertySet3 = visPropertySet3.Parent
Dim bSTR8
bSTR8 = visPropertySet3.Name
Dim bSTR9
bSTR9 = visPropertySet3.Name
visPropertySet3.SetShow 1
selection3.Clear
Set selection4 = partDocument1.Selection
Set visPropertySet4 = selection4.VisProperties
Set axisSystems1 = part1.AxisSystems
Set axisSystem1 = axisSystems1.Item("Axis_00")
Set axisSystems1 = axisSystem1.Parent
Dim bSTR10
bSTR10 = axisSystem1.Name
selection4.Add axisSystem1
Set visPropertySet4 = visPropertySet4.Parent
Dim bSTR11
bSTR11 = visPropertySet4.Name
Dim bSTR12
bSTR12 = visPropertySet4.Name
visPropertySet4.SetShow 1
selection4.Clear
Set specsAndGeomWindow1 = CATIA.ActiveWindow
Set viewer3D1 = specsAndGeomWindow1.ActiveViewer
Set viewpoint3D1 = viewer3D1.Viewpoint3D
Set parameters1 = part1.Parameters
Set length1 = parameters1.CreateDimension("", "LENGTH", 0.000000)
Set relations1 = part1.Relations
Set formula1 = relations1.CreateFormula("Formula.2921", "", length1, "distance(check\Split.55 ,check\window )")
formula1.Rename "Formula.2921"
Set parameters2 = part1.Parameters
Set length2 = parameters2.CreateDimension("", "LENGTH", 0.000000)
Set relations2 = part1.Relations
Set formula2 = relations2.CreateFormula("Formula.2922", "", length2, "distance(check\Split.55 ,check\door ) ")
formula2.Rename "Formula.2922"
Set parameters3 = part1.Parameters
Set length3 = parameters3.CreateDimension("", "LENGTH", 0.000000)
Set relations3 = part1.Relations
Set formula3 = relations3.CreateFormula("Formula.2923", "", length3, "distance(check\Split.55 ,check\brackets ) ")
formula3.Rename "Formula.2923"
length3.Rename "beam_brackets"
length2.Rename "beam_door"
length1.Rename "beam_window"
part1.Update
End Sub