地址的丰裕、浏览、编辑、查找、输出文件等,地址的充分、浏览、编辑、查找、输出文件等

 
落成一个粗略的地址薄,成效包蕴:地址的拉长、浏览、编辑、查找、输出文件等。

 
完毕一个简单易行的地点薄,作用包罗:地址的充分、浏览、编辑、查找、输出文件等。

1  界面和因素

  整个地址薄界面,为 AddressBook 类。其中的 Name、Address
以及七个编辑栏,与 AddressBook 是 “包括” 关系 (has-a),故可将它们注解为 AddressBook
的分子数量。

    图片 1

1) QLabel 

    Name 和 Address 只 显示文本,可用 QLabel 落成,Qt 中其描述为 ”QLabel is used for displaying text or an image. No
user interaction functionality is provided“

2) QLineEdit 

    单行编辑框,可用 QLineEdit 完结,其描述为 ”The QLineEdit widget is a one-line text editor“

3) QTextEdit

    多行编辑框,可用 QTextEdit 完结,其叙述为 ”The QTextEdit class provides a widget that is
used to edit and display both plain and
rich text“

 

1  界面和要素

  整个地址薄界面,为 AddressBook 类。其中的 Name、Address
以及八个编辑栏,与 AddressBook 是 “包蕴” 关系 (has-a),故可将它们声明为 AddressBook
的成员数量。

   
图片 2

1) QLabel 

    Name 和 Address 只 显示文本,可用 QLabel 达成,Qt 中其讲述为 ”QLabel is used for displaying text or an image. No
user interaction functionality is provided“

2) QLineEdit 

    单行编辑框,可用 QLineEdit 完结,其描述为 ”The QLineEdit widget is a one-line text editor“

3) QTextEdit

    多行编辑框,可用 QTextEdit 完成,其描述为 ”The QTextEdit class provides a widget that is
used to edit and display both plain and
rich text“

 

2  子类化 (Subclassing)

  地址薄 属于 自定义窗口部件 (custom widget),在 Qt
中并不曾对应的标准类。常用艺术是:子类化 Qt 中的标准类。

  其它,当一个窗口部件的职能,兼有多少个正规窗口部件的职能时,也常用该办法。子类化的优点如下:

  1)  只需重写基类中的虚函数,来促成所急需的效果,浮现了 “面向对象” 的
多态性

  2)  将 UI 界面封装在一个类中,隐藏了完结的底细,浮现了 “面向对象” 的
封装性

  3)  完结的子类可被多个程序或库调用,突显了统筹的 可复用 原则
(reusable)

 
因而,可以通过子类化 QWidget 来兑现地方薄类 AddressBook

2  子类化 (Subclassing)

  地址薄 属于 自定义窗口部件 (custom widget),在 Qt
中并没有相应的标准类。常用艺术是:子类化 Qt 中的标准类。

  别的,当一个窗口部件的法力,兼有四个正经窗口部件的机能时,也常用该形式。子类化的独到之处如下:

  1)  只需重写基类中的虚函数,来达成所须求的职能,突显了 “面向对象” 的
多态性

  2)  将 UI 界面封装在一个类中,隐藏了落成的底细,显示了 “面向对象” 的
封装性

  3)  完结的子类可被八个程序或库调用,突显了规划的 可复用 原则
(reusable)

 
因而,可以通过子类化 QWidget 来落到实处地点薄类 AddressBook

2.1  Q_OBJECT 宏

  #8 的 Q_OBJECT
宏时,可概括明了为,Qt 中允许此类应用 tr() 和 connect() 函数。

  #15 和 #16 处,申明了三个个人成员数量,QLineEdit 型 和 QTextEdit
型指针,分别代表地址薄中的 Name 和 Address 左侧的编辑框。

  那么,在析构函数 ~AddressBook()
中,是或不是索要 delete 那八个指针呢?

 1 #include <QWidget>  // addressbook.h 
 2 
 3 #include <QLineEdit>
 4 #include <QTextEdit>
 5 
 6 class AddressBook : public QWidget
 7 {
 8     Q_OBJECT
 9 
10 public:
11     AddressBook(QWidget *parent = nullptr);
12     ~AddressBook();
13 
14 private:
15     QLineEdit  *name_line_;
16     QTextEdit  *addr_text_;
17 };

2.1  Q_OBJECT 宏

  #8 的 Q_OBJECT
宏时,可粗略驾驭为,Qt 中允许此类应用 tr() 和 connect() 函数。

  #15 和 #16 处,声明了三个村办成员数量,QLineEdit 型 和 QTextEdit
型指针,分别表示地址薄中的 Name 和 Address 左边的编辑框。

  那么,在析构函数 ~AddressBook()
中,是否要求 delete 那五个指针呢?

 1 #include <QWidget>  // addressbook.h 
 2 
 3 #include <QLineEdit>
 4 #include <QTextEdit>
 5 
 6 class AddressBook : public QWidget
 7 {
 8     Q_OBJECT
 9 
10 public:
11     AddressBook(QWidget *parent = nullptr);
12     ~AddressBook();
13 
14 private:
15     QLineEdit  *name_line_;
16     QTextEdit  *addr_text_;
17 };

  2.2  所有权 (ownership)

  在 AddressBook 的构造函数中,明明 new 了 QLineEdit 和 QTextEdit
型指针,不过在析构函数中,并不曾 delete
相应的指针,难道没有内存走漏么?那要从 Qt 的内存管理说起。

  #11 构造函数宣称中,它有一个 QWidget* 类型的参数
parent,该参数会传给其基类的社团函数 (QWidget)。那样,当实例化一个
AddressBook 对象时,如果为其指定了一个父类,则该父类便具有了那几个子类的
”所有权“(ownership)。

 
当进行资源管理时,只须要销毁那么些父类,则它所怀有的装有子类,都会被机关删除,那是
Qt 中的一个重中之重概念 — “所有权”。

  Qt 中的描述为:“The constructor of AddressBook accepts a QWidget parameter.  By convention, we pass this
parameter to the base class’s
constructor.  This concept of ownership, where a parent can have
one or more children, is useful for grouping widgets.  For example,
if you delete a parent, all of its children
will be deleted as well.”

  具体 AddressBook 是哪些获得 name_line_ 和 addr_text_ 所有权的,会在 “
布局管理中
” 详细演讲。

 1 #include <QtWidgets/QLabel>
 2 #include <QtWidgets/QLineEdit>
 3 #include <QtWidgets/QTextEdit>
 4 #include <QtWidgets/QGridLayout>
 5 
 6 #include "addressbook.h"
 7 
 8 AddressBook::AddressBook(QWidget *parent)
 9     : QWidget(parent)
10 {
11     QLabel *name_label = new QLabel("Name:");
12     name_line = new QLineEdit;
13     QLabel *addr_label = new QLabel("Address:");
14     addr_text = new QTextEdit;
15 
16     ... ... ...
17 
22     setWindowTitle("Address Book");
23 }
24 
25 AddressBook::~AddressBook()
26 {
27 }

 

  2.2  所有权 (ownership)

  在 AddressBook 的构造函数中,明明 new 了 QLineEdit 和 QTextEdit
型指针,不过在析构函数中,并从未 delete
相应的指针,难道没有内存走漏么?那要从 Qt 的内存管理说起。

  #11 构造函数扬言中,它有一个 QWidget* 类型的参数
parent,该参数会传给其基类的布局函数 (QWidget)。那样,当实例化一个
AddressBook 对象时,假诺为其指定了一个父类,则该父类便享有了这么些子类的
”所有权“(ownership)。

 
当举办资源管理时,只须求销毁这一个父类,则它所具备的兼具子类,都会被自动删除,这是
Qt 中的一个关键概念 — “所有权”。

  Qt 中的描述为:“The constructor of AddressBook accepts a QWidget parameter.  By convention, we pass this
parameter to the base class’s
constructor.  This concept of ownership, where a parent can have
one or more children, is useful for grouping widgets.  For example,
if you delete a parent, all of its children
will be deleted as well.”

  具体 AddressBook 是什么样得到 name_line_ 和 addr_text_ 所有权的,会在 “
布局管理中
” 详细讲演。

 1 #include <QtWidgets/QLabel>
 2 #include <QtWidgets/QLineEdit>
 3 #include <QtWidgets/QTextEdit>
 4 #include <QtWidgets/QGridLayout>
 5 
 6 #include "addressbook.h"
 7 
 8 AddressBook::AddressBook(QWidget *parent)
 9     : QWidget(parent)
10 {
11     QLabel *name_label = new QLabel("Name:");
12     name_line = new QLineEdit;
13     QLabel *addr_label = new QLabel("Address:");
14     addr_text = new QTextEdit;
15 
16     ... ... ...
17 
22     setWindowTitle("Address Book");
23 }
24 
25 AddressBook::~AddressBook()
26 {
27 }

 

3  布局管理

  Qt 中有三种布局管理类,可以拍卖窗口部件的岗位摆放,分别是
QHBoxLayout、QVBoxLayout 和 QGridLayout

  其中 QGridLayout
可以透过点名窗口部件的行数和列数,来控制各种窗口部件的布局,如下所示:

    图片 3

  根据上面的行数和列号,在 AddressBook 的构造函数中,添加如下代码:

16     QGridLayout *layout = new QGridLayout;
17 
18     layout->addWidget(name_label, 0, 0);
19     layout->addWidget(name_line_, 0, 1);
20     layout->addWidget(addr_label, 1, 0, Qt::AlignTop);
21     layout->addWidget(addr_text_, 1, 1);
21     setLayout(layout);

   Qt 中 setLayout() 函数的原型为:

void QWidget::setLayout(QLayout *layout);

  具体描述为 “Sets the layout manager for this widget to layout.
The QWidget
will take ownership of layout.”

  通过 #21,可以将 AddressBook
的布局管理器设置为 layout, 同时
AddressBook 获得了 layout
的拥有权。

 

3  布局管理

  Qt 中有三种布局管理类,可以拍卖窗口部件的岗位布署,分别是
QHBoxLayout、QVBoxLayout 和 QGridLayout

  其中 QGridLayout
可以透过点名窗口部件的行数和列数,来决定各样窗口部件的布局,如下所示:

   
图片 4

  根据下面的行数和列号,在 AddressBook 的构造函数中,添加如下代码:

16     QGridLayout *layout = new QGridLayout;
17 
18     layout->addWidget(name_label, 0, 0);
19     layout->addWidget(name_line_, 0, 1);
20     layout->addWidget(addr_label, 1, 0, Qt::AlignTop);
21     layout->addWidget(addr_text_, 1, 1);
21     setLayout(layout);

   Qt 中 setLayout() 函数的原型为:

void QWidget::setLayout(QLayout *layout);

  具体描述为 “Sets the layout manager for this widget to layout.
The QWidget
will take ownership of layout.”

  通过 #21,可以将 AddressBook
的布局管理器设置为 layout, 同时
AddressBook 获得了 layout
的拥有权。

 

参考资料:

   Qt 5.9 | Qt Widgets | Part 1 –
Designning the User Interface

 

参考资料:

   Qt 5.9 | Qt Widgets | Part 1 –
Designning the User Interface