在Qt中,我们不可避免的会用到QLabel类。而Qlabel的强大功能作为程序员的你有多少了解?

下面,跟着我一起在来学习一下吧!

1、添加文本

Qlabel类添加文本有两种方式,一种是直接在实现时添加,如:

 QLabel *label = new QLabel(QString("Holle,世界"), this);
//QLabel *label = new QLabel(tr("Holle,世界"), this);

一种是在实现后添加,如:

 int a = +;
QLabel *label = new QLabel( this);
label ->setText(tr("Holle,世界"));
//label ->setText(tr("1+1=%1").arg(a));
//label ->setText(QString::number(a));
//label ->setText(QString::number(a,'f',2));//保留两位,如果保留一位就把2改为1

2、设置尺寸,位置

设置尺寸也有多种,常用的固定尺寸(FixedSize),最小尺寸(MinimumSize),最大尺寸(MaximumSize),代码如下:

 //setMinimumHeight(30);        //最小行高
//setMinimumWidth(30); //最小列宽
setMinimumSize(, ); //设置最小尺寸
 //setMaximumHeight(30);    //最大行高
//setMaximumWidth(30); //最大列宽
setMaximumSize(, ); //设置最大尺寸
 setFixedSize(,);        //设置固定尺寸
//setFixedWidth(30); //固定列宽
//setFixedHeight(30); //固定行高

设置固定尺寸

 int x,y,w,h;
label = new QLabel(this);
label ->setGeometry(x,y,w,h);
//若label的尺寸已经设置,则w,h的值无效。

设置Geometry

3、设置布局

 QVBoxLayout *layout = new QVBoxLayout(this);
QLabel *label = new QLabel(QString("Holle,世界"), this);
layout->addWidget(label,Qt::AlignCenter); //居中
//Qt::AlignCenter 中心对齐
//Qt::AlignLeft 左对齐
//Qt::AlignRight 右对齐
//QHBoxLayout:水平布局,在水平方向上排列控件,即:左右排列。
//QVBoxLayout:垂直布局,在垂直方向上排列控件,即:上下排列。

4、添加常规可视图片

 labelImg = new QLabel;
Image1.load(":/img/head.jpg");
labelImg->setAlignment(Qt::AlignHCenter|Qt::AlignVCenter);
labelImg->setPixmap(QPixmap::fromImage(Image1));
//.h文件
//#include <QImage>
//private:
//QImage Image1;

5、添加圆形可视图片,即QQ头像类

两种方式,一种直接将图片修改为圆形的透明图片(*.png),一种则是使用蒙版形式,使用图片处理工具创建一个圆形透明图片(*.png),然后Qt操作代码如下:

//.cpp文件
labelImg = new QLabel(this);
//设置蒙版
labelImg ->setMask(pixmapBack.mask());
labelImg ->setStyleSheet("border-image:url(qrc:/img/mask_30x30.png)");//mask_30x30.png,是我做的圆形透明图片,已经导入到资源文件
QPixmap head = QPixmap(":/img/head.jpg").scaled(QSize(labelImg->width(), labelImg->height()), Qt::KeepAspectRatio, Qt::SmoothTransformation); //head.jpg,是要显示的图片类型大小随意,这里我用的是*.jpg。KeepAspectRatio:保持长宽比例
labelImg ->setPixmap(head);

6、实现被点击事件

标签实现被点击事件有两种方式,一种是自定义一个按钮类标签,一种是采用事件过滤,具体的请看代码。注:这里采用了鼠标事件。

1).自定义按钮类标签:

 //ClickedLabel.h文件
#include <QLabel>
class ClickedLabel : public QLabel
{
Q_OBJECT
public:
ClickedLabel( QWidget* parent = );
int IsClicked;
void mousePressEvent(QMouseEvent *e);//添加鼠标响应事件
void mouseReleaseEvent(QMouseEvent *e);//添加鼠标释放事件
signals:
void clicked();//点击信号 };
//ClickedLabel.cpp文件
ClickedLabel::ClickedLabel(QWidget* parent) : QLabel(parent)
{
setText("作者:夜潇!"); //添加标签默认文本
setAlignment(Qt::AlignCenter); //设置默认对齐方式:中心对齐(居中)
//设置默认标签风格
//setStyleSheet("ClickedLabel { background-color: rgb(143,122,102); border-radius: 10px; font: bold; color: white; }");
IsClicked = ;
} void ClickedLabel::mousePressEvent ( QMouseEvent * e )
{
IsClicked = ;
} void ClickedLabel::mouseReleaseEvent ( QMouseEvent * e )
{
if(IsClicked)
{
emit clicked();
IsClicked = ;
}
}

自定义按钮类标签

2).事件过滤标签:

 #include <QDialog>
#include <QLabel>
#include <QEvent> class EventFilter : public QDialog
{
Q_OBJECT public:
EventFilter(QWidget *parent = ,Qt::WindowFlags f=);
~EventFilter();
public slots:
bool eventFilter(QObject *, QEvent *);
private:
QLabel *label1;
};
//这里有一个默认的*.cpp的头文件,故此我将其省略。
#include <QHBoxLayout>
#include <QMouseEvent> EventFilter::EventFilter(QWidget *parent,Qt::WindowFlags f)
: QDialog(parent,f)
{
label1 = new QLabel; QHBoxLayout *layout=new QHBoxLayout(this);
layout->addWidget(label1);
label1->installEventFilter(this);
}
bool EventFilter::eventFilter(QObject *watched, QEvent *event)
{
if(watched==label1)
{
if(event->type()==QEvent::MouseButtonPress)
{
QMouseEvent *mouseEvent=(QMouseEvent *)event;
if(mouseEvent->buttons()&Qt::LeftButton)
{
label1->setText(tr("左键按下"));
}
else if(mouseEvent->buttons()&Qt::MidButton)
{
label1->setText(tr("中键按下"));
}
else if(mouseEvent->buttons()&Qt::RightButton)
{
label1->setText(tr("右键按下"));
}
}
if(event->type()==QEvent::MouseButtonRelease)
{
label1->setText(tr("鼠标释放"));
}
}
return QDialog::eventFilter(watched,event);
}

事件过滤标签

7、实现超链接

 label= new QLabel(tr("<style> a {text-decoration: none} </style><a href = http://haozip.2345.com>2345好压</a>"),this);
//文本无下划线:<style> a {text-decoration: none} </style>,如去掉则有下划线。

8、修改颜色

标签颜色有基本两处,一是文本颜色,二是背景颜色。而文本颜色设置两种,一种是用QPalette类,一种是StyleSheet类,代码如下:

 label = new QLabel(this);
QPalette palette;
palette.setColor(QPalette::WindowText,Qt::red);
label->setPalette(palette);
//文本颜色:红色
 label = new QLabel(this);
label -> setStyleSheet("QLabel { color: rgb(143,122,102);}");
//label -> setStyleSheet("QLabel { color: red;}");
//label -> setStyleSheet("QLabel { "color: #FF0000;";}");
//常见颜色十六进制值
//<font color=red或"#FF0000">红色</font>
//<font color="#dd0000">浅红色</font>
//<font color="#660000">深红色</font>
//<font color="#00dd00">浅绿色</font>
//<font color="#006600">深绿色</font>
//<font color="#0000dd">浅蓝色</font>
//<font color="#000066">深蓝色</font>
//<font color="#dddd00">浅黄色</font>
//<font color="#666600">深黄色</font>
//<font color="#00dddd">浅青色</font>
//<font color="#006666">深青色</font>
//<font color="#dd00dd">浅紫色</font>
//<font color="#660066">深紫色</font>

设置背景颜色:

 label = new QLabel(this);
label ->setStyleSheet("background-color:lightred;");
//颜色值可通用

9、设置圆角标签,且扩展类。注:此圆角和第5点中的圆不同用。

 label = new Qlabel(this);
label -> setStyleSheet("Qlabel{color: white;"
"border-radius: 20px; border: 2px groove gray;border-style: outset;}"/*此处设置圆角*/
"Qlabel:hover{background-color:lightgreen; color: black;}"
"Qlabel:pressed{background-color:rgb(85, 170, 255);border-style: inset; }");
//注:当radius的值是控件高度或者宽度一半时可化作圆;border:边 hover:点燃 outset:常规 pressed:按下 inset:内嵌

好了,今天就先到这吧!如果你也有好的代码可以私信或者加以评论。如有疑问,可随时联系QQ:1285015525。

最新文章

  1. 【Cocos2d-x游戏开发】Cocos2d-x中的数据存储技术
  2. JS中数组去除重复的方法
  3. linux free命令中buffer与cache的区别
  4. ECshop 二次开发模板教程3
  5. 基于事件的异步模式——BackgroundWorker
  6. java byte 16进制转换
  7. 20道Java面试必考题
  8. php学习随笔--定时触发
  9. 使用composer遇到的问题及解决方法
  10. [Tensorflow] **Android Meets TensorFlow
  11. 黄聪:Wordpress程序Mysql查询导致CPU100%,页面错误增量飙高解决方案
  12. ZY、
  13. linux&amp;amp;shell
  14. centos7下搭建NFS服务器
  15. android去掉button默认的点击阴影
  16. Redis 数据类型List链表
  17. VB中的排序问题 15个
  18. ES6入门教程---解构赋值和字符串扩展
  19. HDU 5446 Unknown Treasure
  20. UVA 12649 Folding Machine 搜索

热门文章

  1. LOJ#2540 随机算法
  2. 【转】METADATATYPE的使用,MVC的MODEL层数据验证
  3. No module named flask.ext.script 解决方法
  4. Scala进阶之路-I/O流操作之文件处理
  5. weblogic11G 修改密码
  6. hdu 5755 Gambler Bo (高斯消元法解同余方程组)
  7. AngularJS 启程三
  8. es6笔记(2) let 和 const
  9. [转] 解决RegexKitLite编译报错
  10. MySQL忘记密码了怎么办?