QT--5

1> 将网络聊天室重新实现一遍

服务器端

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);ser = new QTcpServer(this);
}Widget::~Widget()
{delete ui;
}void Widget::on_startBtn_clicked()
{if(ui->startBtn->text() == "启动"){quint16 port = ui->lineEdit->text().toUInt();if(ser->listen(QHostAddress::Any,port)==true){QMessageBox::information(this,"成功","服务器启动成功");}else{QMessageBox::information(this,"失败","服务器启动失败");}//当启动服务器后,如果有客户端发来连接请求,那么该服务器端就会自动化发送一个newConnection信号//我们可以将信号,连接到对应的槽函数connect(ser,&QTcpServer::newConnection,this,&Widget::newconnection_slot);ui->startBtn->setText("关闭");}else{ser->close();ui->startBtn->setText("启动");}
}
//关于readyread信号对应的槽函数的定义
void Widget::readyread_slots()
{//判断客户端容器中,是否已经有退出的客户端,或者无效的客户端,或者无效的客户端,如果有,将其进行移除for(int i=0;i<cliList.length();i++){if(cliList[i]->state() == QTcpSocket::UnconnectedState){//功能:判断当前套接字的状态//参数:无//返回值:readyread_slots表示无效的客服端cliList.removeAt(i);}}for(int i=0;i<cliList.length();i++){if(cliList[i]->bytesAvailable()!=0){//获取当前套接字中套接字中的待读数据的个数//参数:无//返回值:返回套接字中待读//如果不等于0;表示有数据可读,可以使用readall读取数据QByteArray msg = cliList[i]->readAll();ui->msgWidget->addItem(QString::fromLocal8Bit(msg));for(int j=0;j<cliList.length();j++){if(i!=j){cliList[j]->write(msg);}}}}}
void Widget::newconnection_slot()
{qDebug() << "有客户端发来连接请求";QTcpSocket *socket = ser->nextPendingConnection();cliList.append(socket);//当有客户端向服务器发来数据时候,当前客户端套接字就会自动发送一个readyread信号//我们就可以connect(socket,&QTcpSocket::readyRead,this,&Widget::readyread_slots);}

客户端 

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);this->resize(800,600);this->setFixedSize(800,600);this->setWindowTitle("网络聊天室");list = new QListWidget(this);list->resize(800,400);edtsend = new QLineEdit(this);edtsend->setPlaceholderText("发送消息");edtsend->resize(450,80);edtsend->move(50,420);edtname = new QLineEdit(this);edtname->setPlaceholderText("用户名");edtname->resize(100,50);edtname->move(50,500);edtip = new QLineEdit(this);edtip->setPlaceholderText("ip");edtip->resize(300,50);edtip->move(150,500);edtport = new QLineEdit(this);edtport->setPlaceholderText("port");edtport->resize(300,50);edtport->move(100,550);btnsend = new QPushButton("发送",this);btnsend->resize(100,50);btnsend->move(600,450);btnlink = new QPushButton("连接服务器",this);btnlink->resize(100,50);btnlink->move(600,550);cli = new QTcpSocket(this);connect(cli,&QTcpSocket::connected,this,&Widget::connected_slot);connect(cli,&QTcpSocket::readyRead,this,&Widget::readyread_slot);connect(cli,&QTcpSocket::disconnected,this,&Widget::disconnectes_slot);connect(btnlink,&QPushButton::clicked,this,&Widget::on_connectBtn_clicked);connect(btnsend,&QPushButton::clicked,this,&Widget::on_sendBtn_clicked);// connect(btn,&QPushButton::clicked,this,&Widget::cliked_slot);
}Widget::~Widget()
{delete ui;
}void Widget::connected_slot()
{QMessageBox::information(this,"连接","连接服务器成功");}void Widget::readyread_slot()
{QByteArray msg = cli->readAll();list->addItem(QString::fromLocal8Bit(msg));}void Widget::disconnectes_slot()
{QMessageBox::information(this, "断开", "断开服务器成功");
}
//信息发送按钮对应的槽函数
void Widget::on_sendBtn_clicked()
{//1、将ui界面上的文本信息获取下来QString msg = userName + ":" + edtsend->text();//2、将该消息发送给服务器cli->write(msg.toLocal8Bit());//3、清空航编辑器中的内容edtsend->clear();//将消息放入ui界面中QListWidgetItem *item = new QListWidgetItem(msg);item->setTextAlignment(Qt::AlignRight);list->addItem(item);
}
//连接服务器按钮对应的槽函数
void Widget::on_connectBtn_clicked()
{if(btnlink->text() == "连接服务器"){userName = edtname->text();         //用户名QString ip = edtip->text();            //ip地址quint16 port = edtport->text().toUInt();   //端口号cli->connectToHost(ip, port);btnlink->setText("断开服务器");}else{QString msg = userName + ": 离开聊天室";cli->write(msg.toLocal8Bit());cli->disconnectFromHost();btnlink->setText("连接服务器");}
}

2> 将数据库管理系统,进行完善

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//判断当前数据库操作对象中,是否包含了要处理的数据库if(!db.contains("mydb.db")){//添加一个数据库到当前数据库对象中db = QSqlDatabase::addDatabase("QSQLITE");//给数据库设置名字db.setDatabaseName("mydb.db");}//此时,已经创建了一个数据库,但是没有打开if(!db.open()){QMessageBox::information(this,"失败","数据库打开失败");return;}//程序执行至此,数据库打开成功//准备sql语句QString sql = "create table if not exists Stu(numb int , name char , sex char , score double)";//实例化一个sql语句的的执行者QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","创建数据表失败");return;}}Widget::~Widget()
{delete ui;
}//添加学院信息按钮对应的槽函数
void Widget::on_pushButton_clicked()
{//将ui界面上的相关信息获取下来int ui_numb = ui->lineEdit->text().toUInt();QString ui_name = ui->lineEdit_2->text();QString ui_sex = ui->lineEdit_3->text();double ui_score = ui->lineEdit_4->text().toDouble();if(ui_sex==NULL || ui_numb==0 || ui_score==0 || ui_name==NULL){QMessageBox::information(this,"提示","请将信息填写完整");return;}//准备sql语句QString sql = QString("insert into Stu values(%1,'%2','%3',%4)").arg(ui_numb).arg(ui_name).arg(ui_sex).arg(ui_score);//执行sql语句QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","添加数据表失败");return;}else{QMessageBox::information(this,"提示","添加数据表成功");}
}
//删除按钮对应的槽函数
void Widget::on_pushButton_2_clicked()
{QString sql;if(ui->lineEdit_2->text() == NULL){sql = "delete * from Stu";}else{sql = QString("delete  from Stu where name='%1'").arg(ui->lineEdit_2->text());}//执行sql语句QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","删除数据表失败");return;}else{QMessageBox::information(this,"提示","删除数据表成功");}}
//修改
void Widget::on_pushButton_3_clicked()
{QString sql;if(ui->lineEdit_2->text() == NULL){sql = "delete * from Stu";}else{sql = QString("update stu set name='%1' from Stu where numb='%2'").arg(ui->lineEdit_2->text()).arg(ui->lineEdit->text());}//执行sql语句QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","更新数据表失败");return;}else{QMessageBox::information(this,"提示","更新数据表成功");}}
//查找按钮对应的槽函数
void Widget::on_pushButton_4_clicked()
{QString sql;if(ui->lineEdit_2->text() == NULL){sql = "select * from Stu";}else{sql = QString("select * from Stu where name='%1'").arg(ui->lineEdit_2->text());}//执行sql语句QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","查询数据表失败");return;}else{QMessageBox::information(this,"提示","查询数据表成功");}//将查询结果展示到ui上int i = 0;while(query.next()){//这里面是任意一个查询的结果。query对象中保存的是当前的一个记录//可以通过成员函数recordqDebug() << query.record().value(1).toString(); //每一次转变成字符串的值//通过条用Qsqlrecord类的成员函数:valuefor(int j=0;j<query.record().count();j++){//qDebug() << query.record().value(j).toString();QTableWidgetItem *item = new QTableWidgetItem(query.record().value(j).toString());item->setTextAlignment(Qt::AlignCenter);//将数据库中的数据依次存放到ui界面中ui->tableWidget->setItem(i,j,item);}i++;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/687557.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第七届精武杯部分wp

第一部分&#xff1a;计算机和手机取证 1.请综合分析计算机和手机检材&#xff0c;计算机最近一次登录的账户名是 答案&#xff1a;admin 创建虚拟机时直接给出了用户名 2. 请综合分析计算机和手机检材&#xff0c;计算机最近一次插入的USB存储设备串号是 答案&#xff1a…

【赠书活动第4期】《Rust编程与项目实战》

赠书活动 《Rust编程与项目实战》免费赠书 3 本&#xff0c; 收到赠书之后&#xff0c;写一篇 本书某一节内容 的学习博客文章。 可在本帖评论中表示参加&#xff0c;即可获得赠书&#xff0c;先到先得。学习心得博客链接&#xff0c;后面有空发上来。 赠书截止日期为送出3…

探寻高品质狗粮的性价比之选,福派斯鲜肉狗粮无疑是值得推荐的一款!

引言&#xff1a;在狗狗的健康成长道路上&#xff0c;狗粮作为其日常营养来源&#xff0c;其重要性不言而喻。然而&#xff0c;市面上狗粮品牌繁多&#xff0c;价格与质量各异&#xff0c;让养狗人士们在选择时颇为头疼。今天&#xff0c;我们将为大家深入剖析一款备受赞誉的狗…

ALV Color-颜色

目录 前言 实战 列颜色 行颜色 单元格颜色 前言 在ABAP ALV中&#xff0c;Color颜色设置是一种增强列表显示效果的重要手段&#xff0c;可以用来突出显示特定行、列或单元格&#xff0c;以吸引用户注意或传达数据的特定状态。 颜色设置中有优先级顺序&#xff0c;他们是单元格…

##13 如何在Python中优雅地使用异常处理

文章目录 引言1. 异常处理基础2. 处理多种异常3. 捕捉所有异常4. finally 语句5. 自定义异常结语参考链接 引言 在编程中&#xff0c;错误是在所难免的。Python提供了异常处理机制&#xff0c;允许程序在遇到错误时优雅地恢复。本文将介绍Python中异常处理的基本概念&#xff…

探索Baidu Comate智能编码助手的AI编程之旅

本文目录 目录 本文目录 前言 1.1 Baidu Comate智能编码助手概览 1.2 Baidu Comate适用场景 1.3 Baidu Comate安装步骤 1.4 代码编写与智能提示 1.5 试用感受分享 1.6 对Comate未来发展的期望 1.7 总结体验与收获 1.8 对AI编程未来的展望 前言 1.1Baidu Comate智…

文章解读与仿真程序复现思路——电力自动化设备EI\CSCD\北大核心《考虑低碳需求响应的碳捕集燃煤电厂配置-运行协同优化》

本专栏栏目提供文章与程序复现思路&#xff0c;具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…

上网卡免费领取,无成本,免费领,超暴力蓝海项目

随着短视频和直播的流行&#xff0c;对大流量电话卡的需求日益增加。我们提供100G-300G大流量电话卡&#xff0c;包含100多分钟语音通话&#xff0c;月费仅19-29元。这些都是三大运营商的靠谱已有号卡&#xff0c;全国免费领取并包邮到家。客户收到卡片后&#xff0c;可在线充值…

dragonbones 5.6.3不能导出的解决办法

问题描述 使用dragonbones 5.6.3导出资源时无反应。 解决方法 第一步安装node.js&#xff0c;我这里使用的是V18.16.0第二步进入到DragonBonesPro\egretlauncher\server\win目录&#xff0c;然后把里面的node.exe替换为刚刚下载的node文件夹即可&#xff0c;如下图&#xff…

【Linux】冯诺依曼体系

冯诺依曼体系 冯诺依曼体系结构是我们计算机组成的基本架构 中央处理器&#xff08;CPU&#xff09;&#xff1a; 中央处理器是冯诺伊曼体系的核心部分&#xff0c;负责执行计算机程序中的指令。它包括算术逻辑单元&#xff08;ALU&#xff09;和控制单元&#xff08;CU&#x…

番外篇 | YOLOv8改进之利用SCINet解决黑夜目标检测问题 | 低照度图像增强网络

前言:Hello大家好,我是小哥谈。自校正照明网络(Self-Calibrating Illumination Network, SCINet)是一种基于深度学习的图像照明算法,可以自动分析图像的内容并根据图像内容自动优化照明。SCINet是一种专为低光照图像增强设计的框架。它通过级联照明学习过程和权重共享机制…

VISO流程图之子流程的使用

子流程的作用 整个流程图的框图多而且大&#xff0c;进行分块&#xff1b;让流程图简洁对于重复使用的流程&#xff0c;可以归结为一个子流程图&#xff0c;方便使用&#xff0c;避免大量的重复性工作&#xff1b; 新建子流程 方法1&#xff1a; 随便布局 框选3 和4 &#…