From fdc58f59a9b2ce3f1f4b9fd363f355ed113d8902 Mon Sep 17 00:00:00 2001 From: Mike Molinari Date: Mon, 21 Feb 2022 02:22:33 +0000 Subject: [PATCH] Updated primitive cone to use new widgets --- .../modeler/features/primitive_cone/index.ts | 129 ++++++++++-------- 1 file changed, 71 insertions(+), 58 deletions(-) diff --git a/modules/workbenches/modeler/features/primitive_cone/index.ts b/modules/workbenches/modeler/features/primitive_cone/index.ts index e4d0d1a6..6f3a1a7a 100644 --- a/modules/workbenches/modeler/features/primitive_cone/index.ts +++ b/modules/workbenches/modeler/features/primitive_cone/index.ts @@ -1,64 +1,77 @@ import { ApplicationContext } from 'context'; -import { MBrepShell } from 'cad/model/mshell'; import { roundValueForPresentation as r } from 'cad/craft/operationHelper'; -import { occ2brep } from 'cad/occ/occ2models'; -import icon32 from './icon32.png'; -import icon96 from './icon96.png'; +import { EntityKind } from "cad/model/entities"; +import { BooleanDefinition } from "cad/craft/schema/common/BooleanDefinition"; +import { OperationDescriptor } from "cad/craft/operationPlugin"; -export default { - id: 'primitive_cone', - label: 'primitive_cone', - icon: { - iconSet: { - medium: { - iconType: 'image', - iconContent: icon32 - }, - large: { - iconType: 'image', - iconContent: icon96 - } - }, - }, - info: 'primitive_cone', - mutualExclusiveFields: [], - paramsInfo: ({ diameter_A, diameter_B, height }) => `(${r(diameter_A)} ${r(diameter_A)} ${r(height)})`, - schema: { - diameter_A: { - type: 'number', - defaultValue: 50, - label: 'Diameter A' - }, - diameter_B: { - type: 'number', - defaultValue: 100, - label: 'Diameter B' - }, - height: { - type: 'number', - defaultValue: 200, - label: 'height' - }, - }, - run: ({ diameter_A, diameter_B, height, }, ctx: ApplicationContext) => { - const oc = ctx.occService.occContext; - const myLocation = new oc.gp_Pnt_3(0, 0, 0); - const coneCenterline = oc.gp.DZ(); - const coneOrientationAndLocation = new oc.gp_Ax2_3(myLocation, coneCenterline); - - let myBody = new oc.BRepPrimAPI_MakeCone_1(diameter_A, diameter_B, height); - - const aRes = new oc.TopoDS_Compound(); - const aBuilder = new oc.BRep_Builder(); - aBuilder.MakeCompound(aRes); - aBuilder.Add(aRes, myBody.Shape()); - - const mobject = new MBrepShell(occ2brep(aRes, ctx.occService.occContext)); - return { - consumed: [], - created: [mobject] - }; - }, +interface PrimitiveConeParams { + diameterA: number, + diameterB: number, + height: number, + locations: {}, + boolean: BooleanDefinition, } +const PrimitiveConeOperation: OperationDescriptor = { + id: 'primitive_cone', + label: 'Primitive Cone', + icon: 'img/cad/cone', + info: 'Primitive Cone', + paramsInfo: ({ height, diameterA, diameterB }) => `(${r(height)} , ${r(diameterA)} , ${r(diameterB)} )`, + form: [ + { + type: 'number', + label: 'Diameter A', + name: 'diameterA', + defaultValue: 50, + }, + { + type: 'number', + label: 'Diameter B', + name: 'diameterB', + defaultValue: 25, + }, + { + type: 'number', + label: 'Height', + name: 'height', + defaultValue: 50, + }, + { + type: 'selection', + name: 'locations', + capture: [EntityKind.DATUM], + label: 'locations', + multi: false, + optional: true, + defaultValue: { + usePreselection: true, + preselectionIndex: 0 + }, + }, + + { + type: 'boolean', + name: 'boolean', + label: 'boolean', + optional: true, + } + + ], + + + run: (params: PrimitiveConeParams, ctx: ApplicationContext) => { + + let occ = ctx.occService; + const oci = occ.commandInterface; + + //pCone cy 5 10 + oci.pcone("cone", params.diameterA / 2, params.diameterB / 2, params.height); + + return occ.utils.applyBooleanModifier(["cone"], params.boolean); + + }, +} + +export default PrimitiveConeOperation; \ No newline at end of file