Commit 05142340 authored by sumpfralle's avatar sumpfralle

r695@erker: lars | 2010-02-19 04:37:38 +0100

 enable the "material allowance" control only if ODE and the DropCutter is enabled (the others need to be implemented)


git-svn-id: https://pycam.svn.sourceforge.net/svnroot/pycam/trunk@149 bbaffbd6-741e-11dd-a85d-61de82d9cad9
parent 5c936925
...@@ -328,14 +328,19 @@ class ProjectGui: ...@@ -328,14 +328,19 @@ class ProjectGui:
("enable_ode", "SettingEnableODE")): ("enable_ode", "SettingEnableODE")):
obj = self.gui.get_object(objname) obj = self.gui.get_object(objname)
self.settings.add_item(name, obj.get_active, obj.set_active) self.settings.add_item(name, obj.get_active, obj.set_active)
# all of the objects above should trigger redraw
if name != "enable_ode":
obj.connect("toggled", self.update_view) obj.connect("toggled", self.update_view)
# set the availability of ODE # set the availability of ODE
if GuiCommon.is_ode_available(): if GuiCommon.is_ode_available():
self.settings.set("enable_ode", True) self.settings.set("enable_ode", True)
self.gui.get_object("SettingEnableODE").set_sensitive(True) self.gui.get_object("SettingEnableODE").set_sensitive(True)
self.gui.get_object("MaterialAllowanceControl").set_sensitive(True)
else: else:
self.settings.set("enable_ode", False) self.settings.set("enable_ode", False)
self.gui.get_object("SettingEnableODE").set_sensitive(False) self.gui.get_object("SettingEnableODE").set_sensitive(False)
# TODO: remove this as soon as non-ODE toolpath generation respects material allowance
self.gui.get_object("MaterialAllowanceControl").set_sensitive(False)
# preconfigure some values # preconfigure some values
self.settings.set("show_model", True) self.settings.set("show_model", True)
self.settings.set("show_toolpath", True) self.settings.set("show_toolpath", True)
...@@ -380,7 +385,7 @@ class ProjectGui: ...@@ -380,7 +385,7 @@ class ProjectGui:
# connect the "consistency check" with all toolpath settings # connect the "consistency check" with all toolpath settings
for objname in ("PathAccumulator", "SimpleCutter", "ZigZagCutter", "PolygonCutter", "ContourCutter", for objname in ("PathAccumulator", "SimpleCutter", "ZigZagCutter", "PolygonCutter", "ContourCutter",
"DropCutter", "PushCutter", "SphericalCutter", "CylindricalCutter", "ToroidalCutter", "DropCutter", "PushCutter", "SphericalCutter", "CylindricalCutter", "ToroidalCutter",
"PathDirectionX", "PathDirectionY", "PathDirectionXY"): "PathDirectionX", "PathDirectionY", "PathDirectionXY", "SettingEnableODE"):
self.gui.get_object(objname).connect("toggled", self.disable_invalid_toolpath_settings) self.gui.get_object(objname).connect("toggled", self.disable_invalid_toolpath_settings)
# load a processing configuration object # load a processing configuration object
self.processing_settings = pycam.Gui.Settings.ProcessingSettings(self.settings) self.processing_settings = pycam.Gui.Settings.ProcessingSettings(self.settings)
...@@ -452,6 +457,12 @@ class ProjectGui: ...@@ -452,6 +457,12 @@ class ProjectGui:
self.gui.get_object("TorusRadiusControl").set_sensitive(self.settings.get("cutter_shape") == "ToroidalCutter") self.gui.get_object("TorusRadiusControl").set_sensitive(self.settings.get("cutter_shape") == "ToroidalCutter")
# disable "step down" control, if PushCutter is not active # disable "step down" control, if PushCutter is not active
self.gui.get_object("MaxStepDownControl").set_sensitive(self.settings.get("path_generator") == "PushCutter") self.gui.get_object("MaxStepDownControl").set_sensitive(self.settings.get("path_generator") == "PushCutter")
# TODO: remove this as soon as the PushCutter supports "material allowance"
if self.settings.get("enable_ode", True):
self.gui.get_object("MaterialAllowanceControl").set_sensitive(self.settings.get("path_generator") == "DropCutter")
else:
self.gui.get_object("MaterialAllowanceControl").set_sensitive(False)
@gui_activity_guard @gui_activity_guard
def toggle_3d_view(self, widget=None, value=None): def toggle_3d_view(self, widget=None, value=None):
......
...@@ -1706,6 +1706,10 @@ Only available for the Push Cutter.</property> ...@@ -1706,6 +1706,10 @@ Only available for the Push Cutter.</property>
<object class="GtkSpinButton" id="MaterialAllowanceControl"> <object class="GtkSpinButton" id="MaterialAllowanceControl">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="tooltip_text" translatable="yes">Specify the amount of material that should remain around the model.
This is useful for rough and semi-finish operations.
ODE support is currently required for this feature.
For now only the Drop Cutter respects this value.</property>
<property name="invisible_char">&#x2022;</property> <property name="invisible_char">&#x2022;</property>
<property name="adjustment">MaterialAllowanceValue</property> <property name="adjustment">MaterialAllowanceValue</property>
<property name="digits">2</property> <property name="digits">2</property>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment