- 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
您可能关注的文档
- 2013高三数学一轮复习课件7.2.ppt
- 2013高三数学一轮复习课件8.2.ppt
- 2013高三数学一轮复习课件7.4.ppt
- 2013高二化学课件:10.3.3《影响中和滴定准确性的因素分析》(沪科版高二第一学期).ppt
- 2013高三数学一轮复习课件8.1.ppt
- 2013高三数学一轮复习课件8.4.ppt
- 2013高三数学一轮复习课件9.1.ppt
- 2013高考物理鲁科版总复习课件:第一章2013高考导航.ppt
- 2013高三物理一轮复习课件:第八章 带电粒子在复合场中的运动.ppt
- 2013高三数学一轮复习课件7.5.ppt
- 第18讲 第17课 西晋的短暂统一和北方各族的内迁.docx
- 第15讲 第14课 沟通中外文明的“丝绸之路”.docx
- 第13课时 中东 欧洲西部.doc
- 第17讲 第16 课三国鼎立.docx
- 第17讲 第16课 三国鼎立 带解析.docx
- 2024_2025年新教材高中历史课时检测9近代西方的法律与教化含解析新人教版选择性必修1.doc
- 2024_2025学年高二数学下学期期末备考试卷文含解析.docx
- 山西版2024高考政治一轮复习第二单元生产劳动与经营第5课时企业与劳动者教案.docx
- 第16讲 第15课 两汉的科技和文化 带解析.docx
- 第13课 宋元时期的科技与中外交通.docx
文档评论(0)