BbLocalPlacement3D( BbLocalPlacement3D placementRelTo, BbPosition3D relativePlacement) { if (placementRelTo != null && relativePlacement != null) { IfcLocalPlacement = new IfcLocalPlacement { PlacementRelTo = placementRelTo.IfcLocalPlacement, RelativePlacement = new IfcAxis2Placement { Value = relativePlacement.IfcAxis2Placement3D, }, }; } else if (placementRelTo == null && relativePlacement != null) { IfcLocalPlacement = new IfcLocalPlacement { RelativePlacement = new IfcAxis2Placement { Value = relativePlacement.IfcAxis2Placement3D, }, }; } else { IfcLocalPlacement = new IfcLocalPlacement { RelativePlacement = new IfcAxis2Placement { Value = BbHeaderSetting.Setting3D.DefaultBbPosition3D.IfcAxis2Placement3D, }, }; } }
public BbExtrudedGeometry( BbProfile profile, BbPosition3D position3D, BbDirection3D direction3D, double depth ) { _ifcExtrudedAreaSolid = new IfcExtrudedAreaSolid{ SweptArea = profile.IfcProfileDef, Position = position3D.IfcAxis2Placement3D, ExtrudedDirection = direction3D.IfcDirection, Depth = depth, }; _ifcShapeRepresentation = new IfcShapeRepresentation { ContextOfItems = BbHeaderSetting.Setting3D.GeometricRepresentationContext, RepresentationIdentifier = "Body", RepresentationType = "SweptSolid", Items = new List<IfcRepresentationItem>(), }; _ifcShapeRepresentation.Items.Add(_ifcExtrudedAreaSolid); _ifcProductDefinitionShape = new IfcProductDefinitionShape { // Name= // Description = Representations = new List<IfcRepresentation>(), }; _ifcProductDefinitionShape.Representations.Add(_ifcShapeRepresentation); }
BbBrepElement( string name, BbBRepGeometry brepGeometry, BbCoordinate3D position, BbDirection3D zAxis, BbDirection3D xAxis, BbLocalPlacement3D containerLocation, IfcOwnerHistory ownerHistory, Type IfcEntityType) { Name = name; //Profile = profile; BbPosition3D pos = BbPosition3D.Create(position, zAxis, xAxis); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( containerLocation, pos); // ifcBuildingElement = Activator.CreateInstance(EbConstants.Part21NSName, EbConstants.Part21NSName + "." + ifcEntityName); ifcElement = Activator.CreateInstance(IfcEntityType) as IfcElement; ifcElement.GlobalId = IfcGloballyUniqueId.NewGuid(); ifcElement.OwnerHistory = ownerHistory; ifcElement.Name = Name; //ObjectType = , ifcElement.ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement; ifcElement.Representation = brepGeometry.IfcProductDefinitionShape; }
public BbExtrudedGeometry( BbProfile profile, BbPosition3D position3D, BbDirection3D direction3D, double depth ) { _ifcExtrudedAreaSolid = new IfcExtrudedAreaSolid { SweptArea = profile.IfcProfileDef, Position = position3D.IfcAxis2Placement3D, ExtrudedDirection = direction3D.IfcDirection, Depth = depth, }; _ifcShapeRepresentation = new IfcShapeRepresentation { ContextOfItems = BbHeaderSetting.Setting3D.GeometricRepresentationContext, RepresentationIdentifier = "Body", RepresentationType = "SweptSolid", Items = new List <IfcRepresentationItem>(), }; _ifcShapeRepresentation.Items.Add(_ifcExtrudedAreaSolid); _ifcProductDefinitionShape = new IfcProductDefinitionShape { // Name= // Description = Representations = new List <IfcRepresentation>(), }; _ifcProductDefinitionShape.Representations.Add(_ifcShapeRepresentation); }
public static BbLocalPlacement3D Create(BbLocalPlacement3D placementRelTo, BbPosition3D relativePlacement) { var placement3D = new BbLocalPlacement3D(placementRelTo, relativePlacement); BbInstanceDB.AddToExport(placement3D); return(placement3D); }
private BbPiece(string name, string objectType, BbProfile profile, double length, BbCoordinate3D position, BbDirection3D zAxis, BbDirection3D xAxis, BbDirection3D extrudeDirection, BbLocalPlacement3D hostPlacement, Type ifcEntityType) { Length = length; Profile = profile; var pos = BbPosition3D.Create(position, zAxis, xAxis); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( hostPlacement, pos); var semExtrudedGeometry = BbExtrudedGeometry.Create( profile, BbHeaderSetting.Setting3D.DefaultBbPosition3D, extrudeDirection, Length); _ifcElement = Activator.CreateInstance(ifcEntityType) as IfcElement; if (_ifcElement == null) { return; } _ifcElement.GlobalId = IfcGloballyUniqueId.ConvertToIfcGuid(Guid); _ifcElement.OwnerHistory = BbHeaderSetting.Setting3D.IfcOwnerHistory; _ifcElement.Name = name; _ifcElement.ObjectType = objectType; _ifcElement.ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement; _ifcElement.Representation = semExtrudedGeometry.IfcProductDefinitionShape; //_ifcElement.Tag = id; }
// ExtrudedElement( // string name, // Profile profile, // double length, // Coordinate3D position, // Direction3D zAxis, // Direction3D xAxis, // Direction3D extrudeDirection, // Element container) // :this (name, profile, length, position, zAxis, xAxis, extrudeDirection, // container.ObjectLocalPlacement, container.IfcElement.OwnerHistory) // {} // // ExtrudedElement( // string name, // Profile profile, // double length, // Coordinate3D position, // Direction3D zAxis, // Direction3D xAxis, // Direction3D extrudeDirection, // SpatialElement container) // :this (name, profile, length, position, zAxis, xAxis, extrudeDirection, // container.ObjectLocalPlacement, container.IfcSpatialStructureElement.OwnerHistory) // {} BbExtrudedElement( string name, BbProfile profile, double length, BbCoordinate3D position, BbDirection3D zAxis, BbDirection3D xAxis, BbDirection3D extrudeDirection, BbLocalPlacement3D containerLocation, IfcOwnerHistory ownerHistory, Type ifcEntityType) { Name = name; Profile = profile; Length = length; BbPosition3D pos = BbPosition3D.Create(position, zAxis, xAxis); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( containerLocation, pos); BbExtrudedGeometry bbExtrudedGeometry = BbExtrudedGeometry.Create( profile, BbHeaderSetting.Setting3D.DefaultBbPosition3D, BbHeaderSetting.Setting3D.ZAxis, Length); _ifcElement = Activator.CreateInstance(ifcEntityType) as IfcElement; _ifcElement.GlobalId = IfcGloballyUniqueId.NewGuid(); _ifcElement.OwnerHistory = ownerHistory; _ifcElement.Name = Name; //ObjectType = , _ifcElement.ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement; _ifcElement.Representation = bbExtrudedGeometry.IfcProductDefinitionShape; }
public static BbSkewedEnd Create(BbElement hostElement, BbPosition3D position3D) { var cutSkewedEnd = new BbSkewedEnd(hostElement, position3D); BbInstanceDB.AddToExport(cutSkewedEnd); return(cutSkewedEnd); }
// public Position3D (double[] position) // :this(Coordinate3D.Create(position)) // { // } // public static Position3D Create () // { // Position3D position = new Position3D (); // // BbInstanceDB.Add (position); // return position; // } // public static Position3D Create (double[] position) // { // Position3D position3D = new Position3D (position); // BbInstanceDB.Add (position3D); // return position3D; // } //public static BbPosition3D Create() //{ // return Create(BbCoordinate3D.Create()); //} //public static BbPosition3D Create(BbCoordinate3D coordinate3D) //{ // BbPosition3D position3D = new BbPosition3D(coordinate3D); // BbInstanceDB.AddToExport(position3D); // return position3D; //} public static BbPosition3D Create(BbCoordinate3D coordinate3D, BbDirection3D axis, BbDirection3D refDirection) { BbPosition3D position = new BbPosition3D(coordinate3D, axis, refDirection); BbInstanceDB.AddToExport(position); return(position); }
public BbCutCope( BbElement hostElement, BbProfile profile, double length, double[] zAxis, double[] xAxis, double[] extrudeDirection, double[] position) { //ObjectLocalPlacement = new LocalPlacement3D(hostElement.ObjectLocalPlacement, new Position3D(position)); /// from main piece BbPosition3D pos = BbPosition3D.Create( BbCoordinate3D.Create(position), BbDirection3D.Create(zAxis), BbDirection3D.Create(xAxis)); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( hostElement.ObjectBbLocalPlacement, pos); BbDirection3D exDir; if (Math.Round(extrudeDirection[0], 8) == 0.0 && Math.Round(extrudeDirection[0], 8) == 0 && Math.Round(extrudeDirection[0], 8) == 1) { exDir = BbHeaderSetting.Setting3D.ZAxis; } else { exDir = BbDirection3D.Create(extrudeDirection); } BbExtrudedGeometry bbExtrudedGeometry = BbExtrudedGeometry.Create( profile, BbHeaderSetting.Setting3D.DefaultBbPosition3D, exDir, length); _ifcOpeningElement = new IfcOpeningElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, // Name = // Description = ObjectType = "Opening", ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement, Representation = bbExtrudedGeometry.IfcProductDefinitionShape, }; _ifcRelVoidsElement = new IfcRelVoidsElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, Name = "Cope", RelatingBuildingElement = hostElement.IfcObject as IfcElement, RelatedOpeningElement = _ifcOpeningElement, }; }
public static BbSkewedEnd Create(BbElement hostElement, BbPosition3D position3D, BbPropertySet bbPropertySet, double skewedAngleX, double skewedAngleY) { var cutSkewedEnd = new BbSkewedEnd(hostElement, position3D); cutSkewedEnd.AddSkewedEndProperty(bbPropertySet, skewedAngleX, skewedAngleY); BbInstanceDB.AddToExport(cutSkewedEnd); return(cutSkewedEnd); }
protected void AddBoltDirection(BbCurveGeometry boltDirection, BbCoordinate3D position) { BoltDirection = boltDirection; var pos = BbPosition3D.Create(position, BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( MainElement.ObjectBbLocalPlacement, pos); _ifcElement.ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement; }
public void AddWeldingPath(BbCurveGeometry weldingPath, BbCoordinate3D position) { WeldingPath = weldingPath; var pos = BbPosition3D.Create(position, BbHeaderSetting.Setting3D.ZAxis, BbHeaderSetting.Setting3D.XAxis); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( MainElement.ObjectBbLocalPlacement, pos); _ifcElement.ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement; }
void SetBbDirection3D() { XAxis = RefDirection = BbDirection3D.Create(1, 0, 0); YAxis = BbDirection3D.Create(0, 1, 0); ZAxis = Axis = BbDirection3D.Create(0, 0, 1); XAxisMinus = BbDirection3D.Create(-1, 0, 0); YAxisMinus = BbDirection3D.Create(0, -1, 0); ZAxisMinus = BbDirection3D.Create(0, 0, -1); DefaultOrigin = BbCoordinate3D.Create(); DefaultBbPosition3D = BbPosition3D.Create(DefaultOrigin, Axis, RefDirection); }
public static BbExtrudedGeometry Create( BbProfile profile, BbPosition3D position3D, BbDirection3D direction3D, double depth) { var extrudedGeometry = new BbExtrudedGeometry(profile, position3D, direction3D, depth); return(extrudedGeometry); }
public void AddGeometricRepresentation(BbElement hostElement, BbSurfaceGeometry surfaceGeometry, BbPosition3D position3D) { var ploc = BbLocalPlacement3D.Create( hostElement.ObjectBbLocalPlacement, BbPosition3D.Create( BbCoordinate3D.Create(0, 254, 100), BbHeaderSetting.Setting3D.YAxis, BbHeaderSetting.Setting3D.XAxisMinus) ); AddGeometricRepresentation(hostElement, surfaceGeometry, ploc); }
public BbCutCope( BbElement hostElement, double copeWidth, double copeDepth, double copeRadius, double[] position) { BbCopeProfile profile = BbCopeProfile.Create(copeWidth, copeDepth, copeRadius); var mainPart = hostElement as BbPiece; if (mainPart == null) { return; } BbPosition3D pos = BbPosition3D.Create( BbCoordinate3D.Create(position), BbHeaderSetting.Setting3D.XAxisMinus, BbHeaderSetting.Setting3D.ZAxis); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( hostElement.ObjectBbLocalPlacement, pos); BbExtrudedGeometry bbExtrudedGeometry = BbExtrudedGeometry.Create( profile, BbHeaderSetting.Setting3D.DefaultBbPosition3D, BbHeaderSetting.Setting3D.ZAxis, mainPart.Profile.Width); _ifcOpeningElement = new IfcOpeningElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, // Name = // Description = ObjectType = "Opening", ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement, Representation = bbExtrudedGeometry.IfcProductDefinitionShape, }; _ifcRelVoidsElement = new IfcRelVoidsElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, Name = "Cope", RelatingBuildingElement = hostElement.IfcObject as IfcElement, RelatedOpeningElement = _ifcOpeningElement, }; }
public static BbSkewedEnd Create(BbElement hostElement, BbPosition3D position3D, BbPropertySet bbPropertySet, double skewedAngleX, double skewedAngleY) { var cutSkewedEnd = new BbSkewedEnd(hostElement, position3D); cutSkewedEnd.AddSkewedEndProperty(bbPropertySet, skewedAngleX, skewedAngleY); BbInstanceDB.AddToExport(cutSkewedEnd); return cutSkewedEnd; }
public static BbSkewedEnd Create(BbElement hostElement, BbPosition3D position3D) { var cutSkewedEnd = new BbSkewedEnd(hostElement, position3D); BbInstanceDB.AddToExport(cutSkewedEnd); return cutSkewedEnd; }
protected BbAssembly( string assemblyId, string assemblyName, string assemblyMark, string clientMark, string prelimMark, string shippingMark, string barCode, BbSpatialElement floor, BbCoordinate3D position, BbDirection3D zAxis, BbDirection3D xAxis ) { //AssemblyName = assemblyName; //AssemblyMark = assemblyMark; var pos = BbPosition3D.Create(position, zAxis, xAxis); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( floor.ObjectBbLocalPlacement, pos); _ifcElementAssembly = new IfcElementAssembly { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = floor.IfcSpatialStructureElement.OwnerHistory, Name = assemblyName, Description = null, ObjectType = null, ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement, Representation = null, Tag = assemblyId, AssemblyPlace = IfcAssemblyPlaceEnum.NOTDEFINED, PredefinedType = IfcElementAssemblyTypeEnum.RIGID_FRAME }; BbAssemblyIdentity = BbAssemblyIdentity.Create( // assemblyName, assemblyMark, clientMark, prelimMark, shippingMark, barCode); BbAssemblyIdentity.AssignTo(this); AddToSpatialElement(floor); // var relContaineds = EarlyBindingInstanceModel.GetDataByType("IfcRelContainedInSpatialStructure"); //var thecontained = from y in ( from x in relContaineds // select x.Value as IfcRelContainedInSpatialStructure) // where y.; //var b = BbInstanceDB.GetTypedList(typeof(BbAssembly)); //if (b == null) //{ // IfcRelContainedInSpatialStructure = new IfcRelContainedInSpatialStructure // { // GlobalId = IfcGloballyUniqueId.NewGuid(), // OwnerHistory = _ifcElementAssembly.OwnerHistory, // RelatingStructure = floor.IfcSpatialStructureElement, // RelatedElements = new List<IfcProduct>(), // }; //} //else //{ // var otherAssemblies = (from x in b.OfType<BbAssembly>() // select x).ToList(); // //var a = otherAssemblies as IList<BbAssembly>; // var other = (from x in otherAssemblies // where x.BbSpatialElement.IfcSpatialStructureElement.Name // == BbSpatialElement.IfcSpatialStructureElement.Name // select x).First(); // if (other == null) // { // IfcRelContainedInSpatialStructure = new IfcRelContainedInSpatialStructure // { // GlobalId = IfcGloballyUniqueId.NewGuid(), // OwnerHistory = _ifcElementAssembly.OwnerHistory, // RelatingStructure = BbSpatialElement.IfcSpatialStructureElement, // RelatedElements = new List<IfcProduct>(), // }; // } // else // { // IfcRelContainedInSpatialStructure = other.IfcRelContainedInSpatialStructure; // } //} //IfcRelContainedInSpatialStructure.RelatedElements.Add(_ifcElementAssembly); }
BbLocalPlacement3D(BbPosition3D relativePlacement) : this(null, relativePlacement) { }
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)); }
public static BbLocalPlacement3D Create(BbLocalPlacement3D placementRelTo, BbPosition3D relativePlacement) { var placement3D = new BbLocalPlacement3D(placementRelTo, relativePlacement); BbInstanceDB.AddToExport(placement3D); return placement3D; }
BbCutCope( BbElement hostElement, double copeWidth, double copeDepth, double copeRadius, SemCopeLocation copeLocation) { BbCopeProfile profile = BbCopeProfile.Create(copeWidth, copeDepth, copeRadius, copeLocation); var mainPart = hostElement as BbPiece; if (mainPart == null) { return; } BbPosition3D pos; switch (copeLocation) { case SemCopeLocation.BottomLeft: pos = BbPosition3D.Create( BbCoordinate3D.Create(new double[] { mainPart.Profile.Width / 2, -mainPart.Profile.Depth / 2, 0 }), BbHeaderSetting.Setting3D.XAxisMinus, BbHeaderSetting.Setting3D.ZAxis); break; case SemCopeLocation.BottomRight: pos = BbPosition3D.Create( BbCoordinate3D.Create(new double[] { mainPart.Profile.Width / 2, -mainPart.Profile.Depth / 2, mainPart.Length }), BbHeaderSetting.Setting3D.XAxisMinus, BbHeaderSetting.Setting3D.ZAxis); break; case SemCopeLocation.TopRight: pos = BbPosition3D.Create( BbCoordinate3D.Create(new double[] { mainPart.Profile.Width / 2, mainPart.Profile.Depth / 2, mainPart.Length }), BbHeaderSetting.Setting3D.XAxisMinus, BbHeaderSetting.Setting3D.ZAxis); break; default: // TopLeft pos = BbPosition3D.Create( BbCoordinate3D.Create(new double[] { mainPart.Profile.Width / 2, mainPart.Profile.Depth / 2, 0 }), BbHeaderSetting.Setting3D.XAxisMinus, BbHeaderSetting.Setting3D.ZAxis); break; } ObjectBbLocalPlacement = BbLocalPlacement3D.Create( hostElement.ObjectBbLocalPlacement, pos); BbExtrudedGeometry bbExtrudedGeometry = BbExtrudedGeometry.Create( profile, BbHeaderSetting.Setting3D.DefaultBbPosition3D, BbHeaderSetting.Setting3D.ZAxis, mainPart.Profile.Width); _ifcOpeningElement = new IfcOpeningElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, // Name = // Description = ObjectType = "Opening", ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement, Representation = bbExtrudedGeometry.IfcProductDefinitionShape, }; _ifcRelVoidsElement = new IfcRelVoidsElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, Name = "Cope", RelatingBuildingElement = hostElement.IfcObject as IfcElement, RelatedOpeningElement = _ifcOpeningElement, }; }
BbSkewedEnd( BbElement hostElement, BbPosition3D pos) { var mainPart = hostElement as BbPiece; if (mainPart == null) return; var width = mainPart.Length > mainPart.Profile.Width ? mainPart.Length : mainPart.Profile.Width; width = width * 100; var depth = mainPart.Length > mainPart.Profile.Depth ? mainPart.Length : mainPart.Profile.Depth; depth = depth* 100; var profile = BbNamedRectangleProfile.Create(width, depth); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( hostElement.ObjectBbLocalPlacement, pos); //Direction3D exDir = Direction3D.Create(new[] {pos.Axis.X, pos.Axis.Y, pos.Axis.Z}); BbExtrudedGeometry bbExtrudedGeometry = BbExtrudedGeometry.Create( profile, BbHeaderSetting.Setting3D.DefaultBbPosition3D, BbHeaderSetting.Setting3D.ZAxis, mainPart.Length); //IfcHalfSpaceSolid ifcHalfSpaceSolid = new IfcHalfSpaceSolid // { // BaseSurface = new IfcPlane // { // Position = pos.IfcAxis2Placement3D, // }, // AgreementFlag = true, // }; //IfcShapeRepresentation ifcShapeRepresentation = new IfcShapeRepresentation //{ // ContextOfItems = HeaderSetting.Setting3D.GeometricRepresentationContext, // RepresentationIdentifier = "Body", // RepresentationType = "SweptSolid", // //RepresentationIdentifier = "Body", // //RepresentationType = "SolidModel", // Items = new List<IfcRepresentationItem>(), //}; //ifcShapeRepresentation.Items.Add(ifcHalfSpaceSolid); //IfcProductDefinitionShape ifcProductDefinitionShape = new IfcProductDefinitionShape //{ // // Name= // // Description = // Representations = new List<IfcRepresentation>(), //}; //ifcProductDefinitionShape.Representations.Add(ifcShapeRepresentation); _ifcOpeningElement = new IfcOpeningElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, // Name = // Description = ObjectType = "Opening", ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement, Representation = bbExtrudedGeometry.IfcProductDefinitionShape, //Representation = ifcProductDefinitionShape, }; _ifcRelVoidsElement = new IfcRelVoidsElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, Name = "Skewed End", RelatingBuildingElement = hostElement.IfcObject as IfcElement, RelatedOpeningElement = _ifcOpeningElement, }; }
public static BbExtrudedGeometry Create( BbProfile profile, BbPosition3D position3D, BbDirection3D direction3D, double depth) { var extrudedGeometry = new BbExtrudedGeometry(profile, position3D, direction3D, depth); return extrudedGeometry; }
BbSkewedEnd( BbElement hostElement, BbPosition3D pos) { var mainPart = hostElement as BbPiece; if (mainPart == null) { return; } var width = mainPart.Length > mainPart.Profile.Width ? mainPart.Length : mainPart.Profile.Width; width = width * 100; var depth = mainPart.Length > mainPart.Profile.Depth ? mainPart.Length : mainPart.Profile.Depth; depth = depth * 100; var profile = BbNamedRectangleProfile.Create(width, depth); ObjectBbLocalPlacement = BbLocalPlacement3D.Create( hostElement.ObjectBbLocalPlacement, pos); //Direction3D exDir = Direction3D.Create(new[] {pos.Axis.X, pos.Axis.Y, pos.Axis.Z}); BbExtrudedGeometry bbExtrudedGeometry = BbExtrudedGeometry.Create( profile, BbHeaderSetting.Setting3D.DefaultBbPosition3D, BbHeaderSetting.Setting3D.ZAxis, mainPart.Length); //IfcHalfSpaceSolid ifcHalfSpaceSolid = new IfcHalfSpaceSolid // { // BaseSurface = new IfcPlane // { // Position = pos.IfcAxis2Placement3D, // }, // AgreementFlag = true, // }; //IfcShapeRepresentation ifcShapeRepresentation = new IfcShapeRepresentation //{ // ContextOfItems = HeaderSetting.Setting3D.GeometricRepresentationContext, // RepresentationIdentifier = "Body", // RepresentationType = "SweptSolid", // //RepresentationIdentifier = "Body", // //RepresentationType = "SolidModel", // Items = new List<IfcRepresentationItem>(), //}; //ifcShapeRepresentation.Items.Add(ifcHalfSpaceSolid); //IfcProductDefinitionShape ifcProductDefinitionShape = new IfcProductDefinitionShape //{ // // Name= // // Description = // Representations = new List<IfcRepresentation>(), //}; //ifcProductDefinitionShape.Representations.Add(ifcShapeRepresentation); _ifcOpeningElement = new IfcOpeningElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, // Name = // Description = ObjectType = "Opening", ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement, Representation = bbExtrudedGeometry.IfcProductDefinitionShape, //Representation = ifcProductDefinitionShape, }; _ifcRelVoidsElement = new IfcRelVoidsElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, Name = "Skewed End", RelatingBuildingElement = hostElement.IfcObject as IfcElement, RelatedOpeningElement = _ifcOpeningElement, }; }
protected BbOpening( BbElement hostElement, BbCoordinate2D position, BbProfile profile, SemHoleLocation location, bool through, string type ) { var mainPart = hostElement as BbPiece; if (mainPart == null) { return; } double thickness; BbPosition3D pos; // x direction follows extrusion direction // extrude origin projected to bottom or left becomes the origin switch (location) { case SemHoleLocation.Left: pos = BbPosition3D.Create( BbCoordinate3D.Create( -(mainPart.Profile.Width / 2), position.Y, position.X), BbHeaderSetting.Setting3D.XAxis, BbHeaderSetting.Setting3D.ZAxis); if (through) { thickness = mainPart.Profile.Width; } else { thickness = mainPart.Profile.Width / 2; } break; case SemHoleLocation.Right: pos = BbPosition3D.Create( BbCoordinate3D.Create( (mainPart.Profile.Width / 2), position.Y, position.X), BbHeaderSetting.Setting3D.XAxisMinus, BbHeaderSetting.Setting3D.ZAxis); if (through) { thickness = mainPart.Profile.Width; } else { thickness = mainPart.Profile.Width / 2; } break; case SemHoleLocation.Web: if (through) { pos = BbPosition3D.Create( BbCoordinate3D.Create( (mainPart.Profile.Width / 2), position.Y, position.X ), BbHeaderSetting.Setting3D.XAxisMinus, BbHeaderSetting.Setting3D.ZAxis); thickness = mainPart.Profile.Width; } else { pos = BbPosition3D.Create( BbCoordinate3D.Create( (mainPart.Profile.Width / 4), position.Y, position.X ), BbHeaderSetting.Setting3D.XAxisMinus, BbHeaderSetting.Setting3D.ZAxis); thickness = mainPart.Profile.Width / 2; } break; case SemHoleLocation.Bottom: pos = BbPosition3D.Create( BbCoordinate3D.Create( position.Y, -(mainPart.Profile.Depth / 2), position.X ), BbHeaderSetting.Setting3D.YAxis, BbHeaderSetting.Setting3D.ZAxis); if (through) { thickness = mainPart.Profile.Depth; } else { thickness = mainPart.Profile.Depth / 2; } break; case SemHoleLocation.Top: default: pos = BbPosition3D.Create( BbCoordinate3D.Create( position.Y, (mainPart.Profile.Depth / 2), position.X ), BbHeaderSetting.Setting3D.YAxisMinus, BbHeaderSetting.Setting3D.ZAxis); if (through) { thickness = mainPart.Profile.Depth; } else { thickness = mainPart.Profile.Depth / 2; } break; } ObjectBbLocalPlacement = BbLocalPlacement3D.Create( hostElement.ObjectBbLocalPlacement, pos); BbExtrudedGeometry bbExtrudedGeometry = BbExtrudedGeometry.Create( profile, BbHeaderSetting.Setting3D.DefaultBbPosition3D, BbHeaderSetting.Setting3D.ZAxis, thickness); _ifcOpeningElement = new IfcOpeningElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, // Name = // Description = ObjectType = "Opening", ObjectPlacement = ObjectBbLocalPlacement.IfcLocalPlacement, Representation = bbExtrudedGeometry.IfcProductDefinitionShape, }; _ifcRelVoidsElement = new IfcRelVoidsElement { GlobalId = IfcGloballyUniqueId.NewGuid(), OwnerHistory = hostElement.IfcObject.OwnerHistory, Name = type, RelatingBuildingElement = hostElement.IfcObject as IfcElement, RelatedOpeningElement = _ifcOpeningElement, }; }
// public Position3D (double[] position) // :this(Coordinate3D.Create(position)) // { // } // public static Position3D Create () // { // Position3D position = new Position3D (); // // BbInstanceDB.Add (position); // return position; // } // public static Position3D Create (double[] position) // { // Position3D position3D = new Position3D (position); // BbInstanceDB.Add (position3D); // return position3D; // } //public static BbPosition3D Create() //{ // return Create(BbCoordinate3D.Create()); //} //public static BbPosition3D Create(BbCoordinate3D coordinate3D) //{ // BbPosition3D position3D = new BbPosition3D(coordinate3D); // BbInstanceDB.AddToExport(position3D); // return position3D; //} public static BbPosition3D Create(BbCoordinate3D coordinate3D, BbDirection3D axis, BbDirection3D refDirection) { BbPosition3D position = new BbPosition3D(coordinate3D, axis, refDirection); BbInstanceDB.AddToExport(position); return position; }