CDHtmlDialog的基本使用

转自:http://blog.csdn.net/sky04/article/details/7587406

因为我的部门只有我一个人(无奈之极,只有我一个做C++的,其他的都在做C#),所以我去跟技术顾问讨论我们客户端到底该怎么呈现。他说按照以往(上一套系统)的经验,升级很频繁,建议还是使用内嵌 HTML的方式来显示界面,这样以后只要升级HTML就可以了。我听了之后,牙掉了一半,我拖了半个月的对话框就这么给否了,心里着实不是滋味。

然后就开始寻找MFC显示HTML页面的方法,找了一些自定义的HTML类,找了Webbrowser Control(我到现在还没找到这控件到底在哪里),最终锁定了CDHtmlDialog类。

这个类算是最近才开始大放异彩的吧,在vc6.0时代,用这玩意儿做出来的东西很难看,都是win2k风格。现在就可以使用什么win7风格呀之类的,说不定在vs11里还能使用Metro风格呢。。简单试验了一下,发现还是可以一用的,就决定下来要用这个了。

建立一个新的MFC Application工程,在这一步把HTML Dialog给勾上

可以看到如此一来,对话框就是从CDHtmlDialog类派生了。

建立完成后,观察一下代码跟以前的不同之处。发现了四点(可能还有更多):

  1. class CTestHtmlDialogDlg : public CDHtmlDialog

表明此对话框类的确是继承了CDHtmlDialog。

  1. // Dialog Data
  2. enum { IDD = IDD_TESTHTMLDIALOG_DIALOG, IDH = IDR_HTML_TESTHTMLDIALOG_DIALOG };

这儿的枚举变成了两个,也就是有一个普通对话框,还有一个HTML对话框。

  1. CTestHtmlDialogDlg::CTestHtmlDialogDlg(CWnd* pParent /*=NULL*/)
  2. : CDHtmlDialog(CTestHtmlDialogDlg::IDD, CTestHtmlDialogDlg::IDH, pParent)

在CTestHtmlDialogDlg的构造函数中,CDHtmlDialog的成员初始化列表中多了一个CTestHtmlDialogDlg::IDH。

  1. /////////////////////////////////////////////////////////////////////////////
  2. //
  3. // HTML
  4. //
  5. IDR_HTML_TESTHTMLDIALOG_DIALOG    HTML         "TestHtmlDialog.htm"

在resource文件中,多了这么一行,用来指定HTML对话框的HTML文件资源,可以修改成自己喜欢的名字,比如index.html,当然在工程中的html文件也要修改成相应的名字。

我们来做个试验。修改一下TestHtmlDialog.htm。

  1. <HTML>
  2. <HEAD>
  3. </HEAD>
  4. <BODY ID=CTestHtmlDialogDlg style="font-family:MS Shell Dlg;font-size:8">
  5. <h1>This is a test.</h1>
  6. <h2>I told you this is a test.</h2>
  7. <h3>Didn‘t hear me? This is a test!</h3>
  8. <img src="C:\\test.jpg">
  9. </BODY>
  10. </HTML>

显示结果如下:

怎么样?比拖对话框、拖控件、加载资源、修改ID号、关联变量、各种Load各种Show要简单多了吧?

我这儿出了个问题,截止发文时尚未解决,如有大虾指教烦请回复一下。我只能使用绝对路径c:\test.jpg,而不能使用相对路径,无论是test.jpg、..//test.jpg、..//Debug//test.jpg等等都不行,而且我把test.jpg在工程目录里放得到处都是,也不能加载,总是显示一个小红叉。。

-------------------------------我是华丽的分割线--------------------------------------

继续我们的实验。页面不能光是显示啊,总得有点什么互动吧?那么很高兴这东西也支持JavaScript

利用VS2010自带的HTML编辑器对TestHtmlDialog.htm进行编辑。这儿得赞一下VS2010的HTML编辑器,非常人性化,基本可以跟Dreamweaver媲美了,双击按钮呀啥的都可以直接进入 onclick事件的编写,默认Javascript。

我们拖一个按钮在上面,改个名字,然后保存并双击按钮编写onclick事件

  1. function Button1_onclick() {
  2. alert("哈喽,击这么狠干啥");
  3. }

就弹出了刚才的alert信息。

-------------------------------我是华丽的分割线--------------------------------------

接下来我萌生了一个念头,Javascript是不是可以调用本地对话框内的函数呢?去百度上Google了一会,发现当然是可以的。方法也比较简单。

  1. // 1. 让CTestHtmlDialog支持自动化
  2. // 在OnInitDialog()中添加
  3. EnableAutomation();
  4. // 2. 将自身暴露给Javascript
  5. // 在OnInitDialog()中添加
  6. SetExternalDispatch(GetIDispatch(TRUE));    //将浏览器控件的扩展接口设置为对话框自身的IDispatch
  7. // 3. 声明DISPATCH_MAP
  8. // 在TestHtmlDialog.h中
  9. DECLARE_DISPATCH_MAP()
  10. // 4. 定义DISPATCH_MAP
  11. // 在TestHtmlDialog.cpp中
  12. BEGIN_DISPATCH_MAP(CMyDHtmlDialog, CDHtmlDialog)
  13. DISP_FUNCTION(CMyDHTMLDialog, "SayHello", func, VT_EMPTY, VTS_NONE)
  14. END_DISPATCH_MAP()

应该看出来了,有点像MFC的消息映射机制。

接下来随便写个函数:

  1. MessageBox(_T("SayHello Func"), _T("Hello~~"));

修改一下刚才的按钮单击事件:

  1. function Button1_onclick() {
  2. //alert("哈喽,击这么狠干啥");
  3. external.SayHello();
  4. }

好,编译运行。点击按钮,弹出个东西来:

因为要将程序内部暴露出来,Windows认为这可能是不安全的。点击“是”之后,就看到了刚才写的函数的效果。

但是我觉得很安全,我不想再看见刚才的这个东西。。该怎么办呢?一番寻找,便找到了解决方案。

在CTestHtmlDialog中,重载CanAccessExternal()函数。

  1. BOOL CWebbrowserDlg::CanAccessExternal()
  2. {
  3. return TRUE;
  4. }

这下,讨厌的安全提示便不见啦~

-------------------------------我是华丽的分割线--------------------------------------

对话框可否访问Javascript的函数呢?当然也可以,这样就可以仅由Javascipt来判断数据的合法性,让C++来专心作逻辑运算了。

这个资料就相对少一些了,找了一个,还未吃透。仔细想一下,这方面的需要是比较少,所以资料也不太多。在codeproject上倒是找到了一个这方面的东西,感兴趣的朋友就去观望一下吧~ 时空穿梭传送门

时间: 2024-11-17 07:29:22

CDHtmlDialog的基本使用的相关文章

提交了问题给Microsoft,期待回应 - Problem with CDHtmlDialog (Error: Js::JavascriptExceptionObject * __ptr64)

问题大概就是最近发现用户中不少更新的最新补丁的(特别是KB2962872)之后,使用CDHtmlDialog做前端UI的对话框会抛出异常,查了很久,无解. 无奈提交了一个问题给微软. 链接地址: Problem with CDHtmlDialog (Error: Js::JavascriptExceptionObject * __ptr64) 之前Google了一下,发现了一个和我类似的问题,也是今年2014年4月份提交的(估计英文版的windows系统补丁发布得比较早,我的用户反馈这个问题是从

在CDHtmlDialog中处理WindowClosing

要截获window.close(),就得截获CDHtmlDialog的WindowClosing.以下是示例代码: // header DECLARE_EVENTSINK_MAP() void WindowClosing(VARIANT_BOOL IsChildWindow, VARIANT_BOOL *Cancel); // cpp BEGIN_EVENTSINK_MAP(CWebTestDlg, CDHtmlDialog) ON_EVENT(CWebTestDlg, AFX_IDC_BROW

CDHtmlDialog 浏览器遇到的服务器忙( Server Busy)问题

今天用CDHtmlDialog创建了一个简单的浏览器程序,遇到了一个问题,记录一下. 问题描述:当超链接的打开方式为_blank的时候,会弹出一个服务器忙的对话框,如图: 网页内容 <HTML> <HEAD> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"/> </HEAD> <BODY ID=CAntiNetTimeoutD

用MFC实现WebGUI--(CDHtmlDialog)

自从去年年底一次棘手的界面,开始研究用web做界面到现在大约1年,这一年间不是局限在实现层面,也并非一直研究这一个问题,有很多问题其实不是问题,只是自己没有想清楚或者思想没放开.对于一个界面开发人员,想必拉的对话框不少于100个,腻味不必说,光是对话框大小改变导致控件跟着变化都需要一番功夫,加上界面美观,界面的风格统一,界面的灵活多变......,头痛.在对话框里面加载位图,加载gif,超链接......,啊,没法控制了吧!在考虑远点,现在.net3.0技术已经完全打破应用和桌面的界限,我们的界

CDHtmlDialog加壳HTML5页面跳转错误解决(原)

HTML5+Native方式开发应用程序,遇到的一个问题:HTML5实现的阅读器在打开文档时,CDHtmldialog类的跳转函数报错,忽略错误程序可以正确执行. 错误代码:OnNavigateComplete函数的ASSERT(m_spHtmlDoc==NULL); 跟踪分析:_OnBeforeNavigate2和_OnNavigateComplete2总是成对执行,_OnBeforeNavigate2函数中有m_spHtmlDoc = NULL;语句,所以不会出现上述断言错误.而在点击htm

CDHtmlDialog探索----WebBrowser扩展和网页Javascript错误处理

当WebBrowser控件(CDHtmlDialog自动创建了WebBrowser控件)加载的网页中含有错误Javascript代码时默认情况下控件会弹出错误信息提示对话框,相对于用户体验来说这样的提示完全不是开发人员想要的,针对这个问题有两个解决方案,一是完全屏蔽掉错误提示,二是控制错误的提示并且记录错误信息同时也可以控制出现错误后Javascript是否继续执行. 1.屏蔽错误信息提示 1 m_pBrowserApp->put_Silent(VARIANT_TRUE); 在CDHtmlDia

c#winform使用WebBrowser 大全

C# WinForm WebBrowser (一) MSDN资料 1.主要用途:使用户可以在窗体中导航网页. 2.注意:WebBrowser 控件会占用大量资源.使用完该控件后一定要调用 Dispose 方法,以便确保及时释放所有资源.必须在附加事件的同一线程上调用 Dispose 方法,该线程应始终是消息或用户界面 (UI) 线程. 3.WebBrowser 使用下面的成员可以将控件导航到特定 URL.在导航历史记录列表中向后和向前移动,还可以加载当前用户的主页和搜索页: 1.URL属性:可读

Visual C#两分钟搭建BHO IE钩子

微软在1997年正式推出Browser Helper Object (BHO), 使程序员能够更好的对IE进行二次开发和操作. 在通过编写BHO程序数月后, 我希望把我的一些经验告诉才开始的同志, 避免走一些弯路. 我本人是非常喜欢C++的. 因为C++对内存直接操作的方式可以节省非常多的内存损耗, 也更快一些. 但是在开发BHO的时候, 我的确也认识到, C#明显要比C++强大很多. 例如C#提供的FOREACH 循环就可以避免FOR循环产生的溢出. 另外C#的类型转换也明显要强于C++. 毕

C#wenbbrowser浏览器的详细用法

1.主要用途:使用户可以在窗体中导航网页. 2.注意:WebBrowser 控件会占用大量资源.使用完该控件后一定要调用 Dispose 方法,以便确保及时释放所有资源.必须在附加事件的同一线程上调用 Dispose 方法,该线程应始终是消息或用户界面 (UI) 线程. 3.WebBrowser 使用下面的成员可以将控件导航到特定 URL.在导航历史记录列表中向后和向前移动,还可以加载当前用户的主页和搜索页: 1.URL属性:可读.可写,用于获取或设置当前文档的 URL. WebBrowser