文档详情

Qt编程基本.ppt

发布:2017-04-01约1.5万字共40页下载文档
文本预览下载声明
4.1 中央窗口部件 QMainWindow的中央区域可以被任意种类的窗口部件所占用。下面给出的是对所有可能情形的概述。 使用一个标准的Qt窗口部件 使用一个自定义窗口部件 使用一个带布局管理器的普通QWidget 使用切分窗口(splitter) 使用多文档界面工作空间 4.2 子类化QTableWidget 类SpreadSheet派生自QTableWidget,如图4.1所示。QTableWidget是一组格子,可以非常有效地用来表达二维稀疏数组。它可以在规定的维数内显示用户滚动到的任一单元格。 当用户在一个空单元格内输入一些文本的时候,QTableWidget会自动创建一个用来存储这些文本的QTableWidgetItem。 QTableWidget派生自QTableView,它是模型/视图类之一。 4.3 载入和保存 现在,我们将使用一种自定义的二进制数格式来实现Spreadsheet文件的载入和保存。将使用QFile和QDataStream来完成这一工作,由它们共同提供与平台无关的二进制数输入/输出借口。 首先从一个Spreadsheet文件的输出开始: 4.4 实现Edit菜单 Spreadsheet应用程序中的Edit菜单如图4.4所示。 4.5 实现其他菜单 现在我们将要实现那些对Tools和Options菜单做出响应的槽。这些菜单项如图4.7所示。 4.6 子类化QTableWidgetItem Cell类派生自QTableWidgetItem类。这个类被设计用于和Spreadsheet一起工作,但是它对类QTableWidgetItem没有任何特殊依赖关系,所以在理论上讲,它也可以用于任意的QTableWidget类中。这里给出的是Cell类的头文件: * * 图4.1 类Spreadsheet和Cell的继承树 让我们一起来实现SpreadSheet,首先看他的头文件。 头文件是从Cell和SpreadsheetCompare类的前置声明开始的: #ifndef SPREADSHEET_H #define SPREADSHEET_H #include QTableWidget class Cell; class SpreadsheetCompare; 之所以把autoRecalculate()函数实现为内联函数,是因为无论自动重新计算的标识符生效与否,它都必须要有返回值。 class Spreadsheet : public QTableWidget { Q_OBJECT public: Spreadsheet(QWidget *parent = 0); bool autoRecalculate() const { return autoRecalc; } QString currentLocation() const; QString currentFormula() const; QTableWidgetSelectionRange selectedRange() const; void clear(); bool readFile(const QString fileName); bool writeFile(const QString fileName); void sort(const SpreadsheetCompare compare); Spreadsheet提供了许多实现Edit、Tools和Options菜单中的动作的槽,并且它也提供了一个modified()信号,用来告知用户可能已经发生的任何变化。 public slots: void cut(); void copy(); void paste(); void del(); void selectCurrentRow(); void selectCurrentColumn(); void recalculate(); void setAutoRecalculate(bool recalc); void findNext(const QString str, Qt::CaseSensitivity cs); void findPrevious(const QString str, Qt::CaseSensitivity cs); signals: void modified(); 还定义了一个有Spreadsheet内部使用的私有槽: private slots: void somethingChanged(); 在这个类的私有段中,声明了3
显示全部
相似文档