Ref T509, Qwt adjustments in model statistics

This commit is contained in:
Klaus Basan
2019-01-11 13:58:56 +01:00
committed by Mat Sutcliffe
parent dba043c23f
commit 935cffe250
3 changed files with 28 additions and 133 deletions

View File

@@ -16,8 +16,8 @@
#include <QPushButton>
#include <QDesktopServices>
#include <QUrl>
#include <QStringBuilder>
#include <QStringList>
#include <QtCharts>
using namespace QtCharts;
using namespace BlackMisc::Aviation;
@@ -37,10 +37,6 @@ namespace BlackGui
connect(ui->pb_GenerateMatrix, &QPushButton::released, this, &CAircraftModelStatisticsDialog::displayHTMLMatrix);
connect(ui->pb_ShowChart, &QPushButton::released, this, &CAircraftModelStatisticsDialog::showChart);
connect(ui->tb_ZoomIn, &QToolButton::released, this, &CAircraftModelStatisticsDialog::zoom);
connect(ui->tb_ZoomOut, &QToolButton::released, this, &CAircraftModelStatisticsDialog::zoom);
this->initChart();
}
CAircraftModelStatisticsDialog::~CAircraftModelStatisticsDialog()
@@ -59,40 +55,6 @@ namespace BlackGui
QDesktopServices::openUrl(QUrl::fromLocalFile(file));
}
void CAircraftModelStatisticsDialog::zoom()
{
const QObject *sender = QObject::sender();
QChart *chart = ui->qv_Chart->chart();
if (sender == ui->tb_ZoomIn) { chart->zoomIn(); return; }
if (sender == ui->tb_ZoomOut) { chart->zoomOut(); return; }
}
void CAircraftModelStatisticsDialog::initChart()
{
QChart *chart = new QChart();
chart->setAnimationOptions(QChart::SeriesAnimations);
chart->legend()->setVisible(true);
chart->legend()->setAlignment(Qt::AlignBottom);
chart->setTheme(QChart::ChartThemeBlueIcy);
ui->qv_Chart->setChart(chart);
ui->qv_Chart->setRenderHint(QPainter::Antialiasing);
// const QRectF rect(0, 0, 2048, 1526);
// ui->qv_Chart->setSceneRect(rect);
// chart->setPlotArea(rect);
}
void CAircraftModelStatisticsDialog::resetChart()
{
QChart *chart = ui->qv_Chart->chart();
chart->removeAllSeries();
const auto axes = chart->axes();
for (auto axis : axes)
{
chart->removeAxis(axis);
}
}
void CAircraftModelStatisticsDialog::showChart()
{
if (ui->rb_Distributors->isChecked()) { this->chartDistributors(); return; }
@@ -103,83 +65,41 @@ namespace BlackGui
{
const QMap<CDistributor, int> distributors = m_models.countPerDistributor();
QStringList distributorsForAxis;
QBarSet *setDistributors = new QBarSet("Distributors");
// using number as uique key as it can happen there a identical distributor keys
// and QChart requires uniques values
int n = 1;
QList<double> series;
for (const CDistributor &distributor : distributors.keys())
{
const int c = distributors[distributor];
if (c < 1) { continue; }
distributorsForAxis << QString::number(n) % u": " % distributor.getDbKey() % u" " % QString::number(c);
*setDistributors << c;
n++;
distributorsForAxis << (distributor.getDbKey() % u" (" % QString::number(c) % u")");
series << c;
}
QHorizontalBarSeries *series = new QHorizontalBarSeries(this);
series->append(setDistributors);
this->horizontalBarChart(distributorsForAxis, series);
ui->qwt_Chart->setSymbols("distributors", "white");
ui->qwt_Chart->setTitle("distributors");
ui->qwt_Chart->setSamples1Bar(series, distributorsForAxis);
}
void CAircraftModelStatisticsDialog::chartAircraftIcao()
{
const QMap<CAircraftIcaoCode, int> icaos = m_models.countPerAircraftIcao();
QStringList icaosForAxis;
QBarSet *setIcaos = new QBarSet("Aircraft ICAO");
// using number as uique key as it can happen there a identical distributor keys
// and QChart requires uniques values
int n = 1;
QList<double> series;
int unknown = 0;
for (const CAircraftIcaoCode &icao : icaos.keys())
{
const int c = icaos[icao];
if (c < 1) { continue; }
icaosForAxis << QString::number(n) % u": " % icao.getDesignatorDbKey() % u" " % QString::number(c);
*setIcaos << c;
n++;
if (!icao.hasKnownDesignator()) { unknown += c; continue; }
icaosForAxis << (icao.getDesignatorDbKey() % u" (" % QString::number(c) % u")");
series << c;
}
QBarSeries *series = new QBarSeries(this);
series->append(setIcaos);
this->verticalBarChart(icaosForAxis, series);
ui->qwt_Chart->setSymbols("aircraft", "white");
ui->qwt_Chart->setTitle("aircraft ICAO");
ui->qwt_Chart->setSamples1Bar(series, icaosForAxis);
}
void CAircraftModelStatisticsDialog::horizontalBarChart(const QStringList &categories, QHorizontalBarSeries *series)
{
QChart *chart = ui->qv_Chart->chart();
this->resetChart();
chart->addSeries(series);
// Y
QBarCategoryAxis *axisY = new QBarCategoryAxis();
axisY->append(categories);
chart->addAxis(axisY, Qt::AlignLeft);
series->attachAxis(axisY);
// X
QValueAxis *axisX = new QValueAxis();
chart->addAxis(axisX, Qt::AlignBottom);
series->attachAxis(axisX);
axisX->applyNiceNumbers();
}
void CAircraftModelStatisticsDialog::verticalBarChart(const QStringList &categories, QBarSeries *series)
{
QChart *chart = ui->qv_Chart->chart();
this->resetChart();
chart->addSeries(series);
// X
QBarCategoryAxis *axisX = new QBarCategoryAxis();
axisX->append(categories);
chart->addAxis(axisX, Qt::AlignBottom);
series->attachAxis(axisX);
// Y
QValueAxis *axisY = new QValueAxis();
chart->addAxis(axisY, Qt::AlignLeft);
series->attachAxis(axisY);
}
} // ns
} // ns

View File

@@ -45,15 +45,6 @@ namespace BlackGui
//! Display the HTML matrix
void displayHTMLMatrix();
//! Zoom in/out
void zoom();
//! Init chart
void initChart();
//! Reset chart
void resetChart();
//! Chart
void showChart();
@@ -63,12 +54,6 @@ namespace BlackGui
//! Chart for aircraft ICAO
void chartAircraftIcao();
//! Display as horizontal bar chart
void horizontalBarChart(const QStringList &categories, QtCharts::QHorizontalBarSeries *series);
//! Display as vertical bar chart
void verticalBarChart(const QStringList &categories, QtCharts::QBarSeries *series);
QScopedPointer<Ui::CAircraftModelStatisticsDialog> ui;
BlackMisc::Simulation::CAircraftModelList m_models;
};

View File

@@ -23,7 +23,7 @@
<item>
<widget class="QTabWidget" name="tw_ModelStatistics">
<property name="currentIndex">
<number>1</number>
<number>0</number>
</property>
<widget class="QWidget" name="tb_GeneralStatistics">
<attribute name="title">
@@ -98,20 +98,6 @@
</property>
</spacer>
</item>
<item>
<widget class="QToolButton" name="tb_ZoomIn">
<property name="text">
<string>+</string>
</property>
</widget>
</item>
<item>
<widget class="QToolButton" name="tb_ZoomOut">
<property name="text">
<string>-</string>
</property>
</widget>
</item>
<item alignment="Qt::AlignRight">
<widget class="QPushButton" name="pb_ShowChart">
<property name="text">
@@ -123,11 +109,11 @@
</widget>
</item>
<item>
<widget class="QScrollArea" name="scrollArea">
<widget class="QScrollArea" name="sa_Chart">
<property name="widgetResizable">
<bool>true</bool>
</property>
<widget class="QWidget" name="scrollAreaWidgetContents">
<widget class="QWidget" name="sa_ChartContent">
<property name="geometry">
<rect>
<x>0</x>
@@ -138,9 +124,12 @@
</property>
<layout class="QVBoxLayout" name="verticalLayout_2">
<item>
<widget class="QChartView" name="qv_Chart">
<property name="dragMode">
<enum>QGraphicsView::NoDrag</enum>
<widget class="BlackGui::Graphs::CBarChart" name="qwt_Chart">
<property name="frameShape">
<enum>QFrame::StyledPanel</enum>
</property>
<property name="frameShadow">
<enum>QFrame::Raised</enum>
</property>
</widget>
</item>
@@ -187,9 +176,10 @@
</widget>
<customwidgets>
<customwidget>
<class>QChartView</class>
<extends>QGraphicsView</extends>
<header>QtCharts</header>
<class>BlackGui::Graphs::CBarChart</class>
<extends>QFrame</extends>
<header>blackgui/graphs/barchart.h</header>
<container>1</container>
</customwidget>
</customwidgets>
<resources/>