File: baselineplotpage.cpp

package info (click to toggle)
aoflagger 3.4.0-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 8,688 kB
  • sloc: cpp: 83,116; python: 10,187; sh: 260; makefile: 178
file content (37 lines) | stat: -rw-r--r-- 1,377 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#include <limits>

#include "baselineplotpage.h"

#include "controllers/baselinepagecontroller.h"

BaselinePlotPage::BaselinePlotPage(BaselinePageController* controller)
    : GrayScalePlotPage(controller), _controller(controller) {
  grayScaleWidget().OnMouseMovedEvent().connect(
      sigc::mem_fun(*this, &BaselinePlotPage::onMouseMoved));
}

BaselinePlotPage::~BaselinePlotPage() {}

void BaselinePlotPage::onMouseMoved(double x, double y) {
  const MaskedHeatMap& map =
      static_cast<MaskedHeatMap&>(grayScaleWidget().Plot());
  size_t image_x;
  size_t image_y;
  if (map.UnitToImage(x, y, image_x, image_y)) {
    const std::string antenna1Name = _controller->AntennaName(x);
    const std::string antenna2Name = _controller->AntennaName(y);
    const QualityTablesFormatter::StatisticKind kind =
        getSelectedStatisticKind();
    const std::string& kindName = QualityTablesFormatter::KindToName(kind);

    std::stringstream text;
    const size_t stride =
        static_cast<HeatMap&>(grayScaleWidget().Plot()).Image().Stride();
    text << "Correlation " << antenna1Name << " (" << image_x << ") x "
         << antenna2Name << " (" << image_y << "), " << kindName << " = "
         << static_cast<HeatMap&>(grayScaleWidget().Plot())
                .Image()
                .Data()[image_y * stride + image_x];
    _signalStatusChange(text.str());
  }
}