Les interfaces des programmes [C] - C++ - Programmation
Marsh Posté le 28-01-2003 à 22:11:33
... Beaucoup de questions !
Je ne connais pas du tout la programmation graphique sous X, mais il faut savoir que sous Windows, (presque) tout est une Fenêtre. Et ces fenêtres réagissent à des événements envoyés par le système d'exploitation que l'on appelle Messages.
Sous Windows, les fenêtres sont identifiés par des Handles (de type HWND) que tu crées (avec la fonction CreateWindowEx) en y associant une classe (le type WNDCLASSEX) et un certain nombre de paramètres (taille, position, aspect...).
La classe est la chose la plus importante pour une fenêtre. en effet, en plus de définir quelques aspects "esthétiques", elle va définir le "comportement" de la fenêtre au travers notamment de la procédure (WindowProcedure dans le programme). C'est cette procédure qui va permettre à la fenêtre de réagir aux événements du système d'exploitation.
Le corps du programme se situe dans le while. C'est ici que ton programme va récupérer les messages du système d'exploitation qui lui sont destinés (GetMessage) et les envoyer (DispatchMessage) à la fenêtre concernée (au travers de sa procédure).
Après, c'est à ton programme de réagir au messages que Windows lui envoie. On voit ici que le programme ne réagit qu'au message WM_DESTROY qui indique que la fenêtre va être détruite. Pour tous les autres événements, il utilise la réaction classique (DefWindowProc) définie par Windows.
Voila une explication très rapide du fonctionnement des applications graphiques sous Windows. Après, tu trouveras certainement plus d'infos, plus précises et mieux expliquées en faisant quelques recherches (tu peux déjà aller voir chez microsoft).
Pour ajouter un menu, regarde un peu les commentaires ("/* No menu */" ). En fait, un menu c'est une fenêtre particulière que tu crées avec la fonction CreateMenu. Ensuite, tu l'enrichi (en le chargeant à partir d'une ressource en général) puis tu l'associe à ta fenêtre principale en le définissant dans la classe ou lors de l'appel à la fonction CreateWindowEx.
Marsh Posté le 28-01-2003 à 22:56:34
Je ne demandais pas autant de détails techniques mais tant mieux.
Donc si j'ai bien compris, c'est bien grâce au windows.h que l'on va pouvoir programmer une interface de programme, en écrivant des fonctions comme CreateWindowEx pour faire ceci, telle autre fonction pour faire cela et ainsi de suite.
En fait ce qui me gênait, c'était le fait que j'avais en tête la programmation d'interface sous Visual il me semble, là ou on est avec une souris et ou on peut intégrer, toujours à la souris, des scroll, des boites de dialogues, etc.
Sinon, en ce qui concerne GTK ou QT ? Est-ce à peu près la meme chose que sous windows, genre s'il suffit de rajouter quelque chose comme gtk.h puis d'écrire ces fonctions.
Marsh Posté le 28-01-2003 à 23:25:50
Z-Axis a écrit : En fait ce qui me gênait, c'était le fait que j'avais en tête la programmation d'interface sous Visual il me semble, là ou on est avec une souris et ou on peut intégrer, toujours à la souris, des scroll, des boites de dialogues, etc. |
En fait, il n'y a pas tant de différences que ça avec Visual C++. Ce que tu fais avec Visual C++ dans l'éditeur de ressources (tant que tu n'utilises que les composants standards), ce n'est ni plus ni moins que créer tes ressources . Toutes ces ressources sont intégrées dans un fichier texte (*.rc) qui est ajouté au projet. C'est le même fichier texte que tu peux utiliser dans n'importe quel projet (pour charger tes menus, tes boîtes de dialogue...) car c'est le format standard Windows.
Après, tu n'as plus les MFC bien évidemment, mais les MFCs sont très souvent juste une "mise-en-classe" des fonctions de l'API Windows.
Tu peux voir un autre exemple de projet "basique" (avec un menu et une boîte de dialogue) sur le site Microsoft (http://msdn.microsoft.com/library/en-us/winprog/winprog/a_generic_sample_application.asp)
Marsh Posté le 28-01-2003 à 23:47:18
Et pour GTK ?
Code :
|
Trouvé sur gtk.org
Je comprends un peu mieux tout ça.
Et je comprends aussi pourquoi certains ont du mal à porter leurs progammes UNIX vers une plateforme win32 ; en gros il faut tout reprogrammer ! (du moins l'interface)
Marsh Posté le 29-01-2003 à 07:18:00
Z-Axis a écrit :
|
La conception d'interface en C/C++ est une corvée. De plus les toolkits les plus utilisés sous Win n'existent pas sous *NIX. En revanche, des toolkits comme Qt peuvent faciliter le portage, car il existe une implémentation pour chaque OS.
Marsh Posté le 29-01-2003 à 19:48:06
J'ai encore un souci.
Le GTK est-il considéré comme un langage de programmation
Puisque si je regarde le code pour afficher Hello World en GTK :
Code :
|
Ca n'a rien a voir avec celui en C :
Code :
|
Je comprends plus grand chose !? Si je veux faire un programme en GTK, je ne programme donc plus en C mais en GTK ? Puisqu'apparremment g_print en GTK est l'équivalent de printf en C
Marsh Posté le 29-01-2003 à 20:43:45
un programme ecrit CORRECTEMENT en gtk sous linux sera facilement porable sous windows par la suite : exemple, the gimp.
Maintenant, le GTK n'est pas un autre langage, mais c'est une librairie de C ... et pas de C++ comme d'autres .
Certain prefere GTK, d'autres Qt, c'est une question de gout
Marsh Posté le 29-01-2003 à 21:00:20
Oui mais ce que je comprends pas c'est qu'il n'y a aucune correspondance entre le C et le GTK ?
Et si GTK n'est pas un langage, alors pourquoi il y a autant de différence pour afficher un Hello World entre GTK et C ?
Marsh Posté le 29-01-2003 à 22:16:33
Au contraire, gtk esune librairie écrite en C.
Tu ne peux programmer en utilisant gtk sans connaitre le C..
Si tu veux, la librairie gtk va te permettre d'utiliser des fonctions en plus par rapport au C de bae qui vont te permettre de faire des GUI. La différence entre les deux hello world provient du fait que les deux fonctions ne font pas la meme chose : l'une affiche hello world sur la sortie standart, l'autre dans une fenetre (donc spécifique à GTK)
Marsh Posté le 30-01-2003 à 22:10:51
Ca devient compliqué
Marsh Posté le 30-01-2003 à 22:51:12
C'est pour ca qu'il faut connaitre le C avant de se lancer dans la création de GUI. Après le C (en ligne de commande), et tout te sembleras plus claire.
Marsh Posté le 31-01-2003 à 17:36:03
Je ne connais pas de tutorial pour le développement d'interfaces. Et c'est vrai que quand on découvre, c'est assez compliqué.
J'ai appris le fonctionnement de Win32 en utilisant tout d'abord les MFCs (le plus simple est de commencer par des boîtes de dialogue) puis, au travers d'exemples et de tests, j'ai fini par comprendre grossièrement le fonctionnement global et à savoir coder directement mes fenêtres (mais pour des interfaces complexes, j'utilise toujours les MFCs).
J'utilise Visual C++, mais tu dois pouvoir suivre le même chemin avec d'autres outils de développement proposant des librairies simplifiant la conception d'interfaces (C++ Builder, Delphi, Kylix...).
Marsh Posté le 31-01-2003 à 18:57:34
En fait, le côté GTK ou Qt m'intéresserait plus.
Sinon, si je programme "simplement" (cad sans interface particulière) sous Windows, la portabilité (ça se dit ?) du programme sous un environnement Linux est tout à fait envisageable sans la moindre re-programmation ?
Marsh Posté le 31-01-2003 à 20:38:51
Je participe à un tuto fr sur gtk :
jcecchi.free.fr
Si tu programmes en ainsi-C, tes sources seront portables de windows à linux (pour n'importe quel compilateur qui respecte les normes).
L'avantage d'utiliser une librairie pour faire les GUI est justement la portabilité (suffit juste de recompiler). Ainsi gtk et Qt sont portable au moins sur windows / linux..
Marsh Posté le 31-01-2003 à 21:44:10
Oui c'est pour ça que GTK ou Qt c'est bien
Pour le tuto, je te remercie, il va m'etre très utile
Marsh Posté le 01-02-2003 à 01:52:11
A un detail près : GTK, sous Windows, c'est merdique.
Y'aurait Qt mais ... la derniere fois que j'ai voulu tester sous Windows, y'aait que la version 2.3 de Qt de dispo (c'est une lib payante qui en est a la version 3.1 et quelque). Ce que j'ai vu de Qt 2.3 sous Windows m'a bcp reffroidi.
Y'a aussi wxWindows comme lib C++ portable.
C'est gratuit, y'a un petit editeur de ressources avec, ca supporte les themes XP, ca a un gout de deja vu, (enfin, si tu connais un peu C++/STL/MFC).
J'ai testé que sous Windows. (je suis en train de m'y mettre en fait, vu que je dois choisir entre Qt et ca pour un assez gros projet C++ Win/Linux/Mac, j'essai de voir si c'est assez ... "serieux" )
Marsh Posté le 01-02-2003 à 12:38:04
pourkoi tu dis que GTK c'est nul sous win??
the gimp est pas deguelasse quand mem...
en tout cas je trouve pas
Marsh Posté le 01-02-2003 à 12:56:48
moi non plus je trouve pas que ca soit nul (normal je l'utilise).
Par contre c'est vrai que sous windows, il n'y a pas d'éditeur d'interface valable, il faut donc tout coder "à la main".
Enfin, Z-Axis demande une librairie C : parmis gtk, Qt et wxwindow, seul gtk est une librairie C. LEs deux autres demandent une connaissance du C++.
Marsh Posté le 01-02-2003 à 16:10:28
La derniere fois que j'ai vu GTK en action sous Windows, ca donnait :
- 12 dll a se trimballer
- une interface lente, tres lente
- une interface qui n'a rien a voir avec celle de Windows : tout a été recode le look & feel comme sous Linux, meme les boite de dialogue ne sont pas celles de Windows. Je suis personnelement farouchement opposé à ce procédé et c'est aussi ce que je reproche a Qt (a par que lui c'est le seul reproche + le fait d'etre payant).
Mon opinion a ete renforcee avec WinXP : les themes ne fonctionnent pas avec une appli GTK. Pour Qt, il parrait que QT 3.0.5 je crois a resolu le probleme, mais je pense qu'ils l'ont contourné (ils on du utiliser les themes pour dessiner leurs controles, mais ca reste toujours leurs propres controles different de ceux de Windows). Mais Qt utilise tout de meme les boites de dialogues standards de Windows, contrairement a GTK.
Seul wxWindows encapsule Win32. Un prog wxWindows est un "vrai" prog Windows.
Enfin y'a la rumeur qui confirme que l'implémentation de GTK sous Windows est merdique.
Mais oui c'est en C. Mais il semblait OK pour Qt. Et je trouve qu'il y gagnera plus à investir dans le C++ avec Qt/wxWindows qu'en C avec GTK (avis perso).
Marsh Posté le 22-02-2003 à 11:35:17
pour moi, l'exemple type d'un prog GTK+ porté sous win est TheGimp .. et je trouve qu'il s'en tire vraiment pas mal ...
Lent, je vois pas pourkoi, maintenant le look&feel, c'est une ketion de gout, c'est sur
Marsh Posté le 28-01-2003 à 21:23:20
Bonjour,
Je débute en programmation C et je voulais avoir un petit renseignement.
Je ne savais pas comment programmer une interface il y a quelques temps quand je suis tombé sur un exemple tout fait sous Dev C++.
Voici le code que j'ai vu :
Lorsque j'ai compilé ça, j'ai vu que ça faisait une interface comme je voulais.
C'est donc comme ça que l'on fait les interfaces en C sous Windows ? Est-ce grace au include windows.h ? Comment faire pour ajouter à l'interface des menus "Fichier", "Editer", etc. ?
Comment ça se passe pour les interfaces GTK (sous linux) ? Grâce à un include gtk.h (par exemple) ?
Merci
Message édité par Z-Axis le 28-01-2003 à 21:23:42
---------------
x,y,z