Qt基础类03-直线类QLine

摘要

1.本文测试验证了QT5中的QLine直线类的各成员函数和属性

2.本文适用于学习QT的新手入门及练习,老手请绕路。

3.工程上传至CSDN,供同一时期学习QT的网友参考,可自行查看。

基本信息

时间:2024.09.07
QT版本:5.14.2
平台:window 10

程序简介:

  1. 本工程是Qt基础类和基本数据类型专题例程,QLine直线类

  2. 本工程对照着Qt的帮助文档,把每个属性和成员函数测试了一遍

成员函数

程序全貌

这个练习程序,是对照着QT中QLine的帮助文档,一个一个测试形成的。多数成员函数比较简单,看一眼上去知道怎么用。只在关于偏移的4个函数,需要注意一下,理解一下,但也不是很难。

本文链接地址 Qt基础类03-直线类QLine-CSDN博客,转载请注明出处。

QLine类提供了不同的构造函数,以QPoint坐标类初始化的,以int类型提供x和y坐标直接初始化的,也提供了设置、获取起点和终点的坐标的函数,特别的是可以方便的获取直线的中点,不必自己算。

可流化的2个函数没有进行测试。

全貌如下图:
在这里插入图片描述

QLine::QLine()

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

QLine::QLine(const QPoint &p1, const QPoint &p2)

void DrawWidget1::paintEvent(QPaintEvent *)
{
    QPainter painter(this);

    QPoint p1(100,200);
    QPoint p2(600,200);
    QLine qline(p1,p2);

    painter.setPen(Qt::red);
    painter.drawLine(qline);
    label3->setText(tr("画出的直线如下:"));
}

程序运行效果如下:
在这里插入图片描述

QLine::QLine(int x1, int y1, int x2, int y2)

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

QPoint QLine::p1() const

代码未贴,请直接下载去看例程,程序运行效果如下:

在这里插入图片描述

QPoint QLine::p2() const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

int QLine::x1() const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

int QLine::x2() const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

int QLine::y1() const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

int QLine::y2() const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

QPoint QLine::center() const

void DrawWidget9::paintEvent(QPaintEvent *)
{
    QPainter painter(this);

    QPoint p1(100,150);
    QPoint p2(650,350);
    QLine qline(p1,p2);

    painter.setPen(Qt::blue);
    painter.drawLine(qline);

    label3->setText(tr("qline的起点坐标是:%1,%2").arg(qline.x1()).arg(qline.y1()));
    label4->setText(tr("qline的终点坐标是:%1,%2").arg(qline.x2()).arg(qline.y2()));

    QPoint centerPoint;
    centerPoint=qline.center();

    label5->setText(tr("该直线中心点的坐标是:%1,%2").arg(centerPoint.x()).arg(centerPoint.y()));
}

程序运行效果如下:
在这里插入图片描述

int QLine::dx() const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

int QLine::dy() const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

bool QLine::isNull() const

void DrawWidget12::paintEvent(QPaintEvent *)
{
    QPainter painter(this);

    QPoint p1(150,200);
    QPoint p2(650,350);
    QLine qline1(p1,p2);

    painter.setPen(Qt::blue);
    painter.drawLine(qline1);
    label3->setText(tr("qline1的起点坐标是:%1,%2").arg(qline1.x1()).arg(qline1.y1()));
    label4->setText(tr("qline1的终点坐标是:%1,%2").arg(qline1.x2()).arg(qline1.y2()));


    QLine qline2(0,0,0,0);
    label5->setText(tr("qline2的起点坐标是:%1,%2").arg(qline2.x1()).arg(qline2.y1()));
    label6->setText(tr("qline2的终点坐标是:%1,%2").arg(qline2.x2()).arg(qline2.y2()));

    bool result1=qline1.isNull();
    bool result2=qline2.isNull();

    label7->setText(tr("qline1.isNull()=%1,qline2.isNull()=%2").arg((result1?"true":"false")).arg((result2?"true":"false")));
}

程序运行效果如下:
在这里插入图片描述

void QLine::setP1(const QPoint &&p1)

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

void QLine::setP2(const QPoint &&p2)

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

void QLine::setLine(int x1, int y1, int x2, int y2)

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

void QLine::setPoints(const QPoint &p1, const QPoint &p2)

void DrawWidget16::paintEvent(QPaintEvent *)
{
    QPainter painter(this);

    QPoint p1(650,150);
    QPoint p2(100,350);

    QLine qline;
    qline.setPoints(p1,p2);

    painter.setPen(Qt::red);
    painter.drawLine(qline);

    label3->setText(tr("qline的起点坐标是:%1,%2").arg(qline.x1()).arg(qline.y1()));
    label4->setText(tr("qline的终点坐标是:%1,%2").arg(qline.x2()).arg(qline.y2()));
}

程序运行效果如下:
在这里插入图片描述

void QLine::translate(const QPoint &offset)

void DrawWidget17::paintEvent(QPaintEvent *)
{
    QPainter painter(this);

    QPoint p1(350,200);
    QPoint p2(400,250);

    QLine qline(p1,p2);

    painter.setPen(Qt::red);
    painter.drawLine(qline);
    label3->setText(tr("偏移前,qline的起点坐标是:%1,%2,qline的终点坐标是:%3,%4").arg(qline.x1()).arg(qline.y1()).arg(qline.x2()).arg(qline.y2()));

    QPoint p(100,50);
    label4->setText(tr("偏移点坐标是:%1,%2").arg(p.x()).arg(p.y()));

    qline.translate(p);

    painter.setPen(Qt::blue);
    painter.drawLine(qline);

    label5->setText(tr("偏移后,qline的起点坐标是:%1,%2,qline的终点坐标是:%3,%4").arg(qline.x1()).arg(qline.y1()).arg(qline.x2()).arg(qline.y2()));
}

程序运行效果如下:
在这里插入图片描述

void QLine::translate(int dx, int dy)

void DrawWidget18::paintEvent(QPaintEvent *)
{
    QPainter painter(this);

    QPoint p1(350,200);
    QPoint p2(400,250);

    QLine qline(p1,p2);

    painter.setPen(Qt::red);
    painter.drawLine(qline);
    label3->setText(tr("偏移前,qline的起点坐标是:%1,%2,qline的终点坐标是:%3,%4").arg(qline.x1()).arg(qline.y1()).arg(qline.x2()).arg(qline.y2()));

    int dx=100;
    int dy=50;
    label4->setText(tr("偏移距离dx=%1,偏移距离dy=%2").arg(dx).arg(dy));

    qline.translate(dx,dy);

    painter.setPen(Qt::blue);
    painter.drawLine(qline);

    label5->setText(tr("偏移后,qline的起点坐标是:%1,%2,qline的终点坐标是:%3,%4").arg(qline.x1()).arg(qline.y1()).arg(qline.x2()).arg(qline.y2()));
}

程序运行效果如下:
在这里插入图片描述

QLine QLine::translated(const QPoint &&offset) const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

QLine QLine::translated(int dx, int dy) const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

bool QLine::operator!=(const QLine &&line) const

代码未贴,请直接下载去看例程,程序运行效果如下:
在这里插入图片描述

bool QLine::operator==(const QLine &line) const

void DrawWidget22::paintEvent(QPaintEvent *)
{
    QPainter painter(this);

    QLine qline1(100,250,600,250);
    QLine qline2(600,250,100,250);
    QLine qline3(100,250,600,250);

    painter.setPen(Qt::red);
    painter.drawLine(qline1);
    label3->setText(tr("qline1的起点坐标是:%1,%2,qline1的终点坐标是:%3,%4").arg(qline1.x1()).arg(qline1.y1()).arg(qline1.x2()).arg(qline1.y2()));

    painter.setPen(Qt::green);
    painter.drawLine(qline2);
    label4->setText(tr("qline2的起点坐标是:%1,%2,qline2的终点坐标是:%3,%4").arg(qline2.x1()).arg(qline2.y1()).arg(qline2.x2()).arg(qline2.y2()));

    painter.setPen(Qt::blue);
    painter.drawLine(qline2);
    label5->setText(tr("qline3的起点坐标是:%1,%2,qline3的终点坐标是:%3,%4").arg(qline3.x1()).arg(qline3.y1()).arg(qline3.x2()).arg(qline3.y2()));

    bool result12=qline1.operator==(qline2);
    bool result13=qline1.operator==(qline3);

    label6->setText(tr("qline1.operator==(qline2)的结果是:%1").arg((result12?"true":"false")));
    label7->setText(tr("qline1.operator==(qline3)的结果是:%1").arg((result13?"true":"false")));
}

程序运行效果如下:
在这里插入图片描述

技巧

  1. QLine的起点和终点重合,会被视为对象为空。

  2. 在窗体上画线,要使用QPainter类,要重写paintEvent()函数。

  3. QT中的布局,要达到左对齐、右对齐、居中对齐、顶部、底部等等布局,必须请神器弹簧控件出场搞定。预计24年的10月,应该会写关于QT布局的专题。

  4. 不创建对象直接操作对象,会使程序崩溃。比如没有去new QLabel对象,直接去label.setText();程序会崩溃,提示信息并不直观,并不友好。只是告诉我程序崩溃了,但不告诉我为什么。关于调试,再熟悉一段时间,开个专题写QT的调试。

写在后面

  • 本例程为了将QLine直线类可视化,直接在窗体中把直线画了出来。这一部分不属于QLine的范畴。

  • 本例程把每一个函数用窗体进行了展示和输出,没有把信息输出在终端里,改为了用QLabel输出在窗体中。

  • 本工程创建时还是使用了ui进行布局的,看工程中这一堆新添加的文件,没有去整理工程,这个工作也不计划再重新构建工程了,就这样,把时间用在最重要的知识点上。

  • 下一个例程,计划自己用代码写布局了,不用ui文件了。

    1.台式机27寸,1080P的显示器。笔记本14寸,2K分辨率的显示器。算是体验了把”QT对高分屏幕支持不好“

    2.写好的工程,当用笔记本准备发blog时,发现笔记本2k屏幕,150%放大的时候,这界面简直惨不忍睹啊~!于是,又花了点时间,重要改了代码,重新截的图。才有了本文。

体会

  • 自己不动手,永远是纸上谈兵。必须实践,用代码说话。光看兵法不去打仗,基本上上战场就得死。

  • 调整心态,欲速则不达,一个实践一个实践去积累,慢慢会超越很多人的。

系列博文

Qt基础类01–坐标类QPoint-CSDN博客

Qt基础类02-坐标类QPointF-CSDN博客

Qt基础类03-直线类QLine-CSDN博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值