diff --git a/clients/tde/src/part/scope/layout.ui b/clients/tde/src/part/scope/layout.ui
index 16b0d0c..43a0be8 100644
--- a/clients/tde/src/part/scope/layout.ui
+++ b/clients/tde/src/part/scope/layout.ui
@@ -150,6 +150,14 @@
mathTraceControlLayoutWidget
+
+
+ dumpSamples
+
+
+ Export Selected Data
+
+
diff --git a/clients/tde/src/part/scope/part.cpp b/clients/tde/src/part/scope/part.cpp
index 401fd66..efa05a0 100644
--- a/clients/tde/src/part/scope/part.cpp
+++ b/clients/tde/src/part/scope/part.cpp
@@ -638,6 +638,7 @@ ScopePart::ScopePart( TQWidget *parentWidget, const char *widgetName, TQObject *
connect(m_traceWidget, SIGNAL(zoomBoxChanged(const TQRectF&)), this, SLOT(updateZoomWidgetLimits(const TQRectF&)));
connect(m_traceWidget, SIGNAL(offsetChanged(uint, double)), m_base->traceZoomWidget, SLOT(setTraceOffset(uint, double)));
+ connect(m_base->dumpSamples, SIGNAL(clicked()), this, SLOT(dumpSamples()));
connect(m_base->acqStart, SIGNAL(clicked()), this, SLOT(startDAQ()));
connect(m_base->acqStop, SIGNAL(clicked()), this, SLOT(stopDAQ()));
connect(m_base->runControlStartButton, SIGNAL(clicked()), this, SLOT(startScope()));
@@ -2133,6 +2134,30 @@ void ScopePart::startDAQ() {
EXEC_NEXT_STATE_IMMEDIATELY
}
+void ScopePart::dumpSamples() {
+ // Calculate left and right extent of zoom area
+ TQRectF currentZoomBox = m_traceWidget->zoomBox();
+
+ TQString csvData = "";
+ for (int traceno=1; traceno<=m_maxNumberOfTraces; traceno++) {
+ if (m_channelActive[traceno]) {
+ TQString saveFileName = TQString("/tmp/trace%1.csv").arg(traceno);
+ TQFile file(saveFileName);
+ file.open(IO_WriteOnly);
+ csvData = "";
+ int start_sample = ((m_samplesInTrace[traceno] * currentZoomBox.x()) / 100.0);
+ int end_sample = ((m_samplesInTrace[traceno] * currentZoomBox.width()) / 100.0) + start_sample;
+ TQDoubleArray positions = m_traceWidget->positions(traceno-1);
+ TQDoubleArray values = m_traceWidget->samples(traceno-1);
+ for (int sample=start_sample; sample