控件设置透明度:

  QGraphicsOpacityEffect *effect = new QGraphicsOpacityEffect(this);

  effect->setOpacity(0.9); //设置透明度    ui->widget->setGraphicsEffect(effect); //加在需要设置透明的控件上

控件设置圆角边框:

//通过控件的样式表即可实现

ui->widget->setStyleSheet(“border-radius:3px;”);

创建托盘图标:

//加在ico图标

QIcon icon = QIcon(“:/icofire.ico”);

setWindowIcon(icon);

//创建

   trayIcon = new QSystemTrayIcon(this);

    trayIcon=new QSystemTrayIcon(this);

//关联曹函数,用于捕捉图标点击事件

connect(trayIcon, SIGNAL(activated(QSystemTrayIcon::ActivationReason)), this, SLOT(activated (QSystemTrayIcon::ActivationReason)));

trayIcon->setIcon(icon);

//设置上下文菜单

//trayIcon->setContextMenu(this->trayIconMenu);

trayIcon->show();

窗口设置为无边框:

this->setWindowFlags(Qt::FramelessWindowHint);

控件重叠,即实现控件“浮动效果”:

  在界面存在布局的情况下,是无法将连个控件重叠在一起的,如果我们要实现界面中一部分控件“浮动”其他控件上的效果,可以通过栈布局的方式来实现。然而在默认情况下,栈布局同时只能显示一帧画面,要做到栈布局中所有控件同时显示,要用到一下代码:

QStackedLayout*laylout=(QStackedLayout*)ui->stackedWidget->layout();

laylout->setStackingMode(QStackedLayout::StackAll);

QLabel标签添加点击事件:

  QLabel没有特定的信号槽来让我们处理点击事件,需要通过一下方法:

为标签绑定点击事件的监听函数

ui->label ->installEventFilter(this);

重写窗体类的eventFilter()函数

bool MainForm::eventFilter(QObject *obj, QEvent *event){

if(obj==ui->label){

   //过滤出单击事件

        if (event->type() == QEvent::MouseButtonPress) {

             //处理函数

            return true;

        }

}

//其他判断…

    return QWidget::eventFilter(obj,event);

}

  注意,处理完点击事件后,如果 return true,这终止事件处理,反之消息将继续传播下去。

QLabel 同时显示文字和图片:

  QLabel 在QDisginer编辑时可以通过属性窗口设置图片和文字,但最终程序运行时是不会同时显示的,即这两个属性会相互覆盖,只显示其一。为达到图文同时显示,可通过重载QLabel的 paintEvent()函数来实现,若我们在属性中设置好了图片,需显示额文字,可通过以下方法:

void QCustLabel::paintEvent(QPaintEvent *event){

    //先按默认防止进行标签绘制

    QLabel::paintEvent(event);

QPainter painter(this);

//设置文字颜色

    painter.setPen(Qt::white);

    //要显示的可以作为一个成员变量

QString info=this->desInfo;

//设置文字信息的x坐标和y坐标

//此处用了水平居中和垂直居中

    int x=this->width()/2-(this->fontMetrics().width(info)/2);

int y=this->height()/2+(this->fontMetrics().height()/2);

//绘出文字

    painter.drawText(QPoint(x,y),info);

}

  此方法中用到了 Qt的二维绘图类 QPainter,此处使用的方法还是比较简单的,关于QPainter使用总结,会在接下来的文章中给出。

由此,我们可以在label中随意指定文字、图片的显示方式。

QTableView的简单使用方法:

  对于QTableView的内容修改,如设置表头、添加单元格内容,可不不直接操作该控件,操作控件的 model 即可。

tableModel=new QStandardItemModel;

//设置列数

tableModel->setColumnCount(3);

    tableModel->setHeaderData(0,Qt::Horizontal,tr(“colum 0″));

    tableModel->setHeaderData(1,Qt::Horizontal,tr(“colum 1″));

    tableModel->setHeaderData(2,Qt::Horizontal,tr(“colum 2″));

   //为QTableView添加model

ui->tableView->setModel(tableModel);

为QTableView添加行:

//清除所有行

//tableModel->removeRows(0,tableModel->rowCount());

    for(int i=0;i<XXX;i++){

        tableModel->setItem(i,0,new QStandardItem(“xxx”));

        tableModel->setItem(i,1,new QStandardItem(“xxx”));

        tableModel->setItem(i,2,new QStandardItem(“xxx”));

    }

  //表格控件根据内容自动调整宽度和高度

    ui->tableView->resizeColumnsToContents();

    ui->tableView->resizeRowsToContents();

Qt学习总结-ui篇的更多相关文章

  1. Qt学习总结-ui篇(二)

    qccs定义圆角   border-radius:10px; 如果想给特定位置定义圆角,如: 左上角:border-left-top-radius:10px; 右下角色:border-right-bo ...

  2. QT学习:入门篇(三)

    头文件: #ifndef CChatDisplaySet_h #define CChatDisplaySet_h #include "QtGui/QDialog" #include ...

  3. swift学习笔记-UI篇之UIImageView

    1.基本使用 将要使用的图片拖入到项目里,我这里使用的是名为“1.jpg”的图片,然后创建UIImageView,并设置要显示的图片为"1.jpg"//1. 基本使用 let im ...

  4. qt学习笔记(五) QGraphicsPixmapItem与QGraphicsScene的编程实例 图标拖动渐变效果

    应大家的要求,还是把完整的project文件贴出来,大家省点事:http://www.kuaipan.cn/file/id_48923272389086450.htm 先看看执行效果,我用的群创7寸屏 ...

  5. Qt入门之基础篇 ( 二 ) :Qt项目建立、编译、运行和发布过程解析

    转载请注明出处:CN_Simo. 题解: 本篇内容主讲Qt应用从创建到发布的整个过程,旨在帮助读者能够快速走进Qt的世界. 本来计划是讲解Qt源码静态编译,如此的话读者可能并不能清楚地知道为何要静态编 ...

  6. 一步步学习javascript基础篇(3):Object、Function等引用类型

    我们在<一步步学习javascript基础篇(1):基本概念>中简单的介绍了五种基本数据类型Undefined.Null.Boolean.Number和String.今天我们主要介绍下复杂 ...

  7. QT学习第1天

    QT学习第一天  坚持住!! 一 Qt概述 1.Qt发展历史 (1)1991年诞生(Haavard Nord/Eirik Chambe-Eng), (2)1994年创立Troll Tech(奇趣科技) ...

  8. 学习KnockOut第一篇之Hello World

    学习KnockOut第一篇之Hello World 笔者刚开始学习KnockOut.写的内容就相当于一个学习笔记.且在此处向官网致敬,比较喜欢他们家的Live Example版块,里面有jsFiddl ...

  9. Qt入门之基础篇(三):掌握Qt4的静态编译基本方法

    转载载请注明出处:CN_Simo. 导语: 前两章都提到过“静态编译”(Static Compilation),在Windows下一次静态编译差不多需要长达三个小时才能完成,而且还非常容易由于各种原因 ...

随机推荐

  1. javascript 事件相关

    1.添加事件 >基本注册方式 <button id="info">click me!</button> var span = document.get ...

  2. Linux TCP队列相关参数的总结 转

        在Linux上做网络应用的性能优化时,一般都会对TCP相关的内核参数进行调节,特别是和缓冲.队列有关的参数.网上搜到的文章会告诉你需要修改哪些参数,但我们经常是知其然而不知其所以然,每次照抄过 ...

  3. Qt动画效果的实现,QPropertyAnimation

    Qt动画架构中的主要类如下图所示: 动画框架由基类QAbstractAnimation和它的两个儿子QVariantAnimation和QAnimationGroup组成.QAbstractAnima ...

  4. MVC+easyui 完整实现

    学习mvc半月有余,趁几天假期,没事做就动手做一个完整的网站玩玩,顺便和上家公司的方法做个比较.页面引擎采用mvc自带的功能,建立视图,交给.net自带渲染出页面(对比:上家公司采用的第三方组件渲染的 ...

  5. android系统启动时自动运行自己的程序

    android系统在Manifest.permission中有这样一条RECEIVE_BOOT_COMPLETED的定义,当你自己的程序加 入这个权限后,就可以在系统启动完毕后收到一条系统的广播,这个 ...

  6. UIImage的简单用法和实际操作

    png,pdf不需要添加后缀名 jpg添加后缀名 存储 UIImagejpg contentMode属性 这个属性是用来设置图片的显示方式,如居中.居右,是否缩放等,有以下几个常量可供设定: UIVi ...

  7. hdu-5505(数论)

    题目链接: GT and numbers Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 65536/65536 K (Java/Ot ...

  8. ASP三种常用传值方式:

    ASP 页面(两个aspx页面)传值方式:背景: 两个aspx 页面valuepage.aspx tbusername tbpwdobtainvalue.aspx tbusername tbpwd 1 ...

  9. rfc 标准文档目录

    1.  xmpp的文档 (3920版本) https://tools.ietf.org/html/rfc3920 2. MQTT 3. SIP

  10. 宽度的100%和auto的区别

    前段时间做项目,发现分不清width设为100%和auto的区别,实在是太水了,就查了点资料,做个总结,有不对的地方欢迎大家指出. width:auto 块级元素默认的宽度值.看一下MDN上的解释:T ...