summaryrefslogtreecommitdiffstats
path: root/clients/tde/src/widgets
diff options
context:
space:
mode:
authorTimothy Pearson <kb9vqf@pearsoncomputing.net>2014-01-29 18:37:34 -0600
committerTimothy Pearson <kb9vqf@pearsoncomputing.net>2014-01-29 18:37:34 -0600
commit6ae28a47f75bc1096b056ba398a558bd9fcacf73 (patch)
tree3ea8f851e4a31515137abf7b88f989d6b83bf980 /clients/tde/src/widgets
parent72e80dda8e3e692e3afd6e1f07fbb69fca2e80bf (diff)
downloadulab-6ae28a47f75bc1096b056ba398a558bd9fcacf73.tar.gz
ulab-6ae28a47f75bc1096b056ba398a558bd9fcacf73.zip
Add left trace sidebar option to trace viewer widget
Add scrollbar option to trace viewer widget
Diffstat (limited to 'clients/tde/src/widgets')
-rw-r--r--clients/tde/src/widgets/tracewidget.cpp235
-rw-r--r--clients/tde/src/widgets/tracewidget.h29
2 files changed, 257 insertions, 7 deletions
diff --git a/clients/tde/src/widgets/tracewidget.cpp b/clients/tde/src/widgets/tracewidget.cpp
index b19ec7b..6f11ffc 100644
--- a/clients/tde/src/widgets/tracewidget.cpp
+++ b/clients/tde/src/widgets/tracewidget.cpp
@@ -1,4 +1,4 @@
-//Author: Timothy Pearson <kb9vqf@pearsoncomputing.net>, (C) 2012
+//Author: Timothy Pearson <kb9vqf@pearsoncomputing.net>, (C) 2012-2014
//Copyright: See COPYING file that comes with this distribution
#include "tracewidget.h"
@@ -95,6 +95,169 @@ bool TQRectF::operator!=(const TQRectF &r1) {
return !operator==(r1);
}
+class TraceLabelLayout : public TQLayout
+{
+ public:
+ TraceLabelLayout(TraceWidget *traceWidget, TQWidget *parent, int spacing=-1) : TQLayout(parent, 0, spacing), m_traceWidget(traceWidget) {
+ //
+ }
+ TraceLabelLayout(TraceWidget *traceWidget, TQLayout* parent, int spacing=-1) : TQLayout(parent, spacing), m_traceWidget(traceWidget) {
+ //
+ }
+ TraceLabelLayout(TraceWidget *traceWidget, int spacing=-1) : TQLayout(spacing), m_traceWidget(traceWidget) {
+ //
+ }
+ ~TraceLabelLayout();
+
+ void addItem(TQLayoutItem *item);
+ void addWidget(TQWidget *w, int alignment);
+ TQSize sizeHint() const;
+ TQSize minimumSize() const;
+ TQLayoutIterator iterator();
+ void setGeometry(const TQRect &rect);
+ virtual void invalidate();
+
+ private:
+ TQPtrList<TQLayoutItem> list;
+ TraceWidget* m_traceWidget;
+};
+
+class TraceLabelLayoutIterator : public TQGLayoutIterator
+{
+ public:
+ TraceLabelLayoutIterator( TQPtrList<TQLayoutItem> *l ) : idx(0), list(l) {
+ //
+ }
+
+ TQLayoutItem *current() {
+ return idx < int(list->count()) ? list->at(idx) : 0;
+ }
+
+ TQLayoutItem *next() {
+ idx++;
+ return current();
+ }
+
+ TQLayoutItem *takeCurrent() {
+ return list->take(idx);
+ }
+
+ private:
+ int idx;
+ TQPtrList<TQLayoutItem> *list;
+};
+
+TQLayoutIterator TraceLabelLayout::iterator() {
+ return TQLayoutIterator(new TraceLabelLayoutIterator(&list));
+}
+
+void TraceLabelLayout::addItem(TQLayoutItem *item) {
+ list.append( item );
+}
+
+void TraceLabelLayout::addWidget(TQWidget *w, int alignment) {
+ if (!w) {
+ return;
+ }
+
+ TQWidgetItem *b = new TQWidgetItem(w);
+ b->setAlignment(alignment);
+ addItem( b );
+}
+
+TraceLabelLayout::~TraceLabelLayout() {
+ deleteAllItems();
+}
+
+void TraceLabelLayout::setGeometry(const TQRect &rect) {
+ TQLayout::setGeometry(rect);
+
+ TQPtrListIterator<TQLayoutItem> it(list);
+ if (it.count() == 0) {
+ return;
+ }
+
+ TQLayoutItem *item;
+ while ((item = it.current()) != 0) {
+ ++it;
+
+ TQWidgetItem *widgetItem = dynamic_cast<TQWidgetItem*>(item);
+ if (!widgetItem) {
+ continue;
+ }
+
+ TQWidget* widget = widgetItem->widget();
+ if (!widget) {
+ continue;
+ }
+
+ // Find the trace number
+ const TraceData* currentTrace = NULL;
+ for (uint trace=0;trace<m_traceWidget->m_traceArray.count();trace++) {
+ if (m_traceWidget->m_traceArray[trace]->leftLabel == widget) {
+ currentTrace = m_traceWidget->m_traceArray[trace];
+ break;
+ }
+ }
+
+ TQFontMetrics fm(currentTrace->leftLabel->font());
+ int font_height = fm.boundingRect(currentTrace->leftLabel->text()).height();
+ int font_vertical_offset = font_height/2;
+
+ int graticule_height = m_traceWidget->m_graticuleWidget->height();
+ int y = (((currentTrace->offset-currentTrace->topEdge)/(currentTrace->bottomEdge-currentTrace->topEdge))*(graticule_height))-font_vertical_offset;
+ if (m_traceWidget->m_showLeftTraceInfoArea) {
+ if ((y < 0) || ((y+font_height) > graticule_height)) {
+ currentTrace->leftLabel->hide();
+ item->setGeometry(TQRect(0, 0, rect.width(), currentTrace->leftLabel->sizeHint().height()));
+ }
+ else {
+ item->setGeometry(TQRect(0, y, rect.width(), currentTrace->leftLabel->sizeHint().height()));
+ currentTrace->leftLabel->show();
+ }
+ }
+ else {
+ currentTrace->leftLabel->hide();
+ }
+ }
+}
+
+void TraceLabelLayout::invalidate() {
+ setGeometry(geometry());
+}
+
+TQSize TraceLabelLayout::sizeHint() const
+{
+ if (!m_traceWidget->m_showLeftTraceInfoArea) {
+ return TQSize(0, 0);
+ }
+
+ TQSize s(0, 0);
+ TQPtrListIterator<TQLayoutItem> it( list );
+ TQLayoutItem *item;
+ while ((item = it.current()) != 0) {
+ ++it;
+ s = s.expandedTo(item->sizeHint());
+ }
+ return s + TQSize(spacing(), spacing());
+}
+
+TQSize TraceLabelLayout::minimumSize() const
+{
+ if (!m_traceWidget->m_showLeftTraceInfoArea) {
+ return TQSize(0, 0);
+ }
+
+ TQSize s(0, 0);
+ TQPtrListIterator<TQLayoutItem> it(list);
+ TQLayoutItem *item;
+ while ((item = it.current()) != 0) {
+ ++it;
+ s = s.expandedTo(item->minimumSize());
+ }
+ return s + TQSize(spacing(), spacing());
+}
+
TraceData::TraceData(TraceWidget* parent, TQWidget* labelParent) : TQObject(), parentWidget(parent) {
color = TQColor(0, 255, 0);
numberOfSamples = 0;
@@ -120,6 +283,15 @@ TraceData::TraceData(TraceWidget* parent, TQWidget* labelParent) : TQObject(), p
font.setPointSize(font.pointSize()-1);
paramLabel->setFont(font);
paramLabel->hide();
+ leftLabel = new TQLabel(labelParent);
+ leftLabel->setPaletteBackgroundColor(labelParent->paletteBackgroundColor());
+ leftLabel->setPaletteForegroundColor(color);
+ leftLabel->setAlignment(TQt::AlignHCenter|TQt::AlignVCenter|TQt::SingleLine);
+ font = leftLabel->font();
+ font.setPointSize(font.pointSize()-1);
+ leftLabel->setFont(font);
+ leftLabel->setText("<qt></qt>");
+ leftLabel->hide();
graphStatusLabel = new TQLabel(labelParent);
graphStatusLabel->setPaletteBackgroundColor(labelParent->paletteBackgroundColor());
graphStatusLabel->setPaletteForegroundColor(color);
@@ -175,6 +347,7 @@ TraceData::TraceData(TraceWidget* parent, TQWidget* labelParent) : TQObject(), p
}
else {
paramLabel = NULL;
+ leftLabel = NULL;
graphStatusLabel = NULL;
graphStatusLabelInner = NULL;
singleIncrBtn = NULL;
@@ -873,31 +1046,38 @@ TraceWidget::TraceWidget(TQWidget* parent, const char* name) : TQWidget(parent,
m_zoomBoxDarkness(ZOOM_SHADING_DARKNESS_FACTOR),
m_zoomCursorStartIndex(0),
m_zoomBoxEnabled(false),
- m_useAbsoluteHorizontalRange(true) {
+ m_useAbsoluteHorizontalRange(true),
+ m_showLeftTraceInfoArea(false) {
setBackgroundMode(NoBackground);
setSizePolicy(TQSizePolicy(TQSizePolicy::MinimumExpanding, TQSizePolicy::MinimumExpanding));
m_primaryLayout = new TQGridLayout(this);
m_graticuleWidget = new GraticuleWidget(this);
connect(m_graticuleWidget, SIGNAL(cursorPositionChanged(uint, double)), this, SLOT(processChangedCursor(uint, double)));
- m_primaryLayout->addMultiCellWidget(m_graticuleWidget, 0, 254, 0, 254);
+ m_primaryLayout->addMultiCellWidget(m_graticuleWidget, 0, 254, 1, 254);
m_primaryLayout->setAlignment(TQt::AlignTop);
m_rightPaneLayout = new TQGridLayout;
+ m_leftPaneLayout = new TQGridLayout;
m_traceLabelLayout = new TQGridLayout;
m_infoLabelLayout = new TQGridLayout;
m_cursorLabelLayout = new TQGridLayout;
+ m_traceLeftLabelLayout = new TraceLabelLayout(this);
m_statusLabelLayout = new TQVBoxLayout;
m_statusLabelLayoutInner = new TQVBoxLayout;
- m_primaryLayout->addLayout(m_traceLabelLayout, 255, 0);
+ m_primaryLayout->addLayout(m_traceLabelLayout, 255, 1);
m_primaryLayout->addLayout(m_rightPaneLayout, 0, 255);
+ m_primaryLayout->addLayout(m_leftPaneLayout, 0, 0);
m_primaryLayout->addLayout(m_statusLabelLayout, 255, 255);
m_primaryLayout->addLayout(m_statusLabelLayoutInner, 1, 253);
- m_rightPaneLayout->addLayout(m_cursorLabelLayout, 0, 0);
- m_rightPaneLayout->addLayout(m_infoLabelLayout, 1, 0);
+ m_rightPaneLayout->addLayout(m_cursorLabelLayout, 0, 1);
+ m_rightPaneLayout->addLayout(m_infoLabelLayout, 1, 1);
+ m_leftPaneLayout->addLayout(m_traceLeftLabelLayout, 0, 1);
m_traceLabelLayout->addItem(new TQSpacerItem(0, 0, TQSizePolicy::Expanding, TQSizePolicy::Minimum), 0, 255);
m_rightPaneLayout->addItem(new TQSpacerItem(0, 0, TQSizePolicy::Minimum, TQSizePolicy::Expanding), 255, 0);
+ m_leftPaneLayout->addItem(new TQSpacerItem(0, 0, TQSizePolicy::Minimum, TQSizePolicy::Expanding), 255, 0);
m_primaryLayout->addItem(new TQSpacerItem(0, 0, TQSizePolicy::Expanding, TQSizePolicy::Minimum), 1, 128);
m_statusLabelLayout->setSpacing(0);
+ m_leftPaneLayout->setSpacing(0);
setPaletteBackgroundColor(TQt::black);
setPaletteForegroundColor(TQColor(0,128,0));
@@ -992,6 +1172,8 @@ void TraceWidget::updateTraceText() {
double vertical_range = (m_traceArray[trace]->bottomEdge-m_traceArray[trace]->topEdge);
m_traceArray[trace]->paramLabel->setPaletteBackgroundColor(paletteBackgroundColor());
m_traceArray[trace]->paramLabel->setPaletteForegroundColor(m_traceArray[trace]->color);
+ m_traceArray[trace]->leftLabel->setPaletteBackgroundColor(paletteBackgroundColor());
+ m_traceArray[trace]->leftLabel->setPaletteForegroundColor(m_traceArray[trace]->color);
m_traceArray[trace]->graphStatusLabel->setPaletteBackgroundColor(paletteBackgroundColor());
m_traceArray[trace]->graphStatusLabel->setPaletteForegroundColor(m_traceArray[trace]->color);
m_traceArray[trace]->graphStatusLabelInner->setPaletteBackgroundColor(paletteBackgroundColor());
@@ -1007,6 +1189,7 @@ void TraceWidget::updateTraceText() {
}
}
m_traceArray[trace]->paramLabel->setText(TQString("<qt><nobr>%1%2<br>%3/div,%4/div<br>%5,%6<br>%7,%8</qt>").arg(m_traceArray[trace]->traceName).arg(offsetText).arg(prettyFormat(horizontal_units_per_division, horizontal_range, m_traceArray[trace]->horizontalUnits)).arg(prettyFormat(vertical_units_per_division, vertical_range, m_traceArray[trace]->verticalUnits)).arg(prettyFormat(m_traceArray[trace]->leftEdge, (m_useAbsoluteHorizontalRange)?m_traceArray[trace]->rightEdge:horizontal_range, m_traceArray[trace]->horizontalUnits)).arg(prettyFormat(m_traceArray[trace]->topEdge, vertical_range, m_traceArray[trace]->verticalUnits)).arg(prettyFormat(m_traceArray[trace]->rightEdge, (m_useAbsoluteHorizontalRange)?m_traceArray[trace]->rightEdge:horizontal_range, m_traceArray[trace]->horizontalUnits)).arg(prettyFormat(m_traceArray[trace]->bottomEdge, vertical_range, m_traceArray[trace]->verticalUnits)));
+ m_traceArray[trace]->leftLabel->setText(TQString("<qt><nobr>%1</qt>").arg(m_traceArray[trace]->traceName));
}
}
@@ -1138,6 +1321,7 @@ void TraceWidget::setTraceEnabled(uint traceNumber, bool enabled, bool showText)
if (enabled) {
if (showText) {
m_traceArray[traceNumber]->paramLabel->show();
+ m_traceArray[traceNumber]->leftLabel->show();
m_traceArray[traceNumber]->graphStatusLabel->show();
m_traceArray[traceNumber]->graphStatusLabelInner->hide();
m_traceArray[traceNumber]->singleIncrBtn->show();
@@ -1147,6 +1331,7 @@ void TraceWidget::setTraceEnabled(uint traceNumber, bool enabled, bool showText)
}
else {
m_traceArray[traceNumber]->paramLabel->hide();
+ m_traceArray[traceNumber]->leftLabel->hide();
m_traceArray[traceNumber]->graphStatusLabel->hide();
m_traceArray[traceNumber]->graphStatusLabelInner->show();
m_traceArray[traceNumber]->singleIncrBtn->hide();
@@ -1157,6 +1342,7 @@ void TraceWidget::setTraceEnabled(uint traceNumber, bool enabled, bool showText)
}
else {
m_traceArray[traceNumber]->paramLabel->hide();
+ m_traceArray[traceNumber]->leftLabel->hide();
m_traceArray[traceNumber]->graphStatusLabel->hide();
m_traceArray[traceNumber]->graphStatusLabelInner->hide();
m_traceArray[traceNumber]->singleIncrBtn->hide();
@@ -1516,6 +1702,18 @@ void TraceWidget::setZoomBoxEnabled(bool enabled) {
m_graticuleWidget->updateGraticule();
}
+void TraceWidget::showLeftTraceInfoArea(bool show) {
+ m_showLeftTraceInfoArea = show;
+ for (uint i=0;i<m_traceArray.count();i++) {
+ if (m_showLeftTraceInfoArea) {
+ m_traceArray[i]->leftLabel->show();
+ }
+ else {
+ m_traceArray[i]->leftLabel->hide();
+ }
+ }
+}
+
TQString TraceWidget::prettyFormat(double value, double rangeDetectValue, TQString baseUnits, unsigned int precision) {
TQString result;
TQString unitMultiplier;
@@ -1610,6 +1808,7 @@ void TraceWidget::processChangedOffset(double offset) {
}
}
if (tracenumber >= 0) {
+ m_traceLeftLabelLayout->invalidate();
emit(offsetChanged(tracenumber, offset));
}
}
@@ -1649,6 +1848,7 @@ void TraceWidget::resizeTraceArray(uint newsize) {
m_traceLabelLayout->addWidget(m_traceArray[i]->posResetBtn, 1, (i*2)+1);
m_traceLabelLayout->addWidget(m_traceArray[i]->posSetBtn, 2, (i*2)+1);
m_traceLabelLayout->addWidget(m_traceArray[i]->singleDecrBtn, 3, (i*2)+1);
+ m_traceLeftLabelLayout->addWidget(m_traceArray[i]->leftLabel, TQt::AlignTop);
m_statusLabelLayout->insertWidget(i, m_traceArray[i]->graphStatusLabel, TQt::AlignTop);
m_statusLabelLayoutInner->insertWidget(i, m_traceArray[i]->graphStatusLabelInner);
}
@@ -1663,6 +1863,7 @@ void TraceWidget::resizeTraceArray(uint newsize) {
m_traceLabelLayout->remove(m_traceArray[i]->posResetBtn);
m_traceLabelLayout->remove(m_traceArray[i]->posSetBtn);
m_traceLabelLayout->remove(m_traceArray[i]->singleDecrBtn);
+ m_traceLeftLabelLayout->remove(m_traceArray[i]->leftLabel);
m_statusLabelLayout->remove(m_traceArray[i]->graphStatusLabel);
m_statusLabelLayoutInner->remove(m_traceArray[i]->graphStatusLabelInner);
}
@@ -1701,4 +1902,26 @@ void TraceWidget::resizeCursorArray(uint newsize) {
delete m_cursorArray[i];
}
}
+}
+
+TraceScrollWidget::TraceScrollWidget(TQWidget* parent, const char* name) : TQScrollView(parent, name) {
+ m_traceWidget = new TraceWidget(viewport());
+ addChild(m_traceWidget);
+}
+
+TraceScrollWidget::~TraceScrollWidget() {
+ delete m_traceWidget;
+ m_traceWidget = NULL;
+}
+
+TQSize TraceScrollWidget::sizeHint() const {
+ return m_traceWidget->sizeHint();
+}
+
+TQSize TraceScrollWidget::minimumSizeHint() const {
+ return m_traceWidget->minimumSizeHint();
+}
+
+TraceWidget* TraceScrollWidget::traceWidget() {
+ return m_traceWidget;
} \ No newline at end of file
diff --git a/clients/tde/src/widgets/tracewidget.h b/clients/tde/src/widgets/tracewidget.h
index f7afa12..c034149 100644
--- a/clients/tde/src/widgets/tracewidget.h
+++ b/clients/tde/src/widgets/tracewidget.h
@@ -1,7 +1,8 @@
-//Author: Timothy Pearson <kb9vqf@pearsoncomputing.net>, (C) 2012
+//Author: Timothy Pearson <kb9vqf@pearsoncomputing.net>, (C) 2012-2014
//Copyright: See COPYING file that comes with this distribution
#include <tqwidget.h>
+#include <tqscrollview.h>
#include <tqtrla.h>
@@ -12,6 +13,7 @@ class TQGridLayout;
class TQPushButton;
class TQToolButton;
class TraceWidget;
+class TraceLabelLayout;
class TQRectF
{
@@ -79,6 +81,7 @@ class TraceData : public TQObject
TQString horizontalUnits;
TQString verticalUnits;
TQLabel* paramLabel;
+ TQLabel* leftLabel;
TQLabel* graphStatusLabel;
TQLabel* graphStatusLabelInner;
TQToolButton* singleIncrBtn;
@@ -89,6 +92,7 @@ class TraceData : public TQObject
friend class TraceWidget;
friend class GraticuleWidget;
+ friend class TraceLabelLayout;
};
typedef TQMemArray<TraceData*> TraceList;
@@ -235,6 +239,8 @@ class TraceWidget : public TQWidget
unsigned int zoomCursorStartIndex();
void setZoomCursorStartIndex(unsigned int index);
+ void showLeftTraceInfoArea(bool show);
+
double traceOffset(uint traceNumber);
static TQString prettyFormat(double value, double rangeDetectValue, TQString baseUnits, unsigned int precision=3);
@@ -271,15 +277,36 @@ class TraceWidget : public TQWidget
CursorList m_cursorArray;
TQGridLayout* m_primaryLayout;
TQGridLayout* m_rightPaneLayout;
+ TQGridLayout* m_leftPaneLayout;
TQGridLayout* m_traceLabelLayout;
TQGridLayout* m_infoLabelLayout;
TQGridLayout* m_cursorLabelLayout;
+ TraceLabelLayout* m_traceLeftLabelLayout;
TQVBoxLayout* m_statusLabelLayout;
TQVBoxLayout* m_statusLabelLayoutInner;
GraticuleWidget* m_graticuleWidget;
bool m_useAbsoluteHorizontalRange;
+ bool m_showLeftTraceInfoArea;
friend class GraticuleWidget;
friend class TraceData;
friend class CursorData;
+ friend class TraceLabelLayout;
+};
+
+class TraceScrollWidget : public TQScrollView
+{
+ Q_OBJECT
+
+ public:
+ TraceScrollWidget(TQWidget* = 0, const char* = 0);
+ ~TraceScrollWidget();
+
+ TraceWidget* traceWidget();
+
+ virtual TQSize sizeHint() const;
+ virtual TQSize minimumSizeHint() const;
+
+ private:
+ TraceWidget* m_traceWidget;
}; \ No newline at end of file