From 727fc722af2a9213670ae4a21d0a1683c24e8fc2 Mon Sep 17 00:00:00 2001 From: Juan Rosario Date: Thu, 19 Jan 2023 14:09:06 -0600 Subject: [PATCH] feat: add support for cnc mode in g-code viewer (#1239) Signed-off-by: Stefan Dej --- package-lock.json | 14 +++++++------- package.json | 2 +- src/components/gcodeviewer/Viewer.vue | 23 +++++++++++++++++++++-- src/locales/en.json | 3 ++- src/store/gui/index.ts | 1 + src/store/gui/types.ts | 1 + 6 files changed, 33 insertions(+), 11 deletions(-) diff --git a/package-lock.json b/package-lock.json index eabbbe5fb..8850c17c6 100644 --- a/package-lock.json +++ b/package-lock.json @@ -18,7 +18,7 @@ "@codemirror/view": "^6.0.3", "@jaames/iro": "^5.5.2", "@lezer/highlight": "^1.0.0", - "@sindarius/gcodeviewer": "^3.1.14", + "@sindarius/gcodeviewer": "^3.2.0", "@types/node": "^18.0.0", "@types/overlayscrollbars": "^1.12.1", "axios": "^0.27.0", @@ -2757,9 +2757,9 @@ "dev": true }, "node_modules/@sindarius/gcodeviewer": { - "version": "3.1.14", - "resolved": "https://registry.npmjs.org/@sindarius/gcodeviewer/-/gcodeviewer-3.1.14.tgz", - "integrity": "sha512-+kmw2ougPYJzfU4lKvjSNZLsyDbhTKgeOA2KYAHgNnD0BUiSGCmveVLdcs8bSusmnrv8J+M+90eco0LSUuywiw==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/@sindarius/gcodeviewer/-/gcodeviewer-3.2.0.tgz", + "integrity": "sha512-w2MZlqw/BbPZB/ndEq8lZeaqovfujCTVwdKR5AKaMggIGdQQnkE7qZ8uxrZZVxWzoLIUv9h+cbyXiOgDFyiekw==", "dependencies": { "@babylonjs/core": "^5.34.0", "@babylonjs/inspector": "^5.34.0", @@ -12056,9 +12056,9 @@ "dev": true }, "@sindarius/gcodeviewer": { - "version": "3.1.14", - "resolved": "https://registry.npmjs.org/@sindarius/gcodeviewer/-/gcodeviewer-3.1.14.tgz", - "integrity": "sha512-+kmw2ougPYJzfU4lKvjSNZLsyDbhTKgeOA2KYAHgNnD0BUiSGCmveVLdcs8bSusmnrv8J+M+90eco0LSUuywiw==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/@sindarius/gcodeviewer/-/gcodeviewer-3.2.0.tgz", + "integrity": "sha512-w2MZlqw/BbPZB/ndEq8lZeaqovfujCTVwdKR5AKaMggIGdQQnkE7qZ8uxrZZVxWzoLIUv9h+cbyXiOgDFyiekw==", "requires": { "@babylonjs/core": "^5.34.0", "@babylonjs/inspector": "^5.34.0", diff --git a/package.json b/package.json index b73de224c..1bfc89f48 100644 --- a/package.json +++ b/package.json @@ -33,7 +33,7 @@ "@codemirror/view": "^6.0.3", "@jaames/iro": "^5.5.2", "@lezer/highlight": "^1.0.0", - "@sindarius/gcodeviewer": "^3.1.14", + "@sindarius/gcodeviewer": "^3.2.0", "@types/node": "^18.0.0", "@types/overlayscrollbars": "^1.12.1", "axios": "^0.27.0", diff --git a/src/components/gcodeviewer/Viewer.vue b/src/components/gcodeviewer/Viewer.vue index 93b7faca9..eebb2166a 100644 --- a/src/components/gcodeviewer/Viewer.vue +++ b/src/components/gcodeviewer/Viewer.vue @@ -186,6 +186,13 @@ hide-details :label="$t('GCodeViewer.SpecularLighting')"> + + + @@ -508,13 +515,14 @@ export default class Viewer extends Mixins(BaseMixin) { } viewer.gcodeProcessor.useHighQualityExtrusion(this.hdRendering) - viewer.gcodeProcessor.updateForceWireMode(this.forceLineRendering) + viewer.gcodeProcessor.updateForceWireMode(this.forceLineRendering || this.cncMode) viewer.gcodeProcessor.setAlpha(this.transparency) viewer.gcodeProcessor.setVoxelMode(this.voxelMode) viewer.gcodeProcessor.voxelWidth = this.voxelWidth viewer.gcodeProcessor.voxelHeight = this.voxelHeight viewer.gcodeProcessor.useSpecularColor(this.specularLighting) viewer.gcodeProcessor.setLiveTracking(false) + viewer.gcodeProcessor.g1AsExtrusion = this.cncMode viewer.buildObjects.objectCallback = this.objectCallback this.loadToolColors(this.extruderColors) @@ -824,7 +832,7 @@ export default class Viewer extends Mixins(BaseMixin) { @Watch('forceLineRendering') async forceLineRenderingChanged(newVal: boolean) { if (viewer) { - viewer.gcodeProcessor.updateForceWireMode(newVal) + viewer.gcodeProcessor.updateForceWireMode(newVal || this.cncMode) await this.reloadViewer() } } @@ -895,6 +903,17 @@ export default class Viewer extends Mixins(BaseMixin) { } } + get cncMode() { + return this.$store.state.gui.gcodeViewer.cncMode + } + + set cncMode(newVal) { + this.$store.dispatch('gui/saveSetting', { name: 'gcodeViewer.cncMode', value: newVal }) + viewer.gcodeProcessor.g1AsExtrusion = newVal + viewer.gcodeProcessor.updateForceWireMode(true) + this.reloadViewer() + } + get extruderColors() { return this.$store.state.gui.gcodeViewer?.extruderColors ?? false } diff --git a/src/locales/en.json b/src/locales/en.json index ebf3bda2a..58a43ff0d 100644 --- a/src/locales/en.json +++ b/src/locales/en.json @@ -254,7 +254,8 @@ "Transparency": "Transparency", "Ultra": "Ultra", "VoxelMode": "Voxel Mode (ASMBL)", - "ShowGCode": "Show G-Code" + "ShowGCode": "Show G-Code", + "CNCMode": "CNC Mode" }, "Heightmap": { "Abort": "abort", diff --git a/src/store/gui/index.ts b/src/store/gui/index.ts index d959655bc..8fe7c7e81 100644 --- a/src/store/gui/index.ts +++ b/src/store/gui/index.ts @@ -139,6 +139,7 @@ export const getDefaultState = (): GuiState => { axis_maximum: null, }, showGCodePanel: false, + cncMode: false, }, uiSettings: { logo: defaultLogoColor, diff --git a/src/store/gui/types.ts b/src/store/gui/types.ts index e53e93385..86c2fd8c9 100644 --- a/src/store/gui/types.ts +++ b/src/store/gui/types.ts @@ -87,6 +87,7 @@ export interface GuiState { axis_maximum: number[] | null } showGCodePanel: boolean + cncMode: boolean } macros?: GuiMacrosState notifications?: GuiNotificationState