博客
关于我
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 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
MYSQL 幻读(Phantom Problem)不可重复读
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>