Machsupport Forum
		Mach Discussion => Mach4 General Discussion => Topic started by: brianthechemist on January 08, 2023, 03:19:54 PM
		
			
			- 
				Hi guys
 
 I'm trying to incorporate some hard buttons into my machine to take over from GUI buttons.
 
 Is there a general way to execute the "actions" via siglib?  Some of the gui buttons have obvious scripts i can call, others have only these actions.
 
 One example is flood cooling.  The button properties list only "flood toggle".  How can I find the actual command that is triggered by this button? (so that I can copy it into the siglib for my corresponding hard button)
 
 I'm sure this is obvious but it is escaping me
- 
				Here's some of mine. PoKeys, but yours could be whatever pin.
 
 ----------Mach4 Input 17 PoKeys Pin 17-----
 ----------Toggle Coolant M8----------------
 [mc.ISIG_INPUT17] = function (state)
 if (state == 1) then
 local inst = mc.mcGetInstance();
 local sigh = mc.mcSignalGetHandle(inst, mc.OSIG_COOLANTON);
 local sigState = mc.mcSignalGetState(sigh);
 if (sigState == 0) then
 local OSigCool = mc.mcSignalGetHandle (inst,mc.OSIG_COOLANTON)
 mc.mcSignalSetState(OSigCool,1)
 mc.mcCntlSetLastError(inst, "Coolant On")
 else
 local OSigCool = mc.mcSignalGetHandle (inst,mc.OSIG_COOLANTON)
 mc.mcSignalSetState(OSigCool,0)
 mc.mcCntlSetLastError(inst, "Coolant Off")
 end
 end
 
 end,
 
 ----------Mach4 Input 14 PoKeys Pin 14--
 ----------Toggle Mist M7----------------
 [mc.ISIG_INPUT14] = function (state)
 if (state == 1) then
 local inst = mc.mcGetInstance();
 local sigh = mc.mcSignalGetHandle(inst, mc.OSIG_MISTON);
 local sigState = mc.mcSignalGetState(sigh);
 if (sigState == 0) then
 local OSigMist = mc.mcSignalGetHandle (inst,mc.OSIG_MISTON)
 mc.mcSignalSetState(OSigMist,1)
 mc.mcCntlSetLastError(inst, "Mist On")
 else
 local OSigMist = mc.mcSignalGetHandle (inst,mc.OSIG_MISTON)
 mc.mcSignalSetState(OSigMist,0)
 mc.mcCntlSetLastError(inst, "Mist Off")
 end
 end
 
 end,
 
 ------------Mach4 Input 8 PoKeys Pin 8----------------
 ------------Toggle SpinCW-----------------------------
 [mc.ISIG_INPUT8] = function (state)
 if (state == 1) then
 local inst = mc.mcGetInstance();
 local sigh = mc.mcSignalGetHandle(inst, mc.OSIG_SPINDLEON);
 local sigState = mc.mcSignalGetState(sigh);
 if (sigState == 1) then
 mc.mcSpindleSetDirection(inst, 0);
 else
 SpinCW()
 end
 end
 
 
 Might help!
 
 Tom
- 
				That's great!
 
 Thanks, I can't wait to try it.
- 
				Hi,
 
 Is there a general way to execute the "actions" via siglib?  Some of the gui buttons have obvious scripts i can call, others have only these actions.
 
 
 Some Mach elements have an 'Action' and others have a 'Script'.
 
 In general an Action is a bunch of code within Mach4 that performs a specific action. It is not viewable or editable. For example open the screen editor,
 select the Events tab, and inspect the actions available as a drop down menu when you select  say the GCodeLoad button, per the attached screenshot.
 
 Other items items, for instance the CycleStart button has a script rather than an action.......although note from the Events tab it could have either or both. If you wish to see
 the script the control to the right of the script will cause the script editor to open so you can view and in many cases edit the script.
 
 Thosj has posted some code that he has put into the SigLib table, and it looks like it would work fine.
 
 Note the the signal script triggers and runs whenever one of Machs many hundreds, both internal and external, of signal change state, which could happen many hundreds of times a second.
 For this reason it is recommended that you keep the SigLib table very lean and clean, and in this regard I would write the SigLib table entries more like this:
 
 [mc.ISIG_INPUT17]=function(state)
 if(state==1) then
 MyBloodyCoolantPumpON()
 else
 MyBloodyCoolantPumpOFF()
 end
 end,
 The two functions (MyBloodyCoolantPumpON() and MyBloodyCoolantPumpOFF()) are actually functions in the screen load script. This means that there is minimal code burden
 whenever the SigLIb table is called.
 
 Please be assured I never call a spade, just a 'spade' but always a 'Bloody Spade', its a matter of technical pride you understand! :D
 
 Craig
- 
				Ah yes, there is the distinction.  I found a workaround to use these actions by way of the scr commands.  They appear to work well but it feels kinda 'hackey' and not the right way.
 
 Is there a convenient way to have an "include" file or something in the screen script that will pull from a separate lua file of my creation? (for convenience, I'm thinking to modify the actual screen script as little as possible and put my code in one script if at all possible.)
 
 The process that the screen editor uses with temporary files is a bit buggy for my comfort.
- 
				Hi,
 
  I found a workaround to use these actions by way of the scr commands.  They appear to work well but it feels kinda 'hackey' and not the right way.
 
 
 Correct, I try to avoid scr commands. The correct way is to place an object, like a button, it does not have to be visible, but then you get the options of UpAction,
 DownAction, UpScrpit, DownScript, ClikedScript etc.
 
 Is there a convenient way to have an "include" file or something in the screen script that will pull from a separate lua file of my creation? 
 Yes you can write Lua modules or Lua Panels....I'm not really familiar with them Look up some of Daz-the-Gaz's videos.
 
  I'm thinking to modify the actual screen script as little as possible and put my code in one script if at all possible. 
 Why?. I modify the screen load script, PLC script and others all the time. That's what they are for, and they work a treat. Take a copy of your preferred screen script,
 wx4.set say, give it a unique name like Mywx4.set, and modify the hell out of it. When you update to the latest build the uniquely named .set file will survive the update
 unaltered so you can carry on using it.
 
 You are at the very least going to have to edit the SigLib table......so there is no avoiding editing the screen script. It does make sense to have all your edits gathered in one
 place, so I'll often put all my own coded functions at the end of the script, but inevitably you will have to make a few edits throughout the screen script which can be a pain
 to recall and trace. There is a function, if I recall correctly, which allows you to compare the differences between files and thereby locate any edits in one file compared to the
 standard issue .set file.
 
 Craig
- 
				Hi,
 
 https://www.machsupport.com/forum/index.php?topic=35007.0 (https://www.machsupport.com/forum/index.php?topic=35007.0)
 
 Craig
- 
				Hi,
 
  I found a workaround to use these actions by way of the scr commands.  They appear to work well but it feels kinda 'hackey' and not the right way.
 
 
 Correct, I try to avoid scr commands. The correct way is to place an object, like a button, it does not have to be visible, but then you get the options of UpAction,
 DownAction, UpScrpit, DownScript, ClikedScript etc.
 
 
 hmm, i'm not sure how this would work.  to be clear: I want to have an input from siglib execute an action that is identical to a gui button (that isn't a script).  In some cases, it is a momentary switch that I'd like to actually  toggle the state of the button on the screen (the ones that light up when activated).
 
 how do I have the invisible button on the screen be activated by the siglib input? (it seems like the same problem I started with)...  I'm obviously missing something.
 
 thanks for your patience!!
 brian
 
 
- 
				Hi,
 place a toggle button on screen and look at its properties. You'll see that it can be logically connected with an input signal and/or an output signal.
 But note also that on the events tab you have the regular collection of scripts and/or actions. Thus the toggle button can be triggered by an external
 input and that can in turn trigger an event or action.
 
 Craig
- 
				Hi,
 as an added bonus you don't actually need an entry in the SigLib table to have an input trigger a toggle button.
 
 Craig
- 
				Beautiful!
 
 Can the new toggle interact with the existing gui buttons? (as in if I activate the soft limits via this mechanism will the soft limits indicator on the GUI light up green?)
- 
				Hi,
 
  I found a workaround to use these actions by way of the scr commands.  They appear to work well but it feels kinda 'hackey' and not the right way.
 
 
 Correct, I try to avoid scr commands. The correct way is to place an object, like a button, it does not have to be visible, but then you get the options of UpAction,
 DownAction, UpScrpit, DownScript, ClikedScript etc.
 
 Is there a convenient way to have an "include" file or something in the screen script that will pull from a separate lua file of my creation? 
 Yes you can write Lua modules or Lua Panels....I'm not really familiar with them Look up some of Daz-the-Gaz's videos.
 
  I'm thinking to modify the actual screen script as little as possible and put my code in one script if at all possible. 
 Why?. I modify the screen load script, PLC script and others all the time. That's what they are for, and they work a treat. Take a copy of your preferred screen script,
 wx4.set say, give it a unique name like Mywx4.set, and modify the hell out of it. When you update to the latest build the uniquely named .set file will survive the update
 unaltered so you can carry on using it.
 
 You are at the very least going to have to edit the SigLib table......so there is no avoiding editing the screen script. It does make sense to have all your edits gathered in one
 place, so I'll often put all my own coded functions at the end of the script, but inevitably you will have to make a few edits throughout the screen script which can be a pain
 to recall and trace. There is a function, if I recall correctly, which allows you to compare the differences between files and thereby locate any edits in one file compared to the
 standard issue .set file.
 
 Craig
 
 
 Do you usually edit the xml file directly (within the .set file)?  I'm looking for something I can use in a different editor while looking at the current wx screen for reference.   I've got 'visual studio code' which I like because it is close enough to visual studio for me.
- 
				Hi,
 
  (as in if I activate the soft limits via this mechanism will the soft limits indicator on the GUI light up green?) 
 I don't know, its not something that I have tried but yes I believe you can code that.
 
 Do you usually edit the xml file directly (within the .set file)?  I'm looking for something I can use in a different editor while looking at the current wx screen for reference.   I've got 'visual studio code' which I like because it is close enough to visual studio for me. 
 
 
 No, I edit the screen with the screen editor provided, after all that's what it's for. The visual representation of the screen while the editor is active
 is perfectly adequate for the purpose. Mach4 is not a software development environment, it is a CNC software solution, ie a Gcode interpreter and
 trajectory planner. It does have an editable GUI and a fair API and scripting language which allows users to adapt Mach4 to their machine.
 Those extra tools (GUI editor and Lua scripting) are useful but they do not in themselves 'make chips', Mach4's primary purpose.
 
 If you need an ultimately flexible solution then I'd suggest LinuxCNC, its a solution that rewards software developers whereas Mach4 rewards
 machine builders/integrators to produce working machines but does not require software developer skills.
 
 Craig
- 
				Haha, absolutely! I’ll admit that i have the mechanicals of my machine complete and have been procrastinating the sw config because of the learning curve.  
 
 I’m just trying to learn the best practices for sure!
- 
				Hi,
 my suggestion is use Mach4Hobby as is....don't worry about programming any frilly bits, just use the program and start making parts.
 I suspect you'll find as I have that standard Mach4 is pretty much complete as is....you don't really need anything else. There are plenty of things
 that you might like to change, for example your idea of using a joystick for jogging. Yes it can be done, but lack of its not stopping you from using
 the program as is.
 
 There is nothing like making parts to inform you of those things that you need as opposed to want.
 
 I, in the early days, had quite a bit of custom code in my profile but over the years its shrunk, to the extent I have only a few macros related to specific work that
 I do, isolation routed PCBs in particular. All the rest of them have faded away because I just don't use them.
 
 Craig
- 
				Makes sense.
 
 I'm partly using the buttons as an easy way to get to know the custom stuff, as I will need to implement the tool changer control and the remaining 2 axes (although I don't think there is much to do for the AC axes, I may find myself editing existing scripts to work with the additional axes.
 
 I actually have another CNC that I already retrofitted with Mach4 (and all of the same electronics as for my 5 axis) as a test of my architecture and to make some parts for my scratchbuilt machine.  Luckily for me, I've actually had a great experience with it except for a few annoying buttons that I was hoping to implement with the console buttons here.
 
 I'm a little confused about the states on the toggle buttons.  Do you know of a reference to read for me?  for example, how can a toggle be mapped to both an input and an output in the properties tab?  Is it an "and" or is it "or" between them?
 
 Thanks!
 
 
- 
				Hi,
 
 for example, how can a toggle be mapped to both an input and an output in the properties tab?  Is it an "and" or is it "or" between them?
 
 The state of toggle switch is toggled  by an external input. Click the external button and the on screen toggle switch will toggle. The output is driven by the logical state
 of the internal toggle switch. For instance you might have a external button to turn a coolant pump on or off and use one of Machs outputs to illuminate the external button
 when the pump is energized.
 
 Simple expedient here is to try it.....half an hour experimenting with assigning inputs and or outputs, along with various actions and/or scripts and it will be clear.
 
 Craig