X-Git-Url: http://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fdata%2Fdecode%2Frow.cpp;h=d127a2eadaf3045180452a148777f33cb30c9f08;hb=9d307c60d7fc2dee27bca6eaadd1e68bf7ab0cbf;hp=12951556390c15f2a0ed5e2e647365cb567fb675;hpb=cbb2e4da8042495531b406f745ee9d9e20448ef6;p=pulseview.git
diff --git a/pv/data/decode/row.cpp b/pv/data/decode/row.cpp
index 12951556..d127a2ea 100644
--- a/pv/data/decode/row.cpp
+++ b/pv/data/decode/row.cpp
@@ -17,6 +17,8 @@
* along with this program; if not, see .
*/
+#include
+
#include "decoder.hpp"
#include "row.hpp"
@@ -27,15 +29,18 @@ namespace data {
namespace decode {
Row::Row() :
+ index_(0),
decoder_(nullptr),
- row_(nullptr)
+ srd_row_(nullptr),
+ visible_(true)
{
}
-Row::Row(int index, const Decoder* decoder, const srd_decoder_annotation_row* row) :
+Row::Row(uint32_t index, Decoder* decoder, const srd_decoder_annotation_row* srd_row) :
index_(index),
decoder_(decoder),
- row_(row)
+ srd_row_(srd_row),
+ visible_(true)
{
}
@@ -44,45 +49,142 @@ const Decoder* Row::decoder() const
return decoder_;
}
-const srd_decoder_annotation_row* Row::srd_row() const
+const srd_decoder_annotation_row* Row::get_srd_row() const
{
- return row_;
+ return srd_row_;
}
const QString Row::title() const
{
- if (decoder_ && decoder_->name() && row_ && row_->desc)
+ if (decoder_ && decoder_->name() && srd_row_ && srd_row_->desc)
return QString("%1: %2")
.arg(QString::fromUtf8(decoder_->name()),
- QString::fromUtf8(row_->desc));
+ QString::fromUtf8(srd_row_->desc));
if (decoder_ && decoder_->name())
return QString::fromUtf8(decoder_->name());
- if (row_ && row_->desc)
- return QString::fromUtf8(row_->desc);
+ if (srd_row_ && srd_row_->desc)
+ return QString::fromUtf8(srd_row_->desc);
+
return QString();
}
-const QString Row::class_name() const
+const QString Row::description() const
{
- if (row_ && row_->desc)
- return QString::fromUtf8(row_->desc);
+ if (srd_row_ && srd_row_->desc)
+ return QString::fromUtf8(srd_row_->desc);
return QString();
}
-int Row::index() const
+vector Row::ann_classes() const
+{
+ assert(decoder_);
+
+ vector result;
+
+ if (!srd_row_) {
+ if (index_ == 0) {
+ // When operating as the fallback row, all annotation classes belong to it
+ return decoder_->ann_classes();
+ }
+ return result;
+ }
+
+ for (GSList *l = srd_row_->ann_classes; l; l = l->next) {
+ size_t class_id = (size_t)l->data;
+ result.push_back(decoder_->get_ann_class_by_id(class_id));
+ }
+
+ return result;
+}
+
+uint32_t Row::index() const
{
return index_;
}
+bool Row::visible() const
+{
+ return visible_;
+}
+
+void Row::set_visible(bool visible)
+{
+ visible_ = visible;
+
+ visibility_changed();
+}
+
+void Row::set_base_color(QColor base_color)
+{
+ // For the row color, use the base color hue and add an offset that's
+ // not a dividend of 360
+
+ const int h = (base_color.toHsv().hue() + 20 * index_) % 360;
+ const int s = DECODE_COLOR_SATURATION;
+ const int v = DECODE_COLOR_VALUE;
+ color_.setHsl(h, s, v);
+
+ vector classes = ann_classes();
+ for (const AnnotationClass* ann_class : classes) {
+
+ // For each class color, use the row color hue and add an offset that's
+ // not a dividend of 360 and not a multiple of the row offset
+
+ QColor ann_color(color_);
+ const int h = (ann_color.toHsv().hue() + 55 * ann_class->id) % 360;
+ const int s = DECODE_COLOR_SATURATION;
+ const int v = DECODE_COLOR_VALUE;
+ ann_color.setHsl(h, s, v);
+
+ ann_class_color_[ann_class->id] = ann_color;
+ ann_bright_class_color_[ann_class->id] = ann_color.lighter();
+ ann_dark_class_color_[ann_class->id] = ann_color.darker();
+ }
+}
+
+const QColor Row::color() const
+{
+ return color_;
+}
+
+const QColor Row::get_class_color(uint32_t ann_class_id) const
+{
+ return ann_class_color_.at(ann_class_id);
+}
+
+const QColor Row::get_bright_class_color(uint32_t ann_class_id) const
+{
+ return ann_bright_class_color_.at(ann_class_id);
+}
+
+const QColor Row::get_dark_class_color(uint32_t ann_class_id) const
+{
+ return ann_dark_class_color_.at(ann_class_id);
+}
+
+bool Row::has_hidden_classes() const
+{
+ for (const AnnotationClass* c : ann_classes())
+ if (!c->visible())
+ return true;
+
+ return false;
+}
+
+bool Row::class_is_visible(uint32_t ann_class_id) const
+{
+ return decoder_->get_ann_class_by_id(ann_class_id)->visible();
+}
+
bool Row::operator<(const Row& other) const
{
return (decoder_ < other.decoder_) ||
- (decoder_ == other.decoder_ && row_ < other.row_);
+ (decoder_ == other.decoder_ && srd_row_ < other.srd_row_);
}
bool Row::operator==(const Row& other) const
{
- return ((decoder_ == other.decoder()) && (row_ == other.srd_row()));
+ return ((decoder_ == other.decoder()) && (srd_row_ == other.srd_row_));
}
} // namespace decode