Qt 绘制表白爱心【李珣表白爱心】

这篇具有很好参考价值的文章主要介绍了Qt 绘制表白爱心【李珣表白爱心】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Qt 绘制表白爱心【李珣表白爱心】

通过QtPainter进行绘制,具体实现可以参考
B站爱心绘制实现

1. functions.h


#include <QPointF>
#include <QRandomGenerator>

#define IMAGE_ENLARGE 15

// 心形函数
QPointF heart_function(qreal t, qreal shrink_ratio = IMAGE_ENLARGE) {
    qreal x = 16 * (sin(t) * sin(t) * sin(t));
    qreal y = -(13 * cos(t) - 5 * cos(2 * t) - 2 * cos(3 * t) - cos(4 * t));
    x *= shrink_ratio;
    y *= shrink_ratio;
    return QPointF(x, y);
}

// 指数分布, 随机内部扩散点
QPointF scatter_inside(QPointF &point, qreal beta = 0.05) {
    qreal ratiox = -log(QRandomGenerator::global()->bounded(1.0)) * beta;
    qreal ratioy = -log(QRandomGenerator::global()->bounded(1.0)) * beta;
    qreal dx = point.x() * ratiox;
    qreal dy = point.y() * ratioy;
    return QPointF(point.x() - dx, point.y() - dy);
}

QPointF caculate_position(QPointF &point, qreal ratio = 0.9) {
    qreal force = 1 / qPow((point.x() * point.x() + point.y() * point.y()), 0.6);
    qreal dx = point.x() * force * ratio + QRandomGenerator::global()->bounded(-1, 1);
    qreal dy = point.y() * force * ratio + QRandomGenerator::global()->bounded(-1, 1);
    return QPointF(point.x() - dx, point.y() - dy);
}

QPointF shrink_ratio(QPointF &point, qreal ratio = 0.9) {
    qreal force = -1 / qPow((point.x() * point.x() + point.y() * point.y()), 0.6);
    qreal dx = point.x() * force * ratio;
    qreal dy = point.y() * force * ratio;
    return QPointF(point.x() - dx, point.y() - dy);
}

qreal curve(qreal p) {
    return 2 * (2 * sin(4 * p)) / (2 * M_PI);
}

mainwindow.h


#include <QWidget>
#include <QRandomGenerator>


QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QWidget {
Q_OBJECT
protected:
    void paintEvent(QPaintEvent *event) override;
    void resizeEvent(QResizeEvent *event) override;

public:
    explicit MainWindow(QWidget *parent = nullptr);

    ~MainWindow() override;


private:
    Ui::MainWindow *ui;

    qint64 frame = 0; // 当前帧数

    QTimer *timer;
    QList<QPointF> m_points; // 原始爱心坐标集合
    QList<QPointF> m_edge_diffusion_points; // 边缘扩散效果点坐标集合
    QList<QPointF> m_center_diffusion_points; // 中心扩散效果点坐标集合

    void initPoints(); // 初始化爱心坐标集合

};

mainwindow.cpp


#include "mainwindow.h"
#include "utils/functions.h"
#include "ui_MainWindow.h"
#include <QPainter>
#include <QPainterPath>
#include <QTimer>


#define HEART_COLOR "#ff2121"
#define POINTS_NUMBER 2000
#define FREQUENCY 50
#define DANCESIZE 50


MainWindow::MainWindow(QWidget *parent) :
        QWidget(parent), ui(new Ui::MainWindow) {
    ui->setupUi(this);
    // 背景色黑色
    this->setStyleSheet("background-color:black;");
    // 设置窗口大小
     this->setFixedSize(800, 600);
    // 设置窗口标题
    this->setWindowTitle("LoveStar");
    initPoints();
    timer = new QTimer(this);
    connect(timer, &QTimer::timeout, this, qOverload<>(&MainWindow::update));
    timer->start(1000 / FREQUENCY);
}

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


void MainWindow::paintEvent(QPaintEvent *event) {

    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing, true);
    // 画笔设置
    painter.setPen(QPen(QColor(HEART_COLOR), 1));
    painter.save();
    painter.translate(this->width() / 2, this->height() / 2);
    // 绘制每一帧数据
    // 缩放比例
    qreal ratio = DANCESIZE * curve(frame / (double) FREQUENCY * M_PI);
    QPolygonF points;
    qint32 halo_radius = int(4 + 6 * (1 + curve(frame / (double) FREQUENCY * M_PI)));
    qint32 halo_number = int(
            3000 + 4000 * abs(curve(frame / (double) FREQUENCY * M_PI) * curve(frame / (double) FREQUENCY * M_PI)));

    // 光环
    for (int i = 0; i < halo_number; i++) {
        qreal t = QRandomGenerator::global()->bounded(2 * M_PI);
        QPointF p = heart_function(t, IMAGE_ENLARGE);
        QPointF pp = shrink_ratio(p, halo_radius);
        pp.setX(pp.x() + QRandomGenerator::global()->bounded(-14, 14));
        pp.setY(pp.y() + QRandomGenerator::global()->bounded(-14, 14));
        points.append(pp);
    }

    // 轮廓
    for (int i = 0; i < POINTS_NUMBER; i++) {
        QPointF p = m_points.at(i);
        p = caculate_position(p, ratio);
        points.append(p);
    }

    // 边缘扩散效果
    for (int i = 0; i < m_edge_diffusion_points.size(); ++i) {
        QPointF p = m_edge_diffusion_points.at(i);
        p = caculate_position(p, ratio);
        points.append(p);
    }

    // 中心扩散效果
    for (int i = 0; i < m_center_diffusion_points.size(); ++i) {
        QPointF p = m_center_diffusion_points.at(i);
        p = caculate_position(p, ratio);
        points.append(p);
    }

    painter.drawPoints(points);
    painter.restore();
    frame++;
}

void MainWindow::resizeEvent(QResizeEvent *event) {
    update();
}

void MainWindow::initPoints() {

    // 初始化爱心坐标集合
    m_points.clear();
    m_edge_diffusion_points.clear();
    m_center_diffusion_points.clear();
    for (int i = 0; i < POINTS_NUMBER; i++) {
        // 生成随机坐标
        qreal t = QRandomGenerator::global()->bounded(2 * M_PI);
        QPointF p = heart_function(t);
        m_points.append(p);
    }

    // 初始化边缘扩散效果点坐标集合
    for (int i = 0; i < POINTS_NUMBER; i++) {
        QPointF p = m_points.at(i);
        for (int j = 0; j < 3; ++j) {
            QPointF s = scatter_inside(p, 0.05);
            m_edge_diffusion_points.append(s);
        }
    }
    // 初始化中心扩散效果点坐标集合
    for (int i = 0; i < POINTS_NUMBER * 2; i++) {
        qint32 index = QRandomGenerator::global()->bounded(POINTS_NUMBER);
        QPointF p = m_points.at(index);
        QPointF s = scatter_inside(p, 0.17);
        m_center_diffusion_points.append(s);
    }
}

main.cpp

#include <QApplication>
#include <mainwindow.h>


int main(int argc, char *argv[]) {
    QApplication a(argc, argv);
    MainWindow w;
    w.show();
    return QApplication::exec();
}

最终效果

Qt 绘制表白爱心【李珣表白爱心】,Qt,qt,开发语言,ui

项目地址(欢迎star)

项目源码文章来源地址https://www.toymoban.com/news/detail-546653.html

到了这里,关于Qt 绘制表白爱心【李珣表白爱心】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • C++ Qt开发:Charts绘制各类图表详解

    Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍 TreeWidget 与 QCharts 的常用方法及灵活运用。 在之前的文章中笔者介绍了如何使

    2024年02月04日
    浏览(32)
  • C++ Qt开发:Charts折线图绘制详解

    Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍 QCharts 折线图的常用方法及灵活运用。 折线图(Line Chart)是一种常用的数据可

    2024年02月04日
    浏览(31)
  • 基于Qt4开发曲线绘制交互软件Plotter

    目前市面上有很多曲线绘制软件,但其交互功能较差。比如,想要实现数据的交互,同步联动等,都需要大量繁琐的人工操作。所以讲想开发一款轻量级的曲线绘制交互软件。下面就以此为案例,记录一下基于Qt4的开发过程。 目录 1 需求 2 技术路线 3 开发流程 1 框架搭建 2

    2024年01月21日
    浏览(34)
  • Qt教程 — 2.1 如何使用Qt Designer 开发UI程序

    目录 1 Qt Designer简介 2 编辑UI界面 2.1 在 UI 界面添加一个Label 2.2 在 UI 界面添加一个按钮 2.3 在 UI 文件里连接信号与槽 方法一:通过信号和槽编辑栏 方法二:通过导航区信号和槽编按钮 方法三:通过跳转编辑代码实现—通过按钮输出文字 Qt Designer 是属于 Qt Creator 的一个功能

    2024年03月22日
    浏览(40)
  • [编程语言][C++][Qt]单独添加UI文件

    不知什么原因,Qt Creator并不是很完美很智能。当先写好界面类的头文件和源代码文件后,我们再添加用于可视化界面设计的UI文件时,会出现一些问题。 当使用CMake管理项目时,CMake会读取 CMakeLists.txt 文件来确定各种项目设置。需要把 MainWindow.ui 包含进项目时,在 CMakeLists.

    2024年02月07日
    浏览(32)
  • 【QT开发(5)】0919-QT里面新增ui类,新增使用opencv读取图片的普通类,在ui类中显示图片

    1、Qt Creator快速入门_第三版__霍亚飞编著 2、《Qt+OpenCV显示图片(Mat转QImage然后显示在QLabel上)》 https://gitee.com/hiyanyx/qt5.14-cpp_-empty_-project/tree/Study2023-section5/ git分支“Study2023-section5” 新增ui类 新增使用opencv读取图片的普通类 为了更加方便,可在QT 中添加普通类,这样会自动生

    2024年02月07日
    浏览(30)
  • 【QT开发专题-天气预报】16.更新 UI 界面

    本专栏将会在未来 4 个月内,完成以下几个 Qt 项目: 《天气预报》 《文本编辑器》 《俄罗斯方块》 《绘图板》 《网络聊天室》 《串口助手》 完成时间预计在 2022-12-31 ,文章数目在 50 篇左右,更新完毕之后,价格恢复到 ¥299 专栏优势: 每个项目都是从零新建工程开始

    2023年04月08日
    浏览(49)
  • QT QPluginLoader 插件开发 ui界面打包dll

     将项目模块化,每一个模块单独开发,模块的组成形成最终的主程序, 点击左侧按钮就会弹出对应的插件应用,每一个子窗口都是单独的dll 插件, 灵活,升级,下载,卸载。 效果:     打开QT Creator 新建插件开发项目  下一步后选择 Qt Plugin 开发 添加依赖库,在.pro里  

    2024年02月11日
    浏览(31)
  • 【Qt】使用Qt designer(Qt设计师)以及uic工具将ui文件转换到C++代码进行界面开发

    【Qt】编写第一个Qt程序,使用Cmake编译并运行 Qt Designer是一个用于创建Qt应用程序用户界面的图形化界面设计器。它是Python GUI开发的一个重要工具,可以帮助用户快速创建具有丰富功能的用户界面。 打开终端输入以下代码 点击创建 拖一些组件进来,点击保存 得到一个后缀为

    2024年02月16日
    浏览(35)
  • Qt开发_调用OpenCV(4.x)完成人脸检测并绘制马赛克(摄像头实时数据)

    这个基于Qt和OpenCV的人脸检测和人脸打码项目是通过实时视频流中的人脸识别来保护隐私。 该项目目的是保护隐私并确保人脸数据安全。在某些情况下,使用实时视频流进行人脸检测和识别可能涉及对个人隐私的侵犯。通过在图像中打码人脸区域,可以避免未经许可的人脸出

    2024年02月06日
    浏览(36)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包