LinuxCNC Features - native realtime CAM for LinuxCNC - aka new NGCGUI
- Simple usage
-
You can use LinuxCNC Features in "stand alone" mode. It is almost the same except that the Features are not included into Axis window and just lays in a sepparate window. Everything else should work the same including preview in Axis!
To use LinuxCNC Features in stand alone mode, just start them after you have started LinuxCNC providing path to your LinuxCNC ini file in --ini parameter
Example: (in the directory with features.py)
./features.py --ini=/home/nick/linuxcnc/configs/sim/axis/axis_mm.ini
-
Install
-
Move everything to /usr/share/pyshared/gladevcp/ Or better create links there:
cd /usr/share/pyshared/gladevcp/ sudo ln /full-path-to-git-repository/features.py -s sudo ln /full-path-to-git-repository/features.glade -s sudo ln /full-path-to-git-repository/subroutines -s
-
Install python-lxml
sudo apt-get install python-lxml
-
Create links into /usr/lib/pymodules/python2.6/gladevcp
cd /usr/lib/pymodules/python2.6/gladevcp sudo ln /usr/share/pyshared/gladevcp/features.py -s sudo ln /usr/share/pyshared/gladevcp/features.glade -s sudo ln /usr/share/pyshared/gladevcp/subroutines -s
-
Change hal_pythonplugin.py in /usr/share/pyshared/gladevcp/hal_pythonplugin.py Add (find calculator add after :)):
from features import Features
-
Change hal_python.xml in /usr/share/glade3/catalogs glade3 can be glade2
Add (find first calculator add after :)):
<glade-widget-class name="Features" generic-name="features" title="features"> <properties> <property id="size" query="False" default="1" visible="False"/> <property id="spacing" query="False" default="0" visible="False"/> <property id="homogeneous" query="False" default="0" visible="False"/> </properties> </glade-widget-class>
Add (find second calculator add after :)):
<glade-widget-class-ref name="Features"/>
-
Translations: Make links in your system locale directories to translation files
cd /usr/share/locale/<<<YOUR LOCALE>>>/LC_MESSAGES sudo ln /<full path to features sourse>/locale/<<<YOUR LOCALE>>>/LC_MESSAGES/linuxcnc-features.mo -s
Example:
cd /usr/share/locale/ru/LC_MESSAGES sudo ln /home/nick/Design/cnc-club.ru/linuxcnc/features/locale/ru/LC_MESSAGES/linuxcnc-features.mo -s
-
Extending subroutines
-
Param subsitutions "#param_name" can be used to substitude parameters from the feature. "#self_id" - unique id made of feature Name + smallest integer id.
-
Eval and exec
<eval>"hello world!"</eval>
everything inside <eval> tag will be passed trought python's eval function.
<exec>print "hello world"</exec>
allmost the same but will take all printed data.
you can use self as feature's self.
-
Import
<import>filename<import>
will import file into feature text before proceccing.
-
Including Gcode G-code ngc files can be included by using one of the following functions:
<eval>self.include_once("rotate-xy.ngc")</eval> <eval>self.include("rotate-xy.ngc")</eval>
Some information on Russian can be obtained here: http://cnc-club.ru/forum/viewtopic.php?f=15&t=3124&p=72441#p72441