VESPERSEXAFSScanConfigurationView::VESPERSEXAFSScanConfigurationView(VESPERSEXAFSScanConfiguration *config, QWidget *parent) : VESPERSScanConfigurationView(parent) { config_ = config; AMTopFrame *frame = new AMTopFrame("VESPERS EXAFS Configuration"); // Regions setup regionsView_ = new AMRegionsView(config_->regions()); regionsView_->setMinimumWidth(300); regionsLineView_ = new AMEXAFSLineView(config_->exafsRegions()); // The fluorescence detector setup QGroupBox *fluorescenceDetectorGroupBox = addFluorescenceDetectorSelectionView(); connect(fluorescenceButtonGroup_, SIGNAL(buttonClicked(int)), this, SLOT(onFluorescenceChoiceChanged(int))); connect(config_->dbObject(), SIGNAL(fluorescenceDetectorChanged(int)), this, SLOT(updateFluorescenceDetector(int))); fluorescenceButtonGroup_->button((int)config_->fluorescenceDetector())->setChecked(true); // Ion chamber selection QGroupBox *ItGroupBox = addItSelectionView(); connect(ItGroup_, SIGNAL(buttonClicked(int)), this, SLOT(onItClicked(int))); connect(config_->dbObject(), SIGNAL(transmissionChoiceChanged(int)), this, SLOT(updateItButtons(int))); QGroupBox *I0GroupBox = addI0SelectionView(); connect(I0Group_, SIGNAL(buttonClicked(int)), this, SLOT(onI0Clicked(int))); connect(config_->dbObject(), SIGNAL(incomingChoiceChanged(int)), this, SLOT(updateI0Buttons(int))); I0Group_->button((int)config_->incomingChoice())->click(); ItGroup_->button((int)config_->transmissionChoice())->click(); QHBoxLayout *ionChambersLayout = new QHBoxLayout; ionChambersLayout->addWidget(I0GroupBox); ionChambersLayout->addWidget(ItGroupBox); // Scan name selection scanName_ = addScanNameView(config_->name()); connect(scanName_, SIGNAL(editingFinished()), this, SLOT(onScanNameEdited())); connect(config_, SIGNAL(nameChanged(QString)), scanName_, SLOT(setText(QString))); onScanNameEdited(); QFormLayout *scanNameLayout = new QFormLayout; scanNameLayout->addRow("Scan Name:", scanName_); // Energy (Eo) selection energy_ = new QDoubleSpinBox; energy_->setSuffix(" eV"); energy_->setMinimum(0); energy_->setMaximum(30000); connect(energy_, SIGNAL(editingFinished()), this, SLOT(setEnergy())); elementChoice_ = new QToolButton; connect(elementChoice_, SIGNAL(clicked()), this, SLOT(onElementChoiceClicked())); lineChoice_ = new QComboBox; connect(lineChoice_, SIGNAL(currentIndexChanged(int)), this, SLOT(onLinesComboBoxIndexChanged(int))); if (config_->edge().isEmpty()){ elementChoice_->setText("Cu"); fillLinesComboBox(AMPeriodicTable::table()->elementBySymbol("Cu")); lineChoice_->setCurrentIndex(0); } // Resets the view for the view to what it should be. Using the saved for the energy in case it is different from the original line energy. else onEdgeChanged(); connect(config_, SIGNAL(edgeChanged(QString)), this, SLOT(onEdgeChanged())); QCheckBox *useFixedTime = new QCheckBox("Use fixed time (EXAFS)"); useFixedTime->setEnabled(config_->useFixedTime()); connect(config_->exafsRegions(), SIGNAL(regionsHaveKSpaceChanged(bool)), useFixedTime, SLOT(setEnabled(bool))); connect(useFixedTime, SIGNAL(toggled(bool)), config_, SLOT(setUseFixedTime(bool))); QSpinBox *numberOfScans = new QSpinBox; numberOfScans->setMinimum(1); numberOfScans->setValue(config_->numberOfScans()); numberOfScans->setAlignment(Qt::AlignCenter); connect(numberOfScans, SIGNAL(valueChanged(int)), config_, SLOT(setNumberOfScans(int))); connect(config_, SIGNAL(numberOfScansChanged(int)), this, SLOT(onEstimatedTimeChanged())); QFormLayout *numberOfScansLayout = new QFormLayout; numberOfScansLayout->addRow("Number of Scans:", numberOfScans); QFormLayout *energySetpointLayout = new QFormLayout; energySetpointLayout->addRow("Energy:", energy_); QHBoxLayout *energyLayout = new QHBoxLayout; energyLayout->addLayout(energySetpointLayout); energyLayout->addWidget(elementChoice_); energyLayout->addWidget(lineChoice_); // Setting the scan position. QGroupBox *goToPositionGroupBox = addGoToPositionView(config_->goToPosition(), config_->x(), config_->y()); connect(config_, SIGNAL(gotoPositionChanged(bool)), goToPositionCheckBox_, SLOT(setChecked(bool))); connect(goToPositionCheckBox_, SIGNAL(toggled(bool)), config_, SLOT(setGoToPosition(bool))); connect(goToPositionCheckBox_, SIGNAL(toggled(bool)), setCurrentPositionButton_, SLOT(setEnabled(bool))); connect(goToPositionCheckBox_, SIGNAL(toggled(bool)), savedXPosition_, SLOT(setEnabled(bool))); connect(goToPositionCheckBox_, SIGNAL(toggled(bool)), savedYPosition_, SLOT(setEnabled(bool))); connect(goToPositionCheckBox_, SIGNAL(toggled(bool)), positionsSaved_, SLOT(setEnabled(bool))); connect(setCurrentPositionButton_, SIGNAL(clicked()), this, SLOT(setScanPosition())); setSampleStage(VESPERSBeamline::vespers()->experimentConfiguration()->sampleStageChoice()); // The estimated scan time. estimatedTime_ = new QLabel; estimatedSetTime_ = new QLabel; connect(config_, SIGNAL(totalTimeChanged(double)), this, SLOT(onEstimatedTimeChanged())); onEstimatedTimeChanged(); // The roi text edit. roiText_ = new QTextEdit; roiText_->setReadOnly(true); QPushButton *configureXRFDetectorButton = new QPushButton(QIcon(":/hammer-wrench.png"), "Configure XRF Detector"); connect(configureXRFDetectorButton, SIGNAL(clicked()), this, SLOT(onConfigureXRFDetectorClicked())); QFormLayout *roiTextLayout = new QFormLayout; roiTextLayout->addRow(roiText_); roiTextLayout->addRow(configureXRFDetectorButton); roiTextBox_ = new QGroupBox("Regions Of Interest"); roiTextBox_->setLayout(roiTextLayout); roiTextBox_->setVisible(config_->fluorescenceDetector() == VESPERS::NoXRF ? false : true); // Label showing where the data will be saved. QLabel *exportPath = addExportPathLabel(); // Label with a help message for EXAFS. QLabel *helpMessage = new QLabel("Note when using EXAFS: when using variable integration time, the time column is the maximum time."); // Default XANES and EXAFS buttons. QPushButton *defaultXANESButton = new QPushButton("Default XANES"); connect(defaultXANESButton, SIGNAL(clicked()), this, SLOT(onDefaultXANESScanClicked())); QPushButton *defaultEXAFSButton = new QPushButton("Default EXAFS"); connect(defaultEXAFSButton, SIGNAL(clicked()), this, SLOT(onDefaultEXAFSScanClicked())); // Setting up the steps to show the time offset for scan time estimation. connect(this, SIGNAL(customContextMenuRequested(QPoint)), this, SLOT(onCustomContextMenuRequested(QPoint))); setContextMenuPolicy(Qt::CustomContextMenu); QGroupBox *timeOffsetBox = addTimeOffsetLabel(config_->timeOffset()); connect(timeOffset_, SIGNAL(valueChanged(double)), this, SLOT(setTimeOffset(double))); QVBoxLayout *defaultLayout = new QVBoxLayout; defaultLayout->addSpacing(35); defaultLayout->addWidget(defaultXANESButton); defaultLayout->addWidget(defaultEXAFSButton); defaultLayout->addStretch(); // Auto-export option. QGroupBox *autoExportGroupBox = addExporterOptionsView(QStringList(), config_->exportSpectraSources()); connect(autoExportSpectra_, SIGNAL(toggled(bool)), config_, SLOT(setExportSpectraSources(bool))); // Setting up the layout. QGridLayout *contentsLayout = new QGridLayout; contentsLayout->addWidget(regionsView_, 1, 1, 2, 2); contentsLayout->addWidget(fluorescenceDetectorGroupBox, 1, 3); contentsLayout->addLayout(scanNameLayout, 4, 1); contentsLayout->addLayout(energyLayout, 0, 1, 1, 3); contentsLayout->addWidget(goToPositionGroupBox, 4, 3, 4, 1); contentsLayout->addLayout(ionChambersLayout, 2, 3, 2, 1); contentsLayout->addWidget(roiTextBox_, 1, 4, 2, 2); contentsLayout->addWidget(useFixedTime, 3, 1); contentsLayout->addWidget(estimatedTime_, 6, 1, 1, 2); contentsLayout->addWidget(estimatedSetTime_, 7, 1, 1, 2); contentsLayout->addLayout(numberOfScansLayout, 5, 1); contentsLayout->addWidget(timeOffsetBox, 8, 1, 1, 2); contentsLayout->addWidget(autoExportGroupBox, 4, 5, 2, 3); QHBoxLayout *squeezeContents = new QHBoxLayout; squeezeContents->addStretch(); squeezeContents->addLayout(defaultLayout); squeezeContents->addLayout(contentsLayout); squeezeContents->addStretch(); QVBoxLayout *configViewLayout = new QVBoxLayout; configViewLayout->addWidget(frame); configViewLayout->addStretch(); configViewLayout->addWidget(regionsLineView_, 0, Qt::AlignCenter); configViewLayout->addSpacing(30); configViewLayout->addLayout(squeezeContents); configViewLayout->addSpacing(30); configViewLayout->addWidget(exportPath, 0, Qt::AlignCenter); configViewLayout->addSpacing(30); configViewLayout->addWidget(helpMessage, 0, Qt::AlignCenter); configViewLayout->addStretch(); setLayout(configViewLayout); }
VESPERSSpatialLineScanConfigurationView::VESPERSSpatialLineScanConfigurationView(VESPERSSpatialLineScanConfiguration *config, QWidget *parent) : VESPERSScanConfigurationView(parent) { config_ = config; AMTopFrame *frame = new AMTopFrame("VESPERS Line Scan Configuration"); // Setup the group box for setting the start and end points. QGroupBox *positionsBox = new QGroupBox("Positions"); start_ = buildPositionDoubleSpinBox("", " mm", config_->start(), 3); connect(start_, SIGNAL(editingFinished()), this, SLOT(onStartChanged())); connect(config_, SIGNAL(startChanged(double)), start_, SLOT(setValue(double))); QPushButton *startUseCurrentButton = new QPushButton("Use Current"); connect(startUseCurrentButton, SIGNAL(clicked()), this, SLOT(onSetStartPosition())); QHBoxLayout *startPointLayout = new QHBoxLayout; startPointLayout->addWidget(new QLabel("Start:")); startPointLayout->addWidget(start_); startPointLayout->addWidget(startUseCurrentButton); end_ = buildPositionDoubleSpinBox("", " mm", config_->end(), 3); connect(end_, SIGNAL(editingFinished()), this, SLOT(onEndChanged())); connect(config_, SIGNAL(endChanged(double)), end_, SLOT(setValue(double))); QPushButton *endUseCurrentButton = new QPushButton("Use Current"); connect(endUseCurrentButton, SIGNAL(clicked()), this, SLOT(onSetEndPosition())); QHBoxLayout *endPointLayout = new QHBoxLayout; endPointLayout->addWidget(new QLabel("End:")); endPointLayout->addWidget(end_); endPointLayout->addWidget(endUseCurrentButton); step_ = buildPositionDoubleSpinBox("", QString(" %1").arg(QString::fromUtf8("µm")), config_->step()*1000, 1); // xStep needs to be in mm. connect(step_, SIGNAL(editingFinished()), this, SLOT(onStepChanged())); connect(config_, SIGNAL(stepChanged(double)), this, SLOT(updateStep(double))); QHBoxLayout *stepSizeLayout = new QHBoxLayout; stepSizeLayout->addWidget(new QLabel("Step Size:")); stepSizeLayout->addWidget(step_); stepSizeLayout->addStretch(); otherPositionLabel_ = new QLabel(config_->otherMotorString(config_->motor())); otherPosition_ = buildPositionDoubleSpinBox("", " mm", config_->hasOtherPosition() ? config_->otherPosition() : 0, 3); connect(otherPosition_, SIGNAL(editingFinished()), this, SLOT(onOtherPositionChanged())); connect(config_, SIGNAL(otherPositionChanged(double)), otherPosition_, SLOT(setValue(double))); QHBoxLayout *otherPositionLayout = new QHBoxLayout; otherPositionLayout->addWidget(otherPositionLabel_); otherPositionLayout->addWidget(otherPosition_); otherPositionLayout->addStretch(); mapInfo_ = new QLabel; updateMapInfo(); QVBoxLayout *positionsLayout = new QVBoxLayout; positionsLayout->addLayout(startPointLayout); positionsLayout->addLayout(endPointLayout); positionsLayout->addLayout(stepSizeLayout); positionsLayout->addLayout(otherPositionLayout); positionsLayout->addWidget(mapInfo_); positionsBox->setLayout(positionsLayout); // Dwell time. dwellTime_ = addDwellTimeWidget(config_->time()); connect(dwellTime_, SIGNAL(editingFinished()), this, SLOT(onDwellTimeChanged())); connect(config_, SIGNAL(timeChanged(double)), dwellTime_, SLOT(setValue(double))); QHBoxLayout *timeLayout = new QHBoxLayout; timeLayout->addWidget(new QLabel("Dwell Time:")); timeLayout->addWidget(dwellTime_); // The estimated scan time. estimatedTime_ = new QLabel; connect(config_, SIGNAL(totalTimeChanged(double)), this, SLOT(onEstimatedTimeChanged())); onEstimatedTimeChanged(); QVBoxLayout *timeBoxLayout = new QVBoxLayout; timeBoxLayout->addLayout(timeLayout); timeBoxLayout->addWidget(estimatedTime_); QGroupBox *timeGroupBox = new QGroupBox("Time"); timeGroupBox->setLayout(timeBoxLayout); // Using the CCD. QGroupBox *ccdBox = addCCDDetectorSelectionView(); connect(ccdButtonGroup_, SIGNAL(buttonClicked(int)), this, SLOT(onCCDDetectorChanged(int))); connect(config_->dbObject(), SIGNAL(ccdDetectorChanged(int)), this, SLOT(updateCCDDetectorButtons(int))); ccdButtonGroup_->button(int(config_->ccdDetector()))->setChecked(true); ccdButtonGroup_->button((int)VESPERS::Roper)->hide(); ccdButtonGroup_->button((int)VESPERS::Mar)->hide(); configureCCDButton_ = new QPushButton(QIcon(":/hammer-wrench.png"), "Configure CCD"); configureCCDButton_->setEnabled(config_->ccdDetector()); connect(configureCCDButton_, SIGNAL(clicked()), this, SLOT(onConfigureCCDDetectorClicked())); // The fluorescence detector setup QGroupBox *fluorescenceDetectorGroupBox = addFluorescenceDetectorSelectionView(); connect(fluorescenceButtonGroup_, SIGNAL(buttonClicked(int)), this, SLOT(onFluorescenceDetectorChanged(int))); connect(config_->dbObject(), SIGNAL(fluorescenceDetectorChanged(int)), this, SLOT(updateFluorescenceDetector(int))); fluorescenceButtonGroup_->button((int)config_->fluorescenceDetector())->setChecked(true); // Ion chamber selection QGroupBox *ItGroupBox = addItSelectionView(); connect(ItGroup_, SIGNAL(buttonClicked(int)), this, SLOT(onItClicked(int))); connect(config_->dbObject(), SIGNAL(transmissionChoiceChanged(int)), this, SLOT(updateItButtons(int))); QGroupBox *I0GroupBox = addI0SelectionView(); connect(I0Group_, SIGNAL(buttonClicked(int)), this, SLOT(onI0Clicked(int))); connect(config_->dbObject(), SIGNAL(incomingChoiceChanged(int)), this, SLOT(updateI0Buttons(int))); I0Group_->button((int)config_->incomingChoice())->click(); ItGroup_->button((int)config_->transmissionChoice())->click(); QHBoxLayout *ionChambersLayout = new QHBoxLayout; ionChambersLayout->addWidget(I0GroupBox); ionChambersLayout->addWidget(ItGroupBox); // Motor selection. QGroupBox *motorSetChoiceBox = addMotorSelectionView(QStringList() << "H" << "X" << "V" << "Z", QList<int>() << VESPERS::H << VESPERS::X << VESPERS::V << VESPERS::Z); motorButtonGroup_->button(int(config_->motor()))->click(); connect(motorButtonGroup_, SIGNAL(buttonClicked(int)), this, SLOT(onMotorChanged(int))); // CCD label. ccdText_ = new QLabel; ccdHelpText_ = new QLabel; ccdTextBox_ = new QGroupBox("CCD Detector Info"); QVBoxLayout *ccdTextLayout = new QVBoxLayout; ccdTextLayout->addWidget(ccdText_); ccdTextLayout->addWidget(ccdHelpText_); ccdTextBox_->setLayout(ccdTextLayout); ccdTextBox_->setVisible(config_->ccdDetector() != VESPERS::NoCCD); // Scan name selection scanName_ = addScanNameView(config_->name()); connect(scanName_, SIGNAL(editingFinished()), this, SLOT(onScanNameEdited())); connect(config_, SIGNAL(nameChanged(QString)), scanName_, SLOT(setText(QString))); onScanNameEdited(); QFormLayout *scanNameLayout = new QFormLayout; scanNameLayout->addRow("Scan Name:", scanName_); // The roi text edit and configuration. roiText_ = new QTextEdit; roiText_->setReadOnly(true); QPushButton *configureXRFDetectorButton = new QPushButton(QIcon(":/hammer-wrench.png"), "Configure XRF Detector"); connect(configureXRFDetectorButton, SIGNAL(clicked()), this, SLOT(onConfigureXRFDetectorClicked())); QFormLayout *roiTextLayout = new QFormLayout; roiTextLayout->addRow(roiText_); roiTextLayout->addRow(configureXRFDetectorButton); QGroupBox *roiTextBox = new QGroupBox("Regions Of Interest"); roiTextBox->setLayout(roiTextLayout); // Label showing where the data will be saved. QLabel *exportPath = addExportPathLabel(); QGroupBox *timeOffsetBox = addTimeOffsetLabel(config_->timeOffset()); connect(timeOffset_, SIGNAL(valueChanged(double)), this, SLOT(setTimeOffset(double))); // Auto-export option. QGroupBox *autoExportGroupBox = addExporterOptionsView(QStringList(), config_->exportSpectraSources()); connect(autoExportSpectra_, SIGNAL(toggled(bool)), config_, SLOT(setExportSpectraSources(bool))); connect(autoExportSpectra_, SIGNAL(toggled(bool)), config_, SLOT(setExportSpectraSources(bool))); // Setting up the layout. QGridLayout *contentsLayout = new QGridLayout; contentsLayout->addWidget(positionsBox, 0, 0, 2, 3); contentsLayout->addWidget(timeGroupBox, 2, 0, 1, 1); contentsLayout->addWidget(ccdBox, 3, 0, 1, 1); contentsLayout->addLayout(scanNameLayout, 4, 0, 1, 1); contentsLayout->addWidget(timeOffsetBox, 5, 0, 1, 1); contentsLayout->addWidget(configureCCDButton_, 6, 0, 1, 1); contentsLayout->addWidget(motorSetChoiceBox, 0, 3, 1, 1); contentsLayout->addWidget(fluorescenceDetectorGroupBox, 1, 3, 2, 1); contentsLayout->addLayout(ionChambersLayout, 3, 3, 2, 1); contentsLayout->addWidget(ccdTextBox_, 7, 0, 1, 6); contentsLayout->addWidget(roiTextBox, 0, 5, 3, 3); contentsLayout->addWidget(autoExportGroupBox, 3, 5, 1, 3); QHBoxLayout *squeezeContents = new QHBoxLayout; squeezeContents->addStretch(); squeezeContents->addLayout(contentsLayout); squeezeContents->addStretch(); QVBoxLayout *configViewLayout = new QVBoxLayout; configViewLayout->addWidget(frame); configViewLayout->addStretch(); configViewLayout->addLayout(squeezeContents); configViewLayout->addStretch(); configViewLayout->addWidget(exportPath, 0, Qt::AlignCenter); configViewLayout->addSpacing(30); setLayout(configViewLayout); }