2023/9/20 -- C++/QT

时钟:

widget.h:

#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>
#include <QPainter>
#include <QPaintEvent>
#include <QDateTime>
#include <QLabel>
#include <QTimer>
#include <QDebug>QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACEclass Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();void paintEvent(QPaintEvent *event) override;void timerEvent(QTimerEvent *event) override;private:Ui::Widget *ui;QLabel *lab12;QLabel *lab3;QLabel *lab6;QLabel *lab9;int time_id;};
#endif // WIDGET_H

widget.cpp:

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);lab12 = new QLabel(this);lab12->setText("12");lab12->setFont(QFont("楷体",25,3));lab12->move(this->width()/2-20,this->height()/2-175);lab3 = new QLabel(this);lab3->setText("3");lab3->setFont(QFont("楷体",25,3));lab3->move(this->width()/2+150,this->height()/2-20);lab6 = new QLabel(this);lab6->setText("6");lab6->setFont(QFont("楷体",25,3));lab6->move(this->width()/2-10,this->height()/2+135);lab9 = new QLabel(this);lab9->setText("9");lab9->setFont(QFont("楷体",25,3));lab9->move(this->width()/2-160,this->height()/2-20);time_id = startTimer(1000);
}Widget::~Widget()
{delete ui;
}void Widget::paintEvent(QPaintEvent *event)
{//获取系统时间QTime sys_t = QTime::currentTime();int hour = sys_t.hour();int minute = sys_t.minute();int second = sys_t.second();//分刻度绘制QPainter painterMinute(this);QPen penMinute;penMinute.setStyle(Qt::SolidLine);penMinute.setWidth(5);painterMinute.setPen(penMinute);painterMinute.translate(this->width()/2,this->height()/2);painterMinute.drawEllipse(QPoint(0,0),200,200);for(int i = 0;i < 12;i++){painterMinute.drawLine(0,-200,0,-180);painterMinute.rotate(360/12);}//秒钟刻度绘制QPainter painterSecond(this);QPen penSecond;penSecond.setStyle(Qt::SolidLine);penSecond.setWidth(3);painterSecond.setPen(penSecond);painterSecond.translate(this->width()/2,this->height()/2);for(int i = 0;i < 60;i++){painterSecond.drawLine(0,-200,0,-190);painterSecond.rotate(360/60);}//时针绘制QPainter painterHourPoint(this);QPen penHourPoint;penHourPoint.setStyle(Qt::SolidLine);penHourPoint.setWidth(5);painterHourPoint.setPen(penHourPoint);painterHourPoint.translate(this->width()/2,this->height()/2);painterHourPoint.rotate((360/12)*(hour%12+minute/60+second/3600));painterHourPoint.drawLine(0,10,0,-50);//分针绘制QPainter painterMinutePoint(this);QPen penMinutePoint;penMinutePoint.setStyle(Qt::SolidLine);penMinutePoint.setWidth(4);painterMinutePoint.setPen(penMinutePoint);painterMinutePoint.translate(this->width()/2,this->height()/2);painterMinutePoint.rotate((360/60)*(minute+second/60));painterMinutePoint.drawLine(0,10,0,-150);//秒针绘制QPainter painterSecondPoint(this);QPen penSecondPoint;penSecondPoint.setStyle(Qt::SolidLine);penSecondPoint.setWidth(2);painterSecondPoint.setPen(penSecondPoint);painterSecondPoint.translate(this->width()/2,this->height()/2);painterSecondPoint.rotate((360/60)*second);painterSecondPoint.drawLine(0,10,0,-150);
}void Widget::timerEvent(QTimerEvent *event)
{if(time_id == event->timerId()){this->update();}
}

效果图:

一、QT连接TCP网络通信

1.1 回顾网络编程中的通信内容

1.2 QT中服务器端实现

1> 实例化一个QTcpServer的类对象,那么一个服务器就创建好了

2> 调用服务器的listen函数,将服务器设置成监听状态,监听时,可以给定特定的主机地址,也可以监听所有主机地址;可以指定端口号访问该服务器,也可以由该服务器自动分配一个端口号

3> 此时,如果有客户端向服务器发来连接请求,那么该服务器就会自动发射一个newConnection信号,我们可以在该信号对应的槽函数中处理逻辑

4> 可以调用nextPaddingConnection获取最新连接的客户端套接字的地址,并将该地址,放入自己的客户端容器中

5> 如果有客户端向服务器发来数据,那么该客户端就会自动发射一个readyRead信号,我们可以在该信号对应槽函数中处理逻辑

6> 可以通过套接字的成员函数,完成数据通信,发送数据:write函数实现,接收数据:read、readLine、readAll实现

7> 可以调用成员函数close用于停止监听客户端的连接

案例

1、ui界面

2、配置文件

3、头文件

#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>
#include<QTcpServer>            //服务器头文件
#include<QTcpSocket>             //客户端头文件
#include<QList>                  //链表容器
#include<QMessageBox>            //消息对话框
#include<QDebug>QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACEclass Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();private slots:void on_startBtn_clicked();void newConnection_slot();          //自定义处理newConnection信号的槽函数的声明void readyRead_slot();              //自定义处理readyRead信号的槽函数的声明private:Ui::Widget *ui;//定义服务器指针QTcpServer *server;//定义客户端容器QList<QTcpSocket *> clientList;};
#endif // WIDGET_H

4、源文件

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//实例化一个服务器server = new QTcpServer(this);//此时,服务器已经成功进入监听状态,如果有客户端向服务器发来连接请求//那么该服务器,就会自动发射一个newConnection的信号,我们可以将该信号连接到对应槽函数中执行相关逻辑//由于只需要连接一次即可,所以可以将该连接放在构造函数中完成connect(server, &QTcpServer::newConnection, this, &Widget::newConnection_slot);
}Widget::~Widget()
{delete ui;
}//启动服务器按钮对应的槽函数
void Widget::on_startBtn_clicked()
{quint16 port = ui->portEdit->text().toUInt();    //获取ui界面上的端口号//监听客户端的连接请求//函数原型:bool listen(const QHostAddress &address = QHostAddress::Any, quint16 port = 0);//参数1:要监听的主机地址,如果是any表示监听任意一个主机地址,也可以是特定的主机地址//参数2:该服务器提供的端口号,如果是0,表示由服务器自动指定,一般由程序员指定//返回值:成功进入监听状态,返回true,其他情况返回falseif(!server->listen(QHostAddress::Any, port)){QMessageBox::information(this, "失败", "监听失败");return ;}else{QMessageBox::information(this, "成功", "服务器启动成功");}//此时,服务器已经成功进入监听状态,如果有客户端向服务器发来连接请求//那么该服务器,就会自动发射一个newConnection的信号,我们可以将该信号连接到对应槽函数中执行相关逻辑//由于只需要连接一次即可,所以可以将该连接放在构造函数中完成
}//自定义处理newConnection信号的槽函数的实现
void Widget::newConnection_slot()
{qDebug()<<"您有新的客户端发来连接请求了";//获取最新连接的客户端套接字//函数原型:virtual QTcpSocket *nextPendingConnection();//参数:无//返回值:最新连接过来的客户端套接字的地址QTcpSocket *s = server->nextPendingConnection();//将该套接字,放入客户端链表中clientList.push_back(s);//至此,多个客户端已经跟服务器建立连接,并放入客户端容器中了//此时,如果有客户端向服务器发来数据,那么对应的客户端套接字就会自动发射一个readyRead信号//我们可以将该信号连接到自定义的槽函数中,处理相关逻辑connect(s, &QTcpSocket::readyRead, this, &Widget::readyRead_slot);
}//readyRead信号对应槽函数的实现
void Widget::readyRead_slot()
{qDebug()<<"有新的客户端消息发来了";//遍历客户端链表,将无效的客户端移除for(int i=0; i<clientList.size(); i++){//判断当前套接字是否是有效连接//函数原型: SocketState state() const;//参数:无//返回值:套接字的状态,如果是0,表示该套接字为无效连接if(clientList[i]->state() ==0){//将该套接字移除客户端容器clientList.removeAt(i);}}//遍历客户端链表,判断是哪个客户端发来的数据for(int i=0; i<clientList.size(); i++){//函数原型:qint64 bytesAvailable() const override;//功能:求当前客户端套接字中待读数据的字节数//参数:无//返回值:待读数据的字节数,如果是0,表示无数据待读if(clientList[i]->bytesAvailable() != 0){//将该套接字中的数据读取出来QByteArray msg = clientList[i]->readAll();//将数据展示到ui界面ui->msgWidget->addItem( QString::fromLocal8Bit(msg) );//将接受到的数据,转发给所有客户端for(int j=0; j<clientList.size(); j++){clientList[j]->write(msg);}}}
}

1.3 QT中的客户端实现

1> 实例化一个QTcpSocket的对象,此时就创建了一个客户端了

2> 使用该类提供的成员函数connectToHost,向服务器发送连接请求,调用该函数时,需要指定服务器的主机地址和端口号

3> 如果成功连接客户端,那么该客户端就会自动发射一个connected的信号,我们可以在该信号对应的槽函数中处理相关逻辑

4> 此时,客户端和服务就已经建立起来连接了,如果客户端接收到服务器发来的数据,那么该客户端就会自动发射一个readyRead信号

5> 在该信号对应的槽函数中,可以使用成员函数,完成数据通信,发送数据:write函数实现,接收数据:read、readLine、readAll实现

6> 断开连接,使用成员函数disconnectFromHost,如果成功断开连接,该客户端就会自动发射一个disconnected的信号

7> 我们可以在该信号处理函数中处理相关逻辑

案例

1、ui界面

2、配置文件

3、头文件

#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>
#include<QTcpSocket>            //客户端类
#include<QMessageBox>QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACEclass Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();private slots:void on_connectBtn_clicked();void connected_slot();                  //自定义处理connected信号的槽函数的声明void readyRead_slot();                 //自定义处理readyRead信号的槽函数的声明void on_sendBtn_clicked();void on_disconnectBtn_clicked();void disconnected_slot();              //自定义处理disconnected信号的槽函数的声明private:Ui::Widget *ui;//定义客户端指针QTcpSocket * socket;//定义字符串接受用户QString userName;};
#endif // WIDGET_H

4、源文件

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//给客户端指针实例化对象socket = new QTcpSocket(this);//此时,已经向服务器发送连接请求了,如果成功连接服务器,那么该客户端就会自动发射一个connected的信号//我们可以将该信号连接到自定义的槽函数中处理逻辑//由于只需要连接一次,所以将连接写在构造函数中connect(socket, &QTcpSocket::connected, this, &Widget::connected_slot);//如果服务器向客户端发来消息,那么该客户端就会自动发射一个readyRead信号//我们可以将该进行连接到自定义的槽函数中处理相关逻辑connect(socket, &QTcpSocket::readyRead, this, &Widget::readyRead_slot);//当成功与服务器断开连接后,该客户端会自动发射一个disconnected的信号//我们可以将该信号连接到自定义的槽函数中处理相关逻辑//由于该连接只需连接一次即可,所以放在构造函数中进行connect(socket, &QTcpSocket::disconnected, this, &Widget::disconnected_slot);}Widget::~Widget()
{delete ui;
}//连接服务器按钮对应的槽函数
void Widget::on_connectBtn_clicked()
{//获取ui界面上的相关信息userName = ui->userNameEdit->text();         //获取用户名QString ip = ui->ipEdit->text();            //主机地址quint16 port = ui->portEdit->text().toUInt();        //端口号//函数原型:virtual void connectToHost(const QHostAddress &address, quint16 port);//功能:将客户端连接到给定的服务器//参数1:服务器的主机地址//参数2:端口号//返回值:无socket->connectToHost(ip, port);//此时,已经向服务器发送连接请求了,如果成功连接服务器,那么该客户端就会自动发射一个connected的信号//我们可以将该信号连接到自定义的槽函数中处理逻辑//由于只需要连接一次,所以将连接写在构造函数中}//处理connected信号的槽函数的定义
void Widget::connected_slot()
{QMessageBox::information(this, "成功", "您已经成功进入聊天室");//向服务器发送一条数据:***:进入聊天室QString msg = userName +": 进入聊天室";socket->write(msg.toLocal8Bit());          //将数据写给服务器
}//处理readyRead信号的槽函数的定义
void Widget::readyRead_slot()
{//读取套接字中的信息QByteArray msg = socket->readAll();//将数据展示到ui界面ui->msgWidget->addItem(QString::fromLocal8Bit(msg));
}//发送按钮对应的槽函数
void Widget::on_sendBtn_clicked()
{//获取ui界面输入的内容QString msg =userName+ ": " + ui->msgEdit->text();//发送给服务器socket->write(msg.toLocal8Bit());//清空编辑框内容ui->msgEdit->clear();
}//断开服务器按钮对应的槽函数
void Widget::on_disconnectBtn_clicked()
{//告诉大家我走了QString msg = userName +": 离开聊天室";socket->write(msg.toLocal8Bit());//断开连接//函数原型: virtual void disconnectFromHost();socket->disconnectFromHost();//当成功与服务器断开连接后,该客户端会自动发射一个disconnected的信号//我们可以将该信号连接到自定义的槽函数中处理相关逻辑//由于该连接只需连接一次即可,所以放在构造函数中进行
}//disconnected信号对应槽函数的定义
void Widget::disconnected_slot()
{QMessageBox::information(this, "提示", "退出成功");
}

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

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

相关文章

【探索Linux】—— 强大的命令行工具 P.9(进程地址空间)

阅读导航 前言一、内存空间分布二、什么是进程地址空间1. 概念2. 进程地址空间的组成 三、进程地址空间的设计原理1. 基本原理2. 虚拟地址空间 概念 大小和范围 作用 虚拟地址空间的优点 3. 页表 四、为什么要有地址空间五、总结温馨提示 前言 前面我们讲了C语言的基础知识&am…

Godot配置C#语言编写脚本(使用VSCode作为外部编辑器)

文章目录 Godot部分查看VSCode的所在位置配置外部编辑器 配置VSCode编写脚本中文注释 其他文章字符编码 Godot部分 打开编辑器-编辑器设置&#xff1b; 查看VSCode的所在位置 右键单击你的VScode快捷方式&#xff0c;选择属性。 这里的目标就是你的VSCode所在的位置。 配…

安防监控/视频汇聚/云存储/AI智能视频分析平台EasyCVR下级海康设备无法级联是什么原因?

安防视频监控平台/视频集中存储/云存储/磁盘阵列EasyCVR可拓展性强、视频能力灵活、部署轻快&#xff0c;可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等&#xff0c;以及支持厂家私有协议与SDK接入&#xff0c;包括海康Ehome、海大宇等设备的SDK等。 有用户反馈&…

初学phar反序列化

以下内容参考大佬博客&#xff1a;PHP Phar反序列化浅学习 - 跳跳糖 首先了解phar是什么东东 Phar是PHP的压缩文档&#xff0c;是PHP中类似于JAR的一种打包文件。它可以把多个文件存放至同一个文件中&#xff0c;无需解压&#xff0c;PHP就可以进行访问并执行内部语句。 默认开…

深度解剖数据在队列的应用

> 作者简介&#xff1a;დ旧言~&#xff0c;目前大一&#xff0c;现在学习Java&#xff0c;c&#xff0c;c&#xff0c;Python等 > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 望小伙伴们点赞&#x1f44d;收藏✨加关注哟&#x1f495;&#x1…

Linux磁盘管理:最佳实践

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

计算机视觉与深度学习-图像分割-视觉识别任务02-目标检测-【北邮鲁鹏】

目录标题 参考目标检测定义深度学习对目标检测的作用单目标检测多任务框架多任务损失预训练模型姿态估计 多目标检测问题滑动窗口&#xff08;Sliding Window&#xff09;滑动窗口缺点 AdaBoost&#xff08;Adaptive Boosting&#xff09;参考 区域建议 selective search 思想慢…

6.1 使用scikit-learn构建模型

6.1 使用scikit-learn构建模型 6.1.1 使用sklearn转换器处理数据6.1.2 将数据集划分为训练集和测试集6.1.3 使用sklearn转换器进行数据预处理与降维1、数据预处理2、PCA降维算法 代码 scikit-learn&#xff08;简称sklearn&#xff09;库整合了多种机器学习算法&#xff0c;可以…

Pytorch学习:torch.max(input,dim,keepdim=False)

文章目录 torch.max()dimkeepdimdim0dim1 out&#xff1a;返回命名元组 (values, indices) torch.max() torch.max(input) → Tensor&#xff1a;返回 input 张量中所有元素的最大值。 注意输入的必须是张量形式&#xff0c;输出的也为张量形式 当输入为tuple类型时&#xf…

《动手学深度学习》(pytorch版+mxnet版)2023最新

我又来推书了&#xff0c;这次分享的这本书可是重量级&#xff0c;目前已经被55个国家300所大学用于教学&#xff0c;同时受到了学术界与工业界的强烈推荐。 这本书就是李沐、阿斯顿张、立顿、斯莫拉四位大佬联合编写的《动手学深度学习》。本书面向中文读者&#xff0c;能运行…

进阶指针(一)

✨博客主页&#xff1a;小钱编程成长记 &#x1f388;博客专栏&#xff1a;进阶C语言 进阶指针&#xff08;一&#xff09; 0.回顾初阶指针1.字符指针1.1 相关面试题 2.数组指针3.指针数组3.1 数组指针的定义3.2 &数组名VS数组名3.3 数组指针的使用 4.数组传参和指针传参4.…

[Linux入门]---yum软件安装及vim编辑器配置

文章目录 1.Linux软件安装包2.如何安装软件注意事项下载rzsz查看rzsz软件包安装or卸载软件原理 3.简单配置配置文件常用配置选项&#xff08;测试&#xff09;使用插件使用链接配置 1.Linux软件安装包 Linux的三种软件安装方法&#xff1a; ①源代码安装。 在Linux系统下载程序…

AI 时代的向量数据库、关系型数据库与 Serverless 技术丨TiDB Hackathon 2023 随想

TiDB Hackathon 2023 刚刚结束&#xff0c;我仔细地审阅了所有的项目。 在并未强调项目必须使用人工智能&#xff08;AI&#xff09;相关技术的情况下&#xff0c;引人注目的项目几乎一致地都使用了 AI 来构建自己的应用。 大规模语言模型&#xff08;LLM&#xff09;的问世使得…

linux内核——进程

Processes and threads 进程是正在运行的程序&#xff0c;包括下列部分的抽象&#xff1a; &#xff08;独立的&#xff09;地址空间一个或者多个线程打开的文件&#xff08;以描述符fd的形式呈现&#xff09;套接字信号量Semaphore共享的内存区域定时器信号句柄signal handl…

avi怎么转换成视频?

avi怎么转换成视频&#xff1f;在我们日常使用的视频格式中&#xff0c;AVI是一种常见且经常被使用的音频视频交叉格式之一。它的优点之一是占用的存储空间相对较小&#xff0c;但也明显存在着画质损失的缺点。虽然AVI格式的视频在某种程度上也很常见&#xff0c;但与最常见的M…

缓存之缓存简介

目录 一.缓存的作用二.缓存的使用1.适用缓存的数据场景2.读取缓存流程图 三.本地缓存和分布式缓存 一.缓存的作用 Java缓存技术是在应用程序和数据库之间的一种中间层,用于存储暂时性数据,尤其是读取频繁但更新较少的数据。它的作用是减轻应用程序和数据库之间的负担,提高应用程…

PyCharm安装教程,新手详细

首先进入官网&#xff1a;https://www.jetbrains.com/pycharm/download/?sectionwindows#sectionwindows 然后选择版本&#xff0c;我下载的是社区版&#xff0c;一般学习是够了 然后点击Download进行下载。 双击exe运行 然后选择安装路径&#xff0c;建议放在D盘 然后这…

Python 图片处理笔记

import numpy as np import cv2 import os import matplotlib.pyplot as plt# 去除黑边框 def remove_the_blackborder(image):image cv2.imread(image) #读取图片img cv2.medianBlur(image, 5) #中值滤波&#xff0c;去除黑色边际中可能含有的噪声干扰#medianBlur( Inp…

Qt---day4---9.20

qt完成时钟&#xff1a; 头文件&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QPaintEvent> #include <QtDebug> #include <QPainter> #include <QTimerEvent> #include <QTime>QT_BEGIN_NAMESPACE names…

wpf资源Resources探究性学习(一)

测试环境&#xff1a; vistual studio 2017 .net framework 3.5 window 10 新建WPF应用(.net framework)&#xff0c;项目名称为&#xff1a;WpfDemo&#xff0c;如下图&#xff1a; 新建完项目后&#xff0c;默认带有一个名为MainWindow.xaml的代码 一 简单使用字符串资源…