38 MatrixDatafieldDisplayWidget::updateRequested()
41 this->data = matrixDatafieldOffsetFiltered->getDataField()->get<
MatrixFloat>()->
toEigen();
42 this->percentiles = percentilesDatafield->getDataField()->get<
MatrixFloat>()->toVector();
48 ObserverInterfacePrx observer,
52 this->matrixDatafield = DatafieldRefPtr::dynamicCast(matrixDatafield);
53 this->observer = observer;
56 this->data = MatrixXf(1, 1);
59 QColor
c[] = {QColor::fromHsv(0, 0, 0),
60 QColor::fromHsv(240, 255, 255),
61 QColor::fromHsv(270, 255, 255),
62 QColor::fromHsv(300, 255, 255),
63 QColor::fromHsv(0, 255, 255),
64 QColor::fromHsv(30, 255, 255),
65 QColor::fromHsv(60, 255, 255)};
66 this->colors = std::valarray<QColor>(
c,
sizeof c /
sizeof c[0]);
69 connect(
this, SIGNAL(
doUpdate()), SLOT(updateRequested()), Qt::QueuedConnection);
82 int paddingBottom = 40;
83 QPainter painter(
this);
84 painter.fillRect(rect(), QColor::fromRgb(0, 0, 0));
85 int matrixHeight = (height() - paddingBottom) * 8 / 10;
86 int percentilesHeight = (height() - paddingBottom) - matrixHeight;
87 drawMatrix(QRect(0, 0, width(), matrixHeight), painter);
88 drawPercentiles(QRect(0, matrixHeight, width() - 1, percentilesHeight), painter);
90 painter.setPen(QColor(Qt::GlobalColor::gray));
91 painter.setFont(QFont(
"Arial", 12));
92 painter.drawText(rect(), Qt::AlignBottom | Qt::AlignRight, infoOverlay);
102 this->matrixDatafieldOffsetFiltered =
103 DatafieldRefPtr::dynamicCast(observer->createFilteredDatafield(
108 this->matrixDatafieldOffsetFiltered = this->matrixDatafield;
111 this->percentilesDatafield = DatafieldRefPtr::dynamicCast(observer->createFilteredDatafield(
113 matrixDatafieldOffsetFiltered));
126 if (
value >= colors.size() - 1)
128 return colors[colors.size() - 1];
132 float f2 =
value - i;
134 QColor c1 = colors[i];
135 QColor c2 = colors[i + 1];
136 return QColor((
int)(c1.red() * f1 + c2.red() * f2),
137 (
int)(c1.green() * f1 + c2.green() * f2),
138 (
int)(c1.blue() * f1 + c2.blue() * f2));
142 MatrixDatafieldDisplayWidget::drawMatrix(
const QRect&
target, QPainter& painter)
145 int dx = (
target.width() - pixelSize * data.cols()) / 2;
146 int dy = (
target.height() - pixelSize * data.rows()) / 2;
147 painter.setFont(QFont(
"Arial", 8));
148 painter.setPen(QColor(Qt::GlobalColor::gray));
150 for (
int x = 0; x < data.cols(); x++)
152 for (
int y = 0; y < data.rows(); y++)
154 QRect
target = QRect(dx + x * pixelSize, dy + y * pixelSize, pixelSize, pixelSize);
156 painter.drawText(
target, Qt::AlignCenter, QString::number(data(y, x)));
162 MatrixDatafieldDisplayWidget::drawPercentiles(
const QRect&
target, QPainter& painter)
164 painter.setPen(QColor(Qt::GlobalColor::gray));
168 for (
int i = 0; i < (int)percentiles.size() - 1; i++)
170 int x1 = i *
target.width() / (percentiles.size() - 1);
171 int x2 = (i + 1) *
target.width() / (percentiles.size() - 1);
172 float y1 = (percentiles.at(i) - min) / (max - min) *
target.height();
173 float y2 = (percentiles.at(i + 1) - min) / (max - min) *
target.height();
174 painter.drawLine(
target.left() + x1,
175 target.bottom() - (int)y1,
177 target.bottom() - (int)y2);