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 ...
随机推荐
- golang编译之vendor机制
Go 1.5引入了vendor 机制,但是需要手动设置环境变量 GO15VENDOREXPERIMENT= 1,Go编译器才能启用.从Go1.6起,,默认开启 vendor 目录查找,vendor 机 ...
- 小小知识点(二十二)显示屏与主机之间连接,出现无信号字样时,应检查是否正确选择集显和独显VGA接口
显示屏与主机之间连接,出现无信号字样时,应检查是否正确选择集显和独显VGA接口 通过VGA接口判断集成显卡和独立显卡.在台式机主机上,VGA接口竖着放置的说明是集成显卡,VGA接口横着放置的说明是独立 ...
- React Native 性能优化指南【全网最全,值得收藏】
2020 年谈 React Native,在日新月异的前端圈,可能算比较另类了.文章动笔之前我也犹豫过,但是想到写技术文章又不是赶时髦,啥新潮写啥,所以还是动笔写了这篇 React Native 性能 ...
- 【python小随笔】动态创建变量名
PS:有时候我们不知道列表组数里存放几个值,但是又要动态的遍历这些值并且动态的创建每一个对应的一个变量里: t = ['B0716PK6R2','B077X9J24C','B01N2SBH4J'] c ...
- iOS开发常见问题
1. 在 ViewController 中添加子视图时,导航栏遮挡添加的子视图 let bpView = BpView.init(frame: CGRect.init(x: , y: , width: ...
- Winform PPT切换图片效果
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- ECOS问题解决记录
1.finder自定义列 http://club.ec-os.net/doc/ecos/framework-ecos/advance/desktop/dev.html#id5 2.命令行工具 地址 h ...
- H5录音音频可视化-实时波形频谱绘制、频率直方图
这段时间给GitHub Recorder开源库添加了两个新的音频可视化功能,比以前单一的动态波形显示丰富了好多(下图后两行是不是比第一行看起来丰满些):趁热打铁写了一个音频可视化相关扩展测试代码,下面 ...
- dfs 序 欧拉序
推荐博客 :https://www.cnblogs.com/stxy-ferryman/p/7741970.html DFS序其实就是一棵树顺次访问的结点的顺序,例如下面这棵树 它的 dfs 序就是 ...
- 执行sql中的 函数,function
CREATE FUNCTION [dbo].[GetWeight] ( ,)--重量/体积重 ) ,) as begin --顺丰重量/体积重以0.5kg为单位向上取值(小数点后两位4舍5入) ,) ...