资源简介

采用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

评论

共有 条评论