關于光標的一些函數
BOOL CreateCaret(HWND hWnd,HBITMAP hBitmap,int nWidth,int nHeight);為窗口創建光標
BOOL DestroyCaret();銷毀光標
UINT GetCaretBlinkTime();光標閃爍間隔時間
BOOL GetCaretPos(LPPOINT lpPoint);光標在當前窗口的client位置
BOOL HideCaret(HWND hWnd);隱藏
BOOL SetCaretBlinkTime(UINT uMSeconds);光標閃爍間隔時間
BOOL SetCaretPos(int X,int Y);位置
BOOL ShowCaret(HWND hWnd);顯示
CWnd::CreateCaret
CWnd::CreateSolidCaret
CWnd::CreateGrayCaret
CWnd::GetCaretPos
CWnd::SetCaretPos
CWnd::HideCaret
CWnd::ShowCaret
為其它進程模擬輸入字符:摘自
http://www.pcbookcn.com/article/1113.htm 首先要知道在Windows系統中與鍵盤按鍵相關的消息有:WM_KEYDOWN、WM_KEYUP、 WM_SYSKEYDOWN、WM_SYSKEYUP、WM_CHAR等。其中,WM_KEYDOWN為鍵按下,WM_KEYUP為鍵彈起,WM_SYSKEYDOWN為系統鍵按下,WM_SYSKEYUP為系統鍵彈起,WM_CHAR為按鍵對應的字符。
要模擬鍵盤產生鍵盤消息,我們就發送一條鍵盤消息給指定窗口。比如要模擬一個字母鍵“A”,可以這樣:PostMessage(hWnd, WM_CHAR, 'A', 0); 模擬按一個回車:PostMessage(hWnd, WM_KEYDOWN, VK_RETURN, 0)。這里的關鍵問題是要確定窗口句柄(hWnd),使用GetFocus()函數可以得到鍵盤光標所在窗口句柄,但該函數只能得到當前進程內的窗口句柄。
如果要得到其他應用程序的鍵盤光標所在窗口句柄,需要調用 AttachThreadInput()函數。該函數的作用就是將其他窗口線程的輸入附加到本窗口線程的輸入操作中,這樣就可以調用GetFocus()函數得到其他窗口的句柄了。
AttachThreadInput()函數的原形如下:
BOOL?AttachThreadInput(?
DWORD?idAttach,?//?需要附加的線程ID?
DWORD?idAttachTo,?//?附加到的線程ID?
BOOL?fAttach?//?true?附加?false?取消?
);?函數使用的過程大致如下:
HWND?hWnd;?
hWnd?=?GetForegroundWindow();?//?得到當前窗口?
if?(hWnd?==?Form1->Handle)?return;?//?排除程序本身的窗口?
DWORD?FormThreadID?=?GetCurrentThreadId();?//?本程序的線程ID?
//?當前窗口的線程ID?
DWORD?CWndThreadID?=?GetWindowThreadProcessId(hWnd,?NULL);?
//?附加輸入線程?
AttachThreadInput(CWndThreadID,?FormThreadID,?true);?
//?得到當前鍵盤光標所在的窗口?
hWnd?=?GetFocus();?
//?取消附加的輸入線程?
AttachThreadInput(CWndThreadID,?FormThreadID,?false);?
hWnd就是當前鍵盤光標所在的窗口句柄。另外,經過測試發現,在Windows2000系統下發送字符消息(WM_CHAR)時,如果字符是一個漢字,則該字符對應的虛擬鍵盤碼高位不為0,這樣得到的字符就不正確。解決辦法是做一個“與”運算: ch & 0xFF就可以了。
輸入法的切換:WM_INPUTLANGCHANGE
platform sdk=>User Interface Servic=>windowing=>windows=>window reference =>Messages
關于輸入法:platform sdk=>Windows Base Services=>International Features=>Input Method Editor
自己處理鍵盤輸入要做的事:
如果你要自己處理鍵盤和輸入法的輸入而不用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;//用實際的值代替
????CompForm.ptCurrentPos.y?=?10;//用實際的值代替
????::ImmSetCompositionWindow(hIMC,?&CompForm);
????//DropCaret();可在此處隱藏光標,在OnImeEndComposition消息處理中再顯示光標
????::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();
}以上三個消息是不做處理也可以,只不過不會支持如微軟拼音輸入法的跟隨功能。
并WM_IME_CHAR和WM_CHAR添加字符。在WM_KEYDOWN中處理特殊字符,如VK_BACK VK_DELTE