]> sigrok.org Git - pulseview.git/blobdiff - pv/data/decode/row.hpp
Move row/annotation color management out of DecodeTrace
[pulseview.git] / pv / data / decode / row.hpp
index b877b58b85b4ca25300dad8d45e12042ad30a7a8..000bdf9e6b935c8ee838367c7a5c8460badfcca9 100644 (file)
@@ -22,6 +22,8 @@
 
 #include <vector>
 
+#include <QColor>
+
 #include <pv/data/decode/annotation.hpp>
 #include <pv/data/decode/decoder.hpp>
 
@@ -32,6 +34,9 @@ namespace pv {
 namespace data {
 namespace decode {
 
+#define DECODE_COLOR_SATURATION (180) /* 0-255 */
+#define DECODE_COLOR_VALUE (170) /* 0-255 */
+
 struct AnnotationClass;
 class Decoder;
 
@@ -54,6 +59,12 @@ public:
        bool visible() const;
        void set_visible(bool visible);
 
+       void set_base_color(QColor base_color);
+       const QColor color() const;
+       const QColor get_class_color(uint32_t ann_class_id) const;
+       const QColor get_bright_class_color(uint32_t ann_class_id) const;
+       const QColor get_dark_class_color(uint32_t ann_class_id) const;
+
        bool has_hidden_classes() const;
 
        bool operator<(const Row& other) const;
@@ -64,6 +75,11 @@ private:
        Decoder* decoder_;
        const srd_decoder_annotation_row* srd_row_;
        bool visible_;
+
+       QColor color_;
+       map<uint32_t, QColor> ann_class_color_;
+       map<uint32_t, QColor> ann_bright_class_color_;
+       map<uint32_t, QColor> ann_dark_class_color_;
 };
 
 }  // namespace decode