QT学习第2天
#ifndef __CALCULATORDIALOG_H
#define __CALCULATORDIALOG_H
#include <QDialog>
#include <QLabel>
#include <QPushButton>
#include <QLineEdit> //输入文本的组件
#include <QDoubleValidator> //双精度的校验器
#include <QHBoxLayout> //水平布局器
class CalculatorDialog:public QDialog{
//MOC编译器,把不符合标准的语法变成标准的C++语法
Q_OBJECT
public:
CalculatorDialog(void);
private:
QLineEdit *m_editX; //左操作数
QLineEdit *m_editY; //右操作数
QPushButton *m_btnCalc; //等号按钮
QLineEdit *m_editZ; //保存结果,只读属性
private slots:
void enableCalcButton(void); //使能等号按钮
void calcClicked(void); //计算结果
};
#endif // __CALCULATORDIALOG_H
CalculatorDialog.h
#include "CalculatorDialog.h"
//构造函数中初始化UI界面
CalculatorDialog::CalculatorDialog(void){
//设置对话框的标题 (继承过来的成员函数)
setWindowTitle("加法计算器");
m_editX = new QLineEdit(this);
//设置文本右对齐
m_editX->setAlignment(Qt::AlignRight);
//设置验证器,只能输入数字
m_editX->setValidator(new QDoubleValidator(this));
m_editY = new QLineEdit(this);
//设置文本右对齐
m_editY->setAlignment(Qt::AlignRight);
//设置验证器,只能输入数字
m_editY->setValidator(new QDoubleValidator(this));
m_editZ = new QLineEdit(this);
m_editZ->setAlignment(Qt::AlignRight); //设置右对齐
m_editZ->setReadOnly(true); //设置只读
m_btnCalc = new QPushButton("=",this);
m_btnCalc->setEnabled(false);//设置禁用
//使用水平布局器,自动调整每个组件的大小和位置
QHBoxLayout *layout = new QHBoxLayout;
layout->addWidget(m_editX);
layout->addWidget(new QLabel("+"));
layout->addWidget(m_editY);
layout->addWidget(m_btnCalc);
layout->addWidget(m_editZ);
//设置布局器
setLayout(layout);
//编辑框内容改变时发出信号,尝试使能等号按钮
connect(m_editX,SIGNAL(textChanged(const QString &)),this,SLOT(enableCalcButton()));
connect(m_editY,SIGNAL(textChanged(const QString &)),this,SLOT(enableCalcButton()));
//点击等号按钮,计算结果并显示
connect(m_btnCalc,SIGNAL(clicked()),this,SLOT(calcClicked()));
}
void CalculatorDialog::enableCalcButton(void){
bool bXOk;
bool bYOk;
//获取左右操作数的数据(QString),转换成浮点数
m_editX->text().toDouble(&bXOk);
m_editY->text().toDouble(&bYOk);
//如果左右操作数都是有效的数字,使能等号按钮
if(bXOk && bYOk){
m_btnCalc->setEnabled(true);
}
else{
m_btnCalc->setEnabled(false);
}
}
void CalculatorDialog::calcClicked(void){
//计算结果
double res = m_editX->text().toDouble() + m_editY->text().toDouble();
//将结果转换成字符串
QString str = QString::number(res,);
//显示结果到m_editZ
m_editZ->setText(str);
}
CalculatorDialog.cpp
#include "CalculatorDialog.h"
#include <QApplication>
int main(int argc, char **argv){
QApplication app(argc,argv);
CalculatorDialog dialog;
dialog.show();
return app.exec();
}
Calculator.cpp
QT学习第2天的更多相关文章
- QT学习第1天
QT学习第一天 坚持住!! 一 Qt概述 1.Qt发展历史 (1)1991年诞生(Haavard Nord/Eirik Chambe-Eng), (2)1994年创立Troll Tech(奇趣科技) ...
- 【转载】分享一些Qt学习资源,欢迎下载
资源来源:http://bbs.csdn.net/topics/390358737 经过我一翻整理,把一些我收集到的Qt学习资源分享给大家,主要适合新手,老鸟可以直接忽略我.要说明一下,很多资源都是在 ...
- QT学习之路--创建一个对话框
Q_OBJECT:这是一个宏,凡是定义信号槽的类都必须声明这个宏. 函数tr()全名是QObject::tr(),被他处理过的字符串可以使用工具提取出来翻译成其他语言,也就是做国际化使用. 对于QT学 ...
- 转载: Qt 学习之路 2归档
Qt 学习之路 2归档 http://www.devbean.net/2012/08/qt-study-road-2-catelog/
- Qt 学习资料
Qter开源社区http://www.qter.org/ [Qt教程], 作者yafeilinux [视频] QT学习之路:从入门到精通 <C++ Qt 编程视频教程>
- qt学习笔记(五) QGraphicsPixmapItem与QGraphicsScene的编程实例 图标拖动渐变效果
应大家的要求,还是把完整的project文件贴出来,大家省点事:http://www.kuaipan.cn/file/id_48923272389086450.htm 先看看执行效果,我用的群创7寸屏 ...
- Qt学习博客推荐
附录C Qt资源 C.1 Qt 官方资源 全 球各大公司以及独立开发人员每天都在加入 Qt 的开发社区.他们已经认识到了Qt 的架构本身便可加快应用程序开发进度.这些开发人员,无论是想开发单平台软件. ...
- qt学习教程1.qt开发环境搭建
qt学习教程1.qt开发环境搭建 首先下载qt 下载地址:http://download.qt.io/archive/qt/ 此教程使用的版本为5.1.1 下载好后,打开安装包,然后点下一步 选择一个 ...
- QT学习教程
原地址:http://www.devbean.NET/2012/08/qt-study-road-2-catelog/ 网上看到的不错的教程 本教程以qt5为主,部分地方会涉及qt4.据说非常适合qt ...
- Qt学习之路
Qt学习之路_14(简易音乐播放器) Qt学习之路_13(简易俄罗斯方块) Qt学习之路_12(简易数据管理系统) Qt学习之路_11(简易多文档编辑器) Qt学习之路_10(Qt ...
随机推荐
- javaweb学习总结(十一)——使用Cookie进行会话管理
一.会话的概念 会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. 有状态会话:一个同学来过教室,下次再来教室,我们会知道这个同学曾 ...
- 转【实战体验几种MySQLCluster方案】
实战体验几种MySQLCluster方案 1.背景 MySQL的cluster方案有很多官方和第三方的选择,选择多就是一种烦恼,因此,我们考虑MySQL数据库满足下三点需求,考察市面上可行的解决方案: ...
- 静态代码审查工具FxCop插件开发(c#)
FxCop是一款微软官方提供的.net平台代码审查工具,目的是检查我们编写的程序集的代码是否符合规范.FxCop默认提供的是微软默认的审查规则,而且该规则符合<Framework DesignG ...
- ENVI软件操作【数据显示操作——Overlay菜单操作】
一.注记层(Annotation) 注记层是ENVI的一个数据类型,它的后缀名是.ann.往往作为栅格数据层,矢量数据层.三维场景会绘图图表的附加数据叠加在上面,还可以作为镶嵌图像时候的裁剪线.注记数 ...
- Ocrad.js – JS 实现 OCR 光学字符识别
Ocrad.js 相当于是 Ocrad 项目的纯 JavaScript 版本,使用 Emscripten 自动转换.这是一个简单的 OCR (光学字符识别)程序,可以扫描图像中的文字回文本. 不像 G ...
- HTML5 Maker – 在线轻松制作 HTML5 动画效果
HTML5 Maker 是一个在线动画制作工具,帮助你使用 HTML,CSS 和 JavaScript 创建动态,互动的内容.它非常容易使用,同时可以帮你实现非常好的效果.它可以制作跨浏览器的动画内容 ...
- [应用][js+css3]3D盒子导航[PC端]
CSS3构建的3D盒子之导航应用 1.在用css3构建的盒子表面,放上iframe,来加载导航页面. 2.鼠标左键按下移动可旋转盒子,寻找想要的网址. 3.左键单机盒子表面,将全屏现实所点盒子表面的网 ...
- Web安全之CSRF攻击
CSRF是什么? CSRF(Cross Site Request Forgery),中文是跨站点请求伪造.CSRF攻击者在用户已经登录目标网站之后,诱使用户访问一个攻击页面,利用目标网站对用户的信任, ...
- UITableViewDataSource协议
前言: 在iOS开发中,表视图UITableView 是我们做UI界面设计时的重要视图. 那么,使用表视图UITableView 需要遵守哪些协议呢? <UITableViewDataSourc ...
- javascript 中 !~ 什么意思
快过年放假了,也终于闲下来了.每天游览于各种技术文章中,这种状态好极了.下午看篇关于js的文章,其中有如下这么一段引起了我的注意. (function () { var names = []; ret ...