博客
关于我
基于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 Server 5.5安装记录
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql where中如何判断不为空
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>