qwidget美化_Qt美化界面的心得整理

最近在美化QT,一直对纯代码编写和美化界面能力拙急。网上搜了很多很多资料,但由于那个庞大的工程还没完成,先将网上的资料整理一下,有一些没用到的,留着以后看。等我的界面美化完之后再po上来~

/**********************************转载分割线**********************************/

Qt 的一些心得

本文来自:http://blog.csdn.net/lpt19832003/archive/2010/03/15/5381095.aspx

一. 背景刷成黑色,前景色设为白色。

方法一、paltette方式,经测试,该方法不会影响到其他控件,推荐使用

点击(此处)折叠或打开

QPalette bgpal = palette();

bgpal.setColor (QPalette::Background, QColor (0, 0 , 0, 255));

//bgpal.setColor (QPalette::Background, Qt::transparent);

bgpal.setColor (QPalette::Foreground, QColor (255,255,255,255)); setPalette (bgpal);

方法二、stylesheet方式

影响子控件的方法是:

点击(此处)折叠或打开

setStyleSheet ("background-color: rgb(0,0,0);color: rgb(255,255,255);");

不影响子控件的方法是:

点击(此处)折叠或打开

setStyleSheet ("venus--TitleBar {background-color: rgb(0,0,0);color: rgb(255,255,255);}");

点击(此处)折叠或打开

this->setObjectName("pw");// 设置对象句,相当于css里的id

this->setStyleSheet("#pw {border-image: url(:/new/prefix1/Pic/54.png);}");// 设置id对应元素的背景色

二. 圆角控件 用stylesheet方式

点击(此处)折叠或打开

setStyleSheet ("border:2px groove gray;border-radius:10px;padding:2px 4px;");

三. 圆角窗口

点击(此处)折叠或打开

RoundRectWin::RoundRectWin()

{

QPalette p = palette();

QPixmap img("roundrect.png");

QBitmap mask("roundrect_mask.png");

p.setBrush(QPalette::Window, QBrush(img));

setPalette(p);

setMask(mask);

resize(img.size());

//setWindowFlags(Qt::FramelessWindowHint);//这句会去掉标题栏 } 注意:mask的图多余部分设为白色

}

四. 半透明窗口

1.窗口整体透明,但是窗体上的控件不透明。 通过设置窗体的背景色来实现,将背景色设置为全透。

点击(此处)折叠或打开

QPalette pal = palette();

pal.setColor(QPalette::Background, QColor(0x00,0xff,0x00,0x00));

setPalette(pal);

注:窗体标题栏不透明,窗体客户区上的控件不透明,QLabel控件只是字显示,控件背景色透明; 窗体客户区完全透明。

另外从网上看到的方法:

点击(此处)折叠或打开

setAttribute(Qt::WA_TranslucentBackground, true);

试验的结果是类似于上面的方法,但有时候窗体会被一些杂色斑点填充,未找到原因。

2.窗口及其上面的控件都半透明:

点击(此处)折叠或打开

setWindowOpacity(0.7);

试验效果:窗口

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Qt中,可以使用QSS(Qt Style Sheets)来美化界面的边框。 首先,需要在Qt界面文件中使用样式表(QSS)来定义界面元素的样式。可以在QWidget、QDialog、QFrame等容器类的属性面板中找到"Style Sheet"选项,点击后可以进入编辑模式。 然后,在编辑模式中,可以使用CSS样式语法来定义界面元素的样式。针对边框的美化,可以使用border属性来设置,如"border: 2px solid red;"表示设置2像素宽度、红色的实线边框。还可以设置边框的圆角角度,使用"border-radius"属性来实现。 此外,还可以使用box-shadow属性来为界面元素添加阴影效果,例如设置"box-shadow: 2px 2px 5px gray;"可以添加2像素宽度、水平和垂直偏移量为2像素、模糊半径为5像素的灰色阴影。 最后,保存样式表后,将其应用到界面元素上,可以使用QWidget的setStyleSheet方法来设置样式表,或者在Qt Designer中直接设置。 除了QSS,也可以使用C++代码来实现界面边框的美化。通过继承QWidget或相关类,重写其paintEvent方法,在方法内使用QPainter绘制边框样式。 以上就是使用代码美化Qt界面边框的方法。通过定义样式表或重写绘图方法,可以实现个性化的边框样式,提升界面的美观性和用户体验。 ### 回答2: 在Qt中,我们可以使用代码来美化界面边框。下面是一些方法和技巧: 1. 使用QSS(Qt样式表)来设置边框的样式。在Qt中,我们可以使用QSS来定义界面元素的样式。可以使用`setStyleSheet()`方法将QSS样式应用于窗口或窗口部件。例如,可以使用`border: 2px solid red;`来定义边框为2像素宽的红色边框。 2. 自定义绘制边框。Qt提供了`paintEvent()`事件函数,允许我们在窗口或窗口部件上进行绘制操作。我们可以在`paintEvent()`函数中使用QPainter对象来绘制自定义的边框。例如,可以使用`QPainter::drawRect()`绘制一个矩形边框,并设置其线宽和颜色。 3. 使用样式类。Qt提供了许多样式类来帮助我们美化界面元素。例如,可以使用`QFrame`类来创建一个带边框的窗口部件,然后使用`setFrameStyle()`方法来设置边框样式。 4. 使用自定义样式插件。Qt允许我们创建自定义的样式插件来美化界面元素。我们可以使用Qt Creator来创建新的样式插件,并使用其提供的功能来设置边框的样式。 总的来说,Qt提供了多种方法来美化界面边框,我们可以根据需要选择合适的方法进行实现。无论是使用QSS、自定义绘制、样式类还是自定义样式插件,我们都可以通过代码来实现界面边框的美化
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值