QT实现显示聊天信息的控件

本文介绍了如何使用QT来创建一个显示聊天信息的界面,通过自定义控件ChatItem,包含头像和消息的QLabel,并根据聊天角色动态调整布局。代码示例展示了如何在QListWidget中添加这些控件,以及禁用鼠标悬停效果的方法。
摘要由CSDN通过智能技术生成

QT实现显示聊天信息的控件

  • 准备写一个局域网的聊天小软件。UI部分首先考虑的就是显示聊天信息的界面。下面是测试界面。

在这里插入图片描述

  • 思路就是自定义聊天项的控件添加到QListWidget中,控件中包含两个QLabel分别显示头像和消息信息。根据不同的聊天角色调整两个QLabel的位置。下面是代码。
  • ChatItem是控件的名字,头文件如下
#define CHATITEM_H

#include <QWidget>
#include <QLabel>


class ChatItem : public QWidget
{
   
    Q_OBJECT
    
public:
    enum ChatRole
    {
   
        host,
        guest
    };
    ChatItem(QString msg, int headId, ChatRole role, QWidget *parent = 0);
    ~ChatItem();
    
private:
    void hostSet();
    void guestSet();
private:
    QLabel* labelMsg;
    QLabel* labelHead;
    
};

#endif // CHATITEM_H
  • 源文件如下
#include "chatitem.h"

#define WIDTH 600
#define HEAD_WIDTH  50
#define HEAD_HEIGHT 50

ChatItem::ChatItem(QString msg, int headId, ChatItem::ChatRole role, QWidget *parent):
    QWidget(parent
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东海sea

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值