vc显示html文档,在VC对话框中用ChtmView控件显示HTML.doc

在VC对话框中用ChtmView控件显示HTML

微软的MFC在Visual Studio 6.0中提供了一个新类CHtmlView,利用这个类,我们可以实现在基于文档视图结构的程序中显示HTML文件。 但是它是否可以用来在对话框中实现这一功能呢?我们不妨拿CHtmlView和CListView做一个比较,通过比较这两个类,我们会发现一些有趣的差别,MFC中CListView有一个对应的CListCtrl类用来在对话框中使用,而CHtmlView却没有一个CHtmlCtrl类与之对应。所以为了实现在对话框的控制中显示HTML文件,我们不得不为CHtmlView创建一个对应的子类CHtmlCtrl。为了演示该类的使用方法,本实例在程序的About对话框中显示一个名为"about.htm"的HTML文件。更有趣的是,程序所用到的HTML源文件是作为资源存储在EXE文件中的。该程序编译运行后的效果如图一所示:

图一、显示HTML文件的对话框

一、实现方法  为了在对话框中显示HTML文件,我们必须将CHtmlCtrl类与对话框中的一个静态控制(也可以是其它控制)关联起来,这样才能为显示HTML文件提供一个窗口,为此我们在CHtmlCtrl类中定义了CreateFromStatic()函数,具体代码如下:

BOOL CHtmlCtrl::CreateFromStatic(UINT nID, CWnd* pParent){ CStatic wndStatic; //静态控件对象; if (!wndStatic.SubclassDlgItem(nID, pParent))   return FALSE;  // 获取静态控制的矩形区域并转换为父窗口的客户区坐标  CRect rc;  wndStatic.GetWindowRect(&rc);  pParent->ScreenToClient(&rc);  wndStatic.DestroyWindow(); // 创建 HTML 控制 (CHtmlView)  return (Create(NULL, // 类名;  NULL, // 标题;  (WS_CHILD | WS_VISIBLE ), // 风格;   rc, // 矩形区域;   pParent, // 父窗口;   nID, // 控制的ID号;  NULL)); //取消文档框架支持;}

为了避免主控程序将CHtmlView对象看作是文档/视图框架,需要重载CView::OnMouseActivate()和CView::OnDestroy()函数。此外,当用户在控制中单击时,OnMouseActivate要负责响应(WM_MOUSEACTIVATE)。

int CHtmlCtrl::OnMouseActivate(CWnd* pDesktopWnd, UINT nHitTest, UINT msg){  //旁路 CView 文档/框架  return CWnd::OnMouseActivate(pDesktopWnd, nHitTest, msg);}void CHtmlCtrl::OnDestroy(){  if (m_pBrowserApp)  {  m_pBrowserApp->Release();  m_pBrowserApp = NULL;  }  CWnd::OnDestroy(); // 旁路 CView 文档/框架}

通常,CHtmlView是在virtual void PostNcDestroy()中释放空间,但对话框中的控制常常是作为堆栈对象实现的,所以,在PostNcDestroy()中不必在做什么。  为了播放资源中的HTML文件,需要重载导航处理器OnBeforeNavigate2(), 实现"app:" 伪协议,。传递"app:"链接到一个虚拟协议处理器。因为app:是假协议,所以需要设置pbCancel参数为"TRUE",以停止掉这个导航。

void CHtmlCtrl::OnBeforeNavigate2( LPCTSTR lpszURL,DWORD nFlags, LPCTSTR lpszTargetFrameName, CByteArray& baPostedData, LPCTSTR lpszHeaders, BOOL* pbCancel ){ const char APP_PROTOCOL[] = "app:";  int len = _tcslen(APP_PROTOCOL);  if (_tcsnicmp(lpszURL, APP_PROTOCOL, len)==0)  {   OnAppCmd(lpszUR

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenCV是一个开源的计算机视觉库,提供了许多用于处理图像和视频的函数和工具。VC是Visual C++的简称,是微软的集成开发环境,用于开发Windows平台的应用程序。Pic控件VC中的一个图像显示控件。 在VC中,我们可以使用Pic控件显示图像。首先,我们需要导入OpenCV库,并将其与VC项目关联。然后,我们可以使用OpenCV的函数加载图像文件,并将其存储为OpenCV的Mat对象。接下来,我们可以通过将Mat对象转换为位图对象,将图像数据传递给Pic控件显示图像。 具体实现步骤如下: 1. 在VC中创建一个新项目。 2. 导入OpenCV库,并设置OpenCV的头文件路径和库文件路径。 3. 添加一个Pic控件到窗口中。 4. 编写代码,在窗口加载时使用OpenCV的imread函数加载图像文件,并将其存储为Mat对象。 5. 调用Pic控件的SetPicture函数,将Mat对象转换为位图对象并显示控件中。 示例代码如下: #include <opencv2/opencv.hpp> #include <opencv2/highgui/highgui.hpp> #include <opencv2/core/core.hpp> // 根据Pic控件的实际ID修改宏定义 #define IDC_PIC 1001 using namespace cv; int main() { // 创建VC窗口 cvNamedWindow("VC OpenCV Pic控件显示图像"); // 加载图像文件 Mat image = imread("example.jpg"); // 获取Pic控件 CStatic* picControl = (CStatic*)GetDlgItem(IDC_PIC); // 创建位图对象 CBitmap picBitmap; // 将Mat对象转换为位图对象 cv::Size picSize = image.size(); int width = picSize.width; int height = picSize.height; int step = width * 3; cvtColor(image, image, CV_BGR2RGB); // 颜色顺序转换 // 创建位图数据 BITMAPINFO picInfo; picInfo.bmiHeader.biBitCount = 24; picInfo.bmiHeader.biWidth = width; picInfo.bmiHeader.biHeight = -height; picInfo.bmiHeader.biPlanes = 1; picInfo.bmiHeader.biSize = sizeof(BITMAPINFOHEADER); picInfo.bmiHeader.biCompression = BI_RGB; picInfo.bmiHeader.biSizeImage = step * height; // 为位图数据分配内存 uchar* picData = new uchar[step * height]; memcpy((char*)picData, (char*)image.data, step * height); // 创建位图对象 picBitmap.CreateCompatibleBitmap(GetDC(picControl->GetSafeHwnd()), width, height); SetBitmapBits(picBitmap.m_hObject, step * height, picData); // 将位图显示在Pic控件中 picControl->SetBitmap(picBitmap); // 释放内存 delete[] picData; // 显示VC窗口 cvShowImage("VC OpenCV Pic控件显示图像", picControl); // 等待用户按下任意键退出 waitKey(0); // 关闭VC窗口 cvDestroyWindow("VC OpenCV Pic控件显示图像"); return 0; } 以上就是使用OpenCV和VC的Pic控件显示图像的方法。注意,这只是一个简单的示例,具体实现可能需要根据实际情况进行适当的调整和改进。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值