VC2008下CRichEditView加载RichEdit4.1版本(还有一些类似的文章)

在之前的文章《RichEdit 各个版本介绍》中,写到RichEdit已经到达6.0版本了,而我们经常编程使用的却还是2.0,在vc6.0中甚至还使用1.0版本,更高的版本修复了很多的bug,还提供了许多新特性,我们没有理由不去使用它们。在此介绍,在VS2008SP1中如何加载RichEdit4.1版本,甚至更高版本的也可以类似加载。
原理:
1.启动VS2008,新建一个基于CRichEditView的多文档视图Unicode工程,名称取为:CTest_Richedit;
2.查看源代码,CTest_RicheditView派生自CRichEditView,右键CRichEditView“转到声明”,发现CRichEditView派生自CCtrlView,继续查看CRichEditView的构造函数(在文件X:\Program Files\Microsoft Visual Studio 9.0\VC\atlmfc\src\mfc\viewrich.cpp中),如下所示:

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
  CRichEditView::CRichEditView() : CCtrlView(RICHEDIT_CLASS,   
    AFX_WS_DEFAULT_VIEW | WS_HSCROLL | WS_VSCROLL | ES_AUTOHSCROLL |   
    ES_AUTOVSCROLL | ES_MULTILINE | ES_NOHIDESEL | ES_SAVESEL |    
    ES_SELECTIONBAR)   
{   
    m_bSyncCharFormat = m_bSyncParaFormat = TRUE;   
    m_lpRichEditOle = NULL;   
    m_nBulletIndent = 720; // 1/2 inch   
    m_nWordWrap = WrapToWindow;   
    m_nPasteType = 0;   
    SetPaperSize(CSize(8*1440+720, 11*1440));   
    SetMargins(CRect(0,0,0,0));   
    m_charformat.cbSize = sizeof(CHARFORMAT2);   
    m_paraformat.cbSize = sizeof(PARAFORMAT2);   
}   

在第一行发现有RICHEDIT_CLASS,顾名思义这是RichEdit类名的意思,查看这个宏所定义的内容,在文件X:\Program Files\Microsoft SDKs\Windows\v6.0A\Include\Richedit.h中开头:

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
  #define MSFTEDIT_CLASS        L"RICHEDIT50W"  
// NOTE:  MSFTEDIT.DLL only registers MSFTEDIT_CLASS.  If an application wants  
// to use the following Richedit classes, it needs to load the riched20.dll.  
// Otherwise, CreateWindow with RICHEDIT_CLASS would fail.  
// This also applies to any dialog that uses RICHEDIT_CLASS,   
  
// RichEdit 2.0 Window Class   
// On Windows CE, avoid possible conflicts on Win95  
#define CERICHEDIT_CLASSA    "RichEditCEA"  
#define CERICHEDIT_CLASSW    L"RichEditCEW"  
  
#define RICHEDIT_CLASSA        "RichEdit20A"  
#define RICHEDIT_CLASS10A    "RICHEDIT"            // Richedit 1.0  
  
#ifndef MACPORT  
#define RICHEDIT_CLASSW        L"RichEdit20W"  
#else    //----------------------MACPORT   
#define RICHEDIT_CLASSW        TEXT("RichEdit20W")    // MACPORT change   
#endif // MACPORT    
  
#if (_RICHEDIT_VER >= 0x0200 )  
#ifdef UNICODE  
#define RICHEDIT_CLASS        RICHEDIT_CLASSW  
#else  
#define RICHEDIT_CLASS        RICHEDIT_CLASSA  
#endif // UNICODE   
#else  
#define RICHEDIT_CLASS        RICHEDIT_CLASS10A  
#endif // _RICHEDIT_VER >= 0x0200  

摘取那么长的一段,首先RICHEDIT_CLASS在Unicode中代表着"RichEdit20W",否则代表着"RichEdit20A"。另外在上面的语句:

1
2
  #define MSFTEDIT_CLASS        L"RICHEDIT50W"  
// NOTE:  MSFTEDIT.DLL only registers MSFTEDIT_CLASS.  

说明着MSFTEDIT.DLL(即RichEdit4.1版本)注册的类名是"RICHEDIT50W"。继续下一步,因为工程建立的是Unicode,所以CRichEditView的构造函数给CCtrlView的构造函数传了"RichEdit20W"参数,查看CCtrlView的构造函数(在文件X:\Program Files\Microsoft Visual Studio 9.0\VC\atlmfc\src\mfc\viewcore.cpp中),如下所示:

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
  CCtrlView::CCtrlView(LPCTSTR lpszClass, DWORD dwStyle)  
{  
    m_strClass = lpszClass;  
    m_dwDefaultStyle = dwStyle;  
}  
  
BOOL CCtrlView::PreCreateWindow(CREATESTRUCT& cs)  
{  
    ASSERT(cs.lpszClass == NULL);  
    cs.lpszClass = m_strClass;  
  
    // initialize common controls  
    VERIFY(AfxDeferRegisterClass(AFX_WNDCOMMCTLS_REG));  
    AfxDeferRegisterClass(AFX_WNDCOMMCTLSNEW_REG);  
  
    // map default CView style to default style  
    // WS_BORDER is insignificant  
    if ((cs.style | WS_BORDER) == AFX_WS_DEFAULT_VIEW)  
        cs.style = m_dwDefaultStyle & (cs.style | ~WS_BORDER);  
  
    return CView::PreCreateWindow(cs);  
}  

可以发现CCtrlView的构造函数里把"RichEdit20W"传给了m_strClass,而在CCtrlView的PreCreateWindow函数里m_strClass做为变量传值给了CREATESTRUCT结构体,CREATESTRUCT结构定义了传递给应用程序的窗口过程的初始化参数。我们只要改变m_strClass类名,就能创建出我们想要的窗口。
实现:
1.在上面的CTest_Richedit工程中,在CTest_RicheditView的构造函数里赋值想要的类名给m_strClass,如下所示:

1
2
3
4
  CTest_RicheditView::CTest_RicheditView() 

    m_strClass = MSFTEDIT_CLASS;     

然后在CTest_RicheditApp里,声明一个HINSTANCE对象,如下所示:

1
2
3
4
5
6
7
8
  class CTest_RicheditApp : public CWinApp  
{  
public:  
    CTest_RicheditApp();  
    virtual ~CTest_RicheditApp();   //重载析构函数  
    HINSTANCE m_hinstRE41;        //声明实例对象  
    //······  
};  

然后在实现文件里面,写入如下代码:

1
2
3
4
5
6
7
8
9
  CTest_RicheditApp::CTest_RicheditApp()  
{  
    m_hinstRE41 = LoadLibrary(_T("msftedit.dll"));      
}  
CTest_RicheditApp::~CTest_RicheditApp()  
{  
    if(m_hinstRE41)  
      FreeLibrary(m_hinstRE41);  
}  

完成,运行程序。用Spy++检测,为"RICHEDIT50W"类名,如下图所示:

对话框方式:
1.在对话框上放置一个Rich Edit 2.0控件;
2.以文本方式打开工程.rc文件,找到描述该控件的地方,如下所示:

1
2
3
4
5
6
7
8
  IDD_ABOUTBOX DIALOGEX 0, 0, 266, 199 
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU 
CAPTION "关于 Test_Richedit" 
FONT 9, "MS Shell Dlg", 0, 0, 0x1 
BEGIN 
    DEFPUSHBUTTON   "确定",IDOK,209,178,50,14,WS_GROUP 
    CONTROL         "",IDC_RICHEDIT21,"RichEdit20W",ES_AUTOHSCROLL | WS_BORDER | WS_TABSTOP,22,32,140,103 
END 

3.把"RichEdit20W"改成"RICHEDIT50W",保存文件。切换到VS,提示重新加载资源文件,确定即可。
4.跟前面的步骤一样,加载"msftedit.dll",运行如下所示:

参考文章:
A Very Simple Way to Use Richedit 5.0 in VC6 and other VS versions  http://www.codeproject.com/KB/edit/UseRichEdit50.aspx

http://blog.csdn.net/akof1314/article/details/6607265

时间: 2024-10-27 06:40:27

VC2008下CRichEditView加载RichEdit4.1版本(还有一些类似的文章)的相关文章

H5页面下拉加载更多(实用版)

近期在做一个H5网站,需要下拉加载更多产品列表的功能.百度搜索了好久,什么说法都有,什么插件都有.   醉了.基本上每一个能直接拿来用的. 最后发现: 1.dropload.js 插件  还可以,但是有个问题,只能单页使用比较方便.带有tab标签的不推荐使用. 2.自己百度了半天总结出来的一套: <script> document.addEventListener('scroll', watchScroll); var itemIndex = 0; var classid = 10; var

[转] 静态资源的分布对网站加载速度的影响/浏览器对同一域名下并发加载资源数量

静态资源的分布对网站加载速度的影响 / 浏览器对同一域名下并发加载资源数量 / browsers network-http-persistent-max-connections-per-server 引文:浏览器在同一个域名下并发加载的资源数量是有限的,访问淘宝首页需要加载126个资源,那么如此小的并发连接数自然会加载很久,所以前端开发人员往往会将上述这些资源文件分布在多个域名下,变相的绕过浏览器的这个限制,同时也为下文的CDN工作做准备 [ 摘自:<淘宝技术这十年>P6-P7 ] 不同浏览器

iscroll.js实现上拉刷新,下拉加载更多,应用技巧项目实战

上拉刷新,下拉加载更多...仿原生的效果----iscroll是一款做滚动效果的插件,具体介绍我就不废话,看官方文档,我只写下我项目开发的一些用到的用法: (如果不好使,调试你的css,想必是个很蛋疼的问题,给点提示 :#wrapper,以及#scroller-content要注意) html如下: <div class="viewport"> <div id="wrapper" class="wrapper"> <

下拉加载更多DEMO(js实现)

项目的一个前端页面展示已购买商品时,要求能下拉加载更多.花了点时间研究这个功能,以前没做过. 首先需要给div加scroll事件,监听滚动条滚动动作.那何时触发加载动作呢?当滚动条滚到底的时候.如何判断滚动条滚到底呢? 当滚动条的高度加上滚动条到div顶部的高度等于div的可滚动高度时,说明滚动条到底部了.公式如下. [javascript] view plain copy this.scrollHeight <= $(this).scrollTop() + $(this).height() 给

安卓,采用最简单易懂的方式实现上拉刷新下拉加载更多

<!-- Description:上拉刷新,下拉加载更多是现在最流行的手势操作,但是对于初学者来说,在实现上是有一定难度的, 网上很多教程讲的都过于复杂,对于初学者无法起到引导作用,特此写本文,帮助安卓新手入门理解此, 还有最为重要的一点:本文只帮助你理解,并不是想你成为代码搬运工!别被那么多代码吓到了, 其中很多都是注释,仔细看注释对你理解有很大的帮助 Author:Booker L Date:2014-05-16 --> 一,事先准备: 实现该功能,最基本的需要两个东西,一个是OnTouc

WP8_GestureListener实现列表向下滑动加载新数据

利用GestureListener的OnDragCompleted事件,实现列表向下滑动时,加载新的数据: (不建议使用 Touch.FrameReported+=Touch_FrameReported; 此事件是全局的,如果没有注销事件,在离开页面后仍会得到响应,而这不是希望的效果) 前台代码: <Border> <!- 此处放置ScrollViewer或 ListBox--> <ScrollViewer/>   <toolkit:GestureService.

使用谷歌提供的SwipeRefreshLayout下拉控件,并自定义实现下拉加载的功能

package com.loaderman.swiperefreshdemo; import android.os.Bundle; import android.os.Handler; import android.support.v4.widget.SwipeRefreshLayout; import android.support.v7.app.AppCompatActivity; import android.view.Gravity; import android.view.View;

Android之 RecyclerView,CardView 详解和相对应的上拉刷新下拉加载

随着 Google 推出了全新的设计语言 Material Design,还迎来了新的 Android 支持库 v7,其中就包含了 Material Design 设计语言中关于 Card 卡片概念的实现 -- CardView.RecyclerView也是谷歌V7包下新增的控件,用来替代ListView的使用,在RecyclerView标准化了ViewHolder类似于ListView中convertView用来做视图缓存. RecyclerView的优点就是,他可以通过设置LayoutMan

关于MJRefresh的下拉加载数据bug

当没有更多数据的时候显示NoMoreData 我的理解是先结束刷新再显示没有更多 今天之前一直没发现有问题 贴之前的代码 [self.collectionView reloadData]; [self.collectionView.mj_header endRefreshing]; // 结束刷新 [self.collectionView.mj_footer endRefreshing]; NSArray *arr = data[@"Json"]; if (arr.count == 0