MFC使用EasySize类自动调整对话框上控件的布局

easysize.h自行在CSDN下载频道进行下载。

EasySize.h的使用方法:

步骤一:把easysize.h拷贝到CMyDlg项目文件夹中,同时在CMyDlg的.h文件和.cpp文件中加入#include "easysize.h";
步骤二:在CMyDlg类的h文件中,加入DECLARE_EASYSIZE,注意结尾处不要加“;”。
 
class CMyDlg : public CDialog
{
       DECLARE_EASYSIZE
// Construction

}
步骤三:在CMyDlg类的OnInitDialog()函数的结尾处加入INIT_EASYSIZE, 注意此处结尾处要加“;”。
BOOL CMyDlg::OnInitDialog()
{     …
// TODO: Add extra initialization here
       INIT_EASYSIZE;
       return TRUE;  // return TRUE  unless you set the focus to a control
}
 
步骤四:增加WM_SIZE消息响应函数OnSize(),在函数中加入UPDATE_EASYSIZE,注意此处结尾处要加“;”。
void CMyDlg::OnSize(UINT nType, int cx, int cy)
{
       CDialog::OnSize(nType, cx, cy);
       // TODO: Add your message handler code here
       UPDATE_EASYSIZE;
}
步骤五:在CMyDlg的cpp文件中添加EASYSIZE 的宏映射
BEGIN_EASYSIZE_MAP(CMyDlg)
EASYSIZE(control,left,top,right,bottom,options)
END_EASYSIZE_MAP

 

其中:

 

EASYSIZE(control,left,top,right,bottom,options)

Control---控件的ID,需要设置的控件

left top right bottom---矩形框的位置,可以设置的参数:ES_BORDER、ES_KEEPSIZE、其他control的ID。

        ES_BORDER代表控件与边框的距离保持不变

        ES_KEEPSIZE代表控件的宽度和高度保持不变,left/right只能设置其中一个为ES_KEEPSIZE,top/bottom亦然。

Control  ID代表以另一个空间为参照

        具体注释如下,待设置控件记为ID1,参照控件记为ID2

        i left=ID2  ID1左边到ID2右边的距离保持不变(不管ID2如何变化)

        ii right=ID2 ID1右边到ID2左边的距离保持不变(不管ID2如何变化)

iii top=ID2  ID1上边到ID2下边的距离保持不变(不管ID2如何变化)

iv bottom=ID2 ID1下边到ID2上边的距离保持不变(不管ID2如何变化)

options---特别操作ES_HCENTER, ES_VCENTER and 0的结合。

0代表没有任何操作;

ES_HCENTER代表控件在left/right之间水平居中,此时left/right都不能设置成ES_KEEPSIZE,控件的宽度保持不变;

ES_VCENTER同理ES_HCENTER


注意: 布局风格的设置将很大程序影响控件在对话框上的布局,不同设置布局会有天壤之别!!!!


注意:如果没有添加EASYSIZE 的宏映射就开始编译的话,会出现链接错误!

如果您觉得这篇博文有用,请访问我的个人站:http://www.stubbornhuang.com,更多博文干货等着您。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HW140701

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值