diff --git a/CNC Controls Probing/CNC Controls Probing/HeightMapControl.xaml b/CNC Controls Probing/CNC Controls Probing/HeightMapControl.xaml index d658e3bd..d5a68c2f 100644 --- a/CNC Controls Probing/CNC Controls Probing/HeightMapControl.xaml +++ b/CNC Controls Probing/CNC Controls Probing/HeightMapControl.xaml @@ -13,6 +13,7 @@ A rapid motion to X0Y0 will be performed before probing the height map starts.\nEnsure the initial Z-position is clear of any obstacles that might be encountered during probing. Probing failed Probing completed: Z min: {0}, Z max: {1}. + Probing point {0} of {1}... diff --git a/CNC Controls Probing/CNC Controls Probing/HeightMapControl.xaml.cs b/CNC Controls Probing/CNC Controls Probing/HeightMapControl.xaml.cs index c5bb8280..001865be 100644 --- a/CNC Controls Probing/CNC Controls Probing/HeightMapControl.xaml.cs +++ b/CNC Controls Probing/CNC Controls Probing/HeightMapControl.xaml.cs @@ -1,7 +1,7 @@ /* * HeightMapControl.xaml.cs - part of CNC Probing library * - * v0.42 / 2023-03-22 / Io Engineering (Terje Io) + * v0.44 / 2023-10-01 / Io Engineering (Terje Io) * */ @@ -110,10 +110,15 @@ public void Start(bool preview = false) probing.HeightMap.GridSizeX = probing.HeightMap.Map.GridX; probing.HeightMap.GridSizeY = probing.HeightMap.Map.GridY; + int point = 0, points = probing.HeightMap.Map.SizeX * probing.HeightMap.Map.SizeX; + string pointOf = ((string)FindResource("ProbingPointOf")); + for (x = 0; x < probing.HeightMap.Map.SizeX; x++) { for (y = 0; y < probing.HeightMap.Map.SizeY; y++) { + probing.Program.AddMessage(string.Format(pointOf, ++point, points)); + if (probing.HeightMap.AddPause && (x > 0 || y > 0)) probing.Program.AddPause(); probing.Program.AddProbingAction(AxisFlags.Z, true); @@ -184,7 +189,7 @@ private void OnCompleted() // double z = probing.HeightMap.Map.InterpolateZ(0d, 0d); if (probing.HeightMap.SetToolOffset && - (ok = (probing.Positions[0].X == origin.X && probing.Positions[0].Y == origin.Y) || probing.Program.ProbeZ(0d, 0d))) + (ok = /* (probing.Positions[0].X == origin.X && probing.Positions[0].Y == origin.Y) || */ probing.Program.ProbeZ(0d, 0d))) { probing.HeightMap.Map.ZOffset = Z0 - probing.Positions[0].Z; // vs Z above, add check for allowed delta? diff --git a/CNC Controls Probing/CNC Controls Probing/LibStrings.xaml b/CNC Controls Probing/CNC Controls Probing/LibStrings.xaml index d9f1926b..cf8be125 100644 --- a/CNC Controls Probing/CNC Controls Probing/LibStrings.xaml +++ b/CNC Controls Probing/CNC Controls Probing/LibStrings.xaml @@ -17,4 +17,5 @@ Illegal probe position, try again. Probe connection was not verified, continue anyway? Press [Start] again to start probing. + Probing @X0Y0... \ No newline at end of file diff --git a/CNC Controls Probing/CNC Controls Probing/ProbingView.xaml.cs b/CNC Controls Probing/CNC Controls Probing/ProbingView.xaml.cs index 8093195e..3f212480 100644 --- a/CNC Controls Probing/CNC Controls Probing/ProbingView.xaml.cs +++ b/CNC Controls Probing/CNC Controls Probing/ProbingView.xaml.cs @@ -1,7 +1,7 @@ /* * ProbingView.xaml.cs - part of CNC Probing library * - * v0.43 / 2023-07-25 / Io Engineering (Terje Io) + * v0.44 / 2023-08-26 / Io Engineering (Terje Io) * */ @@ -324,18 +324,18 @@ public void Setup(UIViewModel model, AppConfig profile) private void mnu_Click(object sender, RoutedEventArgs e) { - switch ((string)((MenuItem)sender).Header) + switch ((string)((MenuItem)sender).Name) { - case "Add": + case "mnuAdd": cbxProfile.SelectedValue = profiles.Add(cbxProfile.Text, model); break; - case "Update": + case "mnuUpdate": if(model.Profile != null) profiles.Update(model.Profile.Id, cbxProfile.Text, model); break; - case "Delete": + case "mnuDelete": if (model.Profile != null && profiles.Delete(model.Profile.Id)) cbxProfile.SelectedValue = profiles.Profiles[0].Id; break; diff --git a/CNC Controls Probing/CNC Controls Probing/ProbingViewModel.cs b/CNC Controls Probing/CNC Controls Probing/ProbingViewModel.cs index 736dbc04..1b47d7b0 100644 --- a/CNC Controls Probing/CNC Controls Probing/ProbingViewModel.cs +++ b/CNC Controls Probing/CNC Controls Probing/ProbingViewModel.cs @@ -1,7 +1,7 @@ /* * ProbingViewModel.cs - part of CNC Probing library * - * v0.43 / 2023-06-30 / Io Engineering (Terje Io) + * v0.44 / 2023-10-01 / Io Engineering (Terje Io) * */ @@ -171,9 +171,6 @@ public bool WaitForResponse(string command) { bool? res = null; - if (Grbl.ResponseLogVerbose) - Grbl.ResponseLog.Add(command); - var t = new Thread(() => { res = WaitFor.AckResponse( diff --git a/CNC Controls Probing/CNC Controls Probing/Program.cs b/CNC Controls Probing/CNC Controls Probing/Program.cs index f1ea9713..ef258057 100644 --- a/CNC Controls Probing/CNC Controls Probing/Program.cs +++ b/CNC Controls Probing/CNC Controls Probing/Program.cs @@ -1,7 +1,7 @@ /* * Program.cs - part of CNC Probing library * - * v0.42 / 2023-03-22 / Io Engineering (Terje Io) + * v0.44 / 2023-10-01 / Io Engineering (Terje Io) * */ @@ -308,6 +308,11 @@ public void AddProbingAction(AxisFlags axis, bool negative) } } + public void AddMessage(string msg) + { + _program.Add("#" + msg); + } + public void AddSimulatedProbe(int p) { probing.IsSuccess = true; @@ -415,8 +420,7 @@ public bool Execute(bool go) if (response == "ok") { - step++; - if (step < _program.Count) + if (++step < _program.Count) { int i; //if ((i = _program[step].IndexOf('$')) > 0) @@ -426,6 +430,13 @@ public bool Execute(bool go) // double val = _positions[_positions.Count - 1].Values[i] + dbl.Parse(_program[step].Substring(i, 3)); // _program[step] = _program[step] + val.ToInvariantString(); //} + if (_program[step].StartsWith("#")) + { + Grbl.Message = _program[step].Substring(1); + if (++step == _program.Count) + break; + } + if (_program[step].StartsWith("!")) { isProbing = false; @@ -475,6 +486,7 @@ public bool ProbeZ(double x, double y) return false; probing.Program.AddRapid(string.Format("G90X{0}Y{0}", x.ToInvariantString(probing.Grbl.Format), y.ToInvariantString(probing.Grbl.Format))); + probing.Program.AddMessage(LibStrings.FindResource("ProbingAtX0Y0")); probing.Program.Add(string.Format("G91F{0}", probing.ProbeFeedRate.ToInvariantString())); probing.Program.AddProbingAction(AxisFlags.Z, true); diff --git a/CNC Controls/CNC Controls/AppConfig.cs b/CNC Controls/CNC Controls/AppConfig.cs index 1ec067be..063bd643 100644 --- a/CNC Controls/CNC Controls/AppConfig.cs +++ b/CNC Controls/CNC Controls/AppConfig.cs @@ -711,7 +711,7 @@ public RestartResult Restart () { if (MessageBox.Show(LibStrings.FindResource("MsgEStopExit"), "ioSender", MessageBoxButton.YesNo, MessageBoxImage.Question) == MessageBoxResult.Yes) return RestartResult.Close; - }; + } } else AttemptReset(); @@ -725,6 +725,17 @@ public RestartResult Restart () else Message = LibStrings.FindResource("MsgHome"); break; + + case 17: // Motor fault + if (!(GrblInfo.IsGrblHAL && model.Signals.Value.HasFlag(Signals.MotorFault))) + { + AttemptReset(); + if (!GrblInfo.IsLoaded) + model.ExecuteCommand(GrblConstants.CMD_UNLOCK); + } + break; + + } break; diff --git a/CNC Controls/CNC Controls/GCodeListControl.xaml b/CNC Controls/CNC Controls/GCodeListControl.xaml index 6528ee75..2d16b7d2 100644 --- a/CNC Controls/CNC Controls/GCodeListControl.xaml +++ b/CNC Controls/CNC Controls/GCodeListControl.xaml @@ -8,11 +8,19 @@ d:DesignHeight="335" d:DesignWidth="400" Loaded="UserControl_Loaded"> + CanUserSortColumns="false" CanUserResizeRows="False" IsReadOnly="true" SelectionChanged="grdGCode_SelectionChanged" + DragEnter="grdGCode_Drag" DragOver="grdGCode_Drag" DragLeave="grdGCode_Drag" Drop="grdGCode_Drop"> + + + + + + + diff --git a/CNC Controls/CNC Controls/GCodeListControl.xaml.cs b/CNC Controls/CNC Controls/GCodeListControl.xaml.cs index e879fbfd..af88e4b0 100644 --- a/CNC Controls/CNC Controls/GCodeListControl.xaml.cs +++ b/CNC Controls/CNC Controls/GCodeListControl.xaml.cs @@ -1,18 +1,47 @@ -using CNC.Core; -using System; -using System.Collections.Generic; -using System.Linq; -using System.Text; -using System.Threading.Tasks; +/* + * GcodeListControl.xaml.cs - part of CNC Controls library for Grbl + * + * v0.44 / 2023-10-07 / Io Engineering (Terje Io) + * + */ + +/* + +Copyright (c) 2020-2023, Io Engineering (Terje Io) +All rights reserved. + +Redistribution and use in source and binary forms, with or without modification, +are permitted provided that the following conditions are met: + +· Redistributions of source code must retain the above copyright notice, this +list of conditions and the following disclaimer. + +· Redistributions in binary form must reproduce the above copyright notice, this +list of conditions and the following disclaimer in the documentation and/or +other materials provided with the distribution. + +· Neither the name of the copyright holder nor the names of its contributors may +be used to endorse or promote products derived from this software without +specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR +ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON +ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +*/ + +using System.Data; using System.Windows; using System.Windows.Controls; -using System.Windows.Data; -using System.Windows.Documents; -using System.Windows.Input; -using System.Windows.Media; -using System.Windows.Media.Imaging; -using System.Windows.Navigation; -using System.Windows.Shapes; +using System.Collections.Generic; +using CNC.Core; namespace CNC.Controls { @@ -22,12 +51,31 @@ namespace CNC.Controls public partial class GCodeListControl : UserControl { public ScrollViewer scroll = null; - + public GCodeListControl() { InitializeComponent(); + ctxMenu.DataContext = this; } + + #region Dependency properties + + public static readonly DependencyProperty SingleSelectedProperty = DependencyProperty.Register(nameof(SingleSelected), typeof(bool), typeof(GCodeListControl), new PropertyMetadata(false)); + public bool SingleSelected + { + get { return (bool)GetValue(SingleSelectedProperty); } + private set { SetValue(SingleSelectedProperty, value); } + } + + public static readonly DependencyProperty MultipleSelectedProperty = DependencyProperty.Register(nameof(MultipleSelected), typeof(bool), typeof(GCodeListControl), new PropertyMetadata(false)); + public bool MultipleSelected + { + get { return (bool)GetValue(MultipleSelectedProperty); } + private set { SetValue(MultipleSelectedProperty, value); } + } + #endregion + private void grdGCode_Drag(object sender, DragEventArgs e) { GCode.File.Drag(sender, e); @@ -59,5 +107,58 @@ private void GCodeListControl_PropertyChanged(object sender, System.ComponentMod break; } } + + void grdGCode_SelectionChanged(object sender, SelectionChangedEventArgs e) + { + SingleSelected = grdGCode.SelectedItems.Count == 1 && (DataContext as GrblViewModel).StartFromBlock.CanExecute(grdGCode.SelectedIndex); + MultipleSelected = grdGCode.SelectedItems.Count >= 0 && (DataContext as GrblViewModel).StartFromBlock.CanExecute(grdGCode.SelectedIndex); + } + + private void StartHere_Click(object sender, RoutedEventArgs e) + { + if (grdGCode.SelectedItems.Count == 1 && + MessageBox.Show(string.Format(LibStrings.FindResource("VerifyStartFrom"), ((DataRowView)(grdGCode.SelectedItems[0])).Row["LineNum"]), + "ioSender", MessageBoxButton.YesNo, MessageBoxImage.Question, MessageBoxResult.No) == MessageBoxResult.Yes) + { + (DataContext as GrblViewModel).StartFromBlock.Execute(grdGCode.SelectedIndex); + } + } + + private void CopyMDI_Click(object sender, RoutedEventArgs e) + { + if (grdGCode.SelectedItems.Count == 1) + (DataContext as GrblViewModel).MDIText = (string)((DataRowView)(grdGCode.SelectedItems[0])).Row["Data"]; + } + + private void SendController_Click(object sender, RoutedEventArgs e) + { + if (grdGCode.SelectedItems.Count >= 1 && + MessageBox.Show(LibStrings.FindResource("VerifySendController"), "ioSender", + MessageBoxButton.YesNo, MessageBoxImage.Question, MessageBoxResult.No) == MessageBoxResult.Yes) + { + var model = DataContext as GrblViewModel; + + if (model.GrblError != 0) + model.ExecuteCommand(""); + + List rows = new List(); + + for (int i = 0; i < grdGCode.SelectedItems.Count; i++) + rows.Add(((DataRowView)(grdGCode.SelectedItems[i])).Row); + + rows.Sort(new RowComparer()); + + foreach (DataRow row in rows) + model.ExecuteCommand((string)row["Data"]); + } + } + } + + internal class RowComparer : IComparer + { + public int Compare(DataRow a, DataRow b) + { + return (int)a["LineNum"] - (int)b["LineNum"]; + } } } diff --git a/CNC Controls/CNC Controls/GrblConfigView.xaml b/CNC Controls/CNC Controls/GrblConfigView.xaml index fe94054b..5f500d68 100644 --- a/CNC Controls/CNC Controls/GrblConfigView.xaml +++ b/CNC Controls/CNC Controls/GrblConfigView.xaml @@ -17,6 +17,8 @@ Bummer...\nContinue loading? The file does not contain any settings. Restore settings from file + + +