-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathformtreeconsistency.cpp
More file actions
111 lines (97 loc) · 4.49 KB
/
formtreeconsistency.cpp
File metadata and controls
111 lines (97 loc) · 4.49 KB
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*
* ProtonClassicSuite
*
* Copyright Thibault et Gilbert Mondary, Laboratoire de Recherche pour le
* Développement Local (2006--)
*
* labo@gipilab.org
*
* Ce logiciel est un programme informatique servant à cerner l'ensemble des
* données budgétaires de la collectivité territoriale (audit, reporting
* infra-annuel, prévision des dépenses à venir)
*
*
* Ce logiciel est régi par la licence CeCILL soumise au droit français et
* respectant les principes de diffusion des logiciels libres. Vous pouvez
* utiliser, modifier et/ou redistribuer ce programme sous les conditions
* de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
* sur le site "http://www.cecill.info".
*
* En contrepartie de l'accessibilité au code source et des droits de copie,
* de modification et de redistribution accordés par cette licence, il n'est
* offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
* seule une responsabilité restreinte pèse sur l'auteur du programme, le
* titulaire des droits patrimoniaux et les concédants successifs.
*
* A cet égard l'attention de l'utilisateur est attirée sur les risques
* associés au chargement, à l'utilisation, à la modification et/ou au
* développement et à la reproduction du logiciel par l'utilisateur étant
* donné sa spécificité de logiciel libre, qui peut le rendre complexe à
* manipuler et qui le réserve donc à des développeurs et des professionnels
* avertis possédant des connaissances informatiques approfondies. Les
* utilisateurs sont donc invités à charger et tester l'adéquation du
* logiciel à leurs besoins dans des conditions permettant d'assurer la
* sécurité de leurs systèmes et ou de leurs données et, plus généralement,
* à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
*
* Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
* pris connaissance de la licence CeCILL, et que vous en avez accepté les
* termes.
*
*/
#include "formtreeconsistency.h"
#include "pcx_nodesimilaritytablemodel.h"
#include "ui_formtreeconsistency.h"
#include <QDateTime>
#include <QDebug>
#include <QSortFilterProxyModel>
FormTreeConsistency::FormTreeConsistency(unsigned int treeId, QWidget *parent)
: QWidget(parent), ui(new Ui::FormTreeConsistency) {
ui->setupUi(this);
tree = new PCx_Tree(treeId);
QDateTime dt = QDateTime::currentDateTime();
ui->label->setText(
tr("Arbre %1 le %2 à %3").arg(tree->getName(), dt.date().toString("dd/MM/yyyy"), dt.time().toString()));
populateTableInfos();
populateListOfNodesWithSameNameButDifferentTypes();
ui->tableWidget->resizeColumnsToContents();
QStringList completeNodeNames = tree->getListOfCompleteNodeNames();
PCx_NodeSimilarityTableModel *distanceModelWithTypes;
QSortFilterProxyModel *distanceSortModelWithTypes;
distanceModelWithTypes =
new PCx_NodeSimilarityTableModel(completeNodeNames, PCx_StringDistance::SIMILARITYMETRIC::JAROWINKLERCI, this);
distanceSortModelWithTypes = new QSortFilterProxyModel(this);
distanceSortModelWithTypes->setSourceModel(distanceModelWithTypes);
distanceSortModelWithTypes->sort(1, Qt::DescendingOrder);
ui->similarityTableView->setModel(distanceSortModelWithTypes);
ui->similarityTableView->resizeColumnToContents(1);
}
FormTreeConsistency::~FormTreeConsistency() {
delete ui;
delete tree;
}
QSize FormTreeConsistency::sizeHint() const { return {600, 500}; }
void FormTreeConsistency::populateListOfNodesWithSameNameButDifferentTypes() {
QSet<unsigned int> nodes = tree->getNodesWithSharedName();
QString nodeName;
foreach (unsigned int node, nodes) {
nodeName = tree->getNodeName(node);
ui->similarityNodeNotTypeListWidget->addItem(nodeName);
}
}
void FormTreeConsistency::populateTableInfos() {
ui->tableWidget->item(0, 1)->setText(QString::number(tree->getNumberOfNodes()));
QList<QPair<unsigned int, QString>> listOfTypes = tree->getAllTypes();
QPair<unsigned int, QString> type;
int row = ui->tableWidget->rowCount();
foreach (type, listOfTypes) {
ui->tableWidget->insertRow(ui->tableWidget->rowCount());
unsigned int nbOfThisType = tree->getNumberOfNodesWithThisType(type.first);
QTableWidgetItem *item1 = new QTableWidgetItem("Noeuds de type " + type.second);
QTableWidgetItem *item2 = new QTableWidgetItem(QString::number(nbOfThisType));
item2->setTextAlignment(Qt::AlignRight | Qt::AlignVCenter);
ui->tableWidget->setItem(row, 0, item1);
ui->tableWidget->setItem(row, 1, item2);
row++;
}
}