博客
关于我
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 基础模块的面试题总结
查看>>
MySQL 备份 Xtrabackup
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>