博客
关于我
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锁机制
查看>>
mysql锁机制,主从复制
查看>>
Mysql锁机制,行锁表锁
查看>>
Mysql锁(2):表级锁
查看>>
Mysql错误2003 -Can't connect toMySQL server on 'localhost'(10061)解决办法
查看>>
MySQL错误提示mysql Statement violates GTID consistency
查看>>
mysql长事务
查看>>
MySQL集群解决方案(4):负载均衡
查看>>
MySQL面试宝典
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
Mysql面试题精选
查看>>
MySQL面试题集锦
查看>>
mysql面试题,存储引擎InnoDB和MyISAM
查看>>
mysql面试题:为什么MySQL单表不能超过2000W条数据?
查看>>
mysql面试题:创建索引时会不会锁表?
查看>>
mysql面试题:高度为3的B+树可以存放多少数据?
查看>>
mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
查看>>
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>