Files
        @ 81bc58c2b941
    
        
              Branch filter: 
        
    Location: tempo-plotter/src/zoomer.cpp - annotation
        
            
            81bc58c2b941
            4.1 KiB
            text/x-c++hdr
        
        
    
    find values from tracker x position, no drawing yet
    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  | bdc33b5c53c6 81bc58c2b941 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 c9d4060942ac c9d4060942ac 81bc58c2b941 1e848e98efb7 bdc33b5c53c6 c9d4060942ac 81bc58c2b941 c9d4060942ac 3dcdee629416 3dcdee629416 da3f4cd6026d da3f4cd6026d da3f4cd6026d da3f4cd6026d da3f4cd6026d da3f4cd6026d bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 1e848e98efb7 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 bdc33b5c53c6 60d04e19e663 60d04e19e663 60d04e19e663 60d04e19e663 60d04e19e663 60d04e19e663 60d04e19e663 60d04e19e663 60d04e19e663 60d04e19e663 60d04e19e663 d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a 3dcdee629416 e3e70c855836 e3e70c855836 e3e70c855836 e3e70c855836 d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a d4a271f3d46a 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 754420135f22 c9d4060942ac 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 81bc58c2b941 c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac 4539c1ce7a85 c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac 4539c1ce7a85 c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac c9d4060942ac  | /*
  Copyright © 2018 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 "zoomer.h"
#include <qwt_plot.h>
#include <QtDebug>
#include <QMouseEvent>
Zoomer::Zoomer(QWidget* widget, const Stream* stream, bool doReplot) :
    ScrollZoomer(widget)
{
    is_panning = false;
    _stream = stream;
    setTrackerMode(AlwaysOn);
    // set corner widget between the scrollbars with default background color
    auto cornerWidget = new QWidget();
    auto bgColor = cornerWidget->palette().color(QPalette::Window).name();
    auto styleSheet = QString("background-color:%1;").arg(bgColor);
    cornerWidget->setStyleSheet(styleSheet);
    ScrollZoomer::setCornerWidget(cornerWidget);
}
void Zoomer::zoom(int up)
{
    ScrollZoomer::zoom(up);
    if(zoomRectIndex() == 0)
    {
        emit unzoomed();
    }
}
void Zoomer::zoom( const QRectF & rect)
{
    // set the zoom base when user zooms in to first level
    if (zoomRectIndex() == 0)
    {
        this->setZoomBase(false);
    }
    ScrollZoomer::zoom(rect);
}
QwtText Zoomer::trackerTextF(const QPointF& pos) const
{
    QwtText b = ScrollZoomer::trackerTextF(pos);
    const QPolygon pa = selection();
    if (!isActive() || pa.count() < 2)
    {
        return b;
    }
    const QRectF rect = invTransform(QRect(pa.first(), pa.last()).normalized());
    QString sizeText = QString(" [%1, %2]").\
        arg(rect.width(), 0, 'g', 4).\
        arg(rect.height(), 0, 'g', 4);
    b.setText(b.text() + sizeText);
    return b;
}
void Zoomer::drawRubberBand(QPainter* painter) const
{
    const double FILL_ALPHA = 0.2;
    QColor color = painter->pen().color();
    color.setAlphaF(FILL_ALPHA);
    painter->setBrush(color);
    ScrollZoomer::drawRubberBand(painter);
}
QRegion Zoomer::rubberBandMask() const
{
    const QPolygon pa = selection();
    if (pa.count() < 2)
    {
        return QRegion();
    }
    const QRect r = QRect(pa.first(), pa.last()).normalized().adjusted(0, 0, 1, 1);
    return QRegion(r);
}
void Zoomer::drawTracker(QPainter* painter) const
{
    ScrollZoomer::drawTracker(painter);
    auto x = invTransform(trackerPosition()).x();
    qDebug() <<  x;
    if (_stream != nullptr && _stream->numChannels())
    {
        qDebug() << findValues(x);
    }
    return;
}
QVector<double> Zoomer::findValues(double x) const
{
    unsigned nc = _stream->numChannels();
    QVector<double> r(nc);
    for (unsigned ci = 0; ci < nc; ci++)
    {
        auto chan = _stream->channel(ci);
        double val = chan->findValue(x);
        r[ci] = val;
    }
    return r;
}
void Zoomer::widgetMousePressEvent(QMouseEvent* mouseEvent)
{
    if (mouseEvent->modifiers() & Qt::ControlModifier)
    {
        is_panning = true;
        parentWidget()->setCursor(Qt::ClosedHandCursor);
        pan_point = invTransform(mouseEvent->pos());
    }
    else
    {
        ScrollZoomer::widgetMousePressEvent(mouseEvent);
    }
}
void Zoomer::widgetMouseMoveEvent(QMouseEvent* mouseEvent)
{
    if (is_panning)
    {
        auto cur_point = invTransform(mouseEvent->pos());
        auto delta = cur_point - pan_point;
        moveBy(-delta.x(), -delta.y());
        pan_point = invTransform(mouseEvent->pos());
    }
    else
    {
        ScrollZoomer::widgetMouseMoveEvent(mouseEvent);
    }
}
void Zoomer::widgetMouseReleaseEvent(QMouseEvent* mouseEvent)
{
    if (is_panning)
    {
        is_panning = false;
        parentWidget()->setCursor(Qt::CrossCursor);
    }
    else
    {
        ScrollZoomer::widgetMouseReleaseEvent(mouseEvent);
    }
}
 |