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 ...
随机推荐
- nodejs-websocket+ssl证书
1.nodejs配置微信小程序本地服务器(二):利用ws模块创建基于ssl证书的WebSocket服务器:https://segmentfault.com/a/1190000013956534 2.n ...
- Windows To Go 企业版2019 LTSC 开发环境部署
Windows To Go 是一项非常实用的功能,与传统方式安装Windows 10相比更具有灵活性,会根据每次接入的硬件型号保留不同版本驱动. 由于博主是一名全栈程序员(截至发稿处于菜鸟级别),对灵 ...
- Oracle 数据泵expdq,impdq
使用数据泵技术实现逻辑备份 数据泵概述 数据泵(DATA PUMP)是一种在数据库之间.数据库与操作系统之间,高速传输数据的技术(10g推出). 逻辑备份概述 逻辑备份是对数据库对象(如用户.表.存储 ...
- 1068 万绿丛中一点红 (20分)C语言
对于计算机而言,颜色不过是像素点对应的一个 24 位的数值.现给定一幅分辨率为 M×N 的画,要求你找出万绿丛中的一点红,即有独一无二颜色的那个像素点,并且该点的颜色与其周围 8 个相邻像素的颜色差充 ...
- 10_时间戳timeStamp 和 时间 time 转换, 根据时间节点倒计时
1: 时间戳 timeStamp 获取的几种方法及其优劣, 第一种只能精确到秒, 故不推荐使用, 最最常用的也是最官方的是第三种, 通过原型方法进行调用获取精确到毫秒数 : var timestamp ...
- web前端常用知识点
1.常见的块级元素 内联元素 div -最常用的块级元素 dl - 和dt-dd 搭配使用的块级元素 form - 交互表单 h1 -h6- 大标题 hr ...
- 28.python操作excel表格(xlrd/xlwt)
python读excel——xlrd 这个过程有几个比较麻烦的问题,比如读取日期.读合并单元格内容.下面先看看基本的操作: 首先读一个excel文件,有两个sheet,测试用第二个sheet,shee ...
- C#.Net ComboBox控件设置DropDownList之后背景颜色问题,以及发现的微软的一个BUG
先说背景颜色问题怎么处理. C#.Net WinForm中如果设置ComboBox的DropDownStyle为DropDownList,控件背景色会变成灰色,并且这个时候ComboBox控件的Bac ...
- Broken Necklace 坏掉的项链 USACO 模拟(易错)
1004: 1.1.4Broken Necklace 坏掉的项链 时间限制: 1 Sec 内存限制: 128 MB提交: 11 解决: 9[提交] [状态] [讨论版] [命题人:外部导入] 题目 ...
- C#反射与特性(八):反射操作的示例大全
目录 1,InvokeMember 1.1 InvokeMember 参数 1.2 实践使用 InvokeMember 和成员的重载方法 微信平台,此文仅授权<NCC 开源社区>订阅号发布 ...