博客
关于我
基于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/

你可能感兴趣的文章
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
查看>>