X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fdata%2Fsignalbase.hpp;h=b29c6b56558d3dffb74cd22429d20a6b80efb7a9;hb=12ea3616767553ee0a615f14bbcb8ec614589e34;hp=ca3cd5c47c8b0489490c65a66905cc0c000c3a47;hpb=cbd2a2de848f957507096785d3be1cc97d30df9a;p=pulseview.git
diff --git a/pv/data/signalbase.hpp b/pv/data/signalbase.hpp
index ca3cd5c..b29c6b5 100644
--- a/pv/data/signalbase.hpp
+++ b/pv/data/signalbase.hpp
@@ -15,29 +15,32 @@
* 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_DATA_SIGNALBASE_HPP
#define PULSEVIEW_PV_DATA_SIGNALBASE_HPP
+#include
+
#include
#include
+#include
#include
#include
+using std::shared_ptr;
namespace sigrok {
class Channel;
-class ChannelType;
}
namespace pv {
namespace data {
class Analog;
+class DecoderStack;
class Logic;
class SignalData;
@@ -45,18 +48,33 @@ class SignalBase : public QObject
{
Q_OBJECT
+public:
+ enum ChannelType {
+ AnalogChannel = 1,
+ LogicChannel,
+ DecodeChannel,
+ A2LChannel, // Analog converted to logic, joint representation
+ MathChannel
+ };
+
+ enum ConversionType {
+ NoConversion = 0,
+ A2LConversionByTreshold = 1,
+ A2LConversionBySchmittTrigger = 2
+ };
+
private:
static const int ColourBGAlpha;
public:
- SignalBase(std::shared_ptr channel);
- virtual ~SignalBase() {}
+ SignalBase(shared_ptr channel, ChannelType channel_type);
+ virtual ~SignalBase();
public:
/**
* Returns the underlying SR channel.
*/
- std::shared_ptr channel() const;
+ shared_ptr channel() const;
/**
* Returns enabled status of this channel.
@@ -72,7 +90,7 @@ public:
/**
* Gets the type of this channel.
*/
- const sigrok::ChannelType *type() const;
+ ChannelType type() const;
/**
* Gets the index number of this channel.
@@ -84,6 +102,11 @@ public:
*/
QString name() const;
+ /**
+ * Gets the internal name of this signal, i.e. how the device calls it.
+ */
+ QString internal_name() const;
+
/**
* Sets the name of the signal.
*/
@@ -107,18 +130,41 @@ public:
/**
* Sets the internal data object.
*/
- void set_data(std::shared_ptr data);
+ void set_data(shared_ptr data);
/**
* Get the internal data as analog data object in case of analog type.
*/
- std::shared_ptr analog_data() const;
+ shared_ptr analog_data() const;
/**
* Get the internal data as logic data object in case of logic type.
*/
- std::shared_ptr logic_data() const;
+ shared_ptr logic_data() const;
+
+ /**
+ * Changes the kind of conversion performed on this channel.
+ */
+ void set_conversion_type(ConversionType t);
+
+#ifdef ENABLE_DECODE
+ bool is_decode_signal() const;
+
+ shared_ptr decoder_stack() const;
+ void set_decoder_stack(shared_ptr decoder_stack);
+#endif
+
+ void save_settings(QSettings &settings) const;
+
+ void restore_settings(QSettings &settings);
+
+private:
+ uint8_t convert_a2l_threshold(float threshold, float value);
+ uint8_t convert_a2l_schmitt_trigger(float lo_thr, float hi_thr, float value);
+
+ void conversion_thread_proc(QObject* segment, uint64_t start_sample,
+ uint64_t end_sample);
Q_SIGNALS:
void enabled_changed(const bool &value);
@@ -127,11 +173,30 @@ Q_SIGNALS:
void colour_changed(const QColor &colour);
+ void conversion_type_changed(const ConversionType t);
+
+private Q_SLOTS:
+ void on_samples_cleared();
+
+ void on_samples_added(QObject* segment, uint64_t start_sample,
+ uint64_t end_sample);
+
+ void on_capture_state_changed(int state);
+
private:
- std::shared_ptr channel_;
- std::shared_ptr data_;
+ shared_ptr channel_;
+ ChannelType channel_type_;
+ shared_ptr data_;
+ shared_ptr converted_data_;
+ int conversion_type_;
+
+#ifdef ENABLE_DECODE
+ shared_ptr decoder_stack_;
+#endif
+
+ std::thread conversion_thread_;
- QString name_;
+ QString internal_name_, name_;
QColor colour_, bgcolour_;
};