QT 控件阴影效果

在做项目的时候,为了美化界面,我们通常需要设置控件具有阴影效果,具体怎么做呢?

方法一:使用QGraphicsDropShadowEffect

    this->setWindowFlags(Qt::FramelessWindowHint);
    QGraphicsDropShadowEffect *effect = new QGraphicsDropShadowEffect;
    effect->setBlurRadius(8);        // 阴影圆角的大小
    effect->setColor(Qt::gray);      //阴影的颜色
    effect->setOffset(5,5);          //阴影的偏移量
    ui->centralWidget->setGraphicsEffect(effect); //给那个控件设置阴影,这里需要注意的是所有此控件的子控件,也都继承这个阴影。

方法二:重写paintEvent 函数

void MainWindow::paintEvent(QPaintEvent *event)
{
    QPainterPath path;
    path.setFillRule(Qt::WindingFill);
    path.addRect(10, 10, this->width()-20, this->height()-20);

    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing, true);
    painter.fillPath(path, QBrush(Qt::white));

    QColor color(0, 0, 0, 50);
    for(int i = 0; i < 10; i++)
    {
        QPainterPath path;
        path.setFillRule(Qt::WindingFill);
        path.addRect(10-i, 10-i, this->width()-(10-i)*2, this->height()-(10-i)*2);
        color.setAlpha(150 - qSqrt(i)*50);
        painter.setPen(color);
        painter.drawPath(path);
    }
}


bool TDMSummaryForm::eventFilter(QObject *watched, QEvent *event)
{
    if (event->type() == QEvent::Paint && (watched == ui->titleFrame ||
                                           watched == ui->groupDataFrame ||
                                           watched == ui->trendFrame ||
                                           watched == ui->tableFrame))
    {
        QWidget *wgt = static_cast<QWidget*> (watched);

        QPainter painter(wgt);
        QColor color(217, 229, 246, 55);
        for (int i = 0; i<10; i++)
        {
            QPainterPath path;
            path.setFillRule(Qt::WindingFill);
            path.addRoundRect(10 - i, 10 - i,
                              wgt->width() - (10 - i) * 2,
                              wgt->height() - (10 - i) * 2,
                              4);
            color.setAlpha(255 - qSqrt(i) * 70);
            painter.setPen(color);
            painter.drawPath(path);
        }
    }

    return QObject::eventFilter(watched, event);
}

使用此方法,需要添加下面代码,保证不被绘制上的部分透明。

setAttribute(Qt::WA_TranslucentBackground)

方法三:使用带有阴影效果的图片。

 

 

 

 

 

  • 9
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt 3D点云显示控件是一种在Qt框架下实现点云数据可视化的工具。点云是由大量的点云数据构成的三维空间数据集合,可以被用于各种应用领域,如计算机图形学、机器人感知、医学图像处理等。 Qt 3D点云显示控件提供了一系列功能和工具,可以方便地加载、处理和显示点云数据。通过该控件,我们可以实现一些常见的操作,如旋转、缩放、平移、选择和标记等,以便更好地进行点云数据的展示与分析。 在Qt 3D点云显示控件中,我们可以通过加载点云文件或者使用代码动态生成点云数据。加载点云文件可以支持多种点云格式,如PLY、PCD等。一旦加载了点云数据,我们就可以对其进行各种操作和处理,如数据过滤、点云配准、表面重构等。同时,该控件还支持多视图显示,可以在不同的视角下观察和分析点云数据。 除了基本的点云显示功能,Qt 3D点云显示控件还提供了一些高级特性,如光照模型、阴影效果、材质贴图等,可以增强点云的可视化效果。另外,它还支持可交互的用户界面,可以与其他Qt组件结合,方便用户对点云数据进行操作和交互。 总之,Qt 3D点云显示控件是一个功能强大、易于使用的工具,可以帮助我们实现点云数据的可视化和分析。无论是对于学术研究还是实际应用,该控件都提供了丰富的功能和灵活的操作方式,使得点云数据的处理更加高效和方便。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值