Skip to content
Snippets Groups Projects
CompoundForm.cpp 3.55 KiB
Newer Older
  • Learn to ignore specific revisions
  • //  ************************************************************************************************
    //
    //  BornAgain: simulate and fit reflection and scattering
    //
    
    //! @file      GUI/View/Sample/CompoundForm.cpp
    
    //! @brief     Implements class CompoundForm.
    
    //!
    //! @homepage  http://www.bornagainproject.org
    //! @license   GNU General Public License v3 or higher (see COPYING)
    //! @copyright Forschungszentrum Jülich GmbH 2021
    //! @authors   Scientific Computing Group at MLZ (see CITATION, AUTHORS)
    //
    //  ************************************************************************************************
    
    
    #include "GUI/View/Sample/CompoundForm.h"
    
    #include "GUI/Model/Sample/CompoundItem.h"
    
    #include "GUI/View/Sample/HeinzFormLayout.h"
    #include "GUI/View/Sample/LayerEditorUtil.h"
    
    #include "GUI/View/Tool/ActionFactory.h"
    
    #include <QAction>
    #include <QPushButton>
    
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
    CompoundForm::CompoundForm(QWidget* parent, CompoundItem* compoundItem, SampleEditorController* ec,
                               bool allowRemove)
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
        : CollapsibleGroupBox("Compound", parent, compoundItem->expandCompound)
    
        , m_layout(new HeinzFormLayout(ec))
    
        , m_composition_item(compoundItem)
    
    Wuttke, Joachim's avatar
    Wuttke, Joachim committed
        body()->setLayout(m_layout);
    
        m_layout->setContentsMargins(30, 6, 0, 0);
    
    Wuttke, Joachim's avatar
    Wuttke, Joachim committed
        m_layout->addVector(compoundItem->position(), false);
        m_layout->addSelection(compoundItem->rotationSelection());
        m_layout->addValue(compoundItem->abundance());
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
        for (auto* particle : compoundItem->itemsWithParticles())
    
    Wuttke, Joachim's avatar
    Wuttke, Joachim committed
            m_layout->addRow(
    
    Wuttke, Joachim's avatar
    Wuttke, Joachim committed
                GUI::Util::Layer::createWidgetForItemWithParticles(this, particle, false, ec));
    
    Wuttke, Joachim's avatar
    Wuttke, Joachim committed
        auto* btn = GUI::Util::Layer::createAddParticleButton(
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
            this, [=](FormFactorItemCatalog::Type type) { ec->addCompoundItem(compoundItem, type); },
    
            [=](ParticlesCatalog::Type type) { ec->addCompoundItem(compoundItem, type); });
    
        m_structure_editing_widgets << btn;
    
    Wuttke, Joachim's avatar
    Wuttke, Joachim committed
        m_layout->addStructureEditingRow(btn);
    
        // top right corner actions
        // show in real space
        {
            auto* showInRealspaceAction = ActionFactory::createShowInRealspaceAction(
                this, "particle composition",
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
                [ec, compoundItem] { ec->requestViewInRealspace(compoundItem); });
    
            addTitleAction(showInRealspaceAction);
    
        }
        // duplicate
        {
    
            m_duplicate_action =
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
                ActionFactory::createDuplicateAction(this, "particle composition", [ec, compoundItem] {
                    ec->duplicateItemWithParticles(compoundItem);
                });
    
            addTitleAction(m_duplicate_action);
    
        }
        // remove
        {
    
            m_remove_action = ActionFactory::createRemoveAction(
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
                this, "particle composition", [ec, compoundItem] { ec->removeParticle(compoundItem); });
    
            if (allowRemove)
    
                addTitleAction(m_remove_action);
    
    void CompoundForm::onParticleAdded(ItemWithParticles* item)
    
        int index = m_composition_item->itemsWithParticles().indexOf(item);
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
        const int rowInLayout = m_layout->rowCount() - 1
    
                                - (m_composition_item->itemsWithParticles().size() - 1)
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
                                + index; // -1: btn
    
    Wuttke, Joachim's avatar
    Wuttke, Joachim committed
        m_layout->insertRow(
            rowInLayout, GUI::Util::Layer::createWidgetForItemWithParticles(this, item, false, m_ec));
    
    void CompoundForm::onAboutToRemoveParticle(ItemWithParticles* item)
    
        int index = m_composition_item->itemsWithParticles().indexOf(item);
        const int rowInLayout = m_layout->rowCount() - m_composition_item->itemsWithParticles().size()
    
    Mikhail Svechnikov's avatar
    Mikhail Svechnikov committed
                                - 1 + index; // -1: btn