Moved Cursor markers to the outside
authorJoel Holdsworth <joel@airwebreathe.org.uk>
Sat, 20 Apr 2013 11:59:01 +0000 (12:59 +0100)
committerJoel Holdsworth <joel@airwebreathe.org.uk>
Sat, 20 Apr 2013 11:59:01 +0000 (12:59 +0100)
pv/view/cursor.cpp
pv/view/cursor.h
pv/view/cursorpair.cpp

index 1ec3b37a9948cf31d4d492c2af80973685d615b9..855bfa01a7fbc47a0a78d00e6309e835401048e7 100644 (file)
@@ -45,8 +45,9 @@ const int Cursor::Offset = 1;
 
 const int Cursor::ArrowSize = 4;
 
-Cursor::Cursor(const View &view, double time) :
-       TimeMarker(view, LineColour, time)
+Cursor::Cursor(const View &view, double time, Cursor &other) :
+       TimeMarker(view, LineColour, time),
+       _other(other)
 {
 }
 
@@ -68,38 +69,66 @@ void Cursor::paint_label(QPainter &p, const QRect &rect,
        compute_text_size(p, prefix);
        const QRectF r(get_label_rect(rect));
 
-       const float h_centre = (r.left() + r.right()) / 2;
-       const QPointF points[] = {
-               r.topRight(),
-               QPointF(r.right(), r.bottom()),
-               QPointF(h_centre + ArrowSize, r.bottom()),
-               QPointF(h_centre, rect.bottom()),
-               QPointF(h_centre - ArrowSize, r.bottom()),
-               QPointF(r.left(), r.bottom()),
-               r.topLeft()
-       };
-
-       const QPointF highlight_points[] = {
-               QPointF(r.right() - 1, r.top() + 1),
-               QPointF(r.right() - 1, r.bottom() - 1),
-               QPointF(h_centre + ArrowSize - 1, r.bottom() - 1),
-               QPointF(h_centre, rect.bottom() - 1),
-               QPointF(h_centre - ArrowSize + 1, r.bottom() - 1),
-               QPointF(r.left() + 1, r.bottom() - 1),
-               QPointF(r.left() + 1, r.top() + 1),
-       };
-
-       p.setPen(Qt::transparent);
-       p.setBrush(FillColour);
-       p.drawPolygon(points, countof(points));
-
-       p.setPen(HighlightColour);
-       p.setBrush(Qt::transparent);
-       p.drawPolygon(highlight_points, countof(highlight_points));
-
-       p.setPen(LineColour);
-       p.setBrush(Qt::transparent);
-       p.drawPolygon(points, countof(points));
+       if (_time > _other.time())
+       {
+               const QPointF points[] = {
+                       r.topLeft(),
+                       r.topRight(),
+                       r.bottomRight(),
+                       QPointF(r.left() + ArrowSize, r.bottom()),
+                       QPointF(r.left(), rect.bottom()),
+               };
+
+               const QPointF highlight_points[] = {
+                       QPointF(r.left() + 1, r.top() + 1),
+                       QPointF(r.right() - 1, r.top() + 1),
+                       QPointF(r.right() - 1, r.bottom() - 1),
+                       QPointF(r.left() + ArrowSize - 1, r.bottom() - 1),
+                       QPointF(r.left() + 1, rect.bottom() - 1),
+               };
+
+               p.setPen(Qt::transparent);
+               p.setBrush(FillColour);
+               p.drawPolygon(points, countof(points));
+
+               p.setPen(HighlightColour);
+               p.setBrush(Qt::transparent);
+               p.drawPolygon(highlight_points, countof(highlight_points));
+
+               p.setPen(LineColour);
+               p.setBrush(Qt::transparent);
+               p.drawPolygon(points, countof(points));
+       }
+       else
+       {
+               const QPointF points[] = {
+                       r.topRight(),
+                       r.topLeft(),
+                       r.bottomLeft(),
+                       QPointF(r.right() - ArrowSize, r.bottom()),
+                       QPointF(r.right(), rect.bottom()),
+               };
+
+               const QPointF highlight_points[] = {
+                       QPointF(r.right() - 1, r.top() + 1),
+                       QPointF(r.left() + 1, r.top() + 1),
+                       QPointF(r.left() + 1, r.bottom() - 1),
+                       QPointF(r.right() - ArrowSize + 1, r.bottom() - 1),
+                       QPointF(r.right() - 1, rect.bottom() - 1),
+               };
+
+               p.setPen(Qt::transparent);
+               p.setBrush(FillColour);
+               p.drawPolygon(points, countof(points));
+
+               p.setPen(HighlightColour);
+               p.setBrush(Qt::transparent);
+               p.drawPolygon(highlight_points, countof(highlight_points));
+
+               p.setPen(LineColour);
+               p.setBrush(Qt::transparent);
+               p.drawPolygon(points, countof(points));
+       }
 
        p.setPen(TextColour);
        p.drawText(r, Qt::AlignCenter | Qt::AlignVCenter,
index 2e16882dac28613b1d81796a4b2a216c10d413bd..4c0c35dd85de81d8372d0804f090ac9230df3257 100644 (file)
@@ -49,8 +49,9 @@ public:
         * Constructor.
         * @param view A reference to the view that owns this cursor pair.
         * @param time The time to set the flag to.
+        * @param other A reference to the other cursor.
         */
-       Cursor(const View &view, double time);
+       Cursor(const View &view, double time, Cursor &other);
 
 public:
        /**
@@ -73,6 +74,8 @@ private:
        void compute_text_size(QPainter &p, unsigned int prefix);
 
 private:
+       const Cursor &_other;
+
        QSizeF _text_size;
 };
 
index c148b85139d55d052cf5c444af8a18f27cd002e7..feac91d20d47a513c60f0a294c97b4f4fbda65cb 100644 (file)
@@ -30,8 +30,8 @@ namespace pv {
 namespace view {
 
 CursorPair::CursorPair(const View &view) :
-       _first(view, 0.0),
-       _second(view, 1.0),
+       _first(view, 0.0, _second),
+       _second(view, 1.0, _first),
        _view(view)
 {
 }