diff --git a/src/Mod/Fem/Gui/Resources/ui/ElementFluid1D.ui b/src/Mod/Fem/Gui/Resources/ui/ElementFluid1D.ui
index 674eeb10d8..7c12b9a646 100644
--- a/src/Mod/Fem/Gui/Resources/ui/ElementFluid1D.ui
+++ b/src/Mod/Fem/Gui/Resources/ui/ElementFluid1D.ui
@@ -806,6 +806,19 @@
+ -
+
+
+ Qt::Vertical
+
+
+
+ 20
+ 40
+
+
+
+
@@ -838,43 +851,6 @@
- -
-
-
- References
-
-
-
-
-
-
- Select an edge, click Add or Remove
-
-
-
- -
-
-
-
-
-
- Add
-
-
-
- -
-
-
- Remove
-
-
-
-
-
- -
-
-
-
-
-
diff --git a/src/Mod/Fem/femguiobjects/_ViewProviderFemElementFluid1D.py b/src/Mod/Fem/femguiobjects/_ViewProviderFemElementFluid1D.py
index aa01b74496..8a929582e5 100644
--- a/src/Mod/Fem/femguiobjects/_ViewProviderFemElementFluid1D.py
+++ b/src/Mod/Fem/femguiobjects/_ViewProviderFemElementFluid1D.py
@@ -1,7 +1,8 @@
# ***************************************************************************
# * *
# * Copyright (c) 2016 - Ofentse Kgoa *
-# * Based on the FemElementGeometry1D by Bernd Hahnebach *
+# * Based on the FemElementGeometry1D by Bernd Hahnebach *
+# * Copyright (c) 2018 - Bernd Hahnebach *
# * *
# * This program is free software; you can redistribute it and/or modify *
# * it under the terms of the GNU Lesser General Public License (LGPL) *
@@ -22,7 +23,7 @@
# ***************************************************************************
__title__ = "_ViewProviderFemElementFluid1D"
-__author__ = "Ofentse Kgoa"
+__author__ = "Ofentse Kgoa, Bernd Hahnebach"
__url__ = "http://www.freecadweb.org"
## @package ViewProviderFemElementFluid1D
@@ -37,6 +38,7 @@ False if False else FemGui.__name__ # dummy usage of FemGui for flake8, just re
from femobjects import _FemElementFluid1D
from PySide import QtCore
from PySide import QtGui
+from . import FemSelectionWidgets
class _ViewProviderFemElementFluid1D:
@@ -105,78 +107,75 @@ class _TaskPanelFemElementFluid1D:
'''The TaskPanel for editing References property of FemElementFluid1D objects'''
def __init__(self, obj):
- FreeCADGui.Selection.clearSelection()
- self.sel_server = None
+
+ # parameter widget
self.obj = obj
- self.obj_notvisible = []
-
- self.form = FreeCADGui.PySideUic.loadUi(FreeCAD.getHomePath() + "Mod/Fem/Resources/ui/ElementFluid1D.ui")
- QtCore.QObject.connect(self.form.btn_add, QtCore.SIGNAL("clicked()"), self.add_references)
- QtCore.QObject.connect(self.form.btn_remove, QtCore.SIGNAL("clicked()"), self.remove_selected_reference)
- QtCore.QObject.connect(self.form.cb_section_type, QtCore.SIGNAL("activated(int)"), self.sectiontype_changed)
- QtCore.QObject.connect(self.form.cb_liquid_section_type, QtCore.SIGNAL("activated(int)"), self.liquidsectiontype_changed)
- QtCore.QObject.connect(self.form.if_manning_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.manning_area_changed)
- QtCore.QObject.connect(self.form.if_manning_radius, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.manning_radius_changed)
- QtCore.QObject.connect(self.form.sb_manning_coefficient, QtCore.SIGNAL("valueChanged(double)"), self.manning_coefficient_changed)
- QtCore.QObject.connect(self.form.if_enlarge_area1, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.enlarge_area1_changed)
- QtCore.QObject.connect(self.form.if_enlarge_area2, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.enlarge_area2_changed)
- QtCore.QObject.connect(self.form.if_contract_area1, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.contract_area1_changed)
- QtCore.QObject.connect(self.form.if_contract_area2, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.contract_area2_changed)
- QtCore.QObject.connect(self.form.if_inletpressure, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.inlet_pressure_changed)
- QtCore.QObject.connect(self.form.if_outletpressure, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.outlet_pressure_changed)
- QtCore.QObject.connect(self.form.if_inletflowrate, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.inlet_flowrate_changed)
- QtCore.QObject.connect(self.form.if_outletflowrate, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.outlet_flowrate_changed)
- QtCore.QObject.connect(self.form.gb_inletpressure, QtCore.SIGNAL("clicked(bool)"), self.inlet_pressure_active)
- QtCore.QObject.connect(self.form.gb_outletpressure, QtCore.SIGNAL("clicked(bool)"), self.outlet_pressure_active)
- QtCore.QObject.connect(self.form.gb_inletflowrate, QtCore.SIGNAL("clicked(bool)"), self.inlet_flowrate_active)
- QtCore.QObject.connect(self.form.gb_outletflowrate, QtCore.SIGNAL("clicked(bool)"), self.outlet_flowrate_active)
- QtCore.QObject.connect(self.form.if_entrance_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.entrance_pipe_area_changed)
- QtCore.QObject.connect(self.form.if_entrance_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.entrance_area_changed)
- QtCore.QObject.connect(self.form.if_diaphragm_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.diaphragm_pipe_area_changed)
- QtCore.QObject.connect(self.form.if_diaphragm_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.diaphragm_area_changed)
- QtCore.QObject.connect(self.form.if_bend_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.bend_pipe_area_changed)
- QtCore.QObject.connect(self.form.sb_bradius_pdiameter, QtCore.SIGNAL("valueChanged(double)"), self.bradius_pdiameter_changed)
- QtCore.QObject.connect(self.form.sb_bend_angle, QtCore.SIGNAL("valueChanged(double)"), self.bend_angle_changed)
- QtCore.QObject.connect(self.form.sb_bend_loss_coefficient, QtCore.SIGNAL("valueChanged(double)"), self.bend_loss_coefficient_changed)
- QtCore.QObject.connect(self.form.if_gatevalve_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.gatevalve_pipe_area_changed)
- QtCore.QObject.connect(self.form.sb_gatevalve_closing_coeff, QtCore.SIGNAL("valueChanged(double)"), self.gatevalve_closing_coeff_changed)
- QtCore.QObject.connect(self.form.if_colebrooke_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.colebrooke_pipe_area_changed)
- QtCore.QObject.connect(self.form.if_colebrooke_radius, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.colebrooke_radius_changed)
- QtCore.QObject.connect(self.form.if_colebrooke_grain_diameter, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.colebrooke_grain_diameter_changed)
- QtCore.QObject.connect(self.form.sb_colebrooke_form_factor, QtCore.SIGNAL("valueChanged(double)"), self.colebrooke_form_factor_changed)
- QtCore.QObject.connect(self.form.tw_pump_characteristics, QtCore.SIGNAL("cellChanged(int, int)"), self.pump_characteristics_changed)
- self.form.list_References.itemSelectionChanged.connect(self.select_clicked_reference_shape)
- self.form.list_References.setContextMenuPolicy(QtCore.Qt.CustomContextMenu)
- self.form.list_References.connect(self.form.list_References, QtCore.SIGNAL("customContextMenuRequested(QPoint)"), self.references_list_right_clicked)
- self.form.cb_section_type.addItems(_FemElementFluid1D._FemElementFluid1D.known_fluid_types)
- self.form.cb_liquid_section_type.addItems(_FemElementFluid1D._FemElementFluid1D.known_liquid_types)
- self.form.cb_gas_section_type.addItems(_FemElementFluid1D._FemElementFluid1D.known_gas_types)
- self.form.cb_channel_section_type.addItems(_FemElementFluid1D._FemElementFluid1D.known_channel_types)
-
+ self.parameterWidget = FreeCADGui.PySideUic.loadUi(FreeCAD.getHomePath() + "Mod/Fem/Resources/ui/ElementFluid1D.ui")
+ QtCore.QObject.connect(self.parameterWidget.cb_section_type, QtCore.SIGNAL("activated(int)"), self.sectiontype_changed)
+ QtCore.QObject.connect(self.parameterWidget.cb_liquid_section_type, QtCore.SIGNAL("activated(int)"), self.liquidsectiontype_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_manning_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.manning_area_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_manning_radius, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.manning_radius_changed)
+ QtCore.QObject.connect(self.parameterWidget.sb_manning_coefficient, QtCore.SIGNAL("valueChanged(double)"), self.manning_coefficient_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_enlarge_area1, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.enlarge_area1_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_enlarge_area2, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.enlarge_area2_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_contract_area1, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.contract_area1_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_contract_area2, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.contract_area2_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_inletpressure, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.inlet_pressure_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_outletpressure, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.outlet_pressure_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_inletflowrate, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.inlet_flowrate_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_outletflowrate, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.outlet_flowrate_changed)
+ QtCore.QObject.connect(self.parameterWidget.gb_inletpressure, QtCore.SIGNAL("clicked(bool)"), self.inlet_pressure_active)
+ QtCore.QObject.connect(self.parameterWidget.gb_outletpressure, QtCore.SIGNAL("clicked(bool)"), self.outlet_pressure_active)
+ QtCore.QObject.connect(self.parameterWidget.gb_inletflowrate, QtCore.SIGNAL("clicked(bool)"), self.inlet_flowrate_active)
+ QtCore.QObject.connect(self.parameterWidget.gb_outletflowrate, QtCore.SIGNAL("clicked(bool)"), self.outlet_flowrate_active)
+ QtCore.QObject.connect(self.parameterWidget.if_entrance_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.entrance_pipe_area_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_entrance_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.entrance_area_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_diaphragm_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.diaphragm_pipe_area_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_diaphragm_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.diaphragm_area_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_bend_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.bend_pipe_area_changed)
+ QtCore.QObject.connect(self.parameterWidget.sb_bradius_pdiameter, QtCore.SIGNAL("valueChanged(double)"), self.bradius_pdiameter_changed)
+ QtCore.QObject.connect(self.parameterWidget.sb_bend_angle, QtCore.SIGNAL("valueChanged(double)"), self.bend_angle_changed)
+ QtCore.QObject.connect(self.parameterWidget.sb_bend_loss_coefficient, QtCore.SIGNAL("valueChanged(double)"), self.bend_loss_coefficient_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_gatevalve_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.gatevalve_pipe_area_changed)
+ QtCore.QObject.connect(self.parameterWidget.sb_gatevalve_closing_coeff, QtCore.SIGNAL("valueChanged(double)"), self.gatevalve_closing_coeff_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_colebrooke_pipe_area, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.colebrooke_pipe_area_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_colebrooke_radius, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.colebrooke_radius_changed)
+ QtCore.QObject.connect(self.parameterWidget.if_colebrooke_grain_diameter, QtCore.SIGNAL("valueChanged(Base::Quantity)"), self.colebrooke_grain_diameter_changed)
+ QtCore.QObject.connect(self.parameterWidget.sb_colebrooke_form_factor, QtCore.SIGNAL("valueChanged(double)"), self.colebrooke_form_factor_changed)
+ QtCore.QObject.connect(self.parameterWidget.tw_pump_characteristics, QtCore.SIGNAL("cellChanged(int, int)"), self.pump_characteristics_changed)
+ self.parameterWidget.cb_section_type.addItems(_FemElementFluid1D._FemElementFluid1D.known_fluid_types)
+ self.parameterWidget.cb_liquid_section_type.addItems(_FemElementFluid1D._FemElementFluid1D.known_liquid_types)
+ self.parameterWidget.cb_gas_section_type.addItems(_FemElementFluid1D._FemElementFluid1D.known_gas_types)
+ self.parameterWidget.cb_channel_section_type.addItems(_FemElementFluid1D._FemElementFluid1D.known_channel_types)
self.get_fluidsection_props()
- self.update()
+ self.updateParameterWidget()
+
+ # geometry selection widget
+ self.selectionWidget = FemSelectionWidgets.GeometryElementsSelection(obj.References, ['Edge'])
+
+ # form made from param and selection widget
+ self.form = [self.parameterWidget, self.selectionWidget]
def accept(self):
- self.setback_listobj_visibility()
self.set_fluidsection_props()
+ self.obj.References = self.selectionWidget.references
if self.sel_server:
FreeCADGui.Selection.removeObserver(self.sel_server)
- FreeCADGui.ActiveDocument.resetEdit()
FreeCAD.ActiveDocument.recompute()
+ self.set_back_all()
return True
def reject(self):
- self.setback_listobj_visibility()
- if self.sel_server:
- FreeCADGui.Selection.removeObserver(self.sel_server)
- FreeCADGui.ActiveDocument.resetEdit()
+ self.set_back_all()
return True
+ def set_back_all(self):
+ self.selectionWidget.setback_listobj_visibility()
+ if self.selectionWidget.sel_server:
+ FreeCADGui.Selection.removeObserver(self.selectionWidget.sel_server)
+ FreeCADGui.ActiveDocument.resetEdit()
+
def get_fluidsection_props(self):
- self.references = []
- if self.obj.References:
- self.tuplereferences = self.obj.References
- self.get_references()
self.SectionType = self.obj.SectionType
self.LiquidSectionType = self.obj.LiquidSectionType
self.ManningArea = self.obj.ManningArea
@@ -212,7 +211,6 @@ class _TaskPanelFemElementFluid1D:
self.PumpHeadLoss = self.obj.PumpHeadLoss
def set_fluidsection_props(self):
- self.obj.References = self.references
self.obj.LiquidSectionType = self.LiquidSectionType
self.obj.SectionType = self.SectionType
self.obj.ManningArea = self.ManningArea
@@ -247,61 +245,60 @@ class _TaskPanelFemElementFluid1D:
self.obj.PumpFlowRate = self.PumpFlowRate
self.obj.PumpHeadLoss = self.PumpHeadLoss
- def update(self):
+ def updateParameterWidget(self):
'fills the widgets'
- index_sectiontype = self.form.cb_section_type.findText(self.SectionType)
- self.form.cb_section_type.setCurrentIndex(index_sectiontype)
- self.form.sw_section_type.setCurrentIndex(index_sectiontype)
- index_liquidsectiontype = self.form.cb_liquid_section_type.findText(self.LiquidSectionType)
- self.form.cb_liquid_section_type.setCurrentIndex(index_liquidsectiontype)
- self.form.sw_liquid_section_type.setCurrentIndex(index_liquidsectiontype)
- self.form.if_manning_area.setText(self.ManningArea.UserString)
- self.form.if_manning_radius.setText(self.ManningRadius.UserString)
- self.form.sb_manning_coefficient.setValue(self.ManningCoefficient)
- self.form.if_enlarge_area1.setText(self.EnlargeArea1.UserString)
- self.form.if_enlarge_area2.setText(self.EnlargeArea2.UserString)
- self.form.if_contract_area1.setText(self.ContractArea1.UserString)
- self.form.if_contract_area2.setText(self.ContractArea2.UserString)
- self.form.if_inletpressure.setText(FreeCAD.Units.Quantity(1000 * self.InletPressure, FreeCAD.Units.Pressure).UserString)
- self.form.if_outletpressure.setText(FreeCAD.Units.Quantity(1000 * self.OutletPressure, FreeCAD.Units.Pressure).UserString)
- self.form.if_inletflowrate.setText(str(self.InletFlowRate))
- self.form.if_outletflowrate.setText(str(self.OutletFlowRate))
- self.form.gb_inletpressure.setChecked(self.InletPressureActive)
- self.form.gb_outletpressure.setChecked(self.OutletPressureActive)
- self.form.gb_inletflowrate.setChecked(self.InletFlowRateActive)
- self.form.gb_outletflowrate.setChecked(self.OutletFlowRateActive)
- self.form.if_entrance_pipe_area.setText(self.EntrancePipeArea.UserString)
- self.form.if_entrance_area.setText(self.EntranceArea.UserString)
- self.form.if_diaphragm_pipe_area.setText(self.DiaphragmPipeArea.UserString)
- self.form.if_diaphragm_area.setText(self.DiaphragmArea.UserString)
- self.form.if_bend_pipe_area.setText(self.BendPipeArea.UserString)
- self.form.sb_bradius_pdiameter.setValue(self.BendRadiusDiameter)
- self.form.sb_bend_angle.setValue(self.BendAngle)
- self.form.sb_bend_loss_coefficient.setValue(self.BendLossCoefficient)
- self.form.if_gatevalve_pipe_area.setText(self.GateValvePipeArea.UserString)
- self.form.sb_gatevalve_closing_coeff.setValue(self.GateValveClosingCoeff)
- self.form.if_colebrooke_pipe_area.setText(self.ColebrookeArea.UserString)
- self.form.if_colebrooke_radius.setText(self.ColebrookeRadius.UserString)
- self.form.if_colebrooke_grain_diameter.setText(self.ColebrookeGrainDiameter.UserString)
- self.form.sb_colebrooke_form_factor.setValue(self.ColebrookeFormFactor)
+ index_sectiontype = self.parameterWidget.cb_section_type.findText(self.SectionType)
+ self.parameterWidget.cb_section_type.setCurrentIndex(index_sectiontype)
+ self.parameterWidget.sw_section_type.setCurrentIndex(index_sectiontype)
+ index_liquidsectiontype = self.parameterWidget.cb_liquid_section_type.findText(self.LiquidSectionType)
+ self.parameterWidget.cb_liquid_section_type.setCurrentIndex(index_liquidsectiontype)
+ self.parameterWidget.sw_liquid_section_type.setCurrentIndex(index_liquidsectiontype)
+ self.parameterWidget.if_manning_area.setText(self.ManningArea.UserString)
+ self.parameterWidget.if_manning_radius.setText(self.ManningRadius.UserString)
+ self.parameterWidget.sb_manning_coefficient.setValue(self.ManningCoefficient)
+ self.parameterWidget.if_enlarge_area1.setText(self.EnlargeArea1.UserString)
+ self.parameterWidget.if_enlarge_area2.setText(self.EnlargeArea2.UserString)
+ self.parameterWidget.if_contract_area1.setText(self.ContractArea1.UserString)
+ self.parameterWidget.if_contract_area2.setText(self.ContractArea2.UserString)
+ self.parameterWidget.if_inletpressure.setText(FreeCAD.Units.Quantity(1000 * self.InletPressure, FreeCAD.Units.Pressure).UserString)
+ self.parameterWidget.if_outletpressure.setText(FreeCAD.Units.Quantity(1000 * self.OutletPressure, FreeCAD.Units.Pressure).UserString)
+ self.parameterWidget.if_inletflowrate.setText(str(self.InletFlowRate))
+ self.parameterWidget.if_outletflowrate.setText(str(self.OutletFlowRate))
+ self.parameterWidget.gb_inletpressure.setChecked(self.InletPressureActive)
+ self.parameterWidget.gb_outletpressure.setChecked(self.OutletPressureActive)
+ self.parameterWidget.gb_inletflowrate.setChecked(self.InletFlowRateActive)
+ self.parameterWidget.gb_outletflowrate.setChecked(self.OutletFlowRateActive)
+ self.parameterWidget.if_entrance_pipe_area.setText(self.EntrancePipeArea.UserString)
+ self.parameterWidget.if_entrance_area.setText(self.EntranceArea.UserString)
+ self.parameterWidget.if_diaphragm_pipe_area.setText(self.DiaphragmPipeArea.UserString)
+ self.parameterWidget.if_diaphragm_area.setText(self.DiaphragmArea.UserString)
+ self.parameterWidget.if_bend_pipe_area.setText(self.BendPipeArea.UserString)
+ self.parameterWidget.sb_bradius_pdiameter.setValue(self.BendRadiusDiameter)
+ self.parameterWidget.sb_bend_angle.setValue(self.BendAngle)
+ self.parameterWidget.sb_bend_loss_coefficient.setValue(self.BendLossCoefficient)
+ self.parameterWidget.if_gatevalve_pipe_area.setText(self.GateValvePipeArea.UserString)
+ self.parameterWidget.sb_gatevalve_closing_coeff.setValue(self.GateValveClosingCoeff)
+ self.parameterWidget.if_colebrooke_pipe_area.setText(self.ColebrookeArea.UserString)
+ self.parameterWidget.if_colebrooke_radius.setText(self.ColebrookeRadius.UserString)
+ self.parameterWidget.if_colebrooke_grain_diameter.setText(self.ColebrookeGrainDiameter.UserString)
+ self.parameterWidget.sb_colebrooke_form_factor.setValue(self.ColebrookeFormFactor)
for i in range(len(self.PumpFlowRate)):
- self.form.tw_pump_characteristics.setItem(i, 0, QtGui.QTableWidgetItem(str(self.PumpFlowRate[i])))
- self.form.tw_pump_characteristics.setItem(i, 1, QtGui.QTableWidgetItem(str(self.PumpHeadLoss[i])))
- self.rebuild_list_References()
+ self.parameterWidget.tw_pump_characteristics.setItem(i, 0, QtGui.QTableWidgetItem(str(self.PumpFlowRate[i])))
+ self.parameterWidget.tw_pump_characteristics.setItem(i, 1, QtGui.QTableWidgetItem(str(self.PumpHeadLoss[i])))
def sectiontype_changed(self, index):
if index < 0:
return
- self.form.cb_section_type.setCurrentIndex(index)
- self.form.sw_section_type.setCurrentIndex(index)
- self.SectionType = str(self.form.cb_section_type.itemText(index)) # form returns unicode
+ self.parameterWidget.cb_section_type.setCurrentIndex(index)
+ self.parameterWidget.sw_section_type.setCurrentIndex(index)
+ self.SectionType = str(self.parameterWidget.cb_section_type.itemText(index)) # parameterWidget returns unicode
def liquidsectiontype_changed(self, index):
if index < 0:
return
- self.form.cb_liquid_section_type.setCurrentIndex(index)
- self.form.sw_liquid_section_type.setCurrentIndex(index)
- self.LiquidSectionType = str(self.form.cb_liquid_section_type.itemText(index)) # form returns unicode
+ self.parameterWidget.cb_liquid_section_type.setCurrentIndex(index)
+ self.parameterWidget.sw_liquid_section_type.setCurrentIndex(index)
+ self.LiquidSectionType = str(self.parameterWidget.cb_liquid_section_type.itemText(index)) # parameterWidget returns unicode
def manning_area_changed(self, base_quantity_value):
self.ManningArea = base_quantity_value
@@ -392,105 +389,6 @@ class _TaskPanelFemElementFluid1D:
def pump_characteristics_changed(self, row, column):
if column == 0:
- self.PumpFlowRate[row] = float(self.form.tw_pump_characteristics.item(row, column).text())
+ self.PumpFlowRate[row] = float(self.parameterWidget.tw_pump_characteristics.item(row, column).text())
else:
- self.PumpHeadLoss[row] = float(self.form.tw_pump_characteristics.item(row, column).text())
-
- def get_references(self):
- for ref in self.tuplereferences:
- for elem in ref[1]:
- self.references.append((ref[0], elem))
-
- def references_list_right_clicked(self, QPos):
- self.form.contextMenu = QtGui.QMenu()
- menu_item_remove_selected = self.form.contextMenu.addAction("Remove selected reference")
- menu_item_remove_all = self.form.contextMenu.addAction("Remove all references")
- if not self.references:
- menu_item_remove_selected.setDisabled(True)
- menu_item_remove_all.setDisabled(True)
- self.form.connect(menu_item_remove_selected, QtCore.SIGNAL("triggered()"), self.remove_selected_reference)
- self.form.connect(menu_item_remove_all, QtCore.SIGNAL("triggered()"), self.remove_all_references)
- parentPosition = self.form.list_References.mapToGlobal(QtCore.QPoint(0, 0))
- self.form.contextMenu.move(parentPosition + QPos)
- self.form.contextMenu.show()
-
- def remove_selected_reference(self):
- if not self.references:
- return
- currentItemName = str(self.form.list_References.currentItem().text())
- currentRow = self.form.list_References.currentRow()
- for ref in self.references:
- refname_to_compare_listentry = ref[0].Name + ':' + ref[1]
- if refname_to_compare_listentry == currentItemName:
- self.references.remove(ref)
- self.rebuild_list_References(currentRow)
-
- def remove_all_references(self):
- self.references = []
- self.rebuild_list_References()
-
- def add_references(self):
- '''Called if Button add_reference is triggered'''
- # in constraints EditTaskPanel the selection is active as soon as the taskpanel is open
- # here the addReference button EditTaskPanel has to be triggered to start selection mode
- self.setback_listobj_visibility()
- FreeCADGui.Selection.clearSelection()
- # start SelectionObserver and parse the function to add the References to the widget
- print_message = "Select Edges by single click on them to add them to the list"
- if not self.sel_server:
- # if we do not check, we would start a new SelectionObserver on every click on addReference button
- # but close only one SelectionObserver on leaving the task panel
- from . import FemSelectionObserver
- self.sel_server = FemSelectionObserver.FemSelectionObserver(self.selectionParser, print_message)
-
- def selectionParser(self, selection):
- # print('selection: ', selection[0].Shape.ShapeType, ' ', selection[0].Name, ' ', selection[1])
- if hasattr(selection[0], "Shape"):
- if selection[1]:
- elt = selection[0].Shape.getElement(selection[1])
- if elt.ShapeType == 'Edge':
- if selection not in self.references:
- self.references.append(selection)
- self.rebuild_list_References()
- else:
- FreeCAD.Console.PrintMessage(selection[0].Name + ' --> ' + selection[1] + ' is in reference list already!\n')
-
- def rebuild_list_References(self, current_row=0):
- self.form.list_References.clear()
- items = []
- for ref in self.references:
- item_name = ref[0].Name + ':' + ref[1]
- items.append(item_name)
- for listItemName in sorted(items):
- self.form.list_References.addItem(listItemName)
- if current_row > self.form.list_References.count() - 1: # first row is 0
- current_row = self.form.list_References.count() - 1
- if self.form.list_References.count() > 0:
- self.form.list_References.setCurrentItem(self.form.list_References.item(current_row))
-
- def select_clicked_reference_shape(self):
- self.setback_listobj_visibility()
- if self.sel_server:
- FreeCADGui.Selection.removeObserver(self.sel_server)
- self.sel_server = None
- if not self.sel_server:
- if not self.references:
- return
- currentItemName = str(self.form.list_References.currentItem().text())
- for ref in self.references:
- refname_to_compare_listentry = ref[0].Name + ':' + ref[1]
- if refname_to_compare_listentry == currentItemName:
- # print('found: shape: ' + ref[0].Name + ' element: ' + ref[1])
- if not ref[0].ViewObject.Visibility:
- self.obj_notvisible.append(ref[0])
- ref[0].ViewObject.Visibility = True
- FreeCADGui.Selection.clearSelection()
- FreeCADGui.Selection.addSelection(ref[0], ref[1])
-
- def setback_listobj_visibility(self):
- '''set back Visibility of the list objects
- '''
- FreeCADGui.Selection.clearSelection()
- for obj in self.obj_notvisible:
- obj.ViewObject.Visibility = False
- self.obj_notvisible = []
+ self.PumpHeadLoss[row] = float(self.parameterWidget.tw_pump_characteristics.item(row, column).text())