X-Git-Url: http://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fview%2Ftimemarker.cpp;h=4874eb233c7ebf7d9fe5e282883dc93a1efbc8a7;hb=HEAD;hp=614275cf98e04d1d559d211cae6bf9740f595b15;hpb=8b855030926f6c271b650392d34444fd917ec764;p=pulseview.git diff --git a/pv/view/timemarker.cpp b/pv/view/timemarker.cpp deleted file mode 100644 index 614275cf..00000000 --- a/pv/view/timemarker.cpp +++ /dev/null @@ -1,187 +0,0 @@ -/* - * This file is part of the PulseView project. - * - * Copyright (C) 2012 Joel Holdsworth - * - * This program 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 2 of the License, or - * (at your option) any later version. - * - * This program 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 this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -#include - -#include - -#include "timemarker.hpp" - -#include "view.hpp" - -#include -#include -#include -#include - -#include - -using std::max; -using std::min; - -namespace pv { -namespace view { - -const int TimeMarker::ArrowSize = 4; - -TimeMarker::TimeMarker(View &view, const QColor &colour, double time) : - TimeItem(view), - colour_(colour), - time_(time), - value_action_(NULL), - value_widget_(NULL), - updating_value_widget_(false) -{ -} - -double TimeMarker::time() const -{ - return time_; -} - -void TimeMarker::set_time(double time) -{ - time_ = time; - - if (value_widget_) { - updating_value_widget_ = true; - value_widget_->setValue(time); - updating_value_widget_ = false; - } - - view_.time_item_appearance_changed(true, true); -} - -float TimeMarker::get_x() const -{ - return (time_ - view_.offset()) / view_.scale(); -} - -QPoint TimeMarker::point() const -{ - return QPoint(get_x(), 0); -} - -QRectF TimeMarker::label_rect(const QRectF &rect) const -{ - QFontMetrics m(QApplication::font()); - const QSizeF text_size( - max(m.boundingRect(get_text()).size().width(), ArrowSize), - m.height()); - const QSizeF label_size(text_size + LabelPadding * 2); - const float top = rect.height() - label_size.height() - - TimeMarker::ArrowSize - 0.5f; - const float x = (time_ - view_.offset()) / view_.scale(); - - return QRectF(QPointF(x - label_size.width() / 2, top), label_size); -} - -void TimeMarker::paint_label(QPainter &p, const QRect &rect, bool hover) -{ - if (!enabled()) - return; - - const qreal x = (time_ - view_.offset()) / view_.scale(); - const QRectF r(label_rect(rect)); - - const QPointF points[] = { - r.topLeft(), - r.bottomLeft(), - QPointF(max(r.left(), x - ArrowSize), r.bottom()), - QPointF(x, rect.bottom()), - QPointF(min(r.right(), x + ArrowSize), r.bottom()), - r.bottomRight(), - r.topRight() - }; - - const QPointF highlight_points[] = { - QPointF(r.left() + 1, r.top() + 1), - QPointF(r.left() + 1, r.bottom() - 1), - QPointF(max(r.left() + 1, x - ArrowSize), r.bottom() - 1), - QPointF(min(max(r.left() + 1, x), r.right() - 1), - rect.bottom() - 1), - QPointF(min(r.right() - 1, x + ArrowSize), r.bottom() - 1), - QPointF(r.right() - 1, r.bottom() - 1), - QPointF(r.right() - 1, r.top() + 1), - }; - - if (selected()) { - p.setPen(highlight_pen()); - p.setBrush(Qt::transparent); - p.drawPolygon(points, countof(points)); - } - - p.setPen(Qt::transparent); - p.setBrush(hover ? colour_.lighter() : colour_); - p.drawPolygon(points, countof(points)); - - p.setPen(colour_.lighter()); - p.setBrush(Qt::transparent); - p.drawPolygon(highlight_points, countof(highlight_points)); - - p.setPen(colour_.darker()); - p.setBrush(Qt::transparent); - p.drawPolygon(points, countof(points)); - - p.setPen(select_text_colour(colour_)); - p.drawText(r, Qt::AlignCenter | Qt::AlignVCenter, get_text()); -} - -void TimeMarker::paint_fore(QPainter &p, const ViewItemPaintParams &pp) -{ - if (!enabled()) - return; - - const float x = get_x(); - p.setPen(colour_.darker()); - p.drawLine(QPointF(x, pp.top()), QPointF(x, pp.bottom())); -} - -pv::widgets::Popup* TimeMarker::create_popup(QWidget *parent) -{ - using pv::widgets::Popup; - - Popup *const popup = new Popup(parent); - QFormLayout *const form = new QFormLayout(popup); - popup->setLayout(form); - - value_widget_ = new QDoubleSpinBox(parent); - value_widget_->setDecimals(9); - value_widget_->setSuffix("s"); - value_widget_->setSingleStep(1e-6); - value_widget_->setRange(-1.0e9, 1.0e9); - value_widget_->setValue(time_); - - connect(value_widget_, SIGNAL(valueChanged(double)), - this, SLOT(on_value_changed(double))); - - form->addRow(tr("Time"), value_widget_); - - return popup; -} - -void TimeMarker::on_value_changed(double value) -{ - if (!updating_value_widget_) - set_time(value); -} - -} // namespace view -} // namespace pv