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 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176
|
#include <stdlib.h>
#include <gtk/gtk.h>
#include <mysql/mysql.h>
#include <sql.h>
void Action(GtkWidget *Bouton, gpointer data);
void on_activate_entry(GtkWidget *Entryn, gpointer data);
int main(int argc, char **argv)
{
GtkWidget *Window;
GtkWidget *ComboBox,*ComboBoxcanal;
GtkWidget *HBoxp,*HBoxn,*VBox,*HBoxtitre,*HBoxadresse,*HBoxtel,*HBoxrv,*HBoxhd,*HBoxdate,*HBoxheure,*HBoxdh,*HBoxj,*HBoxm,*HBoxa,*HBoxh,*HBoxmin,
*HBox1,*HBox2,*HBox3,*HBox4,*HBoxvide,*HBoxcanal,*HBoxbouton;
GtkWidget *Bouton;
GtkWidget *Labeltitre,*Labelp,*Labeladresse,*Labeltel,*Labeln,*Labelrv,*Labeldate,*Labelj,*Labelm,*Labela,*Labelheure,*Labelh,
*Labelmin,*Labelcanal,*Labelc,*Labelln;
GtkWidget *Entryn,*Entryp,*Entryadresse,*Entrytel,*Entryj,*Entrym,*Entrya,*Entryh,*Entrymin;
GtkWidget *Label;
const gchar *Textnom;
gtk_init(&argc,&argv);
Window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
gtk_window_set_title(GTK_WINDOW(Window), "CALLBACK");
gtk_window_set_default_size(GTK_WINDOW(Window), 500, 400);
gtk_window_set_position(GTK_WINDOW(Window), GTK_WIN_POS_CENTER);
g_signal_connect(G_OBJECT(Window), "destroy", G_CALLBACK(gtk_main_quit), NULL);
/* Creation de la GtkBox verticale */
VBox = gtk_vbox_new(FALSE, 10);
/* Ajout de la GtkVBox dans la fenetre */
gtk_container_add(GTK_CONTAINER(Window), VBox);
/* Creation des box horizontaux */
HBoxtitre = gtk_hbox_new(TRUE, 0);
HBoxn = gtk_hbox_new(TRUE, 0);
HBoxp = gtk_hbox_new(TRUE, 0);
HBoxbouton = gtk_hbox_new(TRUE, 0);
/* Ajout des GtkHBox dans la GtkVBox */
gtk_box_pack_start(GTK_BOX(VBox), HBoxtitre, FALSE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(VBox), HBoxn, FALSE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(VBox), HBoxp, FALSE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(VBox), HBoxbouton, FALSE, TRUE, 0);
/* Creation du label */
Labeln=gtk_label_new("Nom :");
Labelp=gtk_label_new("Prenom :");
Labeltitre=gtk_label_new("COORDONNEES DU CLIENT");
Label = gtk_label_new(NULL);
Labelln = gtk_label_new(NULL);
/* Creation des GtkEntry */
Entryn = gtk_entry_new();
Entryp = gtk_entry_new();
/* On ajoute des labels aux box horizontaux */
gtk_box_pack_start(GTK_BOX(HBoxtitre), Labeltitre, TRUE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(HBoxn), Labeln, TRUE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(HBoxp), Labelp, TRUE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(VBox), Label, TRUE, FALSE, 0);
/* On ajoute des zones de saisie aux box horizontaux */
gtk_box_pack_start(GTK_BOX(HBoxn), Entryn, TRUE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(HBoxp), Entryp, TRUE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(HBoxn), Labelln, TRUE, TRUE, 0);
/* Initialisation du bouton Valider */
Bouton = gtk_button_new_with_label("Valider");
/* Ajout de Bouton dans la GtkHBox */
gtk_box_pack_start(GTK_BOX(HBoxbouton), Bouton, TRUE, FALSE, 0);
/* Connexion du signal "clicked" du bouton */
g_signal_connect(G_OBJECT(Bouton), "clicked", G_CALLBACK(Action), (GtkWidget*) VBox);
//g_signal_connect(G_OBJECT(Bouton), "clicked", G_CALLBACK(Action), (GtkWidget*) HBoxp);
/* Connexion du signal "activate" du GtkEntry */
//g_signal_connect(G_OBJECT(Entryn), "activate", G_CALLBACK(on_activate_entry), (GtkWidget*) Label);
//gtk_container_foreach(GTK_CONTAINER(Window),(GtkCallback)Action,"");
gtk_widget_show_all(Window);
gtk_main();
return EXIT_SUCCESS;
}
void Action(GtkWidget *Bouton, gpointer data)
{
GtkWidget *Tempn;
GtkWidget *nom,*entryn,*prenom,*entryp,*boxn,*boxp,*boxb;
GtkWidget *Label;
GList *pListp=NULL;
GList *pListn=NULL;
const gchar *Textnom,*Textprenom;
const gchar *Txtnom,*Txtprenom;
FILE *fichier;
MYSQL *mysql;
MYSQL *conn;
char *query;
int t,r;
/* Recuperation de la liste des elements que contient la GtkVBox VBox */
pListp = gtk_container_get_children(GTK_CONTAINER((GtkWidget*)data));
/*premier element:HBoxn contient le label nom , le Gtkentry et un 2eme label
vide dans lequel j'affiche le contenu du gtkentry afin de s'assurer que la recuperation a ete bien faite */
boxn = GTK_WIDGET(pListp->data);
/* Element suivant le HBOxp: contient le label prenom et le Gtkentry*/
pListp = g_list_next(pListp);
boxp = GTK_WIDGET(pListp->data);
/*Element suivant le HBoxbouton: contient le bouton */
pListp = g_list_next(pListp);
boxb = GTK_WIDGET(pListp->data);
/* Recuperation de la liste des elements que contient la GtkHBox HBoxn */
pListn = gtk_container_get_children(GTK_CONTAINER((GtkWidget*)boxn));
/* Premier element labeln*/
nom = GTK_WIDGET(pListn->data);
pListn = g_list_next(pListn);
/* Passage a l element suivant le gtkentry*/
entryn = GTK_WIDGET(pListn->data);
/* Passage a l element suivant le label*/
pListn = g_list_next(pListn);
Label = GTK_WIDGET(pListn->data);
/* Recuperation du texte contenu dans les GtkEntry */
Textnom = gtk_entry_get_text(GTK_ENTRY(entryn));
//Textprenom = gtk_entry_get_text(GTK_ENTRY(entryp));
/* Modification du texte contenu dans le GtkLabel */
gtk_label_set_text(GTK_LABEL(Label), Textnom);
/* Liberation de la memoire utilisee par la liste */
//g_list_free(pList);
// initialisation
if((conn = mysql_init(NULL)) == NULL)
{
printf("Erreur d'initialisation\n");
}
// connexion au serveur (ici, en local)
if(mysql_real_connect(conn,"localhost","root","passer","stage",0,NULL,0)==NULL)
{
printf("Erreur de connexion\n");
}
char *to_insert = g_strdup_printf ("insert into clients (nom) values ('%s')", gtk_entry_get_text(GTK_ENTRY(entryn)));
mysql_query(conn,to_insert);
g_free (to_insert);
//Requête qui sélectionne tout dans ma table scores
//mysql_query(conn,"insert into clients (nom) values ('Textnom')");
//On met le jeu de résultat dans le pointeur result
//res = mysql_use_result(mysql);
mysql_close(conn);
} |