p
u
b
l
i
c
i
t
é

Codes sources Qt

Ajouter un nouvel élément

Les performances du mois

Démineur
2
Un éditeur de réseau de places et transitions (RdP)
1
Snake
3

    ang Un éditeur de réseau de places et transitions (RdP)

    Licence : GPL
    Un réseau de places et transitions est un réseau de Petri (Petri Net ou RdP) généralisé et non coloré (sans extensions).

    L'application PTNET Editor permettra de dessiner/editer graphiquement un tel réseau, de l'animer, de l'analyser en construisant et visualisant son graphe de couverture/accessibilité, de le convertir en fichier image et de le sauvegarder en tant que document PNML.

    1. Compiler l'application

    L'application a été développée et testée sous GNU/Linux OpenSUSE 12.3 (KDE). Elle est basée sur le Framework Qt 4.8.4 et utilise aussi:
    • Boost Graph Library 1.49 (BGL) pour construire le graphe de couverture/accessibilité d'un RdP (graphgenerator.cpp)
    • la bibliothèque GraphViz 2.28 pour visualiser le graphe convenablement (graphvisualizer.cpp).

    => Vous devez installer ces bibliothèques pour compiler le code source!

    Important: Pour éliminer les deux étapes suivantes (étape 2 et 3) et tester l'application directement, consultez le
    fichier source tabwidget.cpp et commentez les étape [0], [1] et [2] de la méthode bool validateXml(QFile& file, MessageHandler &messageHandler). Autrement dit, modifiez cette méthode pour qu'elle retourne toujours true indiquant que le document PNML est valide.

    2. PNML

    PNML (Petri Net Markup Language) est un format standard d'échange des réseaux de Petri. L'application est basée sur ce standard. Vous pouvez télécharger le grammaire (spécification) de ce language ici: http://www.pnml.org/grammar.php.

    Notre application est un éditeur des RdP sans extensions. Donc nous somme pas besoin de tous les fichiers de grammaire téléchargé. On va juste utiliser 4:
    • pnmlcoremodel.rng : Contient la définition de PNML Core Model.
    • ptnet.rng : Contient les déclarations des types ajoutées par les réseau de places et transitions : initialMarking (marquage initial d’une place) et inscription (poids d’un arc).
    • anyElement.xsd : Utilisé pour définir une grammaire non fournie par le standard PNML. Dans notre cas ceux sont les éléments ToolInfo.
    • conventions.rng: utilisé par ptnet.rng.

    3. Convertir les fichiers RNG

    Le grammaire PNML est décrit en langage RELAX NG (.rng). Celui ci est un langage de description de document XML alternative de XML Schema. RELAX NG n’est pas supporté par le module XML de la bibliothèque Qt. Donc on doit convertir les fichiers de format RNG en format XSD! A ce propos, on va utiliser l'outil Trang.

    Trang est un outil libre permettant de convertir des schémas RELAX NG en XML Schema. Vous pouvez le télécharger ici:http://code.google.com/p/jing-trang/downloads/list.

    Convertir les fichiers rng en des fichiers xsd ?

    1. Dans le répertoire /home/~Download/Trang, créez un dossier et le nommez rng.
    2. Créez un autre dossier dans le même répertoire /home/~Download/Trang et le nommez xsd.
    3. Copiez les 4 fichiers rng dans le dossier rng.
    4. Pour convertir les 4 fichiers, utilisez la commande : java -jar trang.jar -I rng -O xsd rng/ptnet.rng xsd/ptnet.xsd.
    5. les fichiers RNG sont maintenant convertis en fichiers XSD et copiés dans le dossier xsd.

    L'application va utiliser les 4 fichiers xsd pour valider un document PNML décrivant un RdP !

    Donc, vous devez procéder comme suit:

    6. Copier les 4 fichiers xsd dans le répertoire : ptnet/shemas
    7. Modifier le fichier anyElement.xsd en supprimant la balise xs:group et en ajoutant la balise contenue dans le fichier ptnet/shemas/anyElement.txt

    4. Tester l'application

    Une fois l'application est compilée et les fichiers XSD sont générés (étapes 1-5) et ajoutés au répertoire /ptnet/shemas et modifiés (étapes 6-7), vous pouvez le tester en utilisant les exemples contenus dans le dossier ptnet/examples.
    • Pour changer les attributs d'une Place, Transition ou un arc faite un double-clique sur l'élément correspondant.
    • Pendant l'animation d'un RdP et pour franchir (tirer) une transition faite un clique gauche sur elle.




    Bonne utilisation :)

    ang Animation en 2D

    Licence : Libre
    C'est une animation qui est à 100% écrite en qt (version5.2).Un personnage pousse une caisse,jusqu'a un endroit voulu, c'est une animation d'ou l'inspiration me provient d'un ancien jeu ,dont je ne connais plus le nom.

    ang Décompression de fichiers .tar.xz

    Licence : Autre
    Voilà un mini projet wrapper entre xz et Qt avec un petit bout de code pour décompresser les archives .tar.xz avec/sans crc32 (voir QXzDecode.h). Support en QDataStream ou QByteArray. Il permet d'avoir un décompresseur minimum ; sachant que xz se base sur lzma2, le format est très performant.

    Dans mon cas, ça me sert pour faire un plug-in étant en réalité une archive multi-fichiers.

    Dans l'avenir je referai tout en Qt pour compresser et optimiser le code.

    ang Des livres

    Éditeur : Nokia + 7 Kio
    Une interface de gestion de livres, basée sur le module QtSql et les capacités de modèles/vues.

    ang Un navigateur avec QtWebKit

    Éditeur : Nokia + 96 Kio
    Un simple navigateur exploitant les possibilités du module QtWebKit.

    ang Info-bulles

    Licence : GPL
    Dans un de mes projets, j'ai créé un système d'infos-bulles qui s'affichent pour donner des informations sur certains des composants de ma fenêtre.
    Je trouve ça très utile pour créer une sorte de didacticiel. Du coup, j'aimerai partager ma création avec vous.

    Une info-bulle se compose d'un titre, d'un texte et éventuellement d'un icône. L'icône peut être soit ceux de base utilisés par Qt (notamment pour les QMessageBox), soit un QPixmap.
    Il est possible d'indiquer une durée d'affichage en millisecondes. Une fois ce temps écoulé, la bulle va commencer à disparaître. Si l'utilisateur repasse le curseur sur la bulle avant qu'elle ne s'efface entièrement, la bulle reprend son opacité d'origine.
    Une durée d'affichage égale à -1 implique que la bulle ne se fermera pas automatiquement. L'utilisateur devra, alors, appuyer sur le bouton de fermeture.

    Si vous indiquez un widget parent à une bulle, elle pointera automatiquement vers son centre. Elle le suivra même si vous déplacez ou redimensionnez votre widget (ou ses parents). Vous pouvez également placer la bulle avec la méthode move(QPoint).
    Par contre, attention : c'est le bout de la flèche qui sera à cette position.
    La flèche se place automatiquement en haut à gauche de la bulle quand cette dernière est dans la partie supérieure gauche du bureau, en bas à gauche dans le coin inférieur gauche et pareil pour la droite du bureau.

    ang Téléchargeur d'albums Picasa

    Licence : Autre
    Un petit utilitaire permettant de télécharger un album Picasa. Il n'est pas vraiment optimal (un seul téléchargement à la fois). Il devrait permettre d'illustrer un peu l'utilisation de QHttp pour une récupération d'une page.

    ang Un lecteur multimédia avec Phonon

    Licence : Autre
    Un exemple complet de lecteur audio réalisé avec Phonon.

    ang Signaux et slots avec Qt4

    Licence : Autre

    Le mécanisme des signaux et slots de Qt est très avancé et permet de communiquer entre les threads. Cela est unique pour le moment et est aussi la cause de l'existence de moc et de l'utilisation de qmake pour construire les projets Qt.

    ang Un interpréteur avec des expressions régulières

    Licence : Autre
    Cet interpréteur se présentera sous forme d'une boîte de saisie, où l'utilisateur pourra entrer différentes commandes qui généreront des "morceaux" de code C++, de manière à simplifier le travail du programmeur. Commençons par établir une liste des commandes reconnues :

    un ensemble de commandes destinées à la gestion des fichiers, sous la forme FILE_xxx ;
    un ensemble de commandes destinées à la gestion des chaînes de caractères, sous la forme STRING_xxx.

    ang Afficher une vidéo avec MPlayer

    Licence : Autre
    Comment visualiser une vidéo dans Qt ? Comment intégrer MPlayer et Qt ?

    Qt, dans son souci de framework généraliste, n'implémente pas toujours tout ce dont on peut avoir besoin, surtout lorsque cela n'est pas d'usage courant. Les vidéos font partie de ce qui n'était pas couvert par Qt (maintenant supporté depuis la 4.4 par le biais de Phonon). Cependant, un grand nombre de librairies et autres backends existent. Nous allons voir comment utiliser l'un d'entre eux : MPlayer.

    ang Un color picker (version QML)

    Licence : Autre
    Il répond à la même question que la version C++ mais en QML, avec le tout nouveau Qt Quick.

    ang powerspectrum

    Licence : Libre
    Sources en C/C++ d'une application graphique basée sur la bibliothèque Qt calculant et affichant le spectre de puissance du signal provenant de l'entrée de la carte son du pc.

    ang Créer un menu contextuel (clic droit) en QML

    Licence : Autre
    Le code proposé permet de créer en QML un menu contextuel qui apparaîtra suite à un clic droit et qui se fermera en cas de sélection d'une option ou si le curseur de la souris sort du menu contextuel.

    ang Lecture de fichiers LZMA avec QIODevice

    Licence : Autre
    Comment dériver de QIODevice ? Comment compresser des données avec un algorithme très puissant mais libre en utilisant Qt ? En regardant de plus près cette source : elle vous présente la manière de dériver de QIODevice pour compresser des données à l'aide de LZMA.

    Voir aussi le SDK LZMA (licence libre) (850 Ko)

    ang Création d'une fenêtre personnalisée

    Licence : Autre
    Est-il possible de modifier l'aspect de ma fenêtre avec Qt ? La réponse est oui mais pas directement. En effet, ce n'est pas Qt qui gère la fenêtre mais le window manager sous-jacent (Windows, KDE, Gnome, Xfce, MacOS X...).

    La souplesse de Qt va nous permettre de contourner le problème afin de ne pas se soucier du window manager. N'étant pas évidente de prime abord, la solution utilise pourtant les fonctionnalités de base de Qt et plus particulièrement de QWidget. Cet article introduit ma façon de faire (il en existe surement d'autres) qui, je l'espère, est simple et suffisamment efficace pour s'adapter à tout type de projet.

    Vous pouvez lire le tutoriel associé.

    ang Interaction entre boost.signals et les signaux/slots Qt

    Licence : Autre
    Il est intéressant de savoir faire ceci dans la mesure où vous désireriez utiliser des classes écrites en C++ pur avec les mécanismes Qt. Par exemple, une couche métier utilisant le mécanisme de boost.signals comme implémentation du pattern observateur, que vous désirez connecter à la couche IHM écrite à l'aide de Qt.

    L'article lié.

    ang Utilisation de DevIL avec Qt

    Licence : Autre
    Voici un exemple de plug-un pour utiliser de manière transparente les fonctionnalités de QImage avec la compatibilité de DevIL.

    L'article associé.

    ang Ouverture d'une boîte de dialogue avec Qt 4

    Licence : Autre
    Nous verrons deux façons de faire : utilisation d'une fenêtre principale avec menus pour ouvrir une boîte de dialogue et une boite "À propos..." ET ouverture d'une fenêtre de dialogue par le biais d'un bouton.

    L'article associé

    ang Un updater de base

    Licence : Autre
    Ce premier updater est très basique : il peut télécharger un fichier sur Internet, sans plus, quand l'utilisateur appuie sur un bouton.

    L'article associé

48 éléments

Responsable bénévole de la rubrique Qt : Thibaut Cuvelier -