Qt绘制直线箭头

一.使用QPainter绘制

满足条件:

  • 任意角度直线都可绘制箭头
  • 所有箭头同样大小
cpp 复制代码
void MainWindow::paintEvent(QPaintEvent*)
{
    QPainter painter(this);  // 创建QPainter对象,并指定绘制目标为当前的widget
    QLineF line(50,20,500,500);

    double distanceFromEnd1 = 20;
    qreal t = (line.length() - distanceFromEnd1) / line.length();
    QPointF point = line.pointAt(t);//与两端平行点

    double distanceFromEnd2 = 5;
    qreal z = (line.length() - distanceFromEnd2) / line.length();
    QPointF point_center=line.pointAt(z);//中心点

    qreal slope_line = (line.p2().y() - line.p1().y()) / (line.p2().x() - line.p1().x());  // 计算原直线斜率
    double slope = -1 / slope_line;  // 计算垂线的斜率
    double intercept = point.y() - slope * point.x();  // 计算垂线的截距
    const double m=5;//垂线上下两端距离
    double arrow1_x=(point.y()+m-intercept)/slope;
    double arrow2_x=(point.y()-m-intercept)/slope;
    QPointF arrow1(arrow1_x,slope*arrow1_x+intercept);
    QPointF arrow2(arrow2_x,slope*arrow2_x+intercept);
    painter.setRenderHint(QPainter::Antialiasing, true);  // 可选,抗锯齿设置
    painter.setPen(QPen(Qt::black, 2));  // 设置画笔颜色和宽度
    painter.drawLine(line);  // 绘制直线
    painter.setPen(QPen(Qt::green,3));
    painter.drawLine(arrow1,point_center);
    painter.drawLine(arrow2,point_center);
}

二.使用QPainterPath绘制

1.如何使用 GraphicsView 和 QGraphicsScene 绘制

创建一个类继承 GraphicsView
  • graphicsView.h
cpp 复制代码
#ifndef GRAPHICSVIEW_H
#define GRAPHICSVIEW_H
#include <QGraphicsView>
#include <QMouseEvent>
#include <QGraphicsLineItem>
#include <QGraphicsPathItem>
#include <QPainterPath>
#include <QDebug>
#include <QObject>
#include <QPointF>
#include <QGraphicsEllipseItem>

class GraphicsView : public QGraphicsView
{
public:
     GraphicsView(QGraphicsScene *scene, QWidget *parent = nullptr);
     void setLineData();
private:
     QGraphicsScene *scene_;
};

#endif // GRAPHICSVIEW_H
  • graphicsview.cpp
cpp 复制代码
#include "graphicsview.h"

GraphicsView::GraphicsView(QGraphicsScene *scene,QWidget *parent ) : QGraphicsView(parent),scene_(scene)
{
    setScene(scene_);
    setLineData();
}
void GraphicsView::setLineData()
{
    QLineF line(100,100,600,400);
    QPen pen(Qt::red,3);
    scene_->addLine(line,pen);

}
主函数中添加私有对象:
cpp 复制代码
private:
    Ui::MainWindow *ui;
    GraphicsView *graphics_view;
    QGraphicsScene *scene;
主函数中调用:
cpp 复制代码
MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);


    scene = new QGraphicsScene(this);


    // 创建 GraphicsView 对象并设置场景
    GraphicsView* graphicsView = new GraphicsView(scene, this);

    // 添加 GraphicsView 对象为中央部件
//    setCentralWidget(graphicsView);
    // 将 GraphicsView 添加到主窗口
//    setCentralWidget(graphicsView);

    setCentralWidget(graphicsView);

    // 设置场景大小为主窗口的大小
    QRectF rect(0, 0, width(), height());
    scene->setSceneRect(rect);

    // 根据视图大小调整窗口大小
    adjustSize();

}
图形显示:

2.绘制箭头

相关推荐
秦jh_10 小时前
【Qt】常用控件(上)
服务器·数据库·qt
刃神太酷啦10 小时前
C++ list 容器全解析:从构造到模拟实现的深度探索----《Hello C++ Wrold!》(16)--(C/C++)
java·c语言·c++·qt·算法·leetcode·list
水煎包V:YEDIYYDS88811 小时前
QT modbus 通信教程,把modbus封装到线程单例中,在线程内完成数据收发,解析。把重要数据以信号方式通知到qml层展示,解决UI卡顿
qt·modbus·线程服务
东哥很忙XH11 小时前
python使用PyQt5开发桌面端串口通信
开发语言·驱动开发·python·qt
汪宁宇13 小时前
如何在QT5+MinGW环境中编译使用QGIS开发地图应用
c++·qt·qgis·mingw·地图库
刺客xs13 小时前
Qt-----QSS样式表
开发语言·javascript·qt
qq_4017004113 小时前
QProgressBar+QSS 进度条
qt
小灰灰搞电子15 小时前
Qt PDF模块详解
数据库·qt·pdf
ibuki_fuko15 小时前
QT/C++ 程序启动时检查程序是否已经启动
开发语言·c++·qt
深蓝海拓15 小时前
PySide6从0开始学习的笔记(五) 信号与槽
笔记·qt·学习·pyqt