關(guān)于光標(biāo)的一些函數(shù)
BOOL CreateCaret(HWND hWnd,HBITMAP hBitmap,int nWidth,int nHeight);為窗口創(chuàng)建光標(biāo)
BOOL DestroyCaret();銷(xiāo)毀光標(biāo)
UINT GetCaretBlinkTime();光標(biāo)閃爍間隔時(shí)間
BOOL GetCaretPos(LPPOINT lpPoint);光標(biāo)在當(dāng)前窗口的client位置
BOOL HideCaret(HWND hWnd);隱藏
BOOL SetCaretBlinkTime(UINT uMSeconds);光標(biāo)閃爍間隔時(shí)間
BOOL SetCaretPos(int X,int Y);位置
BOOL ShowCaret(HWND hWnd);顯示
CWnd::CreateCaret
CWnd::CreateSolidCaret
CWnd::CreateGrayCaret
CWnd::GetCaretPos
CWnd::SetCaretPos
CWnd::HideCaret
CWnd::ShowCaret
為其它進(jìn)程模擬輸入字符:摘自
http://www.pcbookcn.com/article/1113.htm 首先要知道在Windows系統(tǒng)中與鍵盤(pán)按鍵相關(guān)的消息有:WM_KEYDOWN、WM_KEYUP、 WM_SYSKEYDOWN、WM_SYSKEYUP、WM_CHAR等。其中,WM_KEYDOWN為鍵按下,WM_KEYUP為鍵彈起,WM_SYSKEYDOWN為系統(tǒng)鍵按下,WM_SYSKEYUP為系統(tǒng)鍵彈起,WM_CHAR為按鍵對(duì)應(yīng)的字符。
要模擬鍵盤(pán)產(chǎn)生鍵盤(pán)消息,我們就發(fā)送一條鍵盤(pán)消息給指定窗口。比如要模擬一個(gè)字母鍵“A”,可以這樣:PostMessage(hWnd, WM_CHAR, 'A', 0); 模擬按一個(gè)回車(chē):PostMessage(hWnd, WM_KEYDOWN, VK_RETURN, 0)。這里的關(guān)鍵問(wèn)題是要確定窗口句柄(hWnd),使用GetFocus()函數(shù)可以得到鍵盤(pán)光標(biāo)所在窗口句柄,但該函數(shù)只能得到當(dāng)前進(jìn)程內(nèi)的窗口句柄。
如果要得到其他應(yīng)用程序的鍵盤(pán)光標(biāo)所在窗口句柄,需要調(diào)用 AttachThreadInput()函數(shù)。該函數(shù)的作用就是將其他窗口線程的輸入附加到本窗口線程的輸入操作中,這樣就可以調(diào)用GetFocus()函數(shù)得到其他窗口的句柄了。
AttachThreadInput()函數(shù)的原形如下:
BOOL?AttachThreadInput(?
DWORD?idAttach,?//?需要附加的線程ID?
DWORD?idAttachTo,?//?附加到的線程ID?
BOOL?fAttach?//?true?附加?false?取消?
);?函數(shù)使用的過(guò)程大致如下:
HWND?hWnd;?
hWnd?=?GetForegroundWindow();?//?得到當(dāng)前窗口?
if?(hWnd?==?Form1->Handle)?return;?//?排除程序本身的窗口?
DWORD?FormThreadID?=?GetCurrentThreadId();?//?本程序的線程ID?
//?當(dāng)前窗口的線程ID?
DWORD?CWndThreadID?=?GetWindowThreadProcessId(hWnd,?NULL);?
//?附加輸入線程?
AttachThreadInput(CWndThreadID,?FormThreadID,?true);?
//?得到當(dāng)前鍵盤(pán)光標(biāo)所在的窗口?
hWnd?=?GetFocus();?
//?取消附加的輸入線程?
AttachThreadInput(CWndThreadID,?FormThreadID,?false);?
hWnd就是當(dāng)前鍵盤(pán)光標(biāo)所在的窗口句柄。另外,經(jīng)過(guò)測(cè)試發(fā)現(xiàn),在Windows2000系統(tǒng)下發(fā)送字符消息(WM_CHAR)時(shí),如果字符是一個(gè)漢字,則該字符對(duì)應(yīng)的虛擬鍵盤(pán)碼高位不為0,這樣得到的字符就不正確。解決辦法是做一個(gè)“與”運(yùn)算: ch & 0xFF就可以了。
輸入法的切換:WM_INPUTLANGCHANGE
platform sdk=>User Interface Servic=>windowing=>windows=>window reference =>Messages
關(guān)于輸入法:platform sdk=>Windows Base Services=>International Features=>Input Method Editor
自己處理鍵盤(pán)輸入要做的事:
如果你要自己處理鍵盤(pán)和輸入法的輸入而不用Eidt或richedit等控件的話,至少需要做以下處理以下消息WM_IME_STARTCOMPOSITION;WM_IME_ENDCOMPOSITION;WM_IME_COMPOSITION;
LRESULT?CCaretStudyView::OnImeStartComposition(WPARAM?wParam,?LPARAM?lParam)


{
????HIMC?hIMC?=?::ImmGetContext(m_hWnd);
????COMPOSITIONFORM?CompForm;
????CompForm.dwStyle?=?CFS_POINT;
????CompForm.ptCurrentPos.x?=?10;//用實(shí)際的值代替
????CompForm.ptCurrentPos.y?=?10;//用實(shí)際的值代替
????::ImmSetCompositionWindow(hIMC,?&CompForm);
????//DropCaret();可在此處隱藏光標(biāo),在OnImeEndComposition消息處理中再顯示光標(biāo)
????::ImmReleaseContext(m_hWnd,?hIMC);
????return?::DefWindowProc(m_hWnd,?WM_IME_STARTCOMPOSITION,?wParam,?lParam);
}


LRESULT?CCaretStudyView::OnImeEndComposition()?
{
????//ShowCaretAtCurrentPosition();
????return?Default();
}

LRESULT?CCaretStudyView::OnImeComposition(WPARAM?wParam,?LPARAM?lParam)


{

????if?(lParam?&?GCS_RESULTSTR)?
{
????????//get?result?text
????????HIMC?hIMC?=?::ImmGetContext(m_hWnd);

????????if?(hIMC)?
{
????????????const?int?maxLenInputIME?=?200;
????????????wchar_t?wcs[maxLenInputIME];
????????????LONG?bytes?=?::ImmGetCompositionStringW(hIMC,
????????????????????GCS_RESULTSTR,?wcs,?(maxLenInputIME-1)*2);
????????????//

????????????//?Set?new?position?after?converted
????????????CPoint?pos?=?GetCurrentPos();
????????????COMPOSITIONFORM?CompForm;
????????????CompForm.dwStyle?=?CFS_POINT;
????????????CompForm.ptCurrentPos.x?=?pos.x;
????????????CompForm.ptCurrentPos.y?=?pos.y;
????????????::ImmSetCompositionWindow(hIMC,?&CompForm);
????????????::ImmReleaseContext(m_hWnd,?hIMC);
????????}
????????return?0;
????}
????return?Default();
}以上三個(gè)消息是不做處理也可以,只不過(guò)不會(huì)支持如微軟拼音輸入法的跟隨功能。
并WM_IME_CHAR和WM_CHAR添加字符。在WM_KEYDOWN中處理特殊字符,如VK_BACK VK_DELTE