/*************************************************************************** * Copyright (c) 2011 Juergen Riegel * * * * This file is part of the FreeCAD CAx development system. * * * * This library is free software; you can redistribute it and/or * * modify it under the terms of the GNU Library General Public * * License as published by the Free Software Foundation; either * * version 2 of the License, or (at your option) any later version. * * * * This library is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU Library General Public License for more details. * * * * You should have received a copy of the GNU Library General Public * * License along with this library; see the file COPYING.LIB. If not, * * write to the Free Software Foundation, Inc., 59 Temple Place, * * Suite 330, Boston, MA 02111-1307, USA * * * ***************************************************************************/ #ifndef GUI_TASKVIEW_TaskRevolutionParameters_H #define GUI_TASKVIEW_TaskRevolutionParameters_H #include #include #include "TaskSketchBasedParameters.h" #include "ViewProviderRevolution.h" class Ui_TaskRevolutionParameters; namespace App { class Property; } namespace Gui { class ViewProvider; } namespace PartDesignGui { class TaskRevolutionParameters : public TaskSketchBasedParameters { Q_OBJECT public: explicit TaskRevolutionParameters(ViewProvider* RevolutionView, QWidget* parent = nullptr); ~TaskRevolutionParameters() override; void apply() override; /** * @brief fillAxisCombo fills the combo and selects the item according to * current value of revolution object's axis reference. * @param forceRefill if true, the combo box will be completely refilled. If * false, the current value of revolution object's axis will be added to the * list (if necessary), and selected. If the list is empty, it will be refilled anyway. */ void fillAxisCombo(bool forceRefill = false); void addAxisToCombo(App::DocumentObject *linkObj, std::string linkSubname, QString itemText); private Q_SLOTS: void onAngleChanged(double); void onAngle2Changed(double); void onAxisChanged(int); void onMidplane(bool); void onReversed(bool); void onModeChanged(int); void onButtonFace(const bool pressed = true); void onFaceName(const QString& text); protected: void onSelectionChanged(const Gui::SelectionChanges& msg) override; void changeEvent(QEvent *event) override; void getReferenceAxis(App::DocumentObject *&obj, std::vector &sub) const; bool getMidplane() const; bool getReversed() const; QString getFaceName() const; void setupDialog(void); void setCheckboxes(PartDesign::Revolution::RevolMethod mode); //mirrors of revolution's or groove's properties //should have been done by inheriting revolution and groove from common class... App::PropertyAngle* propAngle; App::PropertyAngle* propAngle2; App::PropertyBool* propReversed; App::PropertyBool* propMidPlane; App::PropertyLinkSub* propReferenceAxis; App::PropertyLinkSub* propUpToFace; private: void connectSignals(); void updateUI(int index); void translateModeList(int index); // TODO: This is common with extrude. Maybe send to superclass. void translateFaceName(); void clearFaceName(); private: std::unique_ptr ui; QWidget *proxy; bool selectionFace; bool isGroove; /** * @brief axesInList is the list of links corresponding to axis combo; must * be kept in sync with the combo. A special value of zero-pointer link is * for "Select axis" item. * * It is a list of pointers, because properties prohibit assignment. Use new * when adding stuff, and delete when removing stuff. */ std::vector> axesInList; }; /// simulation dialog for the TaskView class TaskDlgRevolutionParameters : public TaskDlgSketchBasedParameters { Q_OBJECT public: explicit TaskDlgRevolutionParameters(PartDesignGui::ViewProvider *RevolutionView); ViewProvider* getRevolutionView() const { return vp; } }; } //namespace PartDesignGui #endif // GUI_TASKVIEW_TASKAPPERANCE_H