QTday4(鼠标事件和键盘事件/QT实现连接TCP协议)

这篇具有很好参考价值的文章主要介绍了QTday4(鼠标事件和键盘事件/QT实现连接TCP协议)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

笔记

QTday4(鼠标事件和键盘事件/QT实现连接TCP协议),c++,qt

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QDebug>
#include <QTcpServer>//服务器类
#include <QTcpSocket>//客户端类
#include <QMessageBox>
#include <QList>//链表容器

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

private slots:
    void on_startBtn_clicked();
    void newConnection_slot();
    void readyRead();

private:
    Ui::Widget *ui;
    QTcpServer *server;//定义服务器指针
    QList<QTcpSocket *> socketList;//定义客户端容器
};
#endif // WIDGET_H
#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //给服务器指针 实例化空间
    server = new QTcpServer(this);
}

Widget::~Widget()
{
    delete ui;
}

//启动服务器按钮对应的槽函数
void Widget::on_startBtn_clicked()
{
    //获取ui界面上输入的端口号
    quint16 port = ui->portEdit->text().toUInt();

    //将服务器设置成监听状态
    if(server->listen(QHostAddress::Any,port)){
//        QMessageBox::information(this,"","服务器启动成功");
        qDebug()<<"服务器启动成功";
    }else{
        QMessageBox::information(this,"","服务器启动失败");
    }

    //服务器进入了监听状态, 如果有客户端发来连接请求,那么该服务器就会自动发射一个newConnection信号
    //我们可以将该信号连接到自定义的槽函数
    connect(server,&QTcpServer::newConnection,this,&Widget::newConnection_slot);
}

//处理newConnection信号的槽函数的实现
void Widget::newConnection_slot()
{
    qDebug()<<"有新用户连接";
    //获取最新连接的客户端套接字
    QTcpSocket* s = server->nextPendingConnection();
    //将该套接字放入到客户端容器中
    socketList.push_back(s);

    //此时,客户端与服务器已经建立起来连接
    //如果有客户端向服务器发来数据,那么该客户端会自动发射一个readyRead信号
    //我们可以在
    connect(s,&QTcpSocket::readyRead,this,&Widget::readyRead);
}

//readyRead信号对于的槽函数的实现
void Widget::readyRead()
{
    //移除无效客户端
    for(int i=0;i<socketList.count();i++){
        if(socketList.at(i)->state() == 0){
            socketList.removeAt(i);
        }
    }

    for(int i=0;i<socketList.count();i++){
        if(socketList.at(i)->bytesAvailable() != 0){
            //说明该套接字中有数据
            //读取该套接字中的所有数据
            QByteArray msgArray = socketList.at(i)->readAll();

            //将数据展示到ui->listWidget
            ui->msgWidget->addItem(QString::fromLocal8Bit(msgArray));

            qDebug()<<QString::fromLocal8Bit(msgArray);

            //将数据发送给所有客户端
            for(int j=0;j<socketList.count();i++){
                socketList.at(j)->write(msgArray);
            }
        }
    }
}

时钟绘制

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
}

Widget::~Widget()
{
    delete ui;
}

void Widget::paintEvent(QPaintEvent *event){
    drawDialPlate();
    drawDialLine();
}

void Widget::drawDialPlate()
{
    float dialWidth = 5.0;
    float radius = 250.0;
    float startPointX = this->width()*0.5;
    float startPointY = this->height()*0.5-radius;
    int hourRotate = 360/12;
    int quarterHourRotate = 360/60;

    //实例化一个画家
    QPainter painter(this);
    //实例化一个画笔
    QPen pen(QColor("red"));
    pen.setWidth(5);
    //添加画笔到画家
    painter.setPen(pen);

    //绘制表盘外圆
    QRectF rectangle(this->width()*0.5-radius, this->height()*0.5-radius, 2*radius, 2*radius);
    painter.drawEllipse(rectangle);

}

void Widget::drawDialLine()
{
    int Div_Max = 12;//大刻度值
    int Div_Min = 5;//小刻度值
    float BaseAngle = 270;//基础仰角
    int R_Inside = 250;//内部圆半径
    float startPointX = this->width()*0.5;
    float radius = 250.0;
    float startPointY = this->height()*0.5-radius;
    QPoint Center_pos = QPoint(startPointX,this->height()*0.5);//时钟圆心坐标

    //实例化一个画家
    QPainter painter(this);
    //实例化一个画笔
    QPen pen(QColor("black"));
//    pen.setWidth(10);
    //添加画笔到画家
    painter.setPen(pen);

    for(int Loop = 0; Loop <= Div_Max*Div_Min; Loop++)
    {
        float Angle = BaseAngle + (360 / (Div_Max * Div_Min))*Loop;//从基础仰角开始绘制的每条刻度线对应的角度
        int R = R_Inside-1;
        int x_start = Center_pos.x() + R * cos((Angle / 180) * PI);
        int y_start = Center_pos.y() + R * sin((Angle / 180) * PI);

        if(Loop % Div_Min == 0)//判断是否为大刻度
        {
            QPen pen(Qt::black);
            pen.setWidth(4);
            painter.setPen(pen);
            R = R_Inside-20;
        }
        else  //判断是否为小刻度
        {
            QPen pen(Qt::black);
            pen.setWidth(2);
            painter.setPen(pen);
            R = R_Inside-15;
        }

        int x_end = Center_pos.x() + R * cos((Angle / 180) * PI);
        int y_end = Center_pos.y() + R * sin((Angle / 180) * PI);

        painter.drawLine(QPoint(x_start,y_start),QPoint(x_end,y_end));//绘制刻度线
    }

}





/*
1程序启动,绘制表盘
2开启一个定时器, 槽函数里执行update
3绘制事件函数, 绘制最新的时分秒针
3.1获取当前的时间,获取时,分,秒数值float 转换成圆形的弧度
3.1画家的原点设置为widget的中心点/每次都旋转画家的正方向 指定角度
3.2绘制时针,分针,秒针
*/

QTday4(鼠标事件和键盘事件/QT实现连接TCP协议),c++,qt

 文章来源地址https://www.toymoban.com/news/detail-615617.html

到了这里,关于QTday4(鼠标事件和键盘事件/QT实现连接TCP协议)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • VTK & QT QVTKWidget自定义鼠标和键盘交互事件

    目录 一、问题描述 二、代码实现 1. 自定义鼠标交互事件 2. 移除默认鼠标交互监听事件,塞入自定义监听事件 在使用VTK显示的过程中,通常会使用QT来进行界面设计。这里通常使用QVTKWidget将VTK的渲染窗口显示到QT的组件中。 QVTKWidget组件自带交互器vtkRenderWindowInteractor和Rende

    2024年02月14日
    浏览(54)
  • Qt/QtCreator:主动触发鼠标或键盘事件QMouseEvent与QKeyEvent

    方法:          构造QMouseEvent或QKeyEvent,使用QApplication::sendEvent或postEvent进行投送事件    。         QApplication::sendEvent()和QApplication::postEvent()都是Qt中用于发送事件的函数,它们之间的区别在于事件的处理方式。         QApplication::sendEvent(target, event)是直接将事件

    2024年02月15日
    浏览(39)
  • python——实现鼠标与键盘监听与事件处理

    侦听按键 侦听鼠标 监听按键 需要注意的是必须使用cv加载图像,只有点击图像窗口才能侦听点击窗口时所使用的按键 ord和chr的用法我这里重复一下,可以实现对于acall码的解释,方便直接看到按键结果 ord()函数主要用来返回对应字符的ascii码, chr()主要用来表示ascii码对应的

    2024年02月06日
    浏览(40)
  • C# 实现全局鼠标钩子操作以及发送键盘事件

    全局钩子定义 winfrom窗体代码: 效果截图:

    2024年02月05日
    浏览(41)
  • Qt实现鼠标双击事件

    当同一个部件既要响应鼠标单击事件又要响应鼠标双击事件时,就会发生冲突,如下例: 创建自己的按钮类,让其继承于QPushButton类 (特别注意!!!) ,在创建类的时候默认可供选择的基类中无QPushButton类且没有QPushButton类的基类,无法使用多重继承,故必须手动修改继承

    2024年02月10日
    浏览(41)
  • Qt实现全局键盘事件监听器-Windows

    更多精彩内容 👉个人内容分类汇总 👈 👉Qt自定义模块、工具👈 Qt版本:V5.12.5 兼容系统: Windows:这里测试了Windows10,其它的版本没有测试; Linux:这里测试了ubuntu18.04、20.04,其它的没有测试; Mac:等啥时候我有了Mac电脑再说。 有时候我们想获取到全局键盘事件,使用

    2024年02月09日
    浏览(46)
  • Qt模拟键盘单击、组合键、鼠标移动的多种实现方式

    Qt模拟键盘点击分为两种情况: 情况一:模拟键盘输入到系统窗口,整个系统都接收这个模拟输入。 情况二:模拟键盘输入到指定的软件,只有指定的软件接收模拟输入。 情况一实现方式: 头文件:windows.h 使用 void keybd_event(BYTE bVk, BYTE bScan, DWORD dwFlags,DWORD dwExtraInfo); 参数:

    2024年02月10日
    浏览(37)
  • Qt实现全局鼠标事件监听器-Windows

    更多精彩内容 👉个人内容分类汇总 👈 👉Qt自定义模块、工具👈 Qt版本:V5.12.5 兼容系统: Windows:这里测试了Windows10,其它的版本没有测试; Linux:这里测试了ubuntu18.04、20.04,其它的没有测试; Mac:等啥时候我有了Mac电脑再说。 有时候我们想获取到【系统全局鼠标事件】

    2024年02月16日
    浏览(38)
  • Qt实现全局鼠标事件监听器-Linux

    更多精彩内容 👉个人内容分类汇总 👈 👉Qt自定义模块、工具👈 Qt版本:V5.12.5 兼容系统: Windows:这里测试了Windows10,其它的版本没有测试; Linux:这里测试了ubuntu18.04、20.04,其它的没有测试; Mac:等啥时候我有了Mac电脑再说。 有时候我们想获取到【系统全局鼠标事件】

    2024年02月11日
    浏览(39)
  • Qt之事件过滤器讲解并且实现快捷键切换鼠标焦点

    现在有一个类似于下方图的ui,用户需要在输入前一行内容后,需要摁下指定案件能够跳转到下一行继续进行输入。 一种更为直接的解决方案是子类化 QLineEdit 并且重新实现鼠标事件 keyPressEvent() ,然后调用 focusNextChild() 。 首先需要创建一个子类MyLineEdit继承于QLineEdit类。然后重

    2024年02月12日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包