QT 网络聊天室简易版

视频:qt开发网络聊天w室软件3.4界面开发_哔哩哔哩_bilibili

目录

UI部分

设计稿图

放置控件

界面美化

拖动窗体

设置界面

网络部分

配置对话框

多项目结果和服务器端设计

客户端框架开发


UI部分

设计稿图

放置控件

界面美化

现在我们把窗体自带的标题栏给去了,用我们自己画的.我们在调用窗口这里调用setWindowFlags()函数,它利用有个隐藏标题栏方法Qt::FramelessWindowHint

拖动窗体

我们需要重写几个虚函数:

cpp 复制代码
    virtual void mousePressEvent(QMouseEvent *event);   //响应鼠标点击
    virtual void mouseReleaseEvent(QMouseEvent *event); //响应鼠标离开
    virtual void mouseMoveEvent(QMouseEvent *event);    //响应鼠标按住窗体移动

这样就可以拖动窗体了:

设置界面

新建一个Dlg文件,名字为Dlg_setting,如下:

把我们的设置按钮重名为btn_set,然后转到槽:

然后调用我们的dlg_setting界面:

cpp 复制代码
void cell_Main::on_btn_set_clicked()
{
    Dlg_setting dlg;
    dlg.exec();
}

此时就可以通过点击设置按钮打开设置界面了吗

新增一个清屏按钮:

网络部分

首先需要在Pro文件中加载socket模块:

cpp 复制代码
QT       +=network

配置对话框

在QDialog类下的QWidge类里有个虚函数showEvent(),我们需要重写这个虚函数

在dlg_setting.cpp文件里重写showEvent虚函数,这样我们就可以在点击设置的时候打印出我们的地址

cpp 复制代码
void Dlg_setting::showEvent(QShowEvent *event)
{
    auto l=QNetworkInterface::allAddresses();
    for(auto it:l)
    {
        qDebug()<<it.toString();
    }
}

现在我们在我们的电脑上模拟两个客户端,一个服务端.我们自己来配一下地址:

在控制面板的网络连接里,选择我们的以太网,在属性的里选择ipv4,在高级选项里新增两个客户端ip地址,一个服务器端ip地址:

此时再调用showEvent(函数),发现我们的自己配置的地址和端口号就显示出来了:

然后我们把我们配置的地址给 加载进我们ui界面ip地址的下拉列表框里:

cpp 复制代码
void Dlg_setting::showEvent(QShowEvent *event)
{
    // 清空下拉框中的IP地址列表
    ui->cb_ips->clear();
    
    // 获取所有网络接口的地址列表
    auto l = QNetworkInterface::allAddresses();
    
    // 遍历所有网络接口的地址
    for (auto it : l)
    {
        // 打印出所有地址,调试用,可以注释掉
        // qDebug()<<it.toString();
        
        // 检查地址是否为IPv4类型
        if (QAbstractSocket::IPv4Protocol == it.protocol())
        {
            // 如果是IPv4地址,则添加到下拉框中
            ui->cb_ips->addItem(it.toString());   
        }
    }
}

多项目结果和服务器端设计

我们创建一个根文件夹qtalk,里面放客户端和服务器端.客户端就是我们上面写的,服务器端不用Ui界面,创建一个控制台文件即可

qtalk.pro文件内容如下:

客户端框架开发

相关推荐
北冥湖畔的燕雀3 小时前
C++泛型编程(函数模板以及类模板)
开发语言·c++
QX_hao4 小时前
【Go】--map和struct数据类型
开发语言·后端·golang
你好,我叫C小白4 小时前
C语言 循环结构(1)
c语言·开发语言·算法·while·do...while
Evand J6 小时前
【MATLAB例程】基于USBL和DVL的线性回归误差补偿,对USBL和DVL导航数据进行相互补偿,提高定位精度,附代码下载链接
开发语言·matlab·线性回归·水下定位·usbl·dvl
Larry_Yanan7 小时前
QML学习笔记(四十二)QML的MessageDialog
c++·笔记·qt·学习·ui
爱喝白开水a7 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
Neverfadeaway7 小时前
【C语言】深入理解函数指针数组应用(4)
c语言·开发语言·算法·回调函数·转移表·c语言实现计算器
武子康7 小时前
Java-152 深入浅出 MongoDB 索引详解 从 MongoDB B-树 到 MySQL B+树 索引机制、数据结构与应用场景的全面对比分析
java·开发语言·数据库·sql·mongodb·性能优化·nosql
杰克尼7 小时前
JavaWeb_p165部门管理
java·开发语言·前端
一成码农7 小时前
JavaSE面向对象(下)
java·开发语言