void AMGenericStepScanConfigurationView::onScanAxisAdded(AMScanAxis *axis) { if (configuration_->scanAxes().size() == 1){ connect(axisStart1_, SIGNAL(editingFinished()), this, SLOT(onStart1Changed())); connect(axisStep1_, SIGNAL(editingFinished()), this, SLOT(onStep1Changed())); connect(axisEnd1_, SIGNAL(editingFinished()), this, SLOT(onEnd1Changed())); connect(dwellTime_, SIGNAL(editingFinished()), this, SLOT(onDwellTimeChanged())); connect(axis->regionAt(0), SIGNAL(regionStartChanged(AMNumber)), this, SLOT(setStart1(AMNumber))); connect(axis->regionAt(0), SIGNAL(regionStepChanged(AMNumber)), this, SLOT(setStep1(AMNumber))); connect(axis->regionAt(0), SIGNAL(regionEndChanged(AMNumber)), this, SLOT(setEnd1(AMNumber))); connect(axis->regionAt(0), SIGNAL(regionTimeChanged(AMNumber)), this, SLOT(setDwellTime(AMNumber))); } else if (configuration_->scanAxes().size() == 2){ connect(axisStart2_, SIGNAL(editingFinished()), this, SLOT(onStart2Changed())); connect(axisStep2_, SIGNAL(editingFinished()), this, SLOT(onStep2Changed())); connect(axisEnd2_, SIGNAL(editingFinished()), this, SLOT(onEnd2Changed())); connect(axis->regionAt(0), SIGNAL(regionStartChanged(AMNumber)), this, SLOT(setStart2(AMNumber))); connect(axis->regionAt(0), SIGNAL(regionStepChanged(AMNumber)), this, SLOT(setStep2(AMNumber))); connect(axis->regionAt(0), SIGNAL(regionEndChanged(AMNumber)), this, SLOT(setEnd2(AMNumber))); } }
void CLSSIS3820ScalerControlsView::setScaler(CLSSIS3820Scaler *newScaler) { if (scaler_ != newScaler) { if (scaler_) { disconnect( scaler_, 0, this, 0 ); } scaler_ = newScaler; if (scaler_) { connect(scaler_, SIGNAL(scanningChanged(bool)), this, SLOT(onScanningChanged()) ); connect(scaler_, SIGNAL(continuousChanged(bool)), this, SLOT(onContinuousChanged())); connect(scaler_, SIGNAL(dwellTimeChanged(double)), this, SLOT(onDwellTimeChanged())); connect(scaler_, SIGNAL(scansPerBufferChanged(int)), this, SLOT(onScansPerBufferChanged())); connect(scaler_, SIGNAL(totalScansChanged(int)), this, SLOT(onTotalScansChanged())); } onScanningChanged(); onContinuousChanged(); onDwellTimeChanged(); onScansPerBufferChanged(); onTotalScansChanged(); } }
void AMGenericStepScanConfigurationView::onAxisControlChoice1Changed() { if (axisControlChoice1_->currentIndex() == 0){ axisStart1_->setEnabled(false); axisStep1_->setEnabled(false); axisEnd1_->setEnabled(false); axisControlChoice2_->setEnabled(false); configuration_->removeControl(0); setStart1(-1.0); setStep1(-1.0); setEnd1(-1.0); } else{ axisStart1_->setEnabled(true); axisStep1_->setEnabled(true); axisEnd1_->setEnabled(true); axisControlChoice2_->setEnabled(true); AMControl *control = controlNameMap_.value( axisControlChoice1_->itemText(axisControlChoice1_->currentIndex()), 0 ); if (control) { configuration_->setControl(0, control->toInfo()); setStart1(control->value()); setStep1(1.0); setEnd1(control->value()+10); } onStart1Changed(); onStep1Changed(); onEnd1Changed(); onDwellTimeChanged(); } onAxisControlChoice2Changed(); QStandardItemModel *model = qobject_cast<QStandardItemModel *>(axisControlChoice2_->model()); for (int i = 1; i < axisControlChoice2_->count(); i++) model->item(i)->setFlags(i == axisControlChoice1_->currentIndex() ? Qt::NoItemFlags : Qt::ItemIsEnabled | Qt::ItemIsSelectable); updateScanInformation(); }
VESPERS2DScanConfigurationView::VESPERS2DScanConfigurationView(VESPERS2DScanConfiguration *config, QWidget *parent) : VESPERSScanConfigurationView(parent) { config_ = config; AMTopFrame *frame = new AMTopFrame("VESPERS 2D Map Configuration"); // Setup the group box for setting the start and end points. QGroupBox *positionsBox = new QGroupBox("Positions"); hStart_ = buildPositionDoubleSpinBox("H: ", " mm", config_->xStart(), 3); connect(hStart_, SIGNAL(editingFinished()), this, SLOT(onXStartChanged())); connect(config_, SIGNAL(xStartChanged(double)), hStart_, SLOT(setValue(double))); vStart_ = buildPositionDoubleSpinBox("V: ", " mm", config_->yStart(), 3); connect(vStart_, SIGNAL(editingFinished()), this, SLOT(onYStartChanged())); connect(config_, SIGNAL(yStartChanged(double)), vStart_, 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(hStart_); startPointLayout->addWidget(vStart_); startPointLayout->addWidget(startUseCurrentButton); hEnd_ = buildPositionDoubleSpinBox("H: ", " mm", config_->xEnd(), 3); connect(hEnd_, SIGNAL(editingFinished()), this, SLOT(onXEndChanged())); connect(config_, SIGNAL(xEndChanged(double)), hEnd_, SLOT(setValue(double))); vEnd_ = buildPositionDoubleSpinBox("V: ", " mm", config_->yEnd(), 3); connect(vEnd_, SIGNAL(editingFinished()), this, SLOT(onYEndChanged())); connect(config_, SIGNAL(yEndChanged(double)), vEnd_, 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(hEnd_); endPointLayout->addWidget(vEnd_); endPointLayout->addWidget(endUseCurrentButton); hStep_ = buildPositionDoubleSpinBox("H: ", QString(" %1").arg(QString::fromUtf8("µm")), config_->xStep()*1000, 1); // xStep needs to be in mm. connect(hStep_, SIGNAL(editingFinished()), this, SLOT(onXStepChanged())); connect(config_, SIGNAL(xStepChanged(double)), this, SLOT(updateXStep(double))); vStep_ = buildPositionDoubleSpinBox("V: ", QString(" %1").arg(QString::fromUtf8("µm")), config_->yStep()*1000, 1); // yStep needs to be in mm. connect(vStep_, SIGNAL(editingFinished()), this, SLOT(onYStepChanged())); connect(config_, SIGNAL(yStepChanged(double)), this, SLOT(updateYStep(double))); QHBoxLayout *stepSizeLayout = new QHBoxLayout; stepSizeLayout->addWidget(new QLabel("Step Size:")); stepSizeLayout->addWidget(hStep_); stepSizeLayout->addWidget(vStep_); stepSizeLayout->addStretch(); mapInfo_ = new QLabel; updateMapInfo(); QVBoxLayout *positionsLayout = new QVBoxLayout; positionsLayout->addLayout(startPointLayout); positionsLayout->addLayout(endPointLayout); positionsLayout->addLayout(stepSizeLayout); positionsLayout->addWidget(mapInfo_); positionsBox->setLayout(positionsLayout); // Dwell time. dwellTime_ = addDwellTimeWidget(config_->timeStep()); connect(dwellTime_, SIGNAL(editingFinished()), this, SLOT(onDwellTimeChanged())); connect(config_, SIGNAL(timeStepChanged(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(); fluorescenceButtonGroup_->button(int(VESPERS::NoXRF))->setDisabled(true); 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 *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(); // Motor selection. QGroupBox *motorSetChoiceBox = addMotorSelectionView(QStringList() << "H and V" << "X and Z", QList<int>() << (VESPERS::H | VESPERS::V) << (VESPERS::X | VESPERS::Z)); connect(motorButtonGroup_, SIGNAL(buttonClicked(int)), this, SLOT(onMotorChanged(int))); motorButtonGroup_->button(int(config_->motor()))->click(); // 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() << "Ascii" << "SMAK", config_->exportSpectraSources()); connect(autoExportButtonGroup_, SIGNAL(buttonClicked(int)), this, SLOT(updateAutoExporter(int))); connect(autoExportSpectra_, SIGNAL(toggled(bool)), config_, SLOT(setExportSpectraSources(bool))); autoExportButtonGroup_->button(config_->exportAsAscii() ? 0 : 1)->click(); // 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->addWidget(I0GroupBox, 3, 3, 2, 1); contentsLayout->addWidget(ccdTextBox_, 7, 0, 1, 6); contentsLayout->addWidget(roiTextBox, 0, 5, 3, 3); contentsLayout->addWidget(autoExportGroupBox, 3, 5, 2, 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); }
VESPERS2DScanConfigurationView::VESPERS2DScanConfigurationView(VESPERS2DScanConfiguration *config, QWidget *parent) : VESPERSScanConfigurationView(parent) { configuration_ = config; AMTopFrame *frame = new AMTopFrame("VESPERS 2D Map Configuration"); // Setup the group box for setting the start and end points. QGroupBox *positionsBox = new QGroupBox("Positions"); hStart_ = createPositionDoubleSpinBox("H: ", " mm", configuration_->scanAxisAt(0)->regionAt(0)->regionStart(), 3); connect(hStart_, SIGNAL(editingFinished()), this, SLOT(onXStartChanged())); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionStartChanged(AMNumber)), this, SLOT(setXAxisStart(AMNumber))); vStart_ = createPositionDoubleSpinBox("V: ", " mm", configuration_->scanAxisAt(1)->regionAt(0)->regionStart(), 3); connect(vStart_, SIGNAL(editingFinished()), this, SLOT(onYStartChanged())); connect(configuration_->scanAxisAt(1)->regionAt(0), SIGNAL(regionStartChanged(AMNumber)), this, SLOT(setYAxisStart(AMNumber))); QPushButton *startUseCurrentButton = new QPushButton("Use Current"); connect(startUseCurrentButton, SIGNAL(clicked()), this, SLOT(onSetStartPosition())); QHBoxLayout *startPointLayout = new QHBoxLayout; startPointLayout->addWidget(new QLabel("Start:")); startPointLayout->addWidget(hStart_); startPointLayout->addWidget(vStart_); startPointLayout->addWidget(startUseCurrentButton); hEnd_ = createPositionDoubleSpinBox("H: ", " mm", configuration_->scanAxisAt(0)->regionAt(0)->regionEnd(), 3); connect(hEnd_, SIGNAL(editingFinished()), this, SLOT(onXEndChanged())); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionEndChanged(AMNumber)), this, SLOT(setXAxisEnd(AMNumber))); vEnd_ = createPositionDoubleSpinBox("V: ", " mm", configuration_->scanAxisAt(1)->regionAt(0)->regionEnd(), 3); connect(vEnd_, SIGNAL(editingFinished()), this, SLOT(onYEndChanged())); connect(configuration_->scanAxisAt(1)->regionAt(0), SIGNAL(regionEndChanged(AMNumber)), this, SLOT(setYAxisEnd(AMNumber))); QPushButton *endUseCurrentButton = new QPushButton("Use Current"); connect(endUseCurrentButton, SIGNAL(clicked()), this, SLOT(onSetEndPosition())); QHBoxLayout *endPointLayout = new QHBoxLayout; endPointLayout->addWidget(new QLabel("End:")); endPointLayout->addWidget(hEnd_); endPointLayout->addWidget(vEnd_); endPointLayout->addWidget(endUseCurrentButton); hStep_ = createPositionDoubleSpinBox("H: ", QString(" %1").arg(QString::fromUtf8("µm")), double(configuration_->scanAxisAt(0)->regionAt(0)->regionStep())*1000, 1); // xStep needs to be in mm. connect(hStep_, SIGNAL(editingFinished()), this, SLOT(onXStepChanged())); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionStepChanged(AMNumber)), this, SLOT(setXAxisStep(AMNumber))); vStep_ = createPositionDoubleSpinBox("V: ", QString(" %1").arg(QString::fromUtf8("µm")), double(configuration_->scanAxisAt(1)->regionAt(0)->regionStep())*1000, 1); // yStep needs to be in mm. connect(vStep_, SIGNAL(editingFinished()), this, SLOT(onYStepChanged())); connect(configuration_->scanAxisAt(1)->regionAt(0), SIGNAL(regionStepChanged(AMNumber)), this, SLOT(setYAxisStep(AMNumber))); QHBoxLayout *stepSizeLayout = new QHBoxLayout; stepSizeLayout->addWidget(new QLabel("Step Size:")); stepSizeLayout->addWidget(hStep_); stepSizeLayout->addWidget(vStep_); stepSizeLayout->addStretch(); normalPosition_ = createPositionDoubleSpinBox("N: ", " mm", configuration_->normalPosition(), 3); connect(normalPosition_, SIGNAL(editingFinished()), this, SLOT(onNormalPositionChanged())); connect(configuration_->dbObject(), SIGNAL(normalPositionChanged(double)), normalPosition_, SLOT(setValue(double))); QPushButton *updateNormalPosition = new QPushButton("Set Normal"); connect(updateNormalPosition, SIGNAL(clicked()), this, SLOT(onSetNormalPosition())); QHBoxLayout *normalLayout = new QHBoxLayout; normalLayout->addWidget(new QLabel("Focus Position:")); normalLayout->addWidget(normalPosition_); normalLayout->addWidget(updateNormalPosition); mapInfo_ = new QLabel; updateMapInfo(); QVBoxLayout *positionsLayout = new QVBoxLayout; positionsLayout->addLayout(startPointLayout); positionsLayout->addLayout(endPointLayout); positionsLayout->addLayout(stepSizeLayout); positionsLayout->addLayout(normalLayout); positionsLayout->addWidget(mapInfo_); positionsBox->setLayout(positionsLayout); // Dwell time. dwellTime_ = createDwellTimeSpinBox(configuration_->scanAxisAt(0)->regionAt(0)->regionTime()); connect(dwellTime_, SIGNAL(editingFinished()), this, SLOT(onDwellTimeChanged())); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionTimeChanged(AMNumber)), this, SLOT(setDwellTime(AMNumber))); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionTimeChanged(AMNumber)), configuration_->scanAxisAt(1)->regionAt(0), SLOT(setRegionTime(AMNumber))); QHBoxLayout *timeLayout = new QHBoxLayout; timeLayout->addWidget(new QLabel("Dwell Time:")); timeLayout->addWidget(dwellTime_); // The estimated scan time. estimatedTime_ = new QLabel; connect(configuration_, 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); // 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(configuration_->ccdDetector() != VESPERS::NoCCD); // Using the CCD. ccdComboBox_ = createCCDComboBox(); connect(ccdComboBox_, SIGNAL(currentIndexChanged(int)), this, SLOT(onCCDDetectorChanged(int))); connect(configuration_->dbObject(), SIGNAL(ccdDetectorChanged(int)), this, SLOT(updateCCDDetectorComboBox(int))); // The fluorescence detector setup fluorescenceDetectorComboBox_ = createFluorescenceComboBox(); connect(fluorescenceDetectorComboBox_, SIGNAL(currentIndexChanged(int)), this, SLOT(onFluorescenceChoiceChanged(int))); connect(configuration_->dbObject(), SIGNAL(fluorescenceDetectorChanged(int)), this, SLOT(updateFluorescenceDetectorComboBox(int))); // Ion chamber selection i0ComboBox_ = createIonChamberComboBox(); connect(i0ComboBox_, SIGNAL(currentIndexChanged(int)), this, SLOT(onI0Clicked(int))); connect(configuration_->dbObject(), SIGNAL(incomingChoiceChanged(int)), this, SLOT(updateI0ComboBox(int))); // Motor selection. motorSelectionComboBox_ = createMotorSelectionComboBox( QStringList() << "H & V" << "X & Z" << "Atto H & V" << "Atto X & Z" << "Big Beam X & Z", QList<int>() << (VESPERS::H | VESPERS::V) << (VESPERS::X | VESPERS::Z) << (VESPERS::AttoH | VESPERS::AttoV) << (VESPERS::AttoX | VESPERS::AttoZ) << (VESPERS::BigBeamX | VESPERS::BigBeamZ)); connect(motorSelectionComboBox_, SIGNAL(currentIndexChanged(int)), this, SLOT(onMotorChanged(int))); connect(configuration_->dbObject(), SIGNAL(motorChanged(int)), this, SLOT(updateMotorSelectionComboBox(int))); // Scan name selection scanName_ = createScanNameView(configuration_->name()); connect(scanName_, SIGNAL(editingFinished()), this, SLOT(onScanNameEdited())); connect(configuration_, SIGNAL(nameChanged(QString)), scanName_, SLOT(setText(QString))); // Only connecting this signal because it is the only CCD available currently. It would need some logic for switching which CCD it was actually connected to. connect(VESPERSBeamline::vespers()->vespersPilatusAreaDetector(), SIGNAL(ccdPathChanged(QString)), this, SLOT(onScanNameEdited())); onScanNameEdited(); QFormLayout *scanNameLayout = new QFormLayout; scanNameLayout->addRow("Scan Name:", scanName_); QGroupBox *scanNameGroupBox = new QGroupBox("Scan Name"); scanNameGroupBox->setLayout(scanNameLayout); // Label showing where the data will be saved. QLabel *exportPath = addExportPathLabel(); QGroupBox *timeOffsetBox = addTimeOffsetLabel(configuration_->timeOffset()); connect(timeOffset_, SIGNAL(valueChanged(double)), this, SLOT(setTimeOffset(double))); // Auto-export option. QGroupBox *autoExportGroupBox = addExporterOptionsView(QStringList() << "Ascii" << "SMAK", configuration_->exportSpectraSources(), configuration_->exportSpectraInRows()); connect(autoExportButtonGroup_, SIGNAL(buttonClicked(int)), this, SLOT(updateAutoExporter(int))); connect(autoExportSpectra_, SIGNAL(toggled(bool)), configuration_, SLOT(setExportSpectraSources(bool))); connect(autoExportSpectra_, SIGNAL(toggled(bool)), exportSpectraInRows_, SLOT(setEnabled(bool))); connect(exportSpectraInRows_, SIGNAL(toggled(bool)), this, SLOT(updateExportSpectraInRows(bool))); autoExportButtonGroup_->button(configuration_->exportAsAscii() ? 0 : 1)->click(); ccdComboBox_->setCurrentIndex(ccdComboBox_->findData(int(configuration_->ccdDetector()))); i0ComboBox_->setCurrentIndex((int)configuration_->incomingChoice()); fluorescenceDetectorComboBox_->setCurrentIndex((int)configuration_->fluorescenceDetector()); motorSelectionComboBox_->setCurrentIndex(motorSelectionComboBox_->findData(int(configuration_->motor()))); disableStandardFluorescenceOptions(); disableStandardXRDOptions(); disableStandardI0Options(); QFormLayout *detectorLayout = new QFormLayout; detectorLayout->addRow("XRF:", fluorescenceDetectorComboBox_); detectorLayout->addRow("XRD:", ccdComboBox_); detectorLayout->addRow("I0:", i0ComboBox_); detectorLayout->addRow("Stage:", motorSelectionComboBox_); QGroupBox *detectorGroupBox = new QGroupBox("Detectors"); detectorGroupBox->setLayout(detectorLayout); QGroupBox *afterScanBox = createAfterScanOptionsBox(configuration_->closeFastShutter(), configuration_->returnToOriginalPosition(), configuration_->cleanupScaler()); connect(closeFastShutterCheckBox_, SIGNAL(toggled(bool)), this, SLOT(setCloseFastShutter(bool))); connect(goToPositionCheckBox_, SIGNAL(toggled(bool)), this, SLOT(setReturnToOriginalPosition(bool))); connect(cleanupScalerCheckBox_, SIGNAL(toggled(bool)), this, SLOT(setCleanupScaler(bool))); // Setting up the layout. QGridLayout *contentsLayout = new QGridLayout; contentsLayout->addWidget(positionsBox, 0, 0, 2, 3); contentsLayout->addWidget(timeGroupBox, 2, 0, 1, 3); contentsLayout->addWidget(scanNameGroupBox, 3, 0, 1, 3); contentsLayout->addWidget(ccdTextBox_, 4, 0, 1, 3); contentsLayout->addWidget(timeOffsetBox, 5, 0, 1, 3); contentsLayout->addWidget(detectorGroupBox, 0, 3, 2, 1); contentsLayout->addWidget(autoExportGroupBox, 2, 3, 2, 1); contentsLayout->addWidget(afterScanBox, 4, 3, 1, 1); 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); }
IDEAS2DScanConfigurationView::IDEAS2DScanConfigurationView(IDEAS2DScanConfiguration *configuration, QWidget *parent) : AMScanConfigurationView(parent) { configuration_ = configuration; // 1st row: set the start position hStart_ = createPositionDoubleSpinBox("H: ", " mm", configuration_->scanAxisAt(0)->regionAt(0)->regionStart(), 3); connect(hStart_, SIGNAL(editingFinished()), this, SLOT(onXStartChanged())); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionStartChanged(AMNumber)), this, SLOT(setXAxisStart(AMNumber))); vStart_ = createPositionDoubleSpinBox("V: ", " mm", configuration_->scanAxisAt(1)->regionAt(0)->regionStart(), 3); connect(vStart_, SIGNAL(editingFinished()), this, SLOT(onYStartChanged())); connect(configuration_->scanAxisAt(1)->regionAt(0), SIGNAL(regionStartChanged(AMNumber)), this, SLOT(setYAxisStart(AMNumber))); QPushButton *startUseCurrentButton = new QPushButton("Use Current"); connect(startUseCurrentButton, SIGNAL(clicked()), this, SLOT(onSetStartPosition())); // 2nd row: set the end position hEnd_ = createPositionDoubleSpinBox("H: ", " mm", configuration_->scanAxisAt(0)->regionAt(0)->regionEnd(), 3); connect(hEnd_, SIGNAL(editingFinished()), this, SLOT(onXEndChanged())); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionEndChanged(AMNumber)), this, SLOT(setXAxisEnd(AMNumber))); vEnd_ = createPositionDoubleSpinBox("V: ", " mm", configuration_->scanAxisAt(1)->regionAt(0)->regionEnd(), 3); connect(vEnd_, SIGNAL(editingFinished()), this, SLOT(onYEndChanged())); connect(configuration_->scanAxisAt(1)->regionAt(0), SIGNAL(regionEndChanged(AMNumber)), this, SLOT(setYAxisEnd(AMNumber))); QPushButton *endUseCurrentButton = new QPushButton("Use Current"); connect(endUseCurrentButton, SIGNAL(clicked()), this, SLOT(onSetEndPosition())); // 3rd row: set the step size hStep_ = createPositionDoubleSpinBox("H: ", QString(" %1").arg(QString::fromUtf8("µm")), double(configuration_->scanAxisAt(0)->regionAt(0)->regionStep())*1000, 1); // xStep needs to be in mm. hStep_->setMinimum(0); connect(hStep_, SIGNAL(editingFinished()), this, SLOT(onXStepChanged())); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionStepChanged(AMNumber)), this, SLOT(setXAxisStep(AMNumber))); vStep_ = createPositionDoubleSpinBox("V: ", QString(" %1").arg(QString::fromUtf8("µm")), double(configuration_->scanAxisAt(1)->regionAt(0)->regionStep())*1000, 1); // yStep needs to be in mm. vStep_->setMinimum(0); connect(vStep_, SIGNAL(editingFinished()), this, SLOT(onYStepChanged())); connect(configuration_->scanAxisAt(1)->regionAt(0), SIGNAL(regionStepChanged(AMNumber)), this, SLOT(setYAxisStep(AMNumber))); // the grid layout to hold the positions QGridLayout *positionGridLayout = new QGridLayout; positionGridLayout->addWidget(new QLabel("Start:"), 0, 0, 1, 2); positionGridLayout->addWidget(hStart_, 0, 2, 1, 2); positionGridLayout->addWidget(vStart_, 0, 4, 1, 2); positionGridLayout->addWidget(startUseCurrentButton, 0, 6, 1, 2); positionGridLayout->addWidget(new QLabel("End:"), 1, 0, 1, 2); positionGridLayout->addWidget(hEnd_, 1, 2, 1, 2); positionGridLayout->addWidget(vEnd_, 1, 4, 1, 2); positionGridLayout->addWidget(endUseCurrentButton, 1, 6, 1, 2); positionGridLayout->addWidget(new QLabel("Step Size:"), 2, 0, 1, 2); positionGridLayout->addWidget(hStep_, 2, 2, 1, 2); positionGridLayout->addWidget(vStep_, 2, 4, 1, 2); // the map information mapInfo_ = new QLabel; updateMapInfo(); // Setup the group box for setting the start and end points. QVBoxLayout *positionsLayout = new QVBoxLayout; positionsLayout->addLayout(positionGridLayout); positionsLayout->addWidget(mapInfo_); QGroupBox *positionsBox = new QGroupBox("Positions"); positionsBox->setLayout(positionsLayout); // Dwell time. dwellTime_ = createDwellTimeSpinBox(configuration_->scanAxisAt(0)->regionAt(0)->regionTime()); connect(dwellTime_, SIGNAL(editingFinished()), this, SLOT(onDwellTimeChanged())); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionTimeChanged(AMNumber)), this, SLOT(setDwellTime(AMNumber))); connect(configuration_->scanAxisAt(0)->regionAt(0), SIGNAL(regionTimeChanged(AMNumber)), configuration_->scanAxisAt(1)->regionAt(0), SLOT(setRegionTime(AMNumber))); QHBoxLayout *timeLayout = new QHBoxLayout; timeLayout->addWidget(new QLabel("Dwell Time:")); timeLayout->addWidget(dwellTime_); // The estimated scan time. estimatedTime_ = new QLabel; connect(configuration_, SIGNAL(totalTimeChanged(double)), this, SLOT(onEstimatedTimeChanged())); onEstimatedTimeChanged(); // Setup the group box for time. QVBoxLayout *timeBoxLayout = new QVBoxLayout; timeBoxLayout->addLayout(timeLayout); timeBoxLayout->addWidget(estimatedTime_); QGroupBox *timeGroupBox = new QGroupBox("Time"); timeGroupBox->setLayout(timeBoxLayout); // Scan name selection scanName_ = createScanNameView(configuration_->userScanName()); connect(scanName_, SIGNAL(editingFinished()), this, SLOT(onScanNameEdited())); connect(configuration_, SIGNAL(nameChanged(QString)), scanName_, SLOT(setText(QString))); onScanNameEdited(); QFormLayout *scanNameLayout = new QFormLayout; scanNameLayout->addRow("Scan Name:", scanName_); QGroupBox *scanNameGroupBox = new QGroupBox("Scan Information"); scanNameGroupBox->setLayout(scanNameLayout); // BL energy setting scanEnergySpinBox_ = createEnergySpinBox("eV", 0, 15000, configuration_->energy()); scanEnergySettingWarningLabel_ = new QLabel("Settings do not match beamline."); scanEnergySettingWarningLabel_->setStyleSheet("QLabel {color: red}"); setScanEnergyFromBeamlineButton_ = new QPushButton("Set From Beamline"); connect(scanEnergySpinBox_, SIGNAL(editingFinished()), this, SLOT(onScanEnergySpinBoxEditingFinished())); connect(setScanEnergyFromBeamlineButton_, SIGNAL(clicked()), this, SLOT(onSetScanEnergyFromBeamlineButtonClicked())); connect(IDEASBeamline::ideas()->monoEnergyControl(), SIGNAL(valueChanged(double)), this, SLOT(onBeamlineEnergyChanged(double))); onScanEnergySpinBoxEditingFinished(); QFormLayout *scanEnergyFL = new QFormLayout(); scanEnergyFL->addRow("Energy", scanEnergySpinBox_); QVBoxLayout *beamlineSettingsGroupBoxVL = new QVBoxLayout(); beamlineSettingsGroupBoxVL->addLayout(scanEnergyFL); beamlineSettingsGroupBoxVL->addStretch(); beamlineSettingsGroupBoxVL->addWidget(scanEnergySettingWarningLabel_); beamlineSettingsGroupBoxVL->addWidget(setScanEnergyFromBeamlineButton_); beamlineSettingsGroupBox_ = new QGroupBox("Beamline Settings"); beamlineSettingsGroupBox_->setMinimumWidth(230); beamlineSettingsGroupBox_->setLayout(beamlineSettingsGroupBoxVL); // detector setting QGroupBox *detectorSettingGroupBox = createAndLayoutDetectorSettings(configuration_); // Error label. errorLabel_ = new QLabel; QFont font = this->font(); font.setPixelSize(16); font.setBold(true); QPalette palette = this->palette(); palette.setColor(QPalette::WindowText, Qt::red); errorLabel_->setFont(font); errorLabel_->setPalette(palette); // Setting up the layout. QGridLayout *contentsLayout = new QGridLayout; contentsLayout->addWidget(positionsBox, 0, 0, 2, 4); contentsLayout->addWidget(timeGroupBox, 2, 0, 1, 4); contentsLayout->addWidget(scanNameGroupBox, 3, 0, 1, 4); contentsLayout->addWidget(beamlineSettingsGroupBox_, 0, 4, 3, 2); contentsLayout->addWidget(detectorSettingGroupBox, 3, 4, 1, 2); contentsLayout->addWidget(errorLabel_, 4, 0, 2, 4); setLayout(contentsLayout); }
AMGenericStepScanConfigurationView::AMGenericStepScanConfigurationView(AMGenericStepScanConfiguration *configuration, AMControlSet *controls, AMDetectorSet *detectors, QWidget *parent) : AMScanConfigurationView(parent) { configuration_ = configuration; controls_ = 0; detectors_ = 0; scanName_ = new QLineEdit; scanName_->setText(configuration_->name()); scanName_->setAlignment(Qt::AlignCenter); connect(scanName_, SIGNAL(editingFinished()), this, SLOT(onScanNameEdited())); connect(configuration_, SIGNAL(nameChanged(QString)), scanName_, SLOT(setText(QString))); onScanNameEdited(); // Dwell time. dwellTime_ = new QDoubleSpinBox; dwellTime_->setRange(0, 1000000); dwellTime_->setSuffix(" s"); dwellTime_->setAlignment(Qt::AlignCenter); dwellTime_->setDecimals(1); dwellTime_->setValue(configuration_->scanAxes().size() > 0 ? double(configuration_->scanAxisAt(0)->regionAt(0)->regionTime()) : 1.0); dwellTime_->setMinimumWidth(100); connect(dwellTime_, SIGNAL(editingFinished()), this, SLOT(onDwellTimeChanged())); QHBoxLayout *timeLayout = new QHBoxLayout; timeLayout->addWidget(new QLabel("Dwell Time:")); timeLayout->addWidget(dwellTime_); // The estimated scan time. estimatedTime_ = new QLabel; connect(configuration_, SIGNAL(totalTimeChanged(double)), this, SLOT(onEstimatedTimeChanged())); onEstimatedTimeChanged(); scanInformation_ = new QLabel("Scan Size:"); QVBoxLayout *timeBoxLayout = new QVBoxLayout; timeBoxLayout->addLayout(timeLayout); timeBoxLayout->addWidget(estimatedTime_); timeBoxLayout->addWidget(scanInformation_); QGroupBox *timeGroupBox = new QGroupBox("Time"); timeGroupBox->setLayout(timeBoxLayout); axisControlChoice1_ = new QComboBox; axisControlChoice2_ = new QComboBox; setControls(controls); connect(axisControlChoice1_, SIGNAL(currentIndexChanged(int)), this, SLOT(onAxisControlChoice1Changed())); connect(axisControlChoice2_, SIGNAL(currentIndexChanged(int)), this, SLOT(onAxisControlChoice2Changed())); // Setup the group box for setting the start and end points. QGroupBox *positionsBox = new QGroupBox("Positions"); axisStart1_ = createPositionDoubleSpinBox("Start: ", "", configuration_->scanAxes().size() > 0 ? double(configuration_->scanAxisAt(0)->regionAt(0)->regionStart()) : -1.0, 3); axisStep1_ = createPositionDoubleSpinBox("Step: ", "", configuration_->scanAxes().size() > 0 ? double(configuration_->scanAxisAt(0)->regionAt(0)->regionStep()) : -1.0, 3); axisEnd1_ = createPositionDoubleSpinBox("End: ", "", configuration_->scanAxes().size() > 0 ? double(configuration_->scanAxisAt(0)->regionAt(0)->regionEnd()) : -1.0, 3); axisStart2_ = createPositionDoubleSpinBox("Start: ", "", configuration_->scanAxes().size() > 1 ? double(configuration_->scanAxisAt(1)->regionAt(0)->regionStart()) : -1.0, 3); axisStep2_ = createPositionDoubleSpinBox("Step: ", "", configuration_->scanAxes().size() > 1 ? double(configuration_->scanAxisAt(1)->regionAt(0)->regionStep()) : -1.0, 3); axisEnd2_ = createPositionDoubleSpinBox("End: ", "", configuration_->scanAxes().size() > 1 ? double(configuration_->scanAxisAt(1)->regionAt(0)->regionEnd()) : -1.0, 3); connect(configuration_, SIGNAL(scanAxisAdded(AMScanAxis*)), this, SLOT(onScanAxisAdded(AMScanAxis*))); QList<AMScanAxis*> axisList = configuration_->scanAxes(); foreach (AMScanAxis *axis, axisList) { if (axis) onScanAxisAdded(axis); } QHBoxLayout *axis1Layout = new QHBoxLayout; axis1Layout->addWidget(axisStart1_); axis1Layout->addWidget(axisStep1_); axis1Layout->addWidget(axisEnd1_); axis1Layout->addWidget(axisControlChoice1_); QHBoxLayout *axis2Layout = new QHBoxLayout; axis2Layout->addWidget(axisStart2_); axis2Layout->addWidget(axisStep2_); axis2Layout->addWidget(axisEnd2_); axis2Layout->addWidget(axisControlChoice2_); QVBoxLayout *positionLayout = new QVBoxLayout; positionLayout->addLayout(axis1Layout); positionLayout->addLayout(axis2Layout); positionsBox->setLayout(positionLayout); // Set initial spinbox values in cases where we don't yet have axes: if(configuration_->scanAxes().count() == 0) { // Set defaults for axis 1 and 2 onAxisControlChoice1Changed(); onAxisControlChoice2Changed(); } else if(configuration_->scanAxes().count() == 1) { // Set defaults just for axis 2 onAxisControlChoice2Changed(); } // Create I0 box and detectors view. i0ComboBox_ = new QComboBox; connect( configuration_, SIGNAL(i0DetectorChanged()), this, SLOT(updateI0Box()) ); connect(i0ComboBox_, SIGNAL(currentIndexChanged(int)), this, SLOT(onI0ChoiceChanged(int))); QHBoxLayout *i0Layout = new QHBoxLayout; i0Layout->addWidget(new QLabel("I0:")); i0Layout->addWidget(i0ComboBox_); detectorsView_ = new AMGenericStepScanConfigurationDetectorsView(configuration_, 0); setDetectors(detectors); QVBoxLayout *detectorsBoxLayout = new QVBoxLayout(); detectorsBoxLayout->addWidget(detectorsView_); QGroupBox *detectorsBox = new QGroupBox("Detectors"); detectorsBox->setFlat(true); detectorsBox->setLayout(detectorsBoxLayout); QScrollArea *detectorScrollArea = new QScrollArea; detectorScrollArea->setWidget(detectorsBox); detectorScrollArea->setFrameStyle(QFrame::NoFrame); QVBoxLayout *detectorsAndI0Layout = new QVBoxLayout; detectorsAndI0Layout->addLayout(i0Layout); detectorsAndI0Layout->addWidget(detectorScrollArea); // Create and set main layouts. QVBoxLayout *layout = new QVBoxLayout; layout->addWidget(positionsBox); layout->addWidget(scanName_); layout->addWidget(timeGroupBox); QHBoxLayout *moreLayout = new QHBoxLayout; moreLayout->addStretch(); moreLayout->addLayout(layout); moreLayout->addLayout(detectorsAndI0Layout); moreLayout->addStretch(); QVBoxLayout *configViewLayout = new QVBoxLayout; configViewLayout->addStretch(); configViewLayout->addLayout(moreLayout); configViewLayout->addStretch(); setLayout(configViewLayout); }