/****************************************************************************** * Copyright (c)2012 Jan Rheinlaender * * * * 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 * * * ******************************************************************************/ #include "PreCompiled.h" #ifndef _PreComp_ # include # include #endif #include "ui_TaskPolarPatternParameters.h" #include "TaskPolarPatternParameters.h" #include "TaskMultiTransformParameters.h" #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace PartDesignGui; using namespace Gui; /* TRANSLATOR PartDesignGui::TaskPolarPatternParameters */ TaskPolarPatternParameters::TaskPolarPatternParameters(ViewProviderTransformed *TransformedView,QWidget *parent) : TaskTransformedParameters(TransformedView, parent) { // we need a separate container widget to add all controls to proxy = new QWidget(this); ui = new Ui_TaskPolarPatternParameters(); ui->setupUi(proxy); QMetaObject::connectSlotsByName(this); this->groupLayout()->addWidget(proxy); ui->buttonOK->hide(); ui->checkBoxUpdateView->setEnabled(true); referenceSelectionMode = false; blockUpdate = false; // Hack, sometimes it is NOT false although set to false in Transformed::Transformed()!! setupUI(); } TaskPolarPatternParameters::TaskPolarPatternParameters(TaskMultiTransformParameters *parentTask, QLayout *layout) : TaskTransformedParameters(parentTask) { proxy = new QWidget(parentTask); ui = new Ui_TaskPolarPatternParameters(); ui->setupUi(proxy); connect(ui->buttonOK, SIGNAL(pressed()), parentTask, SLOT(onSubTaskButtonOK())); QMetaObject::connectSlotsByName(this); layout->addWidget(proxy); ui->buttonOK->setEnabled(true); ui->labelOriginal->hide(); ui->lineOriginal->hide(); ui->checkBoxUpdateView->hide(); referenceSelectionMode = false; blockUpdate = false; // Hack, sometimes it is NOT false although set to false in Transformed::Transformed()!! setupUI(); } void TaskPolarPatternParameters::setupUI() { updateViewTimer = new QTimer(this); updateViewTimer->setSingleShot(true); updateViewTimer->setInterval(getUpdateViewTimeout()); connect(updateViewTimer, SIGNAL(timeout()), this, SLOT(onUpdateViewTimer())); connect(ui->comboAxis, SIGNAL(activated(int)), this, SLOT(onAxisChanged(int))); connect(ui->checkReverse, SIGNAL(toggled(bool)), this, SLOT(onCheckReverse(bool))); connect(ui->polarAngle, SIGNAL(valueChanged(double)), this, SLOT(onAngle(double))); connect(ui->spinOccurrences, SIGNAL(valueChanged(uint)), this, SLOT(onOccurrences(uint))); connect(ui->checkBoxUpdateView, SIGNAL(toggled(bool)), this, SLOT(onUpdateView(bool))); // Get the feature data PartDesign::PolarPattern* pcPolarPattern = static_cast(getObject()); std::vector originals = pcPolarPattern->Originals.getValues(); // Fill data into dialog elements ui->lineOriginal->setEnabled(false); for (std::vector::const_iterator i = originals.begin(); i != originals.end(); ++i) { if ((*i) != NULL) { // find the first valid original ui->lineOriginal->setText(QString::fromLatin1((*i)->getNameInDocument())); break; } } // --------------------- ui->polarAngle->bind(pcPolarPattern->Angle); ui->spinOccurrences->setMaximum(INT_MAX); ui->spinOccurrences->bind(pcPolarPattern->Occurrences); ui->comboAxis->setEnabled(true); ui->checkReverse->setEnabled(true); ui->polarAngle->setEnabled(true); ui->spinOccurrences->setEnabled(true); updateUI(); } void TaskPolarPatternParameters::updateUI() { if (blockUpdate) return; blockUpdate = true; PartDesign::PolarPattern* pcPolarPattern = static_cast(getObject()); App::DocumentObject* axisFeature = pcPolarPattern->Axis.getValue(); std::vector axes = pcPolarPattern->Axis.getSubValues(); bool reverse = pcPolarPattern->Reversed.getValue(); double angle = pcPolarPattern->Angle.getValue(); unsigned occurrences = pcPolarPattern->Occurrences.getValue(); for (int i=ui->comboAxis->count()-1; i >= 1; i--) ui->comboAxis->removeItem(i); if (axisFeature != NULL && !axes.empty()) { if (axes.front() == "N_Axis") ui->comboAxis->setCurrentIndex(0); else if (axisFeature != NULL && !axes.empty()) { ui->comboAxis->addItem(QString::fromLatin1(axes.front().c_str())); ui->comboAxis->setCurrentIndex(1); } } else { // Error message? } if (referenceSelectionMode) { ui->comboAxis->addItem(tr("Select an edge")); ui->comboAxis->setCurrentIndex(ui->comboAxis->count() - 1); } else ui->comboAxis->addItem(tr("Select reference...")); // Note: These three lines would trigger onLength(), on Occurrences() and another updateUI() if we // didn't check for blockUpdate ui->checkReverse->setChecked(reverse); ui->polarAngle->setValue(angle); ui->spinOccurrences->setValue(occurrences); blockUpdate = false; } void TaskPolarPatternParameters::onUpdateViewTimer() { recomputeFeature(); } void TaskPolarPatternParameters::kickUpdateViewTimer() const { updateViewTimer->start(); } void TaskPolarPatternParameters::onSelectionChanged(const Gui::SelectionChanges& msg) { if (msg.Type == Gui::SelectionChanges::AddSelection) { if (strcmp(msg.pDocName, getObject()->getDocument()->getName()) != 0) return; std::string subName(msg.pSubName); if (originalSelected(msg)) { ui->lineOriginal->setText(QString::fromLatin1(msg.pObjectName)); } else if (referenceSelectionMode && (subName.size() > 4 && subName.substr(0,4) == "Edge")) { if (strcmp(msg.pObjectName, getSupportObject()->getNameInDocument()) != 0) return; exitSelectionMode(); if (!blockUpdate) { PartDesign::PolarPattern* pcPolarPattern = static_cast(getObject()); std::vector axes(1,subName); pcPolarPattern->Axis.setValue(getSupportObject(), axes); recomputeFeature(); updateUI(); } else { for (int i=ui->comboAxis->count()-1; i >= 1; i--) ui->comboAxis->removeItem(i); ui->comboAxis->addItem(QString::fromLatin1(subName.c_str())); ui->comboAxis->setCurrentIndex(1); ui->comboAxis->addItem(tr("Select reference...")); } } } } void TaskPolarPatternParameters::onCheckReverse(const bool on) { if (blockUpdate) return; PartDesign::PolarPattern* pcPolarPattern = static_cast(getObject()); pcPolarPattern->Reversed.setValue(on); exitSelectionMode(); kickUpdateViewTimer(); } void TaskPolarPatternParameters::onAngle(const double a) { if (blockUpdate) return; PartDesign::PolarPattern* pcPolarPattern = static_cast(getObject()); pcPolarPattern->Angle.setValue(a); exitSelectionMode(); kickUpdateViewTimer(); } void TaskPolarPatternParameters::onOccurrences(const uint n) { if (blockUpdate) return; PartDesign::PolarPattern* pcPolarPattern = static_cast(getObject()); pcPolarPattern->Occurrences.setValue(n); exitSelectionMode(); kickUpdateViewTimer(); } void TaskPolarPatternParameters::onAxisChanged(int num) { if (blockUpdate) return; PartDesign::PolarPattern* pcPolarPattern = static_cast(getObject()); if (num == 0) { pcPolarPattern->Axis.setValue(getSketchObject(), std::vector(1,"N_Axis")); exitSelectionMode(); } else if (num == ui->comboAxis->count() - 1) { // enter reference selection mode hideObject(); showOriginals(); referenceSelectionMode = true; Gui::Selection().clearSelection(); addReferenceSelectionGate(true, false); } else if (num == 1) exitSelectionMode(); kickUpdateViewTimer(); } void TaskPolarPatternParameters::onUpdateView(bool on) { blockUpdate = !on; if (on) { // Do the same like in TaskDlgPolarPatternParameters::accept() but without doCommand PartDesign::PolarPattern* pcPolarPattern = static_cast(getObject()); std::string axis = getAxis(); if (!axis.empty()) { std::vector axes(1,axis); if (axis == "N_Axis") pcPolarPattern->Axis.setValue(getSketchObject(), axes); else pcPolarPattern->Axis.setValue(getSupportObject(), axes); } else pcPolarPattern->Axis.setValue(NULL); pcPolarPattern->Reversed.setValue(getReverse()); pcPolarPattern->Angle.setValue(getAngle()); pcPolarPattern->Occurrences.setValue(getOccurrences()); recomputeFeature(); } } const std::string TaskPolarPatternParameters::getAxis(void) const { if (ui->comboAxis->currentIndex() == 0) return "N_Axis"; else if (ui->comboAxis->count() > 2 && ui->comboAxis->currentIndex() == 1) return ui->comboAxis->currentText().toStdString(); return std::string(""); } const bool TaskPolarPatternParameters::getReverse(void) const { return ui->checkReverse->isChecked(); } const double TaskPolarPatternParameters::getAngle(void) const { return ui->polarAngle->value().getValue(); } const unsigned TaskPolarPatternParameters::getOccurrences(void) const { return ui->spinOccurrences->value(); } TaskPolarPatternParameters::~TaskPolarPatternParameters() { delete ui; if (proxy) delete proxy; } void TaskPolarPatternParameters::changeEvent(QEvent *e) { TaskBox::changeEvent(e); if (e->type() == QEvent::LanguageChange) { ui->retranslateUi(proxy); } } void TaskPolarPatternParameters::apply() { std::string name = TransformedView->getObject()->getNameInDocument(); std::string axis = getAxis(); if (!axis.empty()) { App::DocumentObject* sketch = 0; if (axis == "N_Axis") sketch = getSketchObject(); else sketch = getSupportObject(); if (sketch) { QString buf = QString::fromLatin1("(App.ActiveDocument.%1,[\"%2\"])"); buf = buf.arg(QString::fromLatin1(sketch->getNameInDocument())); buf = buf.arg(QString::fromLatin1(axis.c_str())); Gui::Command::doCommand(Gui::Command::Doc,"App.ActiveDocument.%s.Axis = %s", name.c_str(), buf.toStdString().c_str()); } } else Gui::Command::doCommand(Gui::Command::Doc,"App.ActiveDocument.%s.Axis = None", name.c_str()); Gui::Command::doCommand(Gui::Command::Doc,"App.ActiveDocument.%s.Reversed = %u",name.c_str(),getReverse()); ui->polarAngle->apply(); ui->spinOccurrences->apply(); Gui::Command::doCommand(Gui::Command::Doc,"App.ActiveDocument.recompute()"); if (!TransformedView->getObject()->isValid()) throw Base::Exception(TransformedView->getObject()->getStatusString()); Gui::Command::doCommand(Gui::Command::Gui,"Gui.activeDocument().resetEdit()"); Gui::Command::commitCommand(); } //************************************************************************** //************************************************************************** // TaskDialog //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ TaskDlgPolarPatternParameters::TaskDlgPolarPatternParameters(ViewProviderPolarPattern *PolarPatternView) : TaskDlgTransformedParameters(PolarPatternView) { parameter = new TaskPolarPatternParameters(PolarPatternView); Content.push_back(parameter); } //==== calls from the TaskView =============================================================== bool TaskDlgPolarPatternParameters::accept() { try { //Gui::Command::openCommand("PolarPattern changed"); // Handle Originals if (!TaskDlgTransformedParameters::accept()) return false; parameter->apply(); } catch (const Base::Exception& e) { QMessageBox::warning(parameter, tr("Input error"), QString::fromLatin1(e.what())); return false; } return true; } #include "moc_TaskPolarPatternParameters.cpp"