@@ -4,17 +4,15 integrated_build:{ | |||||
4 | LIBS += -L $$CHART_BUILD_LIB_DIR -Wl,-rpath,$$CHART_BUILD_LIB_DIR |
|
4 | LIBS += -L $$CHART_BUILD_LIB_DIR -Wl,-rpath,$$CHART_BUILD_LIB_DIR | |
5 | DESTDIR = $$CHART_BUILD_BIN_DIR |
|
5 | DESTDIR = $$CHART_BUILD_BIN_DIR | |
6 | CONFIG(debug, debug|release) { |
|
6 | CONFIG(debug, debug|release) { | |
7 | LIBS += -lQtCommercialChartd |
|
7 | LIBS += -lQtCommercialChartd | |
8 |
|
8 | #this is ugly hack to work around missing rpath, it simply copies lib | ||
9 | #this is ugly hack to work around missing rpath, it simply copies lib |
|
9 | win32:{ | |
10 | win32:{ |
|
10 | copylib.target = $$CHART_BUILD_BIN_DIR/QtCommercialChartd.dll | |
11 | copylib.target = $$CHART_BUILD_BIN_DIR/QtCommercialChartd.dll |
|
11 | copylib.commands = $$QMAKE_COPY $$CHART_BUILD_LIB_DIR\\QtCommercialChartd.dll $$CHART_BUILD_BIN_DIR | |
12 |
copylib. |
|
12 | copylib.depends = $$CHART_BUILD_LIB_DIR/QtCommercialChartd.dll | |
13 |
|
|
13 | PRE_TARGETDEPS += $$CHART_BUILD_BIN_DIR/QtCommercialChartd.dll | |
14 | PRE_TARGETDEPS += $$CHART_BUILD_BIN_DIR/QtCommercialChartd.dll |
|
14 | QMAKE_EXTRA_TARGETS +=copylib | |
15 | QMAKE_EXTRA_TARGETS +=copylib |
|
15 | } | |
16 | } |
|
|||
17 |
|
||||
18 | } else { |
|
16 | } else { | |
19 | LIBS += -lQtCommercialChart |
|
17 | LIBS += -lQtCommercialChart | |
20 |
|
18 |
@@ -66,7 +66,7 class ChartTheme : public QObject | |||||
66 | Q_OBJECT |
|
66 | Q_OBJECT | |
67 | public: |
|
67 | public: | |
68 | explicit ChartTheme(QObject *parent = 0); |
|
68 | explicit ChartTheme(QObject *parent = 0); | |
69 | explicit ChartTheme(const ChartTheme &other) : d(other.d) {} |
|
69 | explicit ChartTheme(const ChartTheme &other, QObject *parent = 0) : QObject(parent), d(other.d) {} | |
70 | void operator =(const ChartTheme &other) { d = other.d; } |
|
70 | void operator =(const ChartTheme &other) { d = other.d; } | |
71 |
|
71 | |||
72 | void setTheme(int theme); |
|
72 | void setTheme(int theme); |
@@ -44,7 +44,7 QPainterPath PieSlice::shape() const | |||||
44 | return path; |
|
44 | return path; | |
45 | } |
|
45 | } | |
46 |
|
46 | |||
47 | void PieSlice::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) |
|
47 | void PieSlice::paint(QPainter *painter, const QStyleOptionGraphicsItem */*option*/, QWidget */*widget*/) | |
48 | { |
|
48 | { | |
49 | painter->setRenderHint(QPainter::Antialiasing); |
|
49 | painter->setRenderHint(QPainter::Antialiasing); | |
50 | // TODO: how to map theme settings to a pie slice? Now we |
|
50 | // TODO: how to map theme settings to a pie slice? Now we |
@@ -26,10 +26,10 QTCOMMERCIALCHART_BEGIN_NAMESPACE | |||||
26 | QChart::QChart(QGraphicsObject* parent) : QGraphicsObject(parent), |
|
26 | QChart::QChart(QGraphicsObject* parent) : QGraphicsObject(parent), | |
27 | m_backgroundItem(0), |
|
27 | m_backgroundItem(0), | |
28 | m_titleItem(0), |
|
28 | m_titleItem(0), | |
29 | m_axisXItem(new AxisItem(AxisItem::X_AXIS,this)), |
|
29 | m_axisXItem(new AxisItem(AxisItem::X_AXIS, this)), | |
30 | m_plotDataIndex(0), |
|
30 | m_plotDataIndex(0), | |
31 | m_marginSize(0), |
|
31 | m_marginSize(0), | |
32 | m_chartTheme(new ChartTheme()) |
|
32 | m_chartTheme(new ChartTheme(this)) | |
33 | { |
|
33 | { | |
34 | // TODO: the default theme? |
|
34 | // TODO: the default theme? | |
35 | setTheme(QChart::ChartThemeDefault); |
|
35 | setTheme(QChart::ChartThemeDefault); |
@@ -50,7 +50,7 public: | |||||
50 |
|
50 | |||
51 | //from QGraphicsItem |
|
51 | //from QGraphicsItem | |
52 | QRectF boundingRect() const; |
|
52 | QRectF boundingRect() const; | |
53 |
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget){} |
|
53 | void paint(QPainter */*painter*/, const QStyleOptionGraphicsItem */*option*/, QWidget */*widget*/) {} | |
54 |
|
54 | |||
55 | void addSeries(QChartSeries* series); |
|
55 | void addSeries(QChartSeries* series); | |
56 | //TODO: QChartSeries* createSeries(QSeriesData *data, QChartSeries::QChartSeriesType type); |
|
56 | //TODO: QChartSeries* createSeries(QSeriesData *data, QChartSeries::QChartSeriesType type); |
@@ -34,12 +34,12 public: | |||||
34 | // Pure virtual |
|
34 | // Pure virtual | |
35 | virtual QChartSeriesType type() const = 0; |
|
35 | virtual QChartSeriesType type() const = 0; | |
36 |
|
36 | |||
37 | virtual bool setData(QList<int> data) { return false; } |
|
37 | virtual bool setData(QList<int> /*data*/) { return false; } | |
38 | virtual bool setData(QList<qreal> data) { return false; } |
|
38 | virtual bool setData(QList<qreal> /*data*/) { return false; } | |
39 | virtual bool setData(QList<qreal> x, QList<qreal> y){ return false; } |
|
39 | virtual bool setData(QList<qreal> /*x*/, QList<qreal> /*y*/){ return false; } | |
40 |
|
40 | |||
41 | // Prototype for data model. TODO: remove the other setData methods and use something like this for now? |
|
41 | // Prototype for data model. TODO: remove the other setData methods and use something like this for now? | |
42 | virtual bool setData(QAbstractItemModel* model) { return false; } |
|
42 | virtual bool setData(QAbstractItemModel* /*model*/) { return false; } | |
43 |
|
43 | |||
44 | }; |
|
44 | }; | |
45 |
|
45 |
@@ -55,7 +55,7 QRectF QScatterSeriesPrivate::boundingRect() const | |||||
55 | return QRectF(0, 0, 55, 100); |
|
55 | return QRectF(0, 0, 55, 100); | |
56 | } |
|
56 | } | |
57 |
|
57 | |||
58 | void QScatterSeriesPrivate::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) |
|
58 | void QScatterSeriesPrivate::paint(QPainter *painter, const QStyleOptionGraphicsItem */*option*/, QWidget */*widget*/) | |
59 | { |
|
59 | { | |
60 | // TODO: The opacity should be user definable? |
|
60 | // TODO: The opacity should be user definable? | |
61 | //brush.setColor(QColor(255, 82, 0, 100)); |
|
61 | //brush.setColor(QColor(255, 82, 0, 100)); |
@@ -25,10 +25,44 MainWidget::MainWidget(QWidget *parent) : | |||||
25 | { |
|
25 | { | |
26 | m_chartWidget = new QChartWidget(this); |
|
26 | m_chartWidget = new QChartWidget(this); | |
27 |
|
27 | |||
|
28 | // GridLayout for the controls for configuring the chart widget | |||
|
29 | QGridLayout *grid = new QGridLayout(); | |||
|
30 | QGridLayout *mainLayout = new QGridLayout(); | |||
28 | QPushButton *addSeriesButton = new QPushButton("Add series"); |
|
31 | QPushButton *addSeriesButton = new QPushButton("Add series"); | |
29 | connect(addSeriesButton, SIGNAL(clicked()), this, SLOT(addSeries())); |
|
32 | connect(addSeriesButton, SIGNAL(clicked()), this, SLOT(addSeries())); | |
|
33 | grid->addWidget(addSeriesButton, 0, 1); | |||
|
34 | initBackroundCombo(grid); | |||
|
35 | initScaleControls(grid); | |||
|
36 | initThemeCombo(grid); | |||
|
37 | QCheckBox *zoomCheckBox = new QCheckBox("Zoom enabled"); | |||
|
38 | connect(zoomCheckBox, SIGNAL(toggled(bool)), m_chartWidget, SLOT(setZoomEnabled(bool))); | |||
|
39 | zoomCheckBox->setChecked(true); | |||
|
40 | grid->addWidget(zoomCheckBox, grid->rowCount(), 0); | |||
|
41 | // add row with empty label to make all the other rows static | |||
|
42 | grid->addWidget(new QLabel(""), grid->rowCount(), 0); | |||
|
43 | grid->setRowStretch(grid->rowCount() - 1, 1); | |||
|
44 | mainLayout->addLayout(grid, 0, 0); | |||
|
45 | ||||
|
46 | // Init series type specific controls | |||
|
47 | initPieControls(); | |||
|
48 | mainLayout->addLayout(m_pieLayout, 2, 0); | |||
|
49 | // Scatter series specific settings | |||
|
50 | // m_scatterLayout = new QGridLayout(); | |||
|
51 | // m_scatterLayout->addWidget(new QLabel("scatter"), 0, 0); | |||
|
52 | // m_scatterLayout->setEnabled(false); | |||
|
53 | // mainLayout->addLayout(m_scatterLayout, 1, 0); | |||
|
54 | ||||
|
55 | // Add layouts and the chart widget to the main layout | |||
|
56 | mainLayout->addWidget(m_chartWidget, 0, 1, 3, 1); | |||
|
57 | setLayout(mainLayout); | |||
|
58 | ||||
|
59 | // force an update to test data | |||
|
60 | testDataChanged(0); | |||
|
61 | } | |||
30 |
|
62 | |||
31 | // Chart background |
|
63 | // Combo box for selecting the chart's background | |
|
64 | void MainWidget::initBackroundCombo(QGridLayout *grid) | |||
|
65 | { | |||
32 | QComboBox *backgroundCombo = new QComboBox(this); |
|
66 | QComboBox *backgroundCombo = new QComboBox(this); | |
33 | backgroundCombo->addItem("Color"); |
|
67 | backgroundCombo->addItem("Color"); | |
34 | backgroundCombo->addItem("Gradient"); |
|
68 | backgroundCombo->addItem("Gradient"); | |
@@ -36,8 +70,13 MainWidget::MainWidget(QWidget *parent) : | |||||
36 | connect(backgroundCombo, SIGNAL(currentIndexChanged(int)), |
|
70 | connect(backgroundCombo, SIGNAL(currentIndexChanged(int)), | |
37 | this, SLOT(backgroundChanged(int))); |
|
71 | this, SLOT(backgroundChanged(int))); | |
38 |
|
72 | |||
39 | // Axis |
|
73 | grid->addWidget(new QLabel("Background:"), grid->rowCount(), 0); | |
40 | // TODO: multiple axes? |
|
74 | grid->addWidget(backgroundCombo, grid->rowCount() - 1, 1); | |
|
75 | } | |||
|
76 | ||||
|
77 | // Scale related controls (auto-scale vs. manual min-max values) | |||
|
78 | void MainWidget::initScaleControls(QGridLayout *grid) | |||
|
79 | { | |||
41 | m_autoScaleCheck = new QCheckBox("Automatic scaling"); |
|
80 | m_autoScaleCheck = new QCheckBox("Automatic scaling"); | |
42 | connect(m_autoScaleCheck, SIGNAL(stateChanged(int)), this, SLOT(autoScaleChanged(int))); |
|
81 | connect(m_autoScaleCheck, SIGNAL(stateChanged(int)), this, SLOT(autoScaleChanged(int))); | |
43 | // Allow setting also non-sense values (like -2147483648 and 2147483647) |
|
82 | // Allow setting also non-sense values (like -2147483648 and 2147483647) | |
@@ -62,6 +101,22 MainWidget::MainWidget(QWidget *parent) : | |||||
62 | m_yMaxSpin->setValue(10); |
|
101 | m_yMaxSpin->setValue(10); | |
63 | connect(m_yMaxSpin, SIGNAL(valueChanged(int)), this, SLOT(yMaxChanged(int))); |
|
102 | connect(m_yMaxSpin, SIGNAL(valueChanged(int)), this, SLOT(yMaxChanged(int))); | |
64 |
|
103 | |||
|
104 | grid->addWidget(m_autoScaleCheck, grid->rowCount(), 0); | |||
|
105 | grid->addWidget(new QLabel("x min:"), grid->rowCount(), 0); | |||
|
106 | grid->addWidget(m_xMinSpin, grid->rowCount() - 1, 1); | |||
|
107 | grid->addWidget(new QLabel("x max:"), grid->rowCount(), 0); | |||
|
108 | grid->addWidget(m_xMaxSpin, grid->rowCount() - 1, 1); | |||
|
109 | grid->addWidget(new QLabel("y min:"), grid->rowCount(), 0); | |||
|
110 | grid->addWidget(m_yMinSpin, grid->rowCount() - 1, 1); | |||
|
111 | grid->addWidget(new QLabel("y max:"), grid->rowCount(), 0); | |||
|
112 | grid->addWidget(m_yMaxSpin, grid->rowCount() - 1, 1); | |||
|
113 | ||||
|
114 | m_autoScaleCheck->setChecked(true); | |||
|
115 | } | |||
|
116 | ||||
|
117 | // Combo box for selecting theme | |||
|
118 | void MainWidget::initThemeCombo(QGridLayout *grid) | |||
|
119 | { | |||
65 | QComboBox *chartTheme = new QComboBox(); |
|
120 | QComboBox *chartTheme = new QComboBox(); | |
66 | chartTheme->addItem("Default"); |
|
121 | chartTheme->addItem("Default"); | |
67 | chartTheme->addItem("Vanilla"); |
|
122 | chartTheme->addItem("Vanilla"); | |
@@ -70,45 +125,13 MainWidget::MainWidget(QWidget *parent) : | |||||
70 | chartTheme->addItem("Unnamed1"); |
|
125 | chartTheme->addItem("Unnamed1"); | |
71 | connect(chartTheme, SIGNAL(currentIndexChanged(int)), |
|
126 | connect(chartTheme, SIGNAL(currentIndexChanged(int)), | |
72 | this, SLOT(changeChartTheme(int))); |
|
127 | this, SLOT(changeChartTheme(int))); | |
73 | // connect(chartTheme, SIGNAL(currentIndexChanged(int)), |
|
|||
74 | // m_signalMapper, SLOT(map())); |
|
|||
75 | // m_signalMapper->setMapping(chartTheme, (QChart::ChartThemeId)chartTheme->currentIndex()); |
|
|||
76 | // connect(m_signalMapper, SIGNAL(mapped(QChart::ChartThemeId)), |
|
|||
77 | // m_chartWidget, SLOT(setTheme(QChart::ChartThemeId))); |
|
|||
78 |
|
||||
79 | QCheckBox *zoomCheckBox = new QCheckBox("Zoom enabled"); |
|
|||
80 | connect(zoomCheckBox, SIGNAL(toggled(bool)), m_chartWidget, SLOT(setZoomEnabled(bool))); |
|
|||
81 | zoomCheckBox->setChecked(true); |
|
|||
82 |
|
||||
83 | QGridLayout *grid = new QGridLayout(); |
|
|||
84 | QGridLayout *mainLayout = new QGridLayout(); |
|
|||
85 | grid->addWidget(addSeriesButton, 0, 1); |
|
|||
86 | grid->addWidget(new QLabel("Background:"), 2, 0); |
|
|||
87 | grid->addWidget(backgroundCombo, 2, 1); |
|
|||
88 | grid->addWidget(m_autoScaleCheck, 3, 0); |
|
|||
89 | grid->addWidget(new QLabel("x min:"), 4, 0); |
|
|||
90 | grid->addWidget(m_xMinSpin, 4, 1); |
|
|||
91 | grid->addWidget(new QLabel("x max:"), 5, 0); |
|
|||
92 | grid->addWidget(m_xMaxSpin, 5, 1); |
|
|||
93 | grid->addWidget(new QLabel("y min:"), 6, 0); |
|
|||
94 | grid->addWidget(m_yMinSpin, 6, 1); |
|
|||
95 | grid->addWidget(new QLabel("y max:"), 7, 0); |
|
|||
96 | grid->addWidget(m_yMaxSpin, 7, 1); |
|
|||
97 | grid->addWidget(new QLabel("Chart theme:"), 8, 0); |
|
128 | grid->addWidget(new QLabel("Chart theme:"), 8, 0); | |
98 | grid->addWidget(chartTheme, 8, 1); |
|
129 | grid->addWidget(chartTheme, 8, 1); | |
99 | grid->addWidget(zoomCheckBox, 9, 0); |
|
130 | } | |
100 | // add row with empty label to make all the other rows static |
|
|||
101 | grid->addWidget(new QLabel(""), 10, 0); |
|
|||
102 | grid->setRowStretch(10, 1); |
|
|||
103 |
|
||||
104 | mainLayout->addLayout(grid, 0, 0); |
|
|||
105 |
|
||||
106 | // Scatter specific settings |
|
|||
107 | m_scatterLayout = new QGridLayout(); |
|
|||
108 | m_scatterLayout->addWidget(new QLabel("scatter"), 0, 0); |
|
|||
109 | m_scatterLayout->setEnabled(false); |
|
|||
110 |
|
131 | |||
111 | // Pie specific settings |
|
132 | void MainWidget::initPieControls() | |
|
133 | { | |||
|
134 | // Pie series specific settings | |||
112 | // Pie size factory |
|
135 | // Pie size factory | |
113 | QDoubleSpinBox *pieSizeSpin = new QDoubleSpinBox(); |
|
136 | QDoubleSpinBox *pieSizeSpin = new QDoubleSpinBox(); | |
114 | pieSizeSpin->setMinimum(LONG_MIN); |
|
137 | pieSizeSpin->setMinimum(LONG_MIN); | |
@@ -131,18 +154,6 MainWidget::MainWidget(QWidget *parent) : | |||||
131 | m_pieLayout->addWidget(pieSizeSpin, 0, 1); |
|
154 | m_pieLayout->addWidget(pieSizeSpin, 0, 1); | |
132 | m_pieLayout->addWidget(new QLabel("Pie position"), 1, 0); |
|
155 | m_pieLayout->addWidget(new QLabel("Pie position"), 1, 0); | |
133 | m_pieLayout->addWidget(piePosCombo, 1, 1); |
|
156 | m_pieLayout->addWidget(piePosCombo, 1, 1); | |
134 |
|
||||
135 | mainLayout->addLayout(m_scatterLayout, 1, 0); |
|
|||
136 | mainLayout->addLayout(m_pieLayout, 2, 0); |
|
|||
137 |
|
||||
138 | //m_chartWidget->setColor(Qt::red); |
|
|||
139 | mainLayout->addWidget(m_chartWidget, 0, 1, 3, 1); |
|
|||
140 | // hbox->setStretch(1, 1); |
|
|||
141 |
|
||||
142 | setLayout(mainLayout); |
|
|||
143 |
|
||||
144 | m_autoScaleCheck->setChecked(true); |
|
|||
145 | testDataChanged(0); |
|
|||
146 | } |
|
157 | } | |
147 |
|
158 | |||
148 | void MainWidget::addSeries() |
|
159 | void MainWidget::addSeries() |
@@ -19,6 +19,12 public: | |||||
19 |
|
19 | |||
20 | signals: |
|
20 | signals: | |
21 |
|
21 | |||
|
22 | private: | |||
|
23 | void initBackroundCombo(QGridLayout *grid); | |||
|
24 | void initScaleControls(QGridLayout *grid); | |||
|
25 | void initThemeCombo(QGridLayout *grid); | |||
|
26 | void initPieControls(); | |||
|
27 | ||||
22 | private slots: |
|
28 | private slots: | |
23 | void addSeries(); |
|
29 | void addSeries(); | |
24 | void addSeries(QString series, QString data); |
|
30 | void addSeries(QString series, QString data); |
General Comments 0
You need to be logged in to leave comments.
Login now