博客
关于我
基于C+sqlite3+GTK的体育馆管理系统项目开发
阅读量:772 次
发布时间:2019-03-24

本文共 5687 字,大约阅读时间需要 18 分钟。

zzuli体育馆管理系统
              #include "sqlite3.h"              
#include
#include
#include
#include
#include
#include
              sqlite3* db = NULL;              GtkWidget* window_main;              GtkWidget* window_rk;              GtkWidget* window_yh;              GtkWidget* window_yh_cd;              GtkWidget* window_yh_cz;              GtkWidget* window_yh_cx;              GtkWidget* window_user_xg;              GtkWidget* window_yh_yu;              GtkWidget* window_gly;              GtkWidget* window_gly_cd;              GtkWidget* window_gly_cx;              GtkWidget* window_gly_xg;              GtkWidget* window_gly_sc;              GtkWidget* window_gly_zj;              GtkWidget* yh_id;              GtkWidget* yh_passwd;              GtkWidget* yh_yzm;              GtkWidget* yh_ye;              GtkWidget* yh_changguan;              GtkWidget* label_user_xm;              GtkWidget* label_user_passwd;              GtkWidget* label_user_ye;              GtkWidget* label_user_changguan;              GtkWidget* label_gly_cx_id;              GtkWidget* label_gly_sc_id;              GtkWidget* label_user_xg_id;              GtkWidget* label_user_xg_xm;              GtkWidget* label_user_xg_passwd;              GtkWidget* label_gly_zj_id;              GtkWidget* label_gly_zj_mm;              GtkWidget* label_user_yzm;              GtkWidget* label_yh_yzms;              GtkWidget* label_gly_yzms;          
              void window_main_to_rk(GtkButton* button, gpointer user_data) {                  gtk_widget_show_all(window_rk);                  gtk_widget_hide_all(window_main);              }              void window_rk_to_yh(GtkButton* button, gpointer user_data) {                  gtk_widget_show_all(window_yh);                  gtk_widget_hide_all(window_rk);              }              void window_yh_to_rk(GtkButton* button, gpointer user_data) {                  gtk_widget_show_all(window_rk);                  gtk_widget_hide_all(window_yh);              }              //其他返回函数...          
              int main(int argc, char* argv[]) {                  my_sql_init();                  gtk_init(&argc, &argv);                  window_main_init();                  window_rk_init();                  window_yh_init();                  window_yh_cd_init();                  window_yh_cz_init();                  window_yh_cx_init();                  window_user_xg_init();                  window_yh_yu_init();                  window_gly_init();                  window_gly_cd_init();                  window_gly_cx_init();                  window_gly_xg_init();                  window_gly_sc_init();                  window_gly_zj_init();                  g_signal_connect(window_main, "destroy", G_CALLBACK(gtk_main_quit), NULL);                  gtk_widget_show_all(window_main);                  gtk_main();                  return 0;              }          

系统功能概述

该系统通过GTK框架搭建一个综合性的管理系统,包括用户和管理员两种用户类型。 用户端主要功能包括登录注册、个人信息修改、余额充值、场馆预约等。 管理员端功能更为全面,涵盖用户管理、权限分配、系统维护等功能。

数据库初始化

              void my_sql_init(void) {                  sqlite3* db;                  sqlite3_open("qf.db", &db);                  //创建用户表                  char* sql = "create table user (xm text, mm text, changguan text, ye int);";                  sqlite3_exec(db, sql, NULL, NULL, &errmsg);                  //创建管理员表                  char* sql2 = "create table gly (xm text, mm text);";                  sqlite3_exec(db, sql2, NULL, NULL, &errmsg);                  sqlite3_close(db);              }          

用户功能模块

用户端界面分为登录界面、功能菜单、个人信息修改、充值功能等模块。 充值功能支持金额输入和余额更新,预约功能可选择场馆并确认预约。 个人信息修改功能支持账号修改及其他相关信息更新。

管理员功能模块

管理员端功能更加全面,包括查询用户信息、修改用户信息、删除用户、增加用户等操作。 管理员权限较高,需通过登录确认登录状态后才能访问各项功能模块。

系统优化区

              static void set_widget_font_size(GtkWidget* widget, int size, gboolean is_button) {                  PangoFontDescription* font = pango_font_description_from_string("Sans");                  pango_font_description_set_size(font, size * PANGO_SCALE);                  if (is_button) {                      GtkWidget* labelChild = gtk_bin_get_child(GTK_BIN(widget));                  } else {                      GtkWidget* labelChild = widget;                  }                  gtk_widget_modify_font(GTK_WIDGET(labelChild), font);                  pango_font_description_free(font);              }              void chang_background(GtkWidget* widget, int w, int h, const gchar* path) {                  gtk_widget_set_app_paintable(widget, TRUE);                  gtk_widget_realize(widget);                  gtk_widget_queue_draw(widget);                  GdkPixbuf* src_pixbuf = gdk_pixbuf_new_from_file(path, NULL);                  GdkPixbuf* dst_pixbuf = gdk_pixbuf_scale_simple(src_pixbuf, w, h, GDK_INTERP_BILINEAR);                  GdkPixmap* pixmap = gdk_pixbuf_render_pixmap_and_mask(dst_pixbuf, NULL, 128);                  gdk_window_set_back_pixmap(widget->window, pixmap, FALSE);                  g_object_unref(src_pixbuf);                  g_object_unref(dst_pixbuf);                  g_object_unref(pixmap);              }          

转载地址:http://vqskk.baihongyu.com/

你可能感兴趣的文章
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
MySQL Cluster与MGR集群实战
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>