public static BbDirection2D Create(double x, double y) { BbDirection2D direction2D = new BbDirection2D(x, y); BbInstanceDB.AddToExport(direction2D); return(direction2D); }
// BbPosition2D (double[] position) // :this(BbCoordinate2D.Create(position)) //{ //} // public static Position2D Create () // { // Position2D position = new Position2D (); // // BbInstanceDB.Add (position); // return position; // } //public static BbPosition2D Create (double[] position) //{ // BbPosition2D position2D = new BbPosition2D (position); // BbInstanceDB.AddToExport (position2D); // return position2D; //} //public static BbPosition2D Create (BbCoordinate2D coordinate2D) //{ // BbPosition2D position2D = new BbPosition2D (coordinate2D); // BbInstanceDB.AddToExport (position2D); // return position2D; //} public static BbPosition2D Create(BbCoordinate2D coordinate2D, BbDirection2D refDirection) { BbPosition2D position = new BbPosition2D(coordinate2D, refDirection); BbInstanceDB.AddToExport(position); return(position); }
// BbPosition2D () // :this(BbCoordinate2D.Origin2D) //{ //} // BbPosition2D (BbCoordinate2D coordinate2D) // :this(coordinate2D, BbDirection2D.RefDirection2D) //{ //} BbPosition2D(BbCoordinate2D coordinate2D, BbDirection2D refDirection) { ifcAxis2Placement2D = new IfcAxis2Placement2D { Location = coordinate2D.IfcCartesianPoint, RefDirection = refDirection.IfcDirection, }; }
void SetBbDirection2D() { XAxis2D = RefDirection2D = BbDirection2D.Create(1, 0); YAxis2D = BbDirection2D.Create(0, 1); XAxisMinus2D = BbDirection2D.Create(-1, 0); YAxisMinus2D = BbDirection2D.Create(0, -1); Origin2D = BbCoordinate2D.Create(); Position2D = BbPosition2D.Create(Origin2D, RefDirection2D); }
protected BbSlottedHole( BbElement hostElement, BbCoordinate2D position, double centerToCenter, double radius, BbDirection2D refDirection, SemHoleLocation location, bool through ) : base(hostElement, position, BbSlottedHoleProfile.Create(centerToCenter, radius, refDirection), location, through, "Slot Hole") { }
public static BbSlottedHole Create( BbElement hostElement, BbCoordinate2D position, double centerToCenter, double radius, BbDirection2D refDirection, SemHoleLocation location, bool through ) { var sl = new BbSlottedHole(hostElement, position, centerToCenter, radius, refDirection, location, through); BbInstanceDB.AddToExport(sl); return sl; }
protected BbSlottedHole( BbElement hostElement, BbCoordinate2D position, double centerToCenter, double radius, BbDirection2D refDirection, SemHoleLocation location, bool through ) : base( hostElement, position, BbSlottedHoleProfile.Create(centerToCenter, radius, refDirection), location, through, "Slot Hole") { }
public static BbSlottedHole Create( BbElement hostElement, BbCoordinate2D position, double centerToCenter, double radius, BbDirection2D refDirection, SemHoleLocation location, bool through ) { var sl = new BbSlottedHole(hostElement, position, centerToCenter, radius, refDirection, location, through); BbInstanceDB.AddToExport(sl); return(sl); }
public static BbSlottedHole Create( BbElement hostElement, BbCoordinate2D position, double centerToCenter, double radius, BbDirection2D refDirection, SemHoleLocation location, bool through, BbPropertySet bbPropertySet, string featureSubType ) { var sl = new BbSlottedHole(hostElement, position, centerToCenter, radius, refDirection, location, through); sl.AddSlottedHoleProperty(bbPropertySet, featureSubType, centerToCenter, centerToCenter + (radius * 2), radius); BbInstanceDB.AddToExport(sl); return sl; }
public static BbSlottedHole Create( BbElement hostElement, BbCoordinate2D position, double centerToCenter, double radius, BbDirection2D refDirection, SemHoleLocation location, bool through, BbPropertySet bbPropertySet, string featureSubType ) { var sl = new BbSlottedHole(hostElement, position, centerToCenter, radius, refDirection, location, through); sl.AddSlottedHoleProperty(bbPropertySet, featureSubType, centerToCenter, centerToCenter + (radius * 2), radius); BbInstanceDB.AddToExport(sl); return(sl); }
public static BbProfile Create(double cToCDistance, double radius, BbDirection2D refDirection) { BbProfile ch = new BbSlottedHoleProfile(cToCDistance, radius); // what is this? // why it creates derived? if (refDirection.IfcDirection.DirectionRatios[0] != 1 && refDirection.IfcDirection.DirectionRatios[1] != 0) { ch = BbDerivedProfile.Create(ch, Math.Atan2(refDirection.IfcDirection.DirectionRatios[1], refDirection.IfcDirection.DirectionRatios[0])); } else { BbInstanceDB.AddToExport(ch); } return(ch); }
public static BbDirection2D Create(double x, double y) { BbDirection2D direction2D = new BbDirection2D (x, y); BbInstanceDB.AddToExport (direction2D); return direction2D; }
public static BbProfile Create(double cToCDistance, double radius, BbDirection2D refDirection) { BbProfile ch = new BbSlottedHoleProfile(cToCDistance, radius); // what is this? // why it creates derived? if (refDirection.IfcDirection.DirectionRatios[0] != 1 && refDirection.IfcDirection.DirectionRatios[1] != 0) { ch = BbDerivedProfile.Create(ch, Math.Atan2(refDirection.IfcDirection.DirectionRatios[1], refDirection.IfcDirection.DirectionRatios[0])); } else { BbInstanceDB.AddToExport(ch); } return ch; }
public static bool Tester4Writer(string filename) { EarlyBindingInstanceModel.Reset(); BbInstanceDB.Reset(); //var em11PsetName = @"AISC_EM11_Pset_Status"; BbHeaderSetting.Create( "donghoon", "Georgia Tech", "sem Tool", "alpha 1", "gatech", BbUnit.Metric); var floor = BbFloor.CreateSingleStoreyProject( "project", "site", "building", "1st floor", 0); // assembly 1-Beam------------------------------------------------------------------------------------- var assembly = BbAssembly.Create( "assid001", "Steel Assembly", "ASS01", "client_marker", "prelim_marker", "ship_mark", "102301123423", floor, BbCoordinate3D.Create(0, 0, 6000), BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis); // assembly 1 properties //Quantity var qAssemBeam = BbQuantityRequired.Create(); qAssemBeam.Add(assembly); //Finish/tearment //var paintAssem = BbPaintFinish.Create(); //var paintAssem = BbPaintFinish.Create("Paint", "PAINTED", assembly); //paintAssem.AddToElement(assembly); // assembly.AddPaintFinish(paintAssem); var pSetAssemSTr01 = BbPropertySet.Create(@"AISC_EM11_Pset_SurfaceTreatment"); var paintAssem1Pset = BbSurfaceTreatmentProperty.Create(pSetAssemSTr01, new List <string> { "Painted" }); paintAssem1Pset.AssignTo(assembly); //Scheduling var pSetAssemSc01 = BbPropertySet.Create(@"AISC_EM11_Pset_Schedule"); var AssemSch01 = BbSchedule.Create(pSetAssemSc01, "seq01", "seqLevel 01", DateTime.Now); AssemSch01.AssignTo(assembly); //Status var pSetAssemSt01 = BbPropertySet.Create(@"AISC_EM11_Pset_StatusInformation"); var AssemStat01 = BbStatus.Create(pSetAssemSt01, "Default", "Default", true); AssemStat01.AssignTo(assembly); //Drawing number var pSetAssemDN01 = BbPropertySet.Create(@"AISC_EM11_Pset_DrawingNumber"); var DnumberAssem1Pset = BbDrawingNumber.Create(pSetAssemDN01, new List <string> { "DR001PH1005", "DR001PH1004" }); DnumberAssem1Pset.AssignTo(assembly); //Version var pSetAssemVr01 = BbPropertySet.Create(@"AISC_EM11_Pset_VersionInformation"); var versionAssem01 = BbVersion.Create(pSetAssemVr01, "versionAssem01"); versionAssem01.AssignTo(assembly); // main piece 1- Beam------------------------------------------------------------------------------------ var profile = BbNamedIProfile.Create("AISC", "W460X260", 260, 508, 22.6, 40.4); var mainPart = BbMainPiece.Create( "P0001", "main piece", profile, 6000, BbCoordinate3D.Create(0, 0, -254), BbHeaderSetting.Setting3D.XAxis, BbHeaderSetting.Setting3D.YAxis, assembly); //var beamType = SemBeamType.Create("wideflange", "pm0001", IfcBeamTypeEnum.BEAM); //beamType.Defines(mainPart); // Main piece 1-Beam properties //Identification var pieceIdBeam01 = BbPieceIdentity.Create("indMark001", "pieceMark001", "prelimMark001", "barcode123456890", true); pieceIdBeam01.AssignTo(mainPart); //Material var pSetMat2 = BbPropertySet.Create(@"AISC_EM11_Pset_MaterialProperty"); var materialBeam01 = BbMaterial.Create("ASTM A992", pSetMat2, "materialID001", "materialCert001", "materialGrade001", "materialType001"); materialBeam01.AssociateTo(mainPart); //Quantity var qBeam = BbQuantityRequired.Create(); qBeam.Add(mainPart); //Finish/treatment ////var paint2 = PaintFinish.Create("p1001", "antirust", "paint"); var coord2d00 = BbCoordinate2D.Create(-100, 0); var coord2d01 = BbCoordinate2D.Create(100, 0); var coord2d02 = BbCoordinate2D.Create(100, 3400); var coord2d03 = BbCoordinate2D.Create(-100, 3400); var poly2d0 = BbPolyline2D.Create(new[] { coord2d00, coord2d01, coord2d02, coord2d03 }); var coord2d10 = BbCoordinate2D.Create(-40, 1500); var coord2d11 = BbCoordinate2D.Create(40, 1500); var coord2d12 = BbCoordinate2D.Create(40, 2500); var coord2d13 = BbCoordinate2D.Create(-40, 2500); var poly2d1 = BbPolyline2D.Create(new[] { coord2d10, coord2d11, coord2d12, coord2d13 }); var sg = BbSurfaceGeometry.Create(poly2d0, new[] { poly2d1 }); //var paint3 = SemPaintFinishPatch.Create("ANTIRUST", "PAINTED", sg); var ploc = BbLocalPlacement3D.Create( mainPart.ObjectBbLocalPlacement, BbPosition3D.Create( BbCoordinate3D.Create(0, 254, 100), BbHeaderSetting.Setting3D.YAxis, BbHeaderSetting.Setting3D.XAxisMinus) ); //paint3.AddToElement(mainPart, ploc); var pSetBeamSTr01 = BbPropertySet.Create(@"AISC_EM11_Pset_SurfaceTreatment"); var paintBeam1Pset = BbSurfaceTreatmentProperty.Create(pSetBeamSTr01, new List <string> { "GALVANIZED" }); paintBeam1Pset.AssignTo(mainPart); //Status var pSetBeamSt01 = BbPropertySet.Create(@"AISC_EM11_Pset_StatusInformation"); var statusBeam01 = BbStatus.Create(pSetBeamSt01, "Default", "Default", false); statusBeam01.AssignTo(mainPart); //Version var pSetBeamVr01 = BbPropertySet.Create(@"AISC_EM11_Pset_VersionInformation"); var versionBeam01 = BbVersion.Create(pSetBeamVr01, "versionBeam01"); versionBeam01.AssignTo(mainPart); //Tolerance var pSetBeamLT01 = BbPropertySet.Create(@"AISC_EM11_Pset_ToleranceForLayout"); var toleranceBeam01 = BbLayoutTolerance.Create(pSetBeamLT01, 0.01); toleranceBeam01.AssignTo(mainPart); //Catellation //No castellation needed //Feature //SemAnnotation.Create // ("north", "LocationOfMark", mainPart, BbCoordinate3D.Create(0, 254, 5), BbDirection3D.YAxis2D, // BbDirection3D.XAxisMinus2D); //BbPosition3D pos = BbPosition3D.Create( // BbCoordinate3D.Create(0, 0, 100), // BbDirection3D.Create(0.215665546, -0.107832773, -0.970494959), // BbDirection3D.Create(-0.970494959, 0.107832773, -0.215665546) // ); //BbSkewedEnd.Create(mainPart, pos); //// var arb = ArbitraryProfile.Create(poly2d0); //// //// ExtrudedElement.Create( //// "new", arb, 10, Coordinate3D.Create(0, 254, 100), //// Direction3D.YAxis2D, Direction3D.XAxisMinus2D, //// mainPart, typeof(IfcPlate)); ////// TypeProduct.Create(mainPart, "main piece", typeof(IfcBeam)); //BbCutCope.Create(mainPart, 210, 50, 10, SemCopeLocation.BottomRight); //BbCutCope.Create(mainPart, 210, 50, 10, SemCopeLocation.TopRight); ////CutCope.Create(mainPart, 210, 50, 10, CopeLocation.BottomLeft); ////CutCope.Create(mainPart, 210, 50, 10, CopeLocation.TopLeft); var bHoleBeam01 = BbDrillHoles.Create(mainPart, BbCoordinate2D.Create(1100, 60), 30, SemHoleLocation.Bottom, false); var bHoleBeam02 = BbDrillHoles.Create(mainPart, BbCoordinate2D.Create(1100, -60), 30, SemHoleLocation.Bottom, true); var bHoleBeam03 = BbDrillHoles.Create(mainPart, BbCoordinate2D.Create(1200, 60), 30, SemHoleLocation.Top, true); var bHoleBeam04 = BbDrillHoles.Create(mainPart, BbCoordinate2D.Create(1200, -60), 30, SemHoleLocation.Top, false); //DrillHoles.Create(mainPart, Coordinate2D.Create(300, 60), 15, HoleLocation.Left, false); //DrillHoles.Create(mainPart, Coordinate2D.Create(400, -60), 15, HoleLocation.Left, true); //DrillHoles.Create(mainPart, Coordinate2D.Create(500, 60), 15, HoleLocation.Right, false); //DrillHoles.Create(mainPart, Coordinate2D.Create(600, -60), 15, HoleLocation.Right, true); var bHoleBeam05 = BbDrillHoles.Create(mainPart, BbCoordinate2D.Create(700, 60), 15, SemHoleLocation.Web, false); var bHoleBeam06 = BbDrillHoles.Create(mainPart, BbCoordinate2D.Create(800, -60), 15, SemHoleLocation.Web, true); //DrillHoles.Create(mainPart, Coordinate2D.Create(6000 - 106.5, -100), 15, HoleLocation.Web, true); //DrillHoles.Create(mainPart, Coordinate2D.Create(6000 - 91.5, 100), 20, HoleLocation.Web, true); //DrillHoles.Create(mainPart, Coordinate2D.Create(101.5 + 5, -100), 15, HoleLocation.Web, true); //DrillHoles.Create(mainPart, Coordinate2D.Create(101.5 + 5, 100), 15, HoleLocation.Web, true); //Beam Bolt Hole properties var pSetBeamBH01 = BbPropertySet.Create(@"AISC_EM11_Pset_BoltHole"); var boltHoleBeamPset1 = BbBoltHoleProperties.Create(pSetBeamBH01, "Drilling", "Top", "No design constraint", "Tapped Hole", 30, false, 0); boltHoleBeamPset1.AssignTo(bHoleBeam01); boltHoleBeamPset1.AssignTo(bHoleBeam02); boltHoleBeamPset1.AssignTo(bHoleBeam03); boltHoleBeamPset1.AssignTo(bHoleBeam04); boltHoleBeamPset1.AssignTo(bHoleBeam05); boltHoleBeamPset1.AssignTo(bHoleBeam06); // Stiffeners------------------------------------------------------------------------------------------- //Stiffener1 var stiffener1 = BbStiffener.Create("st00102", "stiffener", 100, 425, 35, BbCoordinate3D.Create(65, 0, 5000), BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis, mainPart); //Stifenner1 properties //Identification var stiffIdentity1 = BbPieceIdentity.Create("indMark002", "pieceMark002", "prelimMark002", "barcode123456892", false); stiffIdentity1.AssignTo(stiffener1); //Status var pSetStstiff01 = BbPropertySet.Create(@"AISC_EM11_Pset_StatusInformation"); var statusstiff01 = BbStatus.Create(pSetStstiff01, "ReadyForProcurement", "Default", true); statusstiff01.AssignTo(stiffener1); //Version var pSetVrstiff01 = BbPropertySet.Create(@"AISC_EM11_Pset_VersionInformation"); var versionstiff01 = BbVersion.Create(pSetVrstiff01, "versionStiff01"); versionstiff01.AssignTo(stiffener1); //Tolerance var pSetLystiff01 = BbPropertySet.Create(@"AISC_EM11_Pset_ToleranceForLayout"); var tolerancestiff01 = BbLayoutTolerance.Create(pSetLystiff01, 0.01); tolerancestiff01.AssignTo(stiffener1); //Quantity var qStiff = BbQuantityRequired.Create(); qStiff.Add(stiffener1); //Material var pSetMat1 = BbPropertySet.Create(@"AISC_EM11_Pset_MaterialProperty"); var materialStiff = BbMaterial.Create("ASTM A992", pSetMat1, "materialID002", "materialCert002", "materialGrade002", "materialType002"); materialStiff.AssociateTo(stiffener1); //Finish/treatment //var paintStiff = BbPaintFinish.Create("stiffener paint", "PAINTED", stiffener1); //paintStiff.AddToElement(stiffener1); var pSetSTstiff01 = BbPropertySet.Create(@"AISC_EM11_Pset_SurfaceTreatment"); var paintStiffPset = BbSurfaceTreatmentProperty.Create(pSetSTstiff01, new List <string> { "Galvanized" }); paintStiffPset.AssignTo(stiffener1); //Stiffener2------------------------------- var stiffener2 = BbStiffener.Create("st00102", "stiffener", 100, 425, 35, BbCoordinate3D.Create(-65, 0, 5000), BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis, mainPart); //Stifenner2 properties //Identification var stiffIdentity2 = BbPieceIdentity.Create("indMark003", "pieceMark003", "prelimMark003", "barcode123456893", false); stiffIdentity2.AssignTo(stiffener2); //Status statusstiff01.AssignTo(stiffener2); //Version versionstiff01.AssignTo(stiffener2); //Tolerance tolerancestiff01.AssignTo(stiffener2); //Quantity qStiff.Add(stiffener2); //Material materialStiff.AssociateTo(stiffener2); //Finish/treatment //paintStiff.AddToOtherElement(stiffener2); // stiffener2.AddPaintFinish(paintStiff); //paintStiffPset.AssignTo(stiffener2); //Stiffener3------------------------------- var stiffener3 = BbStiffener.Create("st00102", "stiffener", 100, 425, 35, BbCoordinate3D.Create(65, 0, 4600), BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis, mainPart); //Stifenner3 properties //Identification var stiffIdentity3 = BbPieceIdentity.Create("indMark004", "pieceMark004", "prelimMark004", "barcode123456894", false); stiffIdentity3.AssignTo(stiffener3); //Status statusstiff01.AssignTo(stiffener3); //Version versionstiff01.AssignTo(stiffener3); //Tolerance tolerancestiff01.AssignTo(stiffener3); //Quantity qStiff.Add(stiffener3); //Material materialStiff.AssociateTo(stiffener3); //Finish/treatment //paintStiff.AddToOtherElement(stiffener3); //stiffener3.AddPaintFinish(paintStiff); //paintStiffPset.AssignTo(stiffener3); //Stiffener4------------------------------- var stiffener4 = BbStiffener.Create("st00102", "stiffener", 100, 425, 35, BbCoordinate3D.Create(-65, 0, 4600), BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis, mainPart); //Stifenner4 properties //Identification var stiffIdentity4 = BbPieceIdentity.Create("indMark005", "pieceMark005", "prelimMark005", "barcode123456895", false); stiffIdentity4.AssignTo(stiffener4); //Status statusstiff01.AssignTo(stiffener4); //Version versionstiff01.AssignTo(stiffener4); //Tolerance tolerancestiff01.AssignTo(stiffener4); //Quantity qStiff.Add(stiffener4); //Material materialStiff.AssociateTo(stiffener4); //Finish/treatment //paintStiff.AddToOtherElement(stiffener4); //stiffener4.AddPaintFinish(paintStiff); //paintStiffPset.AssignTo(stiffener4); // welding stiffeners with beam //DDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDD //BbSlottedHole.Create(mainPart, BbCoordinate2D.Create(3000, 50), 70, 30, BbDirection2D.RefDirection2D, // SemHoleLocation.Web, true); //2 Clip angles for column1---------------------------------------------------------------------------------- var aProfile = BbNamedLProfile.Create("AISC", "L203X152X19", 203, 152, 19); var derived1 = BbDerivedProfile.Create(aProfile, false, true); // -90.3 for showing gap between elements var angle = BbClipAngle.Create( "a00102", "angle", derived1, 360, //BbCoordinate3D.Create(5898.5, 90.3, -180 - 254), BbCoordinate3D.Create(90.3, -180, 5898.5), BbHeaderSetting.Setting3D.YAxis, BbHeaderSetting.Setting3D.Axis, mainPart ); //var w000 = BbCoordinate3D.Create(5898.5, 0, 0); //var w001 = BbCoordinate3D.Create(5898.5, 0, 200); var w000 = BbCoordinate3D.Create(5898.5, 0, 0); var w001 = BbCoordinate3D.Create(5898.5, 0, 200); var curve = BbPolyline3D.Create(new BbCoordinate3D[] { w000, w001 }); var curveGeometry = BbCurveGeometry.Create(curve); //Clip angle 1 properties //Identification var angleIdentity1 = BbPieceIdentity.Create("indMark006", "pieceMark006", "prelimMark006", "barcode123456896", false); angleIdentity1.AssignTo(angle); //Status var pSetStAngle01 = BbPropertySet.Create(@"AISC_EM11_Pset_StatusInformation"); var statusAngle01 = BbStatus.Create(pSetStAngle01, "ReadyForProcurement", "Default", false); statusAngle01.AssignTo(angle); //Version var pSetVrAngle01 = BbPropertySet.Create(@"AISC_EM11_Pset_VersionInformation"); var versionAngle01 = BbVersion.Create(pSetVrAngle01, "versionAngle001"); versionAngle01.AssignTo(angle); //Tolerance var pSetLyAngle01 = BbPropertySet.Create(@"AISC_EM11_Pset_ToleranceForLayout"); var toleranceAngle01 = BbLayoutTolerance.Create(pSetLyAngle01, 0.01); toleranceAngle01.AssignTo(angle); //Quantity var qAngle = BbQuantityRequired.Create(); qAngle.Add(angle); //Material var pSetMat3 = BbPropertySet.Create(@"AISC_EM11_Pset_MaterialProperty"); var materialAngle = BbMaterial.Create("ASTM A992", pSetMat3, "materialID003", "materialCert003", "materialGrade003", "materialType003"); materialAngle.AssociateTo(angle); //Finish/treatment //var paintAngle = BbPaintFinish.Create("angle blasted", "BLASTED", angle); //angle.AddPaintFinish(paintAngle); //paintAngle.AddToElement(angle); var pSetSTAngle01 = BbPropertySet.Create(@"AISC_EM11_Pset_SurfaceTreatment"); var paintAnglePset = BbSurfaceTreatmentProperty.Create(pSetSTAngle01, new List <string> { "Galvanized" }); paintAnglePset.AssignTo(angle); //Feature //DrillHoles.Create(angle, Coordinate2D.Create(100, -5), 15, HoleLocation.Bottom, false); //DrillHoles.Create(angle, Coordinate2D.Create(300, 10), 20, HoleLocation.Bottom, false); var bHoleAngle01 = BbDrillHoles.Create(angle, BbCoordinate2D.Create(80, 9.5), 15, SemHoleLocation.Right, false); var bHoleAngle02 = BbDrillHoles.Create(angle, BbCoordinate2D.Create(280, 9.5), 20, SemHoleLocation.Right, false); //Clip Angle1 Bolt Hole properties var pSetAngleBH01 = BbPropertySet.Create(@"AISC_EM11_Pset_BoltHole"); var boltHoleAnglePset1 = BbBoltHoleProperties.Create(pSetAngleBH01, "Drilling", "Top", "No design constraint", "Tapped Hole", 30, false, 0); boltHoleAnglePset1.AssignTo(bHoleAngle01); boltHoleAnglePset1.AssignTo(bHoleAngle02); var derived = BbDerivedProfile.Create(aProfile, true, true); var angle2 = BbClipAngle.Create("a00103", "angle", derived, 360, //BbCoordinate3D.Create(5898.5, -90.3, -180 - 254), BbCoordinate3D.Create(-90.3, -180, 5898.5), //BbDirection3D.ZAxis, BbDirection3D.XAxis2D, BbHeaderSetting.Setting3D.YAxis, BbHeaderSetting.Setting3D.Axis, mainPart); //Clip angle 2 properties //Identification var angleIdentity2 = BbPieceIdentity.Create("indMark007", "pieceMark007", "prelimMark007", "barcode123456897", false); angleIdentity2.AssignTo(angle2); //Status statusAngle01.AssignTo(angle2); //Version versionAngle01.AssignTo(angle2); //Tolerance toleranceAngle01.AssignTo(angle2); //Quantity qAngle.Add(angle2); //Material materialAngle.AssociateTo(angle2); //Finish/treatment //angle2.AddPaintFinish(paintAngle); //paintAngle.AddToOtherElement(angle2); //paintAnglePset.AssignTo(angle2); //DrillHoles.Create(angle2, Coordinate2D.Create(100, -5), 15, HoleLocation.Top, false); //DrillHoles.Create(angle2, Coordinate2D.Create(300, 10), 20, HoleLocation.Top, false); var bHoleAngle03 = BbDrillHoles.Create(angle2, BbCoordinate2D.Create(80, -9.5), 15, SemHoleLocation.Right, false); var bHoleAngle04 = BbDrillHoles.Create(angle2, BbCoordinate2D.Create(280, -9.5), 20, SemHoleLocation.Right, false); //Clip Angle2 Bolt Hole properties boltHoleAnglePset1.AssignTo(bHoleAngle03); boltHoleAnglePset1.AssignTo(bHoleAngle04); var w1 = BbWeld.Create(mainPart, angle); //var w1 = BbWeld.Create("Tee Joint", mainPart, angle); //var w2 = Weld.Create("Tee Joint", mainPart, angle2); w1.AddWeldingPath(curveGeometry, BbCoordinate3D.Create(0.0, 0.0, 0.0)); var pSetw1 = BbPropertySet.Create(@"AISC_EM11_Pset_Weld"); w1.AddProperties(pSetw1, "weld id", "weld description", "wps code", "category", "weld grade", 100, false); w1.AddProperties(pSetw1, "weld type1", "weld type2", "weld surface1", "weld surface 2", 123, "weld process", 1, 2, 3, 4, 5, 6, 7, 8, false, false); pSetw1.AssignTo(w1); var wc000 = BbCoordinate3D.Create(5898.5, 0, 0); var wc001 = BbCoordinate3D.Create(5898.5, 0, 200); var ccurve = BbPolyline3D.Create(new BbCoordinate3D[] { wc000, wc001 }); var ccurveGeometry = BbCurveGeometry.Create(ccurve); var boltAss = BbBoltAssembly.Create(mainPart, angle, ccurveGeometry, BbCoordinate3D.Create(1200, 60, 0)); var nut = BbNut.Create(boltAss); var nutPSetw1 = BbPropertySet.Create(@"AISC_EM11_Pset_Nut"); nut.AddProperties(nutPSetw1, "nut standard", "nut type", 5, 3, false); nutPSetw1.AssignTo(nut); var washer1 = BbWasher.Create(boltAss); var washerPSetw1 = BbPropertySet.Create(@"AISC_EM11_Pset_Washer"); nut.AddProperties(washerPSetw1, "washer standard", "washer type", 5, 2, false); washerPSetw1.AssignTo(washer1); var washer2 = BbWasher.Create(boltAss); var washerPSetw2 = BbPropertySet.Create(@"AISC_EM11_Pset_Washer"); nut.AddProperties(washerPSetw2, "washer standard", "washer type", 5, 1, true); washerPSetw2.AssignTo(washer2); //w1.AddProperties(); //var wtype = SemWeldType.Create("Tee Joint", "tj0001"); //wtype.Defines(w1); //wtype.Defines(w2); ////var derived2 = DerivedProfile.Create(aProfile, true, false); ////var angle3 = SteelPiece.Create("a00104", //// "angle", derived2, 400, //// Coordinate3D.Create(101.5, -90.3, -200 - 254), Direction3D.ZAxis, Direction3D.XAxis2D, assembly, //// typeof(IfcDiscreteAccessory)); //////DrillHoles.Create(angle3, Coordinate2D.Create(100, 5), 15, HoleLocation.Top, false); //////DrillHoles.Create(angle3, Coordinate2D.Create(300, 5), 15, HoleLocation.Top, false); ////DrillHoles.Create(angle3, Coordinate2D.Create(100, -10), 15, HoleLocation.Left, false); ////DrillHoles.Create(angle3, Coordinate2D.Create(300, -10), 15, HoleLocation.Left, false); ////var angle4 = SteelPiece.Create("a00105", //// "angle", aProfile, 400, //// Coordinate3D.Create(101.5, 90.3, -200 - 254), Direction3D.ZAxis, Direction3D.XAxis2D, assembly, //// typeof(IfcDiscreteAccessory)); //////DrillHoles.Create(angle4, Coordinate2D.Create(100, 5), 15, HoleLocation.Bottom, false); //////DrillHoles.Create(angle4, Coordinate2D.Create(300, 5), 15, HoleLocation.Bottom, false); ////DrillHoles.Create(angle4, Coordinate2D.Create(100, 10), 15, HoleLocation.Left, false); ////DrillHoles.Create(angle4, Coordinate2D.Create(300, 10), 15, HoleLocation.Left, false); //Clip angle for column2---------------------------------------------------------------------------------- var derived3 = BbDerivedProfile.Create(aProfile, true, false); var angle3 = BbClipAngle.Create( "a00103", "angle", derived3, 360, BbCoordinate3D.Create(-90.3, -180, 5898.5 - 5798.5), BbHeaderSetting.Setting3D.YAxis, BbHeaderSetting.Setting3D.Axis, mainPart ); //Clip angle 3 properties //Identification var angleIdentity3 = BbPieceIdentity.Create("indMark008", "pieceMark008", "prelimMark008", "barcode123456898", false); angleIdentity3.AssignTo(angle3); //Status statusAngle01.AssignTo(angle3); //Version versionAngle01.AssignTo(angle3); //Tolerance toleranceAngle01.AssignTo(angle3); //Quantity qAngle.Add(angle3); //Material materialAngle.AssociateTo(angle3); //Finish/treatment //angle3.AddPaintFinish(paintAngle); //paintAngle.AddToOtherElement(angle3); //paintAnglePset.AssignTo(angle3); var bHoleAngle05 = BbDrillHoles.Create(angle3, BbCoordinate2D.Create(80, -10), 15, SemHoleLocation.Left, false); var bHoleAngle06 = BbDrillHoles.Create(angle3, BbCoordinate2D.Create(280, -10), 15, SemHoleLocation.Left, false); //Clip Angle3 Bolt Hole properties boltHoleAnglePset1.AssignTo(bHoleAngle05); boltHoleAnglePset1.AssignTo(bHoleAngle06); var derived4 = BbDerivedProfile.Create(aProfile, false, false); var angle4 = BbClipAngle.Create( "a00104", "angle", derived4, 360, BbCoordinate3D.Create(90.3, -180, 5898.5 - 5798.5), BbHeaderSetting.Setting3D.YAxis, BbHeaderSetting.Setting3D.Axis, mainPart ); //Clip angle 4 properties //Identification var angleIdentity4 = BbPieceIdentity.Create("indMark009", "pieceMark009", "prelimMark009", "barcode123456899", false); angleIdentity4.AssignTo(angle4); //Status statusAngle01.AssignTo(angle4); //Version versionAngle01.AssignTo(angle4); //Tolerance toleranceAngle01.AssignTo(angle4); //Quantity qAngle.Add(angle4); //Material materialAngle.AssociateTo(angle4); //Finish/treatment //angle4.AddPaintFinish(paintAngle); //paintAngle.AddToOtherElement(angle4); //paintAnglePset.AssignTo(angle4); var bHoleAngle07 = BbDrillHoles.Create(angle4, BbCoordinate2D.Create(80, 10), 15, SemHoleLocation.Left, false); var bHoleAngle08 = BbDrillHoles.Create(angle4, BbCoordinate2D.Create(280, 10), 15, SemHoleLocation.Left, false); boltHoleAnglePset1.AssignTo(bHoleAngle07); boltHoleAnglePset1.AssignTo(bHoleAngle08); // welding column 2 & beam with angle 3,4//DDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDD // Assembly 2- Column1------------------------------------------------------------------------------------- var assembly2 = BbAssembly.Create( "assid003", "Steel Assembly", "ASS02", "client_marker2", "prelim_marker2", "ship_mark2", "202301123433", floor, BbCoordinate3D.Create(6014.3, 0, 0), BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis); // assembly 2 properties //Quantity var qAssemCol1 = BbQuantityRequired.Create(); qAssemCol1.Add(assembly2); //Finish/tearment //var paintAssem2 = BbPaintFinish.Create("Assy gal", "GALVANIZED",assembly2); //assembly2.AddPaintFinish(paintAssem2); //paintAssem2.AddToElement(assembly2); var pSetAssemSTr02 = BbPropertySet.Create(@"AISC_EM11_Pset_SurfaceTreatment"); var paintAssem2Pset = BbSurfaceTreatmentProperty.Create(pSetAssemSTr02, new List <string> { "Galvanized" }); paintAssem2Pset.AssignTo(assembly2); //Scheduling var pSetAssemSc02 = BbPropertySet.Create(@"AISC_EM11_Pset_Schedule"); var AssemSch02 = BbSchedule.Create(pSetAssemSc02, "seq01", "seqLevel 01", DateTime.Now); AssemSch02.AssignTo(assembly2); //Status var pSetAssemSt02 = BbPropertySet.Create(@"AISC_EM11_Pset_StatusInformation"); var AssemStat02 = BbStatus.Create(pSetAssemSt02, "Default", "Default", true); AssemStat02.AssignTo(assembly2); //Drawing number var pSetAssemDN02 = BbPropertySet.Create(@"AISC_EM11_Pset_DrawingNumber"); var DnumberAssem2Pset = BbDrawingNumber.Create(pSetAssemDN02, new List <string> { "DR001PH1006", "DR001PH1005" }); DnumberAssem2Pset.AssignTo(assembly2); //Version var pSetAssemVr02 = BbPropertySet.Create(@"AISC_EM11_Pset_VersionInformation"); var versionAssem02 = BbVersion.Create(pSetAssemVr02, "versionAssem02"); versionAssem02.AssignTo(assembly2); //Main Piece 2- Column1 var mainPart2 = BbMainPiece.Create( "c00102", "main piece", profile, 6000, BbHeaderSetting.Setting3D.DefaultOrigin, BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis, assembly2); // Column1 properties //Identification var pieceIdCol01 = BbPieceIdentity.Create("indMark010", "pieceMark010", "prelimMark010", "barcode123456880", true); pieceIdCol01.AssignTo(mainPart2); //Status var pSetColSt01 = BbPropertySet.Create(@"AISC_EM11_Pset_StatusInformation"); var statusCol01 = BbStatus.Create(pSetColSt01, "ReadyForProcurement", "Default", true); statusCol01.AssignTo(mainPart2); //Version var pSetColVr01 = BbPropertySet.Create(@"AISC_EM11_Pset_VersionInformation"); var versionCol01 = BbVersion.Create(pSetColVr01, "versionCol001"); versionCol01.AssignTo(mainPart2); //Tolerance var pSetColLy01 = BbPropertySet.Create(@"AISC_EM11_Pset_ToleranceForLayout"); var toleranceCol01 = BbLayoutTolerance.Create(pSetColLy01, 0.002); toleranceCol01.AssignTo(mainPart2); //Quantity var qPieceCol = BbQuantityRequired.Create(); qPieceCol.Add(mainPart2); //Material var pSetMat4 = BbPropertySet.Create(@"AISC_EM11_Pset_MaterialProperty"); var materialCol1 = BbMaterial.Create("ASTM A992", pSetMat4, "materialID004", "materialCert004", "materialGrade004", "materialType004"); materialCol1.AssociateTo(mainPart2); //Finish/treatment //var paintCol1 = BbPaintFinish.Create("paint col", "PAINTED", mainPart2); //mainPart2.AddPaintFinish(paintCol1); //paintCol1.AddToElement(mainPart2); var pSetColST01 = BbPropertySet.Create(@"AISC_EM11_Pset_SurfaceTreatment"); var paintColPset = BbSurfaceTreatmentProperty.Create(pSetColST01, new List <string> { "Blast" }); paintColPset.AssignTo(mainPart2); //Castellation //var pSetCt02 = BbPropertySet.Create(@"AISC_EM11_Pset_Castellation"); //var castellation2 = BbCastellation.Create(pSetCt02, "Circular", 0.002, 0.002, 0.001, 0.002, 0.01, 0.001); //castellation2.AssignTo(mainPart2); //Features var bHoleCol01 = BbDrillHoles.Create(mainPart2, BbCoordinate2D.Create(6000 - 508 / 2 - 100, 100), 15, SemHoleLocation.Web, false); var bHoleCol02 = BbDrillHoles.Create(mainPart2, BbCoordinate2D.Create(6000 - 508 / 2 + 100, 100), 15, SemHoleLocation.Web, false); var bHoleCol03 = BbDrillHoles.Create(mainPart2, BbCoordinate2D.Create(6000 - 508 / 2 - 100, -100), 15, SemHoleLocation.Web, false); var bHoleCol04 = BbDrillHoles.Create(mainPart2, BbCoordinate2D.Create(6000 - 508 / 2 + 100, -100), 15, SemHoleLocation.Web, false); var pSetColBH01 = BbPropertySet.Create(@"AISC_EM11_Pset_BoltHole"); var boltHoleColPset1 = BbBoltHoleProperties.Create(pSetColBH01, "Drilling", "Top", "No design constraint", "Tapped Hole", 20, false, 0); boltHoleColPset1.AssignTo(bHoleCol01); boltHoleColPset1.AssignTo(bHoleCol02); boltHoleColPset1.AssignTo(bHoleCol03); boltHoleColPset1.AssignTo(bHoleCol04); BbSlottedHole.Create(mainPart2, BbCoordinate2D.Create(5000, 50), 100, 30, BbDirection2D.Create(0.9, 0.3), SemHoleLocation.Web, true); //Slotted Hole properties // welding colum 1 with angle//DDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDD //SemConnectedElements.Create(assembly, assembly2); ///////////////////////////////////////////weld //var wp = BbWeldProperties.Create(10, 14); //wp.AssignTo(w1); //wp.AssignTo(w2); // Assembly 3- Column2---------------------------------------------------------------------------------------- var assembly3 = BbAssembly.Create( "assid003", "Steel Assembly", "ASS02", "client_marker3", "prelim_marker3", "ship_mark3", "302301123425", floor, BbCoordinate3D.Create(-14.3, 0, 0), BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis); // Assembly 3 properties //Quantity qAssemCol1.Add(assembly3); //Finish/tearment //assembly3.AddPaintFinish(paintAssem2); //paintAssem2.AddToOtherElement(assembly3); //paintAssem2Pset.AssignTo(assembly3); //Scheduling AssemSch02.AssignTo(assembly3); //Status AssemStat02.AssignTo(assembly3); //Drawing number var pSetAssemDN03 = BbPropertySet.Create(@"AISC_EM11_Pset_DrawingNumber"); var DnumberAssem3Pset = BbDrawingNumber.Create(pSetAssemDN03, new List <string> { "DR001PH1006", "DR001PH1005", "DR001PH1008" }); DnumberAssem3Pset.AssignTo(assembly3); //Version versionAssem02.AssignTo(assembly3); //Main Piece 3- Column 2 var mainPart3 = BbMainPiece.Create("c20010", "main piece", profile, 6000, BbHeaderSetting.Setting3D.DefaultOrigin, BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis, assembly3); //Column2 properties //Identification var pieceIdCol02 = BbPieceIdentity.Create("indMark011", "pieceMark011", "prelimMark011", "barcode123456881", true); pieceIdCol02.AssignTo(mainPart3); //Status var pSetColSt02 = BbPropertySet.Create(@"AISC_EM11_Pset_StatusInformation"); var statusCol02 = BbStatus.Create(pSetColSt02, "ReadyForMill", "Default", true); statusCol02.AssignTo(mainPart3); //Version var pSetColVr02 = BbPropertySet.Create(@"AISC_EM11_Pset_VersionInformation"); var versionCol02 = BbVersion.Create(pSetColVr02, "versionCol002"); versionCol02.AssignTo(mainPart3); //Tolerance toleranceCol01.AssignTo(mainPart3); //Quantity qPieceCol.Add(mainPart3); //Material materialCol1.AssociateTo(mainPart3); //Finish/treatment //mainPart3.AddPaintFinish(paintCol1); //paintCol1.AddToOtherElement(mainPart3); //paintColPset.AssignTo(mainPart3); //Castellation- not required //var pSetCt02 = BbPropertySet.Create(@"AISC_EM11_Pset_Castellation"); //var castellation2 = BbCastellation.Create(pSetCt02, "Circular", 0.002, 0.002, 0.001, 0.002, 0.01, 0.001); //castellation2.AssignTo(mainPart2); // Column2 features var bHoleCol05 = BbDrillHoles.Create(mainPart3, BbCoordinate2D.Create(6000 - 508 / 2 - 100, 100), 15, SemHoleLocation.Web, false); var bHoleCol06 = BbDrillHoles.Create(mainPart3, BbCoordinate2D.Create(6000 - 508 / 2 + 100, 100), 15, SemHoleLocation.Web, false); var bHoleCol07 = BbDrillHoles.Create(mainPart3, BbCoordinate2D.Create(6000 - 508 / 2 - 100, -100), 15, SemHoleLocation.Web, false); var bHoleCol08 = BbDrillHoles.Create(mainPart3, BbCoordinate2D.Create(6000 - 508 / 2 + 100, -100), 15, SemHoleLocation.Web, false); boltHoleColPset1.AssignTo(bHoleCol05); boltHoleColPset1.AssignTo(bHoleCol06); boltHoleColPset1.AssignTo(bHoleCol07); boltHoleColPset1.AssignTo(bHoleCol08); return(BbInstanceDB.Write(filename)); }