Qt 实现新手引导

发布于:2025-07-13 ⋅ 阅读:(16) ⋅ 点赞:(0)

Qt实现新手引导

对于一个新安装的软件或者一个新的功能,提供一个新手引导步骤,能够让用户快速熟悉。
在这里插入图片描述
这是最终效果,每一个按钮都会有一个简单引导,通过点击上一步、下一步来切换不同的指导。当前引导的功能,会有一个高光区,该高光区可点击,其他区域不可点击。引导结束后回归主界面。

引导层

void GuideOverlayTip::updateWidgets()
{
    if (m_currentStep >= m_highlightRects.size())
    {
        hide();
        return;
    }

    if(m_currentStep == m_highlightRects.size() - 1)
    {
        m_btnPrev->setText(tr("完成"));
    }

    QRect rect = m_highlightRects[m_currentStep];

    m_tipLabel->setText(m_tips[m_currentStep]);
    m_tipLabel->adjustSize();
    m_tipLabel->move(rect.topRight() + QPoint(10, -rect.height()/2));


    if(m_currentStep != 0)
    {
        m_btnPrev->move(rect.bottomLeft() + QPoint(-80, 10));
        m_btnPrev->show();
    }
    else
    {
        m_btnPrev->hide();
    }
    m_btnNext->move(rect.bottomRight() + QPoint(10, 10));
}

根据当前引导,更新btn、label顺序、文本显示。

void GuideOverlayTip::updateMask()
{
    if (m_currentStep >= m_highlightRects.size())
    {
        return;
    }
    QRegion fullRegion(rect());
    QRegion highlightRegion(m_highlightRects[m_currentStep].adjusted(0, 0, 1, 1), QRegion::Rectangle);
    QRegion maskedRegion = fullRegion.subtracted(highlightRegion);

    setMask(maskedRegion);
}

setMask可以遮挡非高光区的事件。

void GuideOverlayTip::paintEvent(QPaintEvent *)
{
    QPainter painter(this);
    
    QPainterPath maskPath;
    maskPath.addRect(rect());
    maskPath.addRoundedRect(m_highlightRect, 8, 8);
    maskPath.setFillRule(Qt::OddEvenFill);

    painter.fillPath(maskPath, QColor(0, 0, 0, 160));
}

根据需求绘制一个半透明的背景。

调用层

void MainWindow::showGuide()
{
    QList<QRect> steps;
    QStringList tips;

    for (int i = btn1; i <= btn4; ++i)
    {
        QPushButton* btn = m_pushBtns[i];
        QRect btnRect(this->mapFromGlobal(btn->mapToGlobal(QPoint(0, 0))), btn->size());
        steps << btnRect;
    }

    qDebug() << steps;

    tips << "点击这里改变改变背景颜色为A";
    tips << "点击这里改变改变背景颜色为B";
    tips << "点击这里改变改变背景颜色为C";
    tips << "点击这里恢复默认背景";

    m_guide->setSteps(steps, tips);
    m_guide->start();

}

传入高光区位置、提示文本等;
其中为m_guide = new GuideOverlayTip(this);


网站公告

今日签到

点亮在社区的每一天
去签到