- 1、本文档共41页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
CGUIQt4编程(第二版)Chapter4
Chapter 4 实现应用程序的功能 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类的头文件: #ifndef CELL_H #define CELL_H #include QTableWidgetItem class Cell : public QTableWidgetItem { public: Cell(); QTableWidgetItem *clone() const; void setData(int role, const QVariant value); QVariant data(int role) const; void setFormula(const QString formula); QString formula() const; void setDirty(); * * 图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 selectCur
文档评论(0)