博客
关于我
基于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、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>