网络编程 
首页 > 网络编程 > 浏览文章

VS2012下QT creator登录对话框设计

(编辑:jimmy 日期: 2024/11/18 浏览:3 次 )

最近看《Qt教程及软件》学习QT,这本书的编程是在Qt creator上进行的,本人更倾向于在VS2012上进行开发,故根据自己实验中的经验,笔记一下在VS2012进行Qt编程的一些问题及解决方法,本人用的是Qt5.3版本。

首先,新建一个工程

VS2012下QT creator登录对话框设计

选择Qt Application,填写工程名

VS2012下QT creator登录对话框设计

一直Next,Base class选择QWidget,点击Finish创建

VS2012下QT creator登录对话框设计

此时项目未添加对应的include文件,有许多地方显示“can not open source file……”。选择菜单栏PROJECT->User Properties… 进入添加头文件设置页面

VS2012下QT creator登录对话框设计

点击“Additional Include Directories”进行编辑,添加你QT安装目录下的以下文件夹

VS2012下QT creator登录对话框设计

新建一个对话类,右键项目名,添加新类

VS2012下QT creator登录对话框设计

选择Qt5 Classes,双击 Qt5GuiClasses

VS2012下QT creator登录对话框设计

Base Class填QDialog,点击Finish完成创建

VS2012下QT creator登录对话框设计

然后就进行ui布置了,在logindlg.ui中设计下面的界面:行输入框为Line Edit。其中用户名后面的输入框在属性中设置其object Name为usrLineEdit,密码后面的输入框为pwdLineEdit,登录按钮为loginBtn,退出按钮为exitBtn。设置完如下图:

VS2012下QT creator登录对话框设计

点击选择”编辑信号/槽“VS2012下QT creator登录对话框设计,按住退出按钮拖一下VS2012下QT creator登录对话框设计,弹出对话框,信号选择clicked(),槽选择close(),实现点击退出功能。若没有close(),选择“显示从QWidget继承的信号和槽”。

VS2012下QT creator登录对话框设计

按照上面方法设置登录按钮的信号与槽,其槽函数要自己写,所以槽选择那里点击编辑,新增一个slot1(),改名为on_loginBtn_clicked()。点击确定。保存Qt 设计师并关闭。

VS2012下QT creator登录对话框设计

回到VS2012,修改main.cpp:

#include "user.h"
#include <QtWidgets/QApplication>
#include "logindlg.h"

int main(int argc, char *argv[])
{
  QApplication a(argc, argv);
  User w;
  loginDlg login;
  if(login.exec() == QDialog::Accepted)
  {
  w.show();
  return a.exec();
  }
  else return 0;
}

接着修改loginDlg.cpp,先在loginDLg.h中添加之前的槽函数的声明。

#ifndef LOGINDLG_H
#define LOGINDLG_H

#include <QDialog>
#include "ui_logindlg.h"

class loginDlg : public QDialog
{
  Q_OBJECT

public:
  loginDlg(QWidget *parent = 0);
  ~loginDlg();

private:
  Ui::loginDlg *ui; //这里定义ui为指向类的指针
private slots:
  void on_loginBtn_clicked(); //槽函数声明
};

#endif // LOGINDLG_H

最后在loginDlg.cpp中定义槽函数,实现正确输入帐号密码则进入主窗口,否则报错。

void loginDlg::on_loginBtn_clicked()
{
  if(ui->usrLineEdit->text() == tr("caddress")&&ui->pwdLineEdit->text()==tr("123456"))
    accept();
  else{
    QMessageBox::warning(this,tr("Warning"),tr("user name or password error!"),QMessageBox::Yes):
  }
}

至此,程序还有许多错误,有大部分头文件未找到,按照上面的方法继续添加相应文件夹:

VS2012下QT creator登录对话框设计 

添加完后点击编译,则相应的头文件就找到了。

loginDlg.cpp完整代码:

#include "logindlg.h"
#include <qmessagebox> //添加该头文件才能使用QMessageBox

loginDlg::loginDlg(QWidget *parent)
 : QDialog(parent)
{
 (*ui).setupUi(this); //这里ui需要为类类型,所以得解指针
}

loginDlg::~loginDlg()
{

}

void loginDlg::on_loginBtn_clicked()
{
 if(ui->usrLineEdit->text() == tr("caddress")&&ui->pwdLineEdit->text()==tr("123456")) //这里需要指针,直接使用ui
  accept();
 else{
  QMessageBox::warning(this,tr("Warning"),tr("user name or password error!"),QMessageBox::Yes);
 }
}

点击编译就能实现功能

VS2012下QT creator登录对话框设计

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

上一篇:详解在Windows下如何使用AspNetCore Api 和consul
下一篇:VS2012实现简单登录界面
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap