qt5实现简单布局
layout.h
#ifndef LAYOUT_H
#define LAYOUT_H #include <QtWidgets/QDialog>
#include <QLabel>
#include <QTextEdit>
#include <QLineEdit>
#include <QComboBox>
#include <QHBoxLayout>
#include <QVBoxLayout>
#include <QGridLayout>
#include <QPushButton>
#include "ui_layout.h" class layout : public QDialog
{
Q_OBJECT public:
layout(QWidget *parent = 0);
~layout(); private:
Ui::layoutClass ui;
QLabel *labelUser;
QLabel *labelName;
QLabel *labelSex;
QLabel *labelDepartment;
QLabel *labelAge;
QLabel *labelOther; QLineEdit *lineUser;
QLineEdit *lineName;
QLineEdit *lineAge; QComboBox *boxSex;
QTextEdit *textDescription;
QTextEdit *textIntroduction; QLabel *labelHead;
QLabel *labelIcon;
QLabel *labelDescription;
QPushButton *buttonOk;
QPushButton *buttonUpdateicon;
QPushButton *buttonCancel; QGridLayout *leftLayout;
QHBoxLayout *toprightLayout;
QVBoxLayout *rightLayout;
QHBoxLayout *buttonLayout;
private slots:
void on_buttonUpdateicon_clicked();
}; #endif // LAYOUT_H
layout.cpp
#include "layout.h"
#include <QPixmap>
#include <QMessageBox> layout::layout(QWidget *parent)
: QDialog(parent)
{
ui.setupUi(this);
labelUser = new QLabel(QStringLiteral("用户名:"));
lineUser = new QLineEdit; labelName = new QLabel(QStringLiteral("姓名:"));
lineName = new QLineEdit; labelSex = new QLabel(QStringLiteral("性别:"));
boxSex = new QComboBox;
boxSex->addItem(QStringLiteral("男"));
boxSex->addItem(QStringLiteral("女")); labelDepartment = new QLabel(QStringLiteral("部门:"));
textDescription = new QTextEdit; labelAge = new QLabel(QStringLiteral("年龄:"));
lineAge = new QLineEdit; labelOther = new QLabel(QStringLiteral("备注:"));
labelOther->setFrameStyle(QFrame::Panel | QFrame::Sunken); leftLayout = new QGridLayout; leftLayout->addWidget(labelUser,0, 0);
leftLayout->addWidget(lineUser, 0, 1); leftLayout->addWidget(labelName, 1, 0);
leftLayout->addWidget(lineName, 1, 1); leftLayout->addWidget(labelSex, 2, 0);
leftLayout->addWidget(boxSex, 2, 1); leftLayout->addWidget(labelDepartment, 3, 0);
leftLayout->addWidget(textDescription, 3, 1); leftLayout->addWidget(labelAge, 4, 0);
leftLayout->addWidget(lineAge, 4, 1); leftLayout->addWidget(labelOther, 5, 0, 1, 2); leftLayout->setColumnStretch(0, 1);
leftLayout->setColumnStretch(1, 3); labelHead = new QLabel(QStringLiteral("头像:"));
labelIcon = new QLabel;
QPixmap icon("hi.jpg");
labelIcon->setPixmap(icon);
labelIcon->resize(icon.width(), icon.height());
buttonUpdateicon = new QPushButton(QStringLiteral("更新")); toprightLayout = new QHBoxLayout;
toprightLayout->addWidget(labelHead);
toprightLayout->addWidget(labelIcon);
toprightLayout->addWidget(buttonUpdateicon); labelDescription = new QLabel(QStringLiteral("个人说明:"));
textIntroduction = new QTextEdit; rightLayout = new QVBoxLayout;
rightLayout->addLayout(toprightLayout);
rightLayout->addWidget(labelDescription);
rightLayout->addWidget(textIntroduction); buttonOk = new QPushButton(QStringLiteral("确定"));
buttonCancel = new QPushButton(QStringLiteral("取消")); buttonLayout = new QHBoxLayout;
buttonLayout->addStretch();
buttonLayout->addWidget(buttonOk);
buttonLayout->addWidget(buttonCancel); QGridLayout *mainLayout = new QGridLayout(this);
mainLayout->setMargin(15);
mainLayout->setSpacing(10);
mainLayout->addLayout(leftLayout, 0, 0);
mainLayout->addLayout(rightLayout, 0, 1);
mainLayout->addLayout(buttonLayout, 1, 0, 1, 2);
mainLayout->setSizeConstraint(QLayout::SetFixedSize); connect(buttonOk, SIGNAL(clicked()), qApp, SLOT(quit()));
connect(buttonCancel, SIGNAL(clicked()), qApp, SLOT(quit()));
connect(buttonUpdateicon, SIGNAL(clicked()), this, SLOT(on_buttonUpdateicon_clicked()));
} layout::~layout()
{ } void layout::on_buttonUpdateicon_clicked()
{
QMessageBox::information(this, QStringLiteral("嗨"), QStringLiteral("测试"));
}
qt5实现简单布局的更多相关文章
- WPF简单布局 浅尝辄止
WPF的窗口只能包含一个元素,为了在WPF窗口中放置多个元素并创建更实用的用户界面,需要在窗口上放置一个容器,然后在容器中放置其它元素. 注意:造成这一限制的原因是window类继承自 ...
- table 和 div 简单布局
table 简单布局 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:// ...
- 【JQuery Easy UI】后台管理系统的简单布局分享
重要说明:本博已迁移到 石佳劼的博客.有疑问请到 文章新地址 留言..! 近期做的一个简单的后台管理系统,当中用到了JQuery Easy UI框架,对于撸主这样的把控件能摆整齐就谢天谢地的码农来说, ...
- Masonry 布局 cell 高度适应的一种方案(实现类似朋友圈简单布局)
来源:伯乐在线 - 夏天然后 链接:http://ios.jobbole.com/89298/ 点击 → 申请加入伯乐在线专栏作者 前言: 我模仿的是微博的布局所以也就没有 评论动态刷新cell. 1 ...
- 利用CSS简单布局的不同组合类型
关于CSS布局页面的简单组合方式: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " ...
- CSS学习之首页简单布局
作为一个PHPer,在前端方面javascript.jquery这些的日常工作还搞的定.可对于div+css这些东西可就头疼了,所以现在开始学习CSS 跟着燕十八的教程开始从最基础学起,首先练习一个简 ...
- 网页简单布局之结构与表现原则(HTML/CSS)
结构 样式 行为真正的分离 前端初级人员会在页面上单纯的用各个div把相关内容独立开: 前端中级人员明白相关属性的设置会给元素带来什么改变,从而减少div的书写: 前端高级人员会以及其简单的和稳定的方 ...
- 【ExtJS】简单布局应用
前几天学习了ExtJS的各种布局后,以下就是各种实践,从简单做起. 实现目的: 一个提交表单页,一个显示信息页,表单为个人基本资料输入,显示页为基本信息展示. 内容: 总体布局为border布局,展示 ...
- DIV+CSS 样式简单布局Tab 切换
<html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> &l ...
随机推荐
- 从桌面到 Web - 二十几天学 ASP.NETCore 1
这么多年一直从事桌面开发,一直没有时间好好学学 web 开发.感觉自己就像从石器时代走来的古代类人猿.由于工作的调整,现在终于有时间学习一下 Web 开发.出于对技术和框架的熟悉和继承,决定还是学习 ...
- css控制div等比高度
在移动端开发中,在banner轮播图未加载出来之前,banner层是不占文档流高度的,当从服务器获取完banner数据,展示的时候,banner层因为有了内容 所以会撑开,导致banner层下面的内容 ...
- SharePoint REST 上传文件请求403错误
最近,需要在SharePoint上传文件到文档库,但是,上传的过程报错了. 错误代码 { "error": { "code": "-213057525 ...
- docker使用阿里云加速器
1 登录阿里云获得地址 登录https://cr.console.aliyun.com ,点击"镜像加速器",会给我一个地址. 2 写入/etc/docker/daemon.jso ...
- python的input()函数
# input()函数 # 作用: 获取用户的输入,返回输入的内容 ,也可以用于暂停程序的运行 # 影响: 调用此函数,程序会立即暂停,等待用户输入 # 注意:input()的返回值是一个字符串 # ...
- cogs 247. 售票系统 线段树
247. 售票系统 ★★☆ 输入文件:railway.in 输出文件:railway.out 简单对比时间限制:1 s 内存限制:128 MB [问题描述] 某次列车途经C个城市,城市 ...
- SPFA判负环模板
void DFS_SPFA(int u){ if(flag) return; vis[u]=true; for(int i=head[u];i;i=edges[i].nxt){ if(fl ...
- IDEA不编译空文件夹
今天做项目的时候发现idea编译工程不会编译空文件夹,在resources下新建了个存储文件的空文件夹,编译后target里竟然没有,一直报空指针. 随便丢一个文件进去就行了,放一个demo.txt的 ...
- k8s~为服务添加ingress的实现
为服务添加ingress的实现 1 当我们为指定的项目添加ingress支持之后,它会在“负载均衡”标签页出现,并显示出你的域名解析到的服务. 2 我们的ingress是支持https的,所以需要为你 ...
- 求树上任意一点所能到达的最远距离 - 树上dp
A school bought the first computer some time ago(so this computer's id is 1). During the recent year ...