Qt编写自定义控件:文字聚光灯效果

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QTimer>

class Widget : public QWidget
{
    Q_OBJECT

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

protected:
    void paintEvent(QPaintEvent *event)override;

private:
    void onTimer();
    QString text;
    QTimer timer;
    QRect textRect;
    int changeValue{0};
    bool runDirectionIsRight{true};
};
#endif // WIDGET_H
#include "widget.h"
#include <QPainter>
#include <QPaintEvent>
#include <QPainterPath>

Widget::Widget(QWidget *parent)
    : QWidget(parent)
{
    text = "黄河之水天上来,奔流到海不复回";
    auto font = this->font();
    font.setPixelSize(40);
    font.setBold(true);
    setFont(font);

    connect(&timer,&QTimer::timeout,this,&Widget::onTimer);
    timer.start(40);
}

Widget::~Widget()
{
}

void Widget::paintEvent(QPaintEvent *event)
{
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing,true);
    painter.setFont(this->font());
    auto rect = event->rect();

    painter.save();
    painter.setPen(QColor("#574E54"));
    painter.drawText(rect, Qt::AlignCenter | Qt::TextWordWrap, text);
    painter.restore();

    textRect = painter.boundingRect(rect,Qt::AlignCenter | Qt::TextWordWrap,text);
    auto pos = textRect.topLeft() + QPoint(changeValue,0);

    QPainterPath path;
    path.addEllipse(QPointF(pos.x(),pos.y() + textRect.height() / 2),50,50);
    painter.setClipPath(path);

    auto tempRect = path.boundingRect();
    QLinearGradient linearGradient(tempRect.topRight(),tempRect.bottomLeft());
    linearGradient.setColorAt(0.0,Qt::magenta);
    linearGradient.setColorAt(0.2,Qt::darkYellow);
    linearGradient.setColorAt(0.4,Qt::green);
    linearGradient.setColorAt(0.6,Qt::red);
    linearGradient.setColorAt(0.8,Qt::darkRed);
    linearGradient.setColorAt(1.0,Qt::blue);
    painter.setBrush(Qt::transparent);
    painter.setPen(QPen(QBrush(linearGradient),3));

    painter.drawText(rect, Qt::AlignCenter | Qt::TextWordWrap, text);
}

void Widget::onTimer()
{
    if(runDirectionIsRight)
    {
        changeValue += 15;
        if(changeValue >= textRect.width())
        {
            runDirectionIsRight = false;
        }
    }
    else
    {
        changeValue -= 15;
        if(changeValue <= 0)
        {
            runDirectionIsRight = true;
        }
    }
    update();
}

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值