Files
Jungfraujoch/viewer/JFJochViewerStatusBar.cpp
T
leonarski_f 75e401f0e5
Build Packages / Unit tests (push) Successful in 1h31m59s
Build Packages / build:rpm (rocky8_nocuda) (push) Successful in 8m43s
Build Packages / build:rpm (rocky9_nocuda) (push) Successful in 10m5s
Build Packages / build:rpm (ubuntu2204_nocuda) (push) Successful in 9m27s
Build Packages / build:rpm (ubuntu2404_nocuda) (push) Successful in 8m56s
Build Packages / build:rpm (rocky8_sls9) (push) Successful in 9m24s
Build Packages / build:rpm (rocky9_sls9) (push) Successful in 10m27s
Build Packages / build:rpm (rocky8) (push) Successful in 9m20s
Build Packages / build:rpm (rocky9) (push) Successful in 10m50s
Build Packages / build:rpm (ubuntu2204) (push) Successful in 9m54s
Build Packages / build:rpm (ubuntu2404) (push) Successful in 8m38s
Build Packages / DIALS test (push) Successful in 12m13s
Build Packages / XDS test (durin plugin) (push) Successful in 7m8s
Build Packages / XDS test (JFJoch plugin) (push) Successful in 7m8s
Build Packages / XDS test (neggia plugin) (push) Successful in 7m50s
Build Packages / Generate python client (push) Successful in 16s
Build Packages / Build documentation (push) Successful in 50s
Build Packages / Create release (push) Skipped
v1.0.0-rc.153 (#63)
This is an UNSTABLE release. It includes many experimental features, as well as many AI generated fixes. We recommend using rc.152 for production use.

* jfjoch_broker: Add EXPERIMENTAL pixelrefine mode for image processing
* jfjoch_broker: Allow to load user mask from 8-bit and 16-bit TIFF files
* jfjoch_broker: Add ROI calculation in non-FPGA workflow
* jfjoch_broker: Fixes to TCP image pusher
* jfjoch_broker: Remove NUMA bindings
* jfjoch_broker: Improvements to indexing
* jfjoch_broker: For PSI EIGER, trimming energies are taken from the detector configuration (now compulsory) instead of hardcoded values
* jfjoch_writer: Save ROI definitions and the per-pixel ROI bitmap in the master file; azimuthal ROIs support phi (angular) sectors
* jfjoch_viewer: Major redesign with dockable panels and saved layouts, plus on-canvas creation/move/resize of box, circle and azimuthal ROIs
* jfjoch_viewer: Run jfjoch_process reprocessing jobs from inside the GUI and overlay per-run results

Reviewed-on: #63
2026-06-23 20:29:49 +02:00

95 lines
3.3 KiB
C++

// SPDX-FileCopyrightText: 2025 Filip Leonarski, Paul Scherrer Institute <filip.leonarski@psi.ch>
// SPDX-License-Identifier: GPL-3.0-only
#include "JFJochViewerStatusBar.h"
#include <algorithm>
JFJochViewerStatusBar::JFJochViewerStatusBar(QWidget *parent) : QStatusBar(parent) {
rate_label = new QLabel(this);
rate_label->setFixedWidth(60);
rate_label->setAlignment(Qt::AlignCenter);
addPermanentWidget(rate_label);
state_box = new QProgressBar(this);
state_box->setFixedWidth(110);
state_box->setRange(0, 1000);
state_box->setValue(0);
state_box->setTextVisible(true);
state_box->setAlignment(Qt::AlignCenter);
state_box->setFormat("");
addPermanentWidget(state_box);
}
void JFJochViewerStatusBar::display(QString input) {
showMessage(input, 60000);
}
void JFJochViewerStatusBar::setBrokerStatus(BrokerStatus status) {
QString text;
switch (status.state) {
case JFJochState::Inactive: text = "Inactive"; break;
case JFJochState::Idle: text = "Idle"; break;
case JFJochState::Measuring: text = "Measuring"; break;
case JFJochState::Error: text = "Error"; break;
case JFJochState::Busy: text = "Busy"; break;
case JFJochState::Calibration: text = "Calibration"; break;
}
state_box->setFormat(text);
if (status.progress.has_value())
state_box->setValue(std::clamp(static_cast<int>(status.progress.value() * 1000.0f), 0, 1000));
else
state_box->setValue(1000.0);
const QString chunk = (status.state == JFJochState::Error) ? "#d9534f" : "#5cb85c";
state_box->setStyleSheet(QString(
"QProgressBar { border: 1px solid #aaa; border-radius: 2px; background: transparent; }"
"QProgressBar::chunk { background-color: %1; }").arg(chunk));
if (status.message.has_value() && !status.message.value().empty())
state_box->setToolTip(QString::fromStdString(status.message.value()));
else
state_box->setToolTip(text);
}
void JFJochViewerStatusBar::setHttpConnection(bool connected, QString addr) {
if (addr.isEmpty()) {
// No detector session at all -> blank the whole cluster (but keep the reserved space).
state_box->setFormat("");
state_box->setValue(0);
state_box->setStyleSheet("");
state_box->setToolTip("");
rate_label->setText("");
return;
}
if (!connected) {
// Connection lost: clear live readouts but keep the badge so the user sees why.
state_box->setStyleSheet(QString(
"QProgressBar { border: 1px solid #aaa; border-radius: 2px; background: transparent; }"
"QProgressBar::chunk { background-color: #888888; }"));
state_box->setFormat("Disconnected");
state_box->setValue(0);
state_box->setToolTip("");
rate_label->setText("");
}
}
void JFJochViewerStatusBar::setAutoloadMode(JFJochImageReadingWorker::AutoloadMode mode) {
autoload_mode = mode;
}
void JFJochViewerStatusBar::setImageNumber(int64_t in_total_images, int64_t in_current_image) {
total_images = in_total_images;
current_image = in_current_image;
}
void JFJochViewerStatusBar::setLiveRate(double hz) {
if (hz > 0.0)
rate_label->setText(QString::number(hz, 'f', 1) + " Hz");
else
rate_label->setText("");
}