qt 毛玻璃效果

//弹出框之前设置界面模糊
QGraphicsBlurEffect* ef = new QGraphicsBlurEffect;
ef->setBlurRadius(8);
ef->setBlurHints(QGraphicsBlurEffect::AnimationHint);
this->setGraphicsEffect(ef);
//弹出框
QMessageBox::warning(this, "Warning", "This is mohu", QMessageBox::Cancel);
//还原
ef->setBlurRadius(0);
ef->setBlurHints(QGraphicsBlurEffect::AnimationHint);

这样实现的背景模糊有一个缺点,如果表头、底部状态栏或者左右悬浮框、菜单等不属于 this,则不会模糊

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt中实现和Mac一样的毛玻璃效果需要使用Qt提供的QGraphicsEffect类和QGraphicsOpacityEffect类。 首先,我们可以创建一个QGraphicsView来显示我们的窗口内容,然后为该QGraphicsView设置一个毛玻璃效果: ```cpp #include <QtWidgets> int main(int argc, char *argv[]) { QApplication app(argc, argv); QGraphicsView view; QGraphicsOpacityEffect *effect = new QGraphicsOpacityEffect; effect->setOpacity(0.9); // 设置透明度,值在0.0~1.0之间 view.setViewport(new QWidget); view.viewport()->setGraphicsEffect(effect); view.show(); return app.exec(); } ``` 接下来,我们可以使用QGraphicsDropShadowEffect类创建一个阴影效果,使窗口看起来更加逼真: ```cpp #include <QtWidgets> int main(int argc, char *argv[]) { QApplication app(argc, argv); QGraphicsView view; QGraphicsOpacityEffect *opacityEffect = new QGraphicsOpacityEffect; opacityEffect->setOpacity(0.9); // 设置透明度,值在0.0~1.0之间 QGraphicsDropShadowEffect *shadowEffect = new QGraphicsDropShadowEffect; shadowEffect->setBlurRadius(20); // 设置模糊半径 shadowEffect->setColor(Qt::black); // 阴影颜色 shadowEffect->setOffset(0); // 阴影偏移量 QGraphicsEffectGroup *effectGroup = new QGraphicsEffectGroup; effectGroup->setOpacityEffect(opacityEffect); effectGroup->addEffect(shadowEffect); view.setViewport(new QWidget); view.viewport()->setGraphicsEffect(effectGroup); view.show(); return app.exec(); } ``` 以上就是使用Qt实现和Mac一样的毛玻璃效果的方法。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值