mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-09-13 20:23:04 +02:00
git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@31 bfdf4180-ca20-0410-9c96-a3a8aa849046
204 lines
7.3 KiB
C++
204 lines
7.3 KiB
C++
#include "panelappareils.h"
|
|
#include "elementperso.h"
|
|
|
|
/**
|
|
Constructeur
|
|
@param parent Le QWidget parent du panel d'appareils
|
|
*/
|
|
PanelAppareils::PanelAppareils(QWidget *parent) : QTreeWidget(parent) {
|
|
|
|
// selection unique
|
|
setSelectionMode(QAbstractItemView::SingleSelection);
|
|
setColumnCount(1);
|
|
header() -> hide();
|
|
|
|
// drag'n drop autorise
|
|
setDragEnabled(true);
|
|
setAcceptDrops(false);
|
|
setDropIndicatorShown(false);
|
|
|
|
// taille des elements
|
|
setIconSize(QSize(50, 50));
|
|
|
|
// chargement des elements de la collection QET
|
|
ajouterDossier(invisibleRootItem(), QETApp::commonElementsDir(), tr("Collection QET"));
|
|
|
|
// chargement des elements de la collection utilisateur
|
|
ajouterDossier(invisibleRootItem(), QETApp::customElementsDir(), tr("Collection utilisateur"));
|
|
|
|
// force du noir sur une alternance de blanc (comme le schema) et de gris
|
|
// clair, avec du blanc sur bleu pas trop fonce pour la selection
|
|
QPalette qp = palette();
|
|
qp.setColor(QPalette::Text, Qt::black);
|
|
qp.setColor(QPalette::Base, Qt::white);
|
|
qp.setColor(QPalette::AlternateBase, QColor("#e8e8e8"));
|
|
qp.setColor(QPalette::Highlight, QColor("#678db2"));
|
|
qp.setColor(QPalette::HighlightedText, Qt::white);
|
|
setPalette(qp);
|
|
}
|
|
|
|
/**
|
|
Gere le mouvement lors d'un drag'n drop
|
|
*/
|
|
void PanelAppareils::dragMoveEvent(QDragMoveEvent */*e*/) {
|
|
}
|
|
|
|
/**
|
|
Gere le depot lors d'un drag'n drop
|
|
*/
|
|
void PanelAppareils::dropEvent(QDropEvent */*e*/) {
|
|
}
|
|
|
|
/**
|
|
Gere le debut des drag'n drop
|
|
@param supportedActions Les actions supportees
|
|
@todo virer les lignes type «if ("tel appareil") construire TelAppareil» => trouver un moyen d'automatiser ca
|
|
*/
|
|
void PanelAppareils::startDrag(Qt::DropActions /*supportedActions*/) {
|
|
// recupere le nom du fichier decrivant l'element
|
|
QString nom_fichier = currentItem() -> data(0, 42).toString();
|
|
if (nom_fichier == QString()) return;
|
|
|
|
// objet QDrag pour realiser le drag'n drop
|
|
QDrag *drag = new QDrag(this);
|
|
|
|
// donnees qui seront transmises par le drag'n drop
|
|
QMimeData *mimeData = new QMimeData();
|
|
|
|
// appareil temporaire pour fournir un apercu
|
|
int etat;
|
|
Element *appar = new ElementPerso(nom_fichier, 0, 0, &etat);
|
|
if (etat != 0) {
|
|
delete appar;
|
|
return;
|
|
}
|
|
|
|
mimeData -> setText(nom_fichier);
|
|
drag -> setMimeData(mimeData);
|
|
|
|
// accrochage d'une pixmap representant l'appareil au pointeur
|
|
drag -> setPixmap(appar -> pixmap());
|
|
drag -> setHotSpot(appar -> hotspot());
|
|
|
|
// realisation du drag'n drop
|
|
drag -> start(Qt::CopyAction);
|
|
|
|
// suppression de l'appareil temporaire
|
|
delete appar;
|
|
}
|
|
|
|
|
|
/**
|
|
Methode privee permettant d'ajouter un dossier au panel d'appareils
|
|
@param qtwi_parent QTreeWidgetItem parent sous lequel sera insere l'element
|
|
@param dossier Chemin absolu du dossier a inserer
|
|
@param nom Parametre facultatif permettant de forcer le nom du dossier.
|
|
S'il n'est pas precise, la fonction ouvre le fichier qet_directory situe
|
|
dans le dossier et y lit le nom du dossier ; si ce fichier n'existe pas ou
|
|
est invalide, la fonction utilise le nom du dossier.
|
|
*/
|
|
void PanelAppareils::ajouterDossier(QTreeWidgetItem *qtwi_parent, QString adr_dossier, QString nom) {
|
|
QDir dossier(adr_dossier);
|
|
if (!dossier.exists()) return;
|
|
adr_dossier = dossier.canonicalPath() + "/";
|
|
|
|
// recupere le nom de la categorie
|
|
QString nom_categorie = (nom != QString()) ? nom : categoryName(dossier);
|
|
|
|
// creation du QTreeWidgetItem representant le dossier
|
|
QTreeWidgetItem *qtwi_dossier = new QTreeWidgetItem(qtwi_parent, QStringList(nom_categorie));
|
|
QLinearGradient t(0, 0, 200, 0);
|
|
t.setColorAt(0, QColor("#e8e8e8"));
|
|
t.setColorAt(1, QColor("#ffffff"));
|
|
qtwi_dossier -> setBackground(0, QBrush(t));
|
|
qtwi_dossier -> setExpanded(true);
|
|
|
|
// ajout des sous-categories / sous-dossiers
|
|
QStringList dossiers = dossier.entryList(QStringList(), QDir::AllDirs | QDir::NoSymLinks | QDir::NoDotAndDotDot, QDir::Name);
|
|
foreach(QString dossier, dossiers) ajouterDossier(qtwi_dossier, adr_dossier + dossier);
|
|
|
|
// ajout des elements / fichiers
|
|
QStringList fichiers = dossier.entryList(QStringList("*.elmt"), QDir::Files, QDir::Name);
|
|
foreach(QString fichier, fichiers) ajouterFichier(qtwi_dossier, adr_dossier + fichier);
|
|
}
|
|
|
|
/**
|
|
Methode privee permettant d'ajouter un element au panel d'appareils
|
|
@param qtwi_parent QTreeWidgetItem parent sous lequel sera insere l'element
|
|
@param fichier Chemin absolu du fichier XML decrivant l'element a inserer
|
|
*/
|
|
void PanelAppareils::ajouterFichier(QTreeWidgetItem *qtwi_parent, QString fichier) {
|
|
QString whats_this = tr("Ceci est un \351l\351ment que vous pouvez ins\351rer dans votre sch\351ma par cliquer-d\351placer");
|
|
QString tool_tip = tr("Cliquer-d\351posez cet \351l\351ment sur le sch\351ma pour ins\351rer un \351l\351ment ");
|
|
int etat;
|
|
ElementPerso *elmt_perso = new ElementPerso(fichier, 0, 0, &etat);
|
|
if (etat != 0) {
|
|
qDebug() << "Le chargement du composant" << fichier << "a echoue avec le code d'erreur" << etat;
|
|
return;
|
|
}
|
|
QTreeWidgetItem *qtwi = new QTreeWidgetItem(qtwi_parent, QStringList(elmt_perso -> nom()));
|
|
qtwi -> setStatusTip(0, tool_tip + "\253 " + elmt_perso -> nom() + " \273");
|
|
qtwi -> setToolTip(0, elmt_perso -> nom());
|
|
qtwi -> setWhatsThis(0, whats_this);
|
|
qtwi -> setFlags(Qt::ItemIsSelectable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled);
|
|
qtwi -> setIcon(0, QIcon(elmt_perso -> pixmap()));
|
|
qtwi -> setData(0, 42, fichier);
|
|
}
|
|
|
|
|
|
/**
|
|
Methode permettant d'obtenir le nom affichable d'une categorie etant donne
|
|
son chemin (dossier).
|
|
@param directory le chemin du dossier representant la categorie
|
|
@return Le nom affichable de la categorie
|
|
*/
|
|
QString PanelAppareils::categoryName(QDir &directory) {
|
|
// en cas d'echec de la lecture du fichier de configuration
|
|
// "qet_directory", le nom du dossier est retourne
|
|
QString category_name = directory.dirName();
|
|
// repere le chemin du fichier de configuration de la categorie
|
|
QFile directory_conf(directory.canonicalPath() + "/qet_directory");
|
|
// verifie l'existence du fichier
|
|
if (directory_conf.exists()) {
|
|
// ouvre le fichier
|
|
if (directory_conf.open(QIODevice::ReadOnly | QIODevice::Text)) {
|
|
// recupere les deux premiers caracteres de la lcoale en cours du systeme
|
|
QString system_language = QLocale::system().name().left(2);
|
|
// lit le contenu du fichier dans un QDomDocument XML
|
|
QDomDocument document;
|
|
if (document.setContent(&directory_conf)) {
|
|
/* parcourt le document XML a la recherche d'un nom
|
|
par ordre de preference, on prendra :
|
|
- le nom dans la langue du systeme
|
|
- le nom en anglais
|
|
- le nom du dossier
|
|
*/
|
|
QDomElement root = document.documentElement();
|
|
if (root.tagName() == "qet-directory") {
|
|
bool name_found = false;
|
|
// parcourt les "names"
|
|
for (QDomNode node = root.firstChild() ; !node.isNull() ; node = node.nextSibling()) {
|
|
QDomElement names = node.toElement();
|
|
if (names.isNull() || names.tagName() != "names") continue;
|
|
// parcourt les "name"
|
|
for (QDomNode n = names.firstChild() ; !n.isNull() ; n = n.nextSibling()) {
|
|
QDomElement name = n.toElement();
|
|
if (name.isNull() || name.tagName() != "name") continue;
|
|
if (name.attribute("lang") == system_language) {
|
|
category_name = name.text();
|
|
name_found = true;
|
|
break;
|
|
} else if (name.attribute("lang") == "en") {
|
|
category_name = name.text();
|
|
}
|
|
}
|
|
if (name_found) break;
|
|
}
|
|
}
|
|
}
|
|
directory_conf.close();
|
|
}
|
|
}
|
|
return(category_name);
|
|
}
|