分类: C/C++
2008-08-05 14:01:29
首先我们要先生成一个普通的SDI程序。启动Microsoft Visual C 6.0开发环境,进入主菜单中的File->New,在New对话框,选择Projects页,然后选择MFC AppWizard (exe),在Project name中输入SDI(请注意:这里的SDI是工程名,你也可以随便取个什么名字),然后单击OK按钮,在向导的第一页选择Single document(单文档)类型,然后单击Finish完成单文档程序的创建,你也可以不直接Finish,可以先Next做一些别的修改,然后完成。
由于不是对话框程序,这次我们不能直接在界面上拖入TangramMiniCtrl控件,只能动态创建TangramMiniCtrl控件,在这里我们有两个办法创建TangramMiniCtrl,一个办法当然是直接手工创建;另一个办法就是利用TangramMiniB2C组件创建,因为TangramMiniB2C有辅助创建TangramMiniCtrl的功能,当然要利用TangramMiniB2C组件创建TangramMiniCtrl控件,我们就必须先创建TangramMiniB2C组件。在这里我决定使用第二种办法,就是利用TangramMiniB2C组件创建TangramMiniCtrl控件,因为方法更加简单方便,编码更少。在TangramMini组件安装之后,所带的案例中,这两种创建方法都有相对应的例子,大家也可以自己查看。
为了编码方便,我们直接从安装包的案例源码中找到TangramMini_i.c与TangramMini_i.h两个文件复制到之前新建的SDI工程源码下。搞定之后,我们前期工作准备完毕,开始编码:
1、 打开stdafx.h文件,加入包含头文件语句:
#include "TangramMini_i.c" #include "TangramMini_i.h"为了编译不出现问题,我这里提醒大家,最好是先包含.c文件,再包含.h文件。
CoInitialize(NULL); HRESULT hr = CoCreateInstance(CLSID_TangramMiniB2C, NULL, CLSCTX_INPROC_SERVER, IID_ITangramMiniB2C, (LPVOID*)&m_pMiniB2C); if (SUCCEEDED(hr) && (m_pMiniB2C != NULL)) { m_pMiniB2C->put_TargetHandle((LONG)m_hWnd); m_pMiniB2C->get_TangramMiniCtrl(&m_pMiniCtrl); VARIANT_BOOL bSucceed; m_pMiniCtrl->LoadFile(L"test.xtml",&bSucceed); m_pMiniCtrl->SetMDIClient( L"Page1_S0001_S0000", (LONG)theApp.m_pClientView->m_hWnd, 0,&bSucceed); }
其中CoInitialize(NULL)为初始化,然后调用CoCreateInstance()函数创建TangramMiniB2C组件并保存在m_pMiniB2C成员变量中,创建TangramMiniB2C组件之后,开始由TangramMiniB2C组件辅助创建TangramMiniCtrl控件,在这里我先说明下一下TangramMiniB2C的TargetHandle与TangramMiniCtrl两个属性,其中TargetHandle表示要创建的TangramMiniCtrl控件的父窗口,这里设置为m_hWnd,表示将TangramMiniCtrl控件创建在主框架窗口上,成为主框架窗口的一个子窗口。TangramMiniB2C的TangramMiniCtrl属性表示为创建后的TangramMiniCtrl控件的引用,在这里我们用get_TangramMiniCtrl(&m_pMiniCtrl)得到创建后的TangramMiniCtrl控件的引用并返回给成员变量m_pMiniCtrl。
得到TangramMiniCtrl控件的引用之后,我们就像之前在对话框程序中使用TangramMiniCtrl控件了,首先调用LoadFile()方法加载框架文件,然后调用SetMDIClient(…)方法安装框架以及客户区。其中theApp.m_pClientView变量保存了当前视图的指针,关键在哪保存此值,大家可以查看源代码,使用SetMDIClient的方法表示将TangramMiniCtrl控件填充当前视图的位置,并将当前视图平移到名为Page1_S0001_S0000(你也可以用别的有效空白视图名称)的Tangram空白视图区域中。
BOOL SetMDIClient(BSTR strObjName, LONG nMDIHandle, LONG nMDIStyle);
由于TangramMini组件最初的设计目的是针对MDI应用程序而设计的,所以存在这个SetMDIClient方法,此方法存在三个参数,第一个参数就是像其它方法一样,为Tangram空白视图的名称,第二个为MDI客户区窗口句柄,第三个参数为MDI客户区风格,其中nMDIStyle在本篇中无效果,不必关心。虽然这个方法是针对MDI应用程序而存在的,但是在普通的程序中也可以利用此方法,像现在在这个SDI中就要使用此方法。此方法的功能是将TangramMiniCtrl控件填充nMDIHandle句柄对应的位置,并将nMDIHandle窗口定位到strObjName区域中。也就是说TangramMiniCtrl自动适用nMDIHandle窗口的大小,并且平移nMDIHandle窗口的位置,有点难理解,也许是我自己也说不清,大家看最终效果就可以明白。
经过上面几个简单的步骤之后,最终的效果图如下。由于是在SDI应用程序中,为了视觉效果更好,我这里将之前设计的框架文件(test.xtml)文件用XTML Designer修改了一下,将之前介绍的3号Tangram空白视图区域重新设计为一个三页的Tab分页(分别为:Output、Building与Debug)。
有上图可见,TangramMiniCtrl控件填充了整个客户区,其实并不是TangramMiniCtrl控件自动填充了整个客户区,而是因为当前视图m_pClientView对象填充整个客户区,而调用SetMDIClient方法之后,TangramMiniCtrl控件就会自动适应m_pClientView对象的窗口位置,而且平移m_pClientView对象到指定的Tangram空白视图位置。我自己认为自己很难用文字上来解释清楚,也许大家已经明白了,我就不啰嗦了。
可以看出我们在一个简单的SDI程序中利用TangramMini组件就很快速的建立了一个复杂框架,我相信大家通过之前几篇关于对话框程序的了解,应该可以自行的在其余的Tangram空白视图中安装自己感兴趣的窗口对象,在这里我就安装一个简单的CEdit box窗口到名为Output的Tangram空白视图区域中,效果如下图所示,具体细节请查看源代码。
好了,关于TangramMini组件在SDI应用程序中的使用就简单介绍到这里,从下一篇我将开始介绍TangramMini组件在MDI(多文档界面)应用程序中的使用,由于刚开始我说明了TangramMini组件最初的设计是为MDI程序而设计的,所以TangramMini组件在MDI应用程序中功能最为强大,表现形式也最好,另外非常感谢大家的关注。