1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
/*
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version
2 of the License, or (at your option) any later version.
*/
#include <QTabWidget>
#include <QPainter>
#include <QVBoxLayout>
#include <QHBoxLayout>
#include <QSqlQuery>
#include <QVariant>
#include <QFontMetrics>
#include <QApplication>
#include <QPainter>
#include <QPen>
#include <QBrush>
#include <QLinearGradient>
#include <QPushButton>
#include <QSqlError>
#include <QTreeView>
#include <QSortFilterProxyModel>
#include "statisticsdialog.h"
#include "actorcountmodel.h"
#include "graphbarwidget.h"
StatisticsDialog::StatisticsDialog(QWidget *parent, Qt::WindowFlags f) : QDialog(parent, f){
QVBoxLayout *mainLayout = new QVBoxLayout;
mTab = new QTabWidget;
// quality distribution
QList<QList<QVariant> > qualityData;
QSqlQuery q("SELECT DISTINCT(iquality), COUNT(iquality) FROM movies GROUP BY iquality ORDER BY iquality");
while(q.next()){
QList<QVariant> d;
d << q.value(0) << q.value(1) << q.value(1);
qualityData << d;
}
GraphBarWidget *qs = new GraphBarWidget(qualityData);
qs->setCaption(tr("Movie qualities"));
mTab->addTab(qs, tr("Quality Distribution"));
mainLayout->addWidget(mTab);
// genre distribution
QList<QList<QVariant> > genreData;
QSqlQuery q2("SELECT DISTINCT(genre.igenreid), genre.tgenrename, COUNT(movies.imovid) FROM movies, genre WHERE movies.igenreid = genre.igenreid GROUP by genre.igenreid, genre.tgenrename ORDER by genre.tgenrename");
while(q2.next()){
QList<QVariant> d;
d << q2.value(1) << q2.value(2) << q2.value(2);
genreData << d;
}
GraphBarWidget *gs = new GraphBarWidget(genreData);
gs->setCaption(tr("Genre Distribution"));
mTab->addTab(gs, tr("Genre Distribution"));
// top ten actors
QList<QList<QVariant> > actorData;
QSqlQuery q3("SELECT DISTINCT(actor.iactorid), actor.tactorname, COUNT(DISTINCT(movies.ttitle)) AS num FROM movies, actor, movieactormap WHERE actor.iactorid = movieactormap.iactorid AND movieactormap.imovid = movies.imovid GROUP BY actor.iactorid, actor.tactorname ORDER BY num DESC LIMIT 10");
while(q3.next()){
QList<QVariant> d;
d << q3.value(1) << q3.value(2) << q3.value(2);
actorData << d;
}
GraphBarWidget *as = new GraphBarWidget(actorData);
as->setCaption(tr("Top 10 actors"));
mTab->addTab(as, tr("Top 10 actors"));
// actor count
QWidget *actorWidget = new QWidget;
QHBoxLayout *actorLayout = new QHBoxLayout;
QTreeView *actorView = new QTreeView;
actorView->setRootIsDecorated(false);
ActorCountModel *aModel = new ActorCountModel;
QSortFilterProxyModel *proxy = new QSortFilterProxyModel(this);
proxy->setSourceModel(aModel);
actorView->setModel(proxy);
actorView->resizeColumnToContents(0);
actorLayout->addWidget(actorView);
actorWidget->setLayout(actorLayout);
actorView->setSortingEnabled(true);
mTab->addTab(actorWidget, tr("Actor overview"));
QHBoxLayout *buttonLayout = new QHBoxLayout;
buttonLayout->setAlignment(Qt::AlignHCenter);
mOk = new QPushButton(tr("Ok"));
connect(mOk, SIGNAL(clicked()), this, SLOT(accept()));
buttonLayout->addWidget(mOk);
mainLayout->addLayout(buttonLayout);
QString title = QString(tr("%1 - Statistics")).arg(qApp->applicationName());
setLayout(mainLayout);
setWindowTitle(title);
}
|