Files
        @ 3216cc699a63
    
        
              Branch filter: 
        
    Location: tempo-plotter/plot.cpp - annotation
        
            
            3216cc699a63
            5.3 KiB
            text/x-c++hdr
        
        
    
    added "Commands" menu
    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 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220  | e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef b0ad4149e405 e8c51b2d8584 28d94037f25d e8c51b2d8584 e1ce86573eef e8c51b2d8584 e8c51b2d8584 e1ce86573eef e1ce86573eef 19375fc29267 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e1ce86573eef bb5876e1e5d6 e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef 62a88b598bdb a3678ca6cfab c8ad43700b6a a3678ca6cfab e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 c8ad43700b6a e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 c8ad43700b6a c8ad43700b6a e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e8c51b2d8584 e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef e1ce86573eef d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 d678428ad457 a3678ca6cfab a3678ca6cfab a3678ca6cfab 28d94037f25d a3678ca6cfab a3678ca6cfab a3678ca6cfab 28d94037f25d 28d94037f25d a3678ca6cfab a3678ca6cfab 1d12f68d4882 a3678ca6cfab a3678ca6cfab a3678ca6cfab a3678ca6cfab 28d94037f25d 28d94037f25d a3678ca6cfab a3678ca6cfab 1d12f68d4882 a3678ca6cfab a3678ca6cfab a3678ca6cfab 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b 52f54b71dc6b c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f c51c9195eb8f  | /*
  Copyright © 2015 Hasan Yavuz Özderya
  This file is part of serialplot.
  serialplot is free software: you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation, either version 3 of the License, or
  (at your option) any later version.
  serialplot is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.
  You should have received a copy of the GNU General Public License
  along with serialplot.  If not, see <http://www.gnu.org/licenses/>.
*/
#include <QRectF>
#include <QKeySequence>
#include <QColor>
#include "plot.h"
#include "utils.h"
Plot::Plot(QWidget* parent) :
    QwtPlot(parent),
    zoomer(this->canvas(), false),
    sZoomer(this, &zoomer),
    _showGridAction("Grid", this),
    _showMinorGridAction("Minor Grid", this),
    _unzoomAction("Unzoom", this),
    _darkBackgroundAction("Dark Background", this)
{
    isAutoScaled = true;
    QObject::connect(&zoomer, &Zoomer::unzoomed, this, &Plot::unzoomed);
    zoomer.setZoomBase();
    grid.attach(this);
    showGrid(false);
    darkBackground(false);
    _showGridAction.setToolTip("Show Grid");
    _showMinorGridAction.setToolTip("Show Minor Grid");
    _unzoomAction.setToolTip("Unzoom the Plot");
    _darkBackgroundAction.setToolTip("Enable Dark Plot Background");
    _showGridAction.setShortcut(QKeySequence("G"));
    _showMinorGridAction.setShortcut(QKeySequence("M"));
    _showGridAction.setCheckable(true);
    _showMinorGridAction.setCheckable(true);
    _darkBackgroundAction.setCheckable(true);
    _showGridAction.setChecked(false);
    _showMinorGridAction.setChecked(false);
    _darkBackgroundAction.setChecked(false);
    _showMinorGridAction.setEnabled(false);
    connect(&_showGridAction, SELECT<bool>::OVERLOAD_OF(&QAction::triggered),
            this, &Plot::showGrid);
    connect(&_showGridAction, SELECT<bool>::OVERLOAD_OF(&QAction::triggered),
            &_showMinorGridAction, &QAction::setEnabled);
    connect(&_showMinorGridAction, SELECT<bool>::OVERLOAD_OF(&QAction::triggered),
            this, &Plot::showMinorGrid);
    connect(&_unzoomAction, &QAction::triggered, this, &Plot::unzoom);
    connect(&_darkBackgroundAction, SELECT<bool>::OVERLOAD_OF(&QAction::triggered),
            this, &Plot::darkBackground);
    snapshotOverlay = NULL;
}
Plot::~Plot()
{
    if (snapshotOverlay != NULL) delete snapshotOverlay;
}
void Plot::setAxis(bool autoScaled, double yAxisMin, double yAxisMax)
{
    this->isAutoScaled = autoScaled;
    if (!autoScaled)
    {
        yMin = yAxisMin;
        yMax = yAxisMax;
    }
    zoomer.zoom(0);
    resetAxes();
}
QList<QAction*> Plot::menuActions()
{
    QList<QAction*> actions;
    actions << &_showGridAction;
    actions << &_showMinorGridAction;
    actions << &_unzoomAction;
    actions << &_darkBackgroundAction;
    return actions;
}
void Plot::resetAxes()
{
    if (isAutoScaled)
    {
        setAxisAutoScale(QwtPlot::yLeft);
    }
    else
    {
        setAxisScale(QwtPlot::yLeft, yMin, yMax);
    }
    replot();
}
void Plot::unzoomed()
{
    setAxisAutoScale(QwtPlot::xBottom);
    resetAxes();
}
void Plot::showGrid(bool show)
{
    grid.enableX(show);
    grid.enableY(show);
    replot();
}
void Plot::showMinorGrid(bool show)
{
    grid.enableXMin(show);
    grid.enableYMin(show);
    replot();
}
void Plot::unzoom()
{
    zoomer.zoom(0);
}
void Plot::darkBackground(bool enabled)
{
    QColor gridColor;
    if (enabled)
    {
        setCanvasBackground(QBrush(Qt::black));
        gridColor.setHsvF(0, 0, 0.25);
        grid.setPen(gridColor);
        zoomer.setRubberBandPen(QPen(Qt::white));
        zoomer.setTrackerPen(QPen(Qt::white));
        sZoomer.setPickerPen(QPen(Qt::white));
    }
    else
    {
        setCanvasBackground(QBrush(Qt::white));
        gridColor.setHsvF(0, 0, 0.80);
        grid.setPen(gridColor);
        zoomer.setRubberBandPen(QPen(Qt::black));
        zoomer.setTrackerPen(QPen(Qt::black));
        sZoomer.setPickerPen(QPen(Qt::black));
    }
    replot();
}
/*
  Below crude drawing demostrates how color selection occurs for
  given channel index
  0°                     <--Hue Value-->                           360°
  |* . o . + . o . * . o . + . o . * . o . + . o . * . o . + . o . |
  * -> 0-3
  + -> 4-7
  o -> 8-15
  . -> 16-31
 */
QColor Plot::makeColor(unsigned int channelIndex)
{
    auto i = channelIndex;
    if (i < 4)
    {
        return QColor::fromHsv(360*i/4, 255, 230);
    }
    else
    {
        double p = floor(log2(i));
        double n = pow(2, p);
        i = i - n;
        return QColor::fromHsv(360*i/n + 360/pow(2,p+1), 255, 230);
    }
}
void Plot::flashSnapshotOverlay()
{
    if (snapshotOverlay != NULL) delete snapshotOverlay;
    QColor color;
    if (_darkBackgroundAction.isChecked())
    {
        color = QColor(Qt::white);
    }
    else
    {
        color = QColor(Qt::black);
    }
    snapshotOverlay = new PlotSnapshotOverlay(this->canvas(), color);
    connect(snapshotOverlay, &PlotSnapshotOverlay::done,
            [this]()
            {
                delete snapshotOverlay;
                snapshotOverlay = NULL;
            });
}
 |