博客
关于我
MFC在CDockablePane中添加对话框
阅读量:237 次
发布时间:2019-02-28

本文共 738 字,大约阅读时间需要 2 分钟。

1.创建MFC项目,选择使用菜单栏和工具栏,这时会发现CMainFrame基类是CFraneWndEx

 

2.建好项目打开类向导,添加MFC类,基类是今天的主角CDockablePane

3.在CMainFrame类的OnCreate中添加如下代码

 

if (!dock.Create(_T("窗口"), this, CRect(0, 0, 500, 500), TRUE, 1000,WS_CHILD | WS_VISIBLE | WS_CLIPSIBLINGS | WS_CLIPCHILDREN | CBRS_ALIGN_BOTTOM | CBRS_FLOAT_MULTI))	{		return FALSE;	}	dock.EnableDocking(CBRS_ALIGN_ANY);	DockPane(&dock);//

其中dock是类CDock的成员变量,运行程序出现如下窗口

4.添加对话框

这时我们已经添加出了悬浮窗口,接下来的任务就是将对话框与悬浮窗口相关联。

(1)在资源视图中添加新的对话框,注意,对话框必须有Child属性,Border设置为None,将对话框生成类,我们这里叫做CDUIHUA。

(2)在对话框中 添加几个按钮,在CDOCK类中添加OnCreate函数,在其中添加一下代码将对话框和窗口相关联,其中duihua是DUIHUA类的成员函数

运行图如下

发现一个问题就是在拉大窗口会出现上图的情况,是因为CDock重绘出现错误。

有两种解决方法

第一种就是CDock中添加函数OnPain,并在函数中添加如下代码,使背景发生重绘为白色。

 第二种就是在CDock中添加函数OnSize,,并在函数中添加如下代码,这样使整个窗口被对话框所覆盖/

转载地址:http://qtip.baihongyu.com/

你可能感兴趣的文章
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
MySQL —— 视图
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
MySQL 中的外键检查设置:SET FOREIGN_KEY_CHECKS = 1
查看>>
Mysql 中的日期时间字符串查询
查看>>
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>