57#include <QSvgGenerator>
62#if !defined(NO_QOPENGLWIDGET)
63 #include <QOpenGLWidget>
93#if !defined(NO_QOPENGLWIDGET)
102 QVBoxLayout *neLayout =
new QVBoxLayout(
this);
104 neLayout->setContentsMargins(0,0,0,0);
105 this->setLayout(neLayout);
121#if !defined(NO_QOPENGLWIDGET)
154 for(
int i = 0; i<
m_pModel->rowCount(); i++) {
170 m_pTableView->setContextMenuPolicy(Qt::CustomContextMenu);
172 connect(
m_pTableView.data(), &QTableView::doubleClicked,
175 connect(
m_pTableView.data(), &QTableView::customContextMenuRequested,
179 m_pTableView->setSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding);
181 m_pTableView->horizontalHeader()->setSectionResizeMode(1, QHeaderView::Stretch);
188 m_pTableView->setHorizontalScrollMode(QAbstractItemView::ScrollPerPixel);
190 connect(
m_pTableView->verticalScrollBar(), &QScrollBar::valueChanged,
198 if(!data.isEmpty()) {
203 for(
int i = 0; i<
m_pModel->rowCount(); i++) {
219 qWarning() <<
"[RtFiffRawView::addData] Received data list is empty.";
240 return QWidget::eventFilter(
object, event);
332 for(
int i = 0; i<
m_pModel->rowCount(); i++) {
333 QString channel =
m_pModel->data(
m_pModel->index(i, 0), Qt::DisplayRole).toString();
390 if(fileName.contains(
".svg", Qt::CaseInsensitive)) {
392 QSvgGenerator svgGen;
393 svgGen.setFileName(fileName);
400 if(fileName.contains(
".png", Qt::CaseInsensitive)) {
402 pixMap.save(fileName);
424 m_pModel->updateSpharaActivation(state);
431 m_pModel->updateSpharaOptions(sSytemType, nBaseFctsFirst, nBaseFctsSecond);
452 m_pModel->setFilterChannelType(channelType);
459 const QString &triggerCh,
462 m_pModel->triggerInfoChanged(colorMap, active, triggerCh, threshold);
470 m_pModel->distanceTimeSpacerChanged(value);
495 QSettings settings(
"MNECPP");
506 QSettings settings(
"MNECPP");
543 QModelIndexList selected =
m_pTableView->selectionModel()->selectedIndexes();
546 QMenu *menu =
new QMenu(
this);
548 menu->addSection(
"Events");
550 QAction* addEventMarker = menu->addAction(tr(
"Add event"));
551 connect(addEventMarker, &QAction::triggered,
556 menu->addSection(
"Channel Marking");
559 QAction* doMarkChBad = menu->addAction(tr(
"Mark as bad"));
560 connect(doMarkChBad, &QAction::triggered,
563 QAction* doMarkChGood = menu->addAction(tr(
"Mark as good"));
564 connect(doMarkChGood, &QAction::triggered,
570 for(qint32 i = 0; i < selected.size(); ++i)
571 if(selected[i].column() == 1)
574 menu->addSection(
"Selection");
576 QAction* doSelection = menu->addAction(tr(
"Only show selection"));
577 connect(doSelection, &QAction::triggered,
581 QAction*
hideSelection = menu->addAction(tr(
"Hide selection"));
586 QAction* resetAppliedSelection = menu->addAction(tr(
"Reset selection"));
587 connect(resetAppliedSelection, &QAction::triggered,
589 connect(resetAppliedSelection, &QAction::triggered,
593 menu->popup(
m_pTableView->viewport()->mapToGlobal(pos));
601 for(
int i = 0; i<
m_pModel->rowCount(); i++) {
633 for(qint32 i = 0; i <
m_pFiffInfo->chs.size(); ++i) {
684 QModelIndexList selected =
m_pTableView->selectionModel()->selectedIndexes();
686 for(
int i=0; i<selected.size(); i++) {
688 m_pModel->markChBad(selected[i],
false);
692 m_pModel->markChBad(selected[i],
true);
723 double dDx =
static_cast<double>(
m_pTableView->columnWidth(1)) /
static_cast<double>(
m_pModel->getMaxSamples());
724 double dSample =
static_cast<double>(
m_iClickPosX) / dDx;
726 int iFirstSampleOffset =
m_pModel->getFirstSampleOffset();
729 if (dSample >
m_pModel->getCurrentSampleIndex() && iFirstSampleOffset == 0){
734 int iAbsoluteSample =
static_cast<int>(dSample) + iFirstSampleOffset;
737 if (dSample >
m_pModel->getCurrentSampleIndex()){
738 iAbsoluteSample -=
m_pModel->getMaxSamples();
741 qDebug() <<
"EVENT SAMPLE:" << iAbsoluteSample;
The FilterKernel class represents a filter object that generates the FIR filter coefficients using Pa...
Declaration of the RtFiffRawView Class.
Declaration of the RtFiffRawViewModel Class.
Declaration of the RtFiffRawViewDelegate Class.
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).
Real-time signal processing (filtering, averaging, HPI fitting, noise reduction).
Eigen::MatrixXd filterData(const Eigen::MatrixXd &matData, int type, double dCenterfreq, double dBandwidth, double dTransition, double dSFreq, int iOrder=1024, int designMethod=FilterKernel::m_designMethods.indexOf(FilterParameter("Cosine")), const Eigen::RowVectorXi &vecPicks=Eigen::RowVectorXi(), bool bUseThreads=true, bool bKeepOverhead=false)
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 updateOpenGLViewport()
QList< qint32 > m_qListCurrentSelection
void updateProjection(const QList< FIFFLIB::FiffProj > &projs)
int getDistanceTimeSpacer()
void setZoom(double zoomFac)
void setFilter(const RTPROCESSINGLIB::FilterKernel &filterData)
void setScalingMap(const QMap< qint32, float > &scaleMap)
The FilterKernel class provides methods to create/design a FIR filter kernel.