<b>关于RICHEDIT的两个问题</b>[VC/C++编程]
本文“<b>关于RICHEDIT的两个问题</b>[VC/C++编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
问题1:RichEditCtrl在用DDX举行数据交换的时刻会发生数据丧失问题?为什么!
当我们在拖了一个控件到程序里后,普通的做发是Ctrl+W,用类向导给控件关联一个变量,然后依靠DDX/DDV举行数据交换,假如我们用一样的办法来给RICHEDIT关联一个CString范例的变量就会存在一个问题,就是假如我们的数据大于了64K,数据就会丧失.
通过查MSDN发现,WM_GETTEXT消息并没有计划在RICHEDIT的数据大于64K的时刻怎样处理.而类向导生成的代码是用DDX_Text来交换控件和CString变量的数据.刚好,DDX_Text函数是调用GetWindowText函数,而这个函数又会发出WM_GETTEXT消息到控件来返回控件里的数据.WM_GETTEXT消息不能承受超越64K的数据,因此招致了RICHEDIT在数据交换的时刻发生了丧失.
为了办理这个问题,我们要用到DDX_RichText函数.增添下面两个函数到工程
以下是引用片段:
DWORDCALLBACKES2MemCallBack(DWORD_PTRdwCookie,LPBYTEpbBuff,LONGcb,LONG*pcb)
{
LPTSTR&lpszStrFill=*(LPTSTR*)dwCookie;
memcpy(lpszStrFill,pbBuff,*pcb=cb);
lpszStrFill+=cb;
*lpszStrFill=TCHAR('');
return0;
}
voidAFXAPIDDX_RichText(CDataExchange*pDX,intnIDC,CString&value)
{
externvoidAFXAPIAfxSetWindowText(HWNDhWndCtrl,LPCTSTRlpszNew);
HWNDhWndCtrl=pDX->PrepareEditCtrl(nIDC);
if(pDX->m_bSaveAndValidate)
{
intnLen=::GetWindowTextLength(hWndCtrl);
LPTSTRlpszStrFill=value.GetBufferSetLength(nLen);
EDITSTREAMes={(DWORD_PTR)&lpszStrFill,0,ES2MemCallBack};
::SendMessage(hWndCtrl,EM_STREAMOUT,SF_TEXT,(LPARAM)&es);
value.ReleaseBuffer();
}
else
{
AfxSetWindowText(hWndCtrl,value);
}
}
以上是“<b>关于RICHEDIT的两个问题</b>[VC/C++编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |