C++ GUI Qt4编程-创建自定义窗口部件

C++ GUI Qt4编程-创建自定义窗口部件

Qtqt4

通过Qt窗口部件进行子类化或者直接对QWidget进行子类化,就可以创建自定义窗口部件,下面示范两种方式,并且也会说明如何把自定义窗口部件集成到Qt设计师中,这样就可以像使用内置的Qt窗口部件一样来使用它们,最后展示使用双缓冲技术(一种用于快速绘制的强大技术)的自定义窗口部件。

1.自定义Qt窗口部件

我们发现Qt窗口部件需要更多的自定义定制,这些定制可能要比它在Qt设计师里设置的属性或者对它调用的那些函数更多一些,一个简单而直接的解决方法就是对相关的窗口部件类进行子类化并且使它能够满足我们的需要。

如果没有任何一个Qt窗口部件能够满足任务要求,并且也没有办法通过组合现有窗口部件来满足所需的期望结果时,仍旧可以创建出我们想要的窗口部件来,要实现这一点,只需通过子类化QWidget,并且通过重新实现一些用来绘制窗口部件和响应鼠标点击的时间处理器即可,这一方法给了我们定义并且控制自己的窗口部件的外观和行为的完全自由。Qt的一下内置窗口部件,像QLabel/QPushButton/QTableWidget,都是通过这种方法得以重新实现的。如果它们没有在Qt中存在,那么还是完全有可能以与平台无关的方式使用QWidget锁提供的共有函数来创建它们。

#include<QColor>

#include<QImage>

#include<QWidget>

class IconEditor:public QWidget

{

Q_OBJECT

//声明自定义属性,每个属性都有一个数据类型/一个读函数/一个可选项的写函数

Q_PROPERTY(QImage iconImage READ iconImage WRITE setIconImage)

}

当我们在Qt设计师中使用这个窗口部件时,在Qt设计师属性编辑框里,那些继承于QWidget的属性下面,将会显示这些自定义的属性,这些属性可以是由QVariant锁所支持的任何类型。

IconEditor::IconEditor(QWidget *parent) : QWidget(parent)

{

setAttribute(Qt::WA_StaticContents);

setSizePolicy(QSizePolicy::Minimum, QSizePolicy::Minimum);

//画笔的颜色设置为黑色

curColor = Qt::black;

//缩放因子设置为8,图标中的每一个像素都将会显示成一个8×8正方形。

zoom = 8;

//图片初始化为16×16的像素大小和32位的ARGB颜色格式,这种颜色支持半透明效果。

image = QImage(16, 16, QImage::Format_ARGB32);

//通过填充透明的颜色,从而清空image中的数据。

image.fill(qRgba(0, 0, 0, 0));

}

QRgb只是unsigned int 类型的一个typedef(类型别名),并且qRgb()和qRgba()都是用来把它们的参数组合成一个32位的QRGB整数值的内联函数,格式如下。

QRgb red = 0xFFFF0000;

这里的第一个FF对应于alpha分量,第二个FF对应于红色分量。

Qt提供了两种存储颜色的类型:QRgb和QColor。虽然QRgb仅仅是一个用于QImage中存储32位像素数据的类型别名,但QColor则是一个具有许多有用函数并且在Qt中广泛用于存储颜色的类。

QSize IconEditor::sizeHinit() const    //从QWidget中重新实现的,并且可以返回一个窗口部件的理想大小

{

QSize size = zoom * image.size();

//如果缩放因子是3或者更大,那么在每个方向上需要再额外增加一个像素,以便可以容纳一个网格线。如果缩放因子是2或者1,就不必再显示网格线,因为这些网格线将几乎不能再给图标的像素留下任何空间。

if (zoom >= 3)

{

size += QSize(1,1);

}

return size;

}

void IconEditor::setIconImage(const QImage &newImage)     //设置需要编辑的图像

{

if (newImage != image)

{

//转换成一个带alpha缓冲的32位图像

iamge = newImage.convertFormat(QImage::Format_ARGB32);

//强制重绘窗口部件

update();

//告诉包含这个窗口部件的任意布局,这个窗口部件的大小提示发生了变化了,于是,该布局将会自动适应这个新的大小提示。

updateGeometry();

}

}

窗口部件的调色板颜色组

(1)Active颜色组可用于当前激活窗口中的那些窗口部件。

(2)Inactive颜色组可用于其他窗口中的那些窗口部件。

(3)Disabled颜色组可用于任意窗口中的那些不可用窗口部件。

2.双缓存

双缓存是一种图像用户界面编程技术,它包括把一个窗口部件渲染到一个脱屏像素映射中以及把这个像素映射复制到显示器上,在Qt的早期版本中,这种技术通常用于消除屏幕的闪烁以及为用户提供一个漂亮的用户界面。

Qt提供了两种用于控制鼠标光标形状的机制

(1).当鼠标悬停在某个特殊的窗口部件上时,QWidget::setCursor()可以设置它所使用的光标形状,如果没有为窗口部件专门设置光标,那么就会使用父窗口部件中的光标,顶层窗口部件的默认光标是箭头光标。

(2)对于整个应用程序中所使用的光标形状,可以通过QApplication::setOverrideCursor()进行设置,它会把不同窗口部件中的光标形状全部覆盖掉,直到调用restoreOverrideCursor‘()。

C++ GUI Qt4编程-创建自定义窗口部件

时间: 2024-08-06 15:04:47

C++ GUI Qt4编程-创建自定义窗口部件的相关文章

C++ GUI Qt4编程(10)-3.4spreadsheet

1. C++ GUI Qt4编程第三章,增加spreadsheet. 2. spreadsheet.h 1 /**/ 2 #ifndef SPREADSHEET_H 3 #define SPREADSHEET_H 4 5 #include <QTableWidget> 6 7 class Spreadsheet : public QTableWidget 8 { 9 Q_OBJECT 10 11 public: 12 Spreadsheet(QWidget *parent = 0); 13 v

C++ GUI Qt4编程(03)-1.3layout

1. 根据C++ GUI Qt4编程(第二版)整理2. 系统:centos7:  Qt版本:5.5.13. 程序:layout.cpp #include <QApplication> #include <QHBoxLayout> #include <QSlider> #include <QSpinBox> int main(int argc, char *argv[]) { QApplication app(argc, argv); QWidget *win

Qt自定义窗口部件

QtDesigner自定义窗口部件有两种方法:改进法(promotion)和插件法(plugin) 改进法 1.改进法之前,要先写好子类化QSpinBox后的HexspinBox.h和HexspinBox.cpp文件.把这两个文件拷贝到想要的项目中. HexspinBox.h Cpp代码   #ifndef HEXSPINBOX_H #define HEXSPINBOX_H #include <QSpinBox> class QRegExpValidator; class HexSpinBox

Kivy 中文教程 实例入门 简易画板 (Simple Paint App):1. 自定义窗口部件 (widget)

1. 框架代码 用 PyCharm 新建一个名为 SimplePaintApp 的项目,然后新建一个名为 simple_paint_app.py 的 Python 源文件, 在代码编辑器中,输入以下框架代码 1 from kivy.app import App 2 from kivy.uix.widget import Widget 3 4 5 class MyPaintWidget(Widget): 6 pass 7 8 9 class MyPaintApp(App): 10 def buil

C++ Gui Qt4编程学习之路(1)——Qt环境搭建

前言 因为公司需要做一个关于linux下qt的开发,加上直接接触过一些qt,便开始临阵磨枪了. 之前有用qt写过一个2048的游戏,大概3.4月份的时候,那会2048正火,想想自己在电脑上也做了一个~便默默的写了一个,界面有些丑陋,却五脏俱全~下次把思路和一些代码再归纳归纳,再写到博客里来. 虽然写过一点小东西,但基础还是很单薄,所以为了让基础更加巩固一些,便开始阅读C++ Gui Qt4编程这本书,这本书的确挺不错的. Qt环境搭建 首先要搭建Qt的环境,网上有很多版本供下载的,我便下载最新的

C++ GUI Qt4编程(01)-1.1Hello Qt

1. 根据C++ GUI Qt4编程(第二版)整理2. 系统:centos7:  Qt版本:5.5.13. 程序:hello.cpp #include <QApplication> #include <QLabel> int main(int argc, char *argv[]) { QApplication app(argc, argv); QLabel *label = new QLabel("Hello, Qt!"); label->show();

C++ GUI Qt4编程(07)-3.1menu

1. C++ GUI Qt4编程第三章,添加menu菜单. 2. mainwindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> class QMenu; class QAction; class MainWindow : public QMainWindow { Q_OBJECT public: MainWindow(); private: /*菜单*/ QMenu *fileMenu; QMenu

使用程序创建自定义Web部件Web Part

使用程序创建自定义Web部件Web Part 使用VS2010你可以通过程序创建自定义Web部件. 1. 以管理员身份打开VS2010.新建项目----空白SharePoint项目.命名MyFirstWebPart,点击确定. 2. 部署为场解决方案. 3. 右击项目添加新项目---Web Part.命名MyFirstWebPart. 4. 查看Web part代码文件,添加如下代码: 5. 点击F6查看能否成功生成项目. 6. 成功后设置断点,F5调试. 7. 调试完毕后,部署. 8. 在站点

自定义窗口部件--Custom widget

通过继承的手段,子类原有的窗口部件 (1)改进法(promotion):新建一个项目,在UI界面拖QSpinBox部件到窗体中,右键点击部件.在弹出菜单中,选择“提升为”.(把下面两个文件加到项目中) #ifndef HEXSPINBOX_H #define HEXSPINBOX_H #include <QSpinBox> class QRegExpValidator; class HexSpinBox:public QSpinBox { Q_OBJECT public: HexSpinBox