资源简介
采用C/S模式,完成一前台(服务器)对多客服端通讯,用Mysql数据库保存信息;
主要技术:
1.采用TCP/IP协议,容器完成服务端与多客户端的链接
服务端:
server=new QTcpServer(this);建立端口
server->listen(QHostAddress::Any,PORT);监听端口
connect(server,SIGNAL(newConnection()),this,SLOT(accpetConnection()));等待用户链接
QTcpSocket* temp = server->nextPendingConnection();建立链接
client.push_back(temp);用户压栈
connect(temp,SIGNAL(readyRead()),this,SLOT(readData()));当端口有数据就读
读数据时先用迭代器遍历容器找到发送信息的客户端,再解析数据并响应
客户端:
client=new QTcpSocket(this);建立端口
client->connectToHost(IP,PORT);链接主机
connect(client,SIGNAL(readyRead()),this,SLOT(readData()));端口有数据就读
2.界面布局
服务器
a.主菜单,预订,开台,换台,电子账单功能项采用QToolButton文字置于图片下面,水平布局
b.当前餐台信息与总餐台状态信息用QLabel垂直布局放于主窗体左侧
c.餐台信息采用QGraphicsView+QGraphicsScene+QGraphicsItem布局,view与item需要重写自己的类,Item包括图片与文本信息;将Item放入墙纸scene中,墙纸scene贴到墙view上完成显示。
客户端
a.选择桌号与人数用QLabel,对应的下拉选项用QComboBox,确认,呼叫与结账功能用QToolButton,这些控件水平布局放置于窗体最上方
b.左侧用QTabWidget其中加入特价菜单与我的菜单两个子窗体
c.中间为QGraphicsView+QGraphicsScene+QGraphicsItem布局,布局菜单图片与价格名称,菜单信息服务器发送至客户端与客户端的图片匹配起来。
d.右侧为菜单类型分类按键,采用垂直布局
3.信号与槽机制的运用
a.预订,开台,换台功能的实现:点击对应的按钮触发clicked()信号,与之对应的槽函数中QToolButton *btn = (QToolButton *)sender();区分信号源,弹出对应的子窗体让用户输入相应信息,按确定按钮修改SQL对应Table内容然后发送输入信息信号,主窗体接受到信号调用槽函数(相应窗体成员调用其布局函数重布局)重新布局整个界面(餐台信息与左侧总餐台状态同时更新)
b.鼠标悬浮于餐台信息Item时图片放大:改写了QGraphicsSceneMouseEvent事件实现
c.主菜单与电子账单的显示采用QSqlTableModel+QTableView加载整个SQL中相应的Table显示Table内容
代码片段和文件信息
#include
#include ject>
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#includese>
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define PORT 8808
QSqlDatabase getDB(QString database)
{
QSqlDatabase db;
if(QSqlDatabase::contains(“mysql“))
{
db=QSqlDatabase::database(“mysql“);
}
else
{
db = QSqlDatabase::addDatabase(“QMYSQL““mysql“);
db.setHostName(“LocalHost“);
db.setDatabaseName(database);qDebug()<<“Open database :“<se;
db.setUserName(“root“);
db.setPassword(“admin“);
}
return db;
}
void set_sql(void)
{
QSqlDatabase db = getDB(“ordersystem“);
if(db.open())
{
qDebug()<<“0“<
QString op = “use ordersystem“;
QSqlQuery query(db);
query.exec(op);
op = “create table menu(id int(10) primary key not nullname varchar(20)price int(10)num intsell intstate intsprice inttype int)“;
query.exec(op);
qDebug()<<“create table:menu“;
db.close();
}
else
{
qDebug()<<“error“;
}
}
void display_menu(void)
{
QSqlDatabase db = getDB(“ordersystem“);
if(db.open())
{
qDebug()<<“1“< }
QSqlTableModel *model = new QSqlTableModel(0db);
model->setTable(“menu“);
model->setEditStrategy(QSqlTableModel::OnManualSubmit);
model->select();
model->setHeaderData(0 Qt::HorizontalQobject::tr(“id“));
model->setHeaderData(1 Qt::HorizontalQobject::tr(“菜名“));
model->setHeaderData(2 Qt::HorizontalQobject::tr(“单价“));
model->setHeaderData(3 Qt::HorizontalQobject::tr(“可供数量“));
model->setHeaderData(4 Qt::HorizontalQobject::tr(“已售数量“));
model->setHeaderData(5 Qt::HorizontalQobject::tr(“供应状态“));
model->setHeaderData(6 Qt::HorizontalQobject::tr(“是否特价“));
model->setHeaderData(7 Qt::HorizontalQobject::tr(“种类“));
QTableView *view = new QTableView();view->setModel(model);
view->hideColumn(0); // don‘t show the ID
view->show();
db.close();
}
void display_elec()
{
QSqlDatabase db = getDB(“ordersystem“);qDebug()< QSqlTableModel *model = new QSqlTableModel(0db);
model->setTable(“bill“);
model->setEditStrategy(QSqlTableModel::OnManualSubmit);
model->select();
model->setHeaderData(0 Qt::HorizontalQobject::tr(“ 日 期 “));
model->setHeaderData(1 Qt::Horizon
- 上一篇:C语言:英文单词小助手源代码
- 下一篇:导引头模型仿真
相关资源
- qTox (基于 peer-to-peer )
- 国际象棋的qt源代码
- QT上位机
- qt媒体播放器
- QT5开发及源代码
- qt完整项目
- C++ mqtt 用法
- qt进度条(RoundProgressBar)
- Qt的纽带风格界面实现(Office Ribbon风
- qt 实现画板
- QT Hisi demo
- 基础qt数据库读取和显示
- Qt画图工具源码(qgraphics draw)
- Qt查询SQLite数据库
- QtWebApp
- Qt 实现心电图
- Qt实现 屏幕截图
- qt cmd实现ping
- QT实现USB摄像头拍照
- qt texteditor(富文本编辑器)
- qt 串口助手源码
- qt登录富文本编辑器和文档打印设计
- 使用QWT库实现接收串口数据,并根据
- QT SQLite封装
- QT半透明效果界面
- Qt5串口通信-windows
- 计算机远程唤醒和关机
- 使用wxWidgets进行跨平台程序开发
- QT 动态曲线
- QT视频播放器(基于FFmpeg)
评论
共有 条评论