57#include <QSvgGenerator>
93 auto *rhiViewport =
new QRhiWidget;
94#if defined(WASMBUILD) || defined(__EMSCRIPTEN__)
95 rhiViewport->setApi(QRhiWidget::Api::OpenGL);
96#elif defined(Q_OS_MACOS) || defined(Q_OS_IOS)
97 rhiViewport->setApi(QRhiWidget::Api::Metal);
98#elif defined(Q_OS_WIN)
99 rhiViewport->setApi(QRhiWidget::Api::Direct3D11);
101 rhiViewport->setApi(QRhiWidget::Api::OpenGL);
110 QVBoxLayout *neLayout =
new QVBoxLayout(
this);
112 neLayout->setContentsMargins(0,0,0,0);
113 this->setLayout(neLayout);
130 auto *rhiViewport =
new QRhiWidget;
131#if defined(WASMBUILD) || defined(__EMSCRIPTEN__)
132 rhiViewport->setApi(QRhiWidget::Api::OpenGL);
133#elif defined(Q_OS_MACOS) || defined(Q_OS_IOS)
134 rhiViewport->setApi(QRhiWidget::Api::Metal);
135#elif defined(Q_OS_WIN)
136 rhiViewport->setApi(QRhiWidget::Api::Direct3D11);
138 rhiViewport->setApi(QRhiWidget::Api::OpenGL);
170 for(
int i = 0; i<
m_pModel->rowCount(); i++) {
186 m_pTableView->setContextMenuPolicy(Qt::CustomContextMenu);
188 connect(
m_pTableView.data(), &QTableView::doubleClicked,
191 connect(
m_pTableView.data(), &QTableView::customContextMenuRequested,
195 m_pTableView->setSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding);
197 m_pTableView->horizontalHeader()->setSectionResizeMode(1, QHeaderView::Stretch);
204 m_pTableView->setHorizontalScrollMode(QAbstractItemView::ScrollPerPixel);
206 connect(
m_pTableView->verticalScrollBar(), &QScrollBar::valueChanged,
214 if(!data.isEmpty()) {
219 for(
int i = 0; i<
m_pModel->rowCount(); i++) {
235 qWarning() <<
"[RtFiffRawView::addData] Received data list is empty.";
256 return QWidget::eventFilter(
object, event);
348 for(
int i = 0; i<
m_pModel->rowCount(); i++) {
349 QString channel =
m_pModel->data(
m_pModel->index(i, 0), Qt::DisplayRole).toString();
406 if(fileName.contains(
".svg", Qt::CaseInsensitive)) {
408 QSvgGenerator svgGen;
409 svgGen.setFileName(fileName);
416 if(fileName.contains(
".png", Qt::CaseInsensitive)) {
418 pixMap.save(fileName);
440 m_pModel->updateSpharaActivation(state);
447 m_pModel->updateSpharaOptions(sSytemType, nBaseFctsFirst, nBaseFctsSecond);
468 m_pModel->setFilterChannelType(channelType);
475 const QString &triggerCh,
478 m_pModel->triggerInfoChanged(colorMap, active, triggerCh, threshold);
486 m_pModel->distanceTimeSpacerChanged(value);
511 QSettings settings(
"MNECPP");
522 QSettings settings(
"MNECPP");
559 QModelIndexList selected =
m_pTableView->selectionModel()->selectedIndexes();
562 QMenu *menu =
new QMenu(
this);
564 menu->addSection(
"Events");
566 QAction* addEventMarker = menu->addAction(tr(
"Add event"));
567 connect(addEventMarker, &QAction::triggered,
572 menu->addSection(
"Channel Marking");
575 QAction* doMarkChBad = menu->addAction(tr(
"Mark as bad"));
576 connect(doMarkChBad, &QAction::triggered,
579 QAction* doMarkChGood = menu->addAction(tr(
"Mark as good"));
580 connect(doMarkChGood, &QAction::triggered,
586 for(qint32 i = 0; i < selected.size(); ++i)
587 if(selected[i].column() == 1)
590 menu->addSection(
"Selection");
592 QAction* doSelection = menu->addAction(tr(
"Only show selection"));
593 connect(doSelection, &QAction::triggered,
597 QAction*
hideSelection = menu->addAction(tr(
"Hide selection"));
602 QAction* resetAppliedSelection = menu->addAction(tr(
"Reset selection"));
603 connect(resetAppliedSelection, &QAction::triggered,
605 connect(resetAppliedSelection, &QAction::triggered,
609 menu->popup(
m_pTableView->viewport()->mapToGlobal(pos));
617 for(
int i = 0; i<
m_pModel->rowCount(); i++) {
649 for(qint32 i = 0; i <
m_pFiffInfo->chs.size(); ++i) {
700 QModelIndexList selected =
m_pTableView->selectionModel()->selectedIndexes();
702 for(
int i=0; i<selected.size(); i++) {
704 m_pModel->markChBad(selected[i],
false);
708 m_pModel->markChBad(selected[i],
true);
739 double dDx =
static_cast<double>(
m_pTableView->columnWidth(1)) /
static_cast<double>(
m_pModel->getMaxSamples());
740 double dSample =
static_cast<double>(
m_iClickPosX) / dDx;
742 int iFirstSampleOffset =
m_pModel->getFirstSampleOffset();
745 if (dSample >
m_pModel->getCurrentSampleIndex() && iFirstSampleOffset == 0){
750 int iAbsoluteSample =
static_cast<int>(dSample) + iFirstSampleOffset;
753 if (dSample >
m_pModel->getCurrentSampleIndex()){
754 iAbsoluteSample -=
m_pModel->getMaxSamples();
757 qDebug() <<
"EVENT SAMPLE:" << iAbsoluteSample;
Declaration of the RtFiffRawViewModel Class.
Declaration of the RtFiffRawViewDelegate Class.
Declaration of the RtFiffRawView Class.
The FilterKernel class represents a filter object that generates the FIR filter coefficients using Pa...
FiffInfo class declaration.
FIFF file I/O and data structures (raw, epochs, evoked, covariance, forward).
2-D display widgets and visualisation helpers (charts, topography, colour maps).
DSPSHARED_EXPORT Eigen::MatrixXd filterData(const Eigen::MatrixXd &matData, int type, double dCenterfreq, double dBandwidth, double dTransition, double dSFreq, int iOrder=1024, int designMethod=UTILSLIB::FilterKernel::m_designMethods.indexOf(UTILSLIB::FilterParameter("Cosine")), const Eigen::RowVectorXi &vecPicks=Eigen::RowVectorXi(), bool bUseThreads=true, bool bKeepOverhead=false)
Shared utilities (I/O helpers, spectral analysis, layout management, warp algorithms).
AbstractView(QWidget *parent=0, Qt::WindowFlags f=Qt::Widget)
The RtFiffRawViewDelegate class represents a RTMSA delegate which creates the plot paths.
void markerMoved(QPoint position, int activeRow)
The RtFiffRawViewModel class implements the data access model for a real-time multi sample array data...
void addEvent(int iSample)
void toggleFreeze(const QModelIndex &index)
void triggerDetected(int numberDetectedTriggers, const QMap< int, QList< QPair< int, double > > > &mapDetectedTriggers)
void setFilterChannelType(const QString &channelType)
QPointer< DISPLIB::RtFiffRawViewModel > m_pModel
QMap< qint32, float > m_qMapChScaling
void init(QSharedPointer< FIFFLIB::FiffInfo > &info)
QMap< qint32, float > getScalingMap()
RtFiffRawView(const QString &sSettingsPath="", QWidget *parent=0, Qt::WindowFlags f=Qt::Widget)
void takeScreenshot(const QString &fileName)
void updateGuiMode(GuiMode mode)
void setWindowSize(int T)
void visibleRowsChanged()
void updateCompensator(int to)
bool eventFilter(QObject *object, QEvent *event)
void triggerDetected(int numberDetectedTriggers, const QMap< int, QList< QPair< int, double > > > &mapDetectedTriggers)
void setBackgroundColor(const QColor &backgroundColor)
void addSampleAsEvent(int iSample)
void updateSpharaOptions(const QString &sSytemType, int nBaseFctsFirst, int nBaseFctsSecond)
void setDistanceTimeSpacer(int value)
QList< qint32 > m_qListBadChannels
float getSamplingFreq() const
QStringList m_slSelectedChannels
void channelContextMenu(QPoint pos)
Eigen::MatrixXd getLastBlock()
QPointer< QTableView > m_pTableView
void channelMarkingChanged()
void markerMoved(QPoint position, int activeRow)
void addData(const QList< Eigen::MatrixXd > &data)
void updateProcessingMode(ProcessingMode mode)
int m_iDistanceTimeSpacer
void showSelectedChannelsOnly(const QStringList &selectedChannels)
void updateSpharaActivation(bool state)
QSharedPointer< FIFFLIB::FiffInfo > m_pFiffInfo
void triggerInfoChanged(const QMap< double, QColor > &colorMap, bool active, const QString &triggerCh, double threshold)
void setSignalColor(const QColor &signalColor)
QColor getBackgroundColor()
void setSettingsPath(const QString &sSettingsPath)
QPointer< DISPLIB::RtFiffRawViewDelegate > m_pDelegate
void onAddEvent(bool bChecked)
bool getBadChannelHideStatus()
void resetTriggerCounter()
void setFilterActive(bool state)
void setFilter(const UTILSLIB::FilterKernel &filterData)
QList< qint32 > m_qListCurrentSelection
void updateProjection(const QList< FIFFLIB::FiffProj > &projs)
int getDistanceTimeSpacer()
void setZoom(double zoomFac)
void setScalingMap(const QMap< qint32, float > &scaleMap)
The FilterKernel class provides methods to create/design a FIR filter kernel.