X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;ds=inline;f=pv%2Fview%2Fsignal.hpp;h=8796660e175fd4ce84d779afbeb660889681ee0f;hb=53bb2e1de75f5cca9244efc83c4e77a222e322f4;hp=714b44f6d9d27fcfc4881dc9e4850138f575b0a4;hpb=214470fc17e73bbf4664f4c1678a7dd30c905bf2;p=pulseview.git
diff --git a/pv/view/signal.hpp b/pv/view/signal.hpp
index 714b44f..8796660 100644
--- a/pv/view/signal.hpp
+++ b/pv/view/signal.hpp
@@ -14,12 +14,11 @@
* 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
+ * along with this program; if not, see .
*/
-#ifndef PULSEVIEW_PV_VIEW_SIGNAL_HPP
-#define PULSEVIEW_PV_VIEW_SIGNAL_HPP
+#ifndef PULSEVIEW_PV_VIEWS_TRACEVIEW_SIGNAL_HPP
+#define PULSEVIEW_PV_VIEWS_TRACEVIEW_SIGNAL_HPP
#include
@@ -28,22 +27,21 @@
#include
+#include "signalscalehandle.hpp"
#include "trace.hpp"
#include "viewitemowner.hpp"
-namespace sigrok {
- class Channel;
-}
-
namespace pv {
class Session;
namespace data {
+class SignalBase;
class SignalData;
}
-namespace view {
+namespace views {
+namespace TraceView {
class Signal : public Trace, public ViewItemOwner
{
@@ -51,13 +49,13 @@ class Signal : public Trace, public ViewItemOwner
protected:
Signal(pv::Session &session,
- std::shared_ptr channel);
+ std::shared_ptr channel);
public:
/**
* Sets the name of the signal.
*/
- void set_name(QString name);
+ virtual void set_name(QString name);
virtual std::shared_ptr data() const = 0;
@@ -66,15 +64,19 @@ public:
*/
bool enabled() const;
- void enable(bool enable = true);
+ std::shared_ptr base() const;
+
+ virtual void save_settings(QSettings &settings) const;
- std::shared_ptr channel() const;
+ virtual void restore_settings(QSettings &settings);
/**
* Returns a list of row items owned by this object.
*/
const item_list& child_items() const;
+ void paint_back(QPainter &p, const ViewItemPaintParams &pp);
+
virtual void populate_popup_form(QWidget *parent, QFormLayout *form);
QMenu* create_context_menu(QWidget *parent);
@@ -97,20 +99,24 @@ public:
*/
virtual void scale_handle_released() {};
-private Q_SLOTS:
+protected Q_SLOTS:
+ virtual void on_name_changed(const QString &text);
+
void on_disable();
+ void on_enabled_changed(bool enabled);
+
protected:
pv::Session &session_;
- std::shared_ptr channel_;
+ const std::shared_ptr scale_handle_;
const item_list items_;
QComboBox *name_widget_;
- bool updating_name_widget_;
};
-} // namespace view
+} // namespace TraceView
+} // namespace views
} // namespace pv
-#endif // PULSEVIEW_PV_VIEW_SIGNAL_HPP
+#endif // PULSEVIEW_PV_VIEWS_TRACEVIEW_SIGNAL_HPP