X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fdata%2Fsignalbase.hpp;h=b29c6b56558d3dffb74cd22429d20a6b80efb7a9;hb=12ea3616767553ee0a615f14bbcb8ec614589e34;hp=54d9ee0adc2d337a87e9b3195a5223099e46e4c6;hpb=6de38b17e7a9182b6557104dd3a902bb7784db95;p=pulseview.git
diff --git a/pv/data/signalbase.hpp b/pv/data/signalbase.hpp
index 54d9ee0..b29c6b5 100644
--- a/pv/data/signalbase.hpp
+++ b/pv/data/signalbase.hpp
@@ -15,13 +15,14 @@
* 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
@@ -29,10 +30,10 @@
#include
+using std::shared_ptr;
namespace sigrok {
class Channel;
-class ChannelType;
}
namespace pv {
@@ -47,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.
@@ -74,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.
@@ -114,31 +130,42 @@ 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;
- std::shared_ptr decoder_stack() const;
+ shared_ptr decoder_stack() const;
- void set_decoder_stack(std::shared_ptr
- decoder_stack);
+ 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);
@@ -146,14 +173,29 @@ 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
- std::shared_ptr decoder_stack_;
+ shared_ptr decoder_stack_;
#endif
+ std::thread conversion_thread_;
+
QString internal_name_, name_;
QColor colour_, bgcolour_;
};