]> sigrok.org Git - pulseview.git/blame - pv/views/trace/signal.hpp
DecoderOutput: Add basic view skeleton
[pulseview.git] / pv / views / trace / signal.hpp
CommitLineData
28a4c9c5 1/*
b3f22de0 2 * This file is part of the PulseView project.
28a4c9c5
JH
3 *
4 * Copyright (C) 2012 Joel Holdsworth <joel@airwebreathe.org.uk>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
efdec55a 17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
28a4c9c5
JH
18 */
19
f4e57597
SA
20#ifndef PULSEVIEW_PV_VIEWS_TRACEVIEW_SIGNAL_HPP
21#define PULSEVIEW_PV_VIEWS_TRACEVIEW_SIGNAL_HPP
640d091b 22
f9abf97e 23#include <memory>
9a0cd293 24
9e40e83d 25#include <QComboBox>
9e40e83d 26#include <QWidgetAction>
e3f65ace 27
cafe470e 28#include <cstdint>
28a4c9c5 29
eeceee99
SA
30#include <pv/data/logicsegment.hpp>
31
2acdb232 32#include "trace.hpp"
4b5782e1 33#include "viewitemowner.hpp"
e0e90d80 34
6f925ba9
UH
35using std::shared_ptr;
36
51e77110
JH
37namespace pv {
38
2b81ae46 39class Session;
b86aa8f4 40
1b1ec774 41namespace data {
bf0edd2b 42class SignalBase;
28a4c9c5 43class SignalData;
1b1ec774 44}
28a4c9c5 45
f4e57597 46namespace views {
1573bf16 47namespace trace {
a2f71ef0 48
1373fec5
SA
49/**
50 * The Signal class represents a series of numeric values that can be drawn.
51 * This is the main difference to the more generic @ref Trace class.
52 *
53 * It is generally accepted that Signal instances consider themselves to be
54 * individual channels on e.g. an oscilloscope, though it should be kept in
55 * mind that virtual signals (e.g. math) will also be served by the Signal
56 * class.
57 */
4b5782e1 58class Signal : public Trace, public ViewItemOwner
28a4c9c5 59{
2a2512b2
JH
60 Q_OBJECT
61
28a4c9c5 62protected:
6f925ba9 63 Signal(pv::Session &session, shared_ptr<data::SignalBase> channel);
28a4c9c5
JH
64
65public:
49f8ff3f
JH
66 /**
67 * Sets the name of the signal.
68 */
bf0edd2b 69 virtual void set_name(QString name);
49f8ff3f 70
6f925ba9 71 virtual shared_ptr<pv::data::SignalData> data() const = 0;
9a0cd293 72
eeceee99
SA
73 /**
74 * Determines the closest level change (i.e. edge) to a given sample, which
75 * is useful for e.g. the "snap to edge" functionality.
76 *
77 * @param sample_pos Sample to use
78 * @return The changes left and right of the given position
79 */
80 virtual vector<data::LogicSegment::EdgePair> get_nearest_level_changes(uint64_t sample_pos) = 0;
81
b3b57abc 82 /**
931f20b0 83 * Returns true if the trace is visible and enabled.
a29bb7fb 84 */
931f20b0 85 bool enabled() const;
a29bb7fb 86
6f925ba9 87 shared_ptr<data::SignalBase> base() const;
632ba77e 88
3a21afa6
SA
89 virtual void save_settings(QSettings &settings) const;
90
91 virtual void restore_settings(QSettings &settings);
92
60938e04 93 void paint_back(QPainter &p, ViewItemPaintParams &pp);
99af6802 94
0c0218fd
JH
95 virtual void populate_popup_form(QWidget *parent, QFormLayout *form);
96
9e773fec 97 QMenu* create_header_context_menu(QWidget *parent);
86e823ca 98
5ed1adf5
JH
99 void delete_pressed();
100
bf0edd2b
SA
101protected Q_SLOTS:
102 virtual void on_name_changed(const QString &text);
103
86e823ca
JH
104 void on_disable();
105
a45b9b9e
SA
106 void on_enabled_changed(bool enabled);
107
28a4c9c5 108protected:
2b81ae46 109 pv::Session &session_;
cec48d16 110
8dbbc7f0 111 QComboBox *name_widget_;
28a4c9c5 112};
51e77110 113
1573bf16 114} // namespace trace
f4e57597 115} // namespace views
51e77110 116} // namespace pv
640d091b 117
f4e57597 118#endif // PULSEVIEW_PV_VIEWS_TRACEVIEW_SIGNAL_HPP