首先,在Form中添加一個文本框(TextBox),將其MultiLine屬性設置為True,以便輸入多行文本;再在Form中添加兩個標題欄(Label),以便顯示光標位置;然後,在Form的代碼窗口中添加程序中的代碼。
OptionExplici
ConstEM_GETSEL=&HB0
ConstEM_LINEFROMCHAR=&HC9
ConstEM_LINEINDEX=&HBB
PrivateDeclareFunctionSendMessageLib"user32"Alias"SendMessageA"(ByValhwndAsLong,ByValwMsgAsLong,ByValwParamAsLong,lParamAsAny)AsLong
PublicSubGetCaretPos(ByValTextHwndAsLong,LineNoAsLong,ColNoAsLong)
DimIAsLong,jAsLong
DimlParamAsLong,wParamAsLong
DimkAsLong
'首先向文本框傳遞EM_GETSEL消息以獲取從起始位置到
'光標所在位置的字符數
I=SendMessage(TextHwnd,EM_GETSEL,wParam,lParam)
j=I/2^16
'再向文本框傳遞EM_LINEFROMCHAR消息根據獲得的字符
'數確定光標以獲取所在行數
LineNo=SendMessage(TextHwnd,EM_LINEFROMCHAR,j,0)
LineNo=LineNo 1
'向文本框傳遞EM_LINEINDEX消息以獲取所在列數
k=SendMessage(TextHwnd,EM_LINEINDEX,-1,0)
ColNo=j-k 1
EndSub
PrivateSubForm_Load()
DimLineNoAsLong,ColNoAsLong
CallGetCaretPos(Text1.hwnd,LineNo,ColNo)
Label1.Caption=LineNo
Label2.Caption=ColNo
EndSub
PrivateSubForm_Resize()
Text1.Width=Me.ScaleWidth
EndSub
PrivateSubText1_KeyUp(KeyCodeAsInteger,ShiftAsInteger)
DimLineNoAsLong,ColNoAsLong
CallGetCaretPos(Text1.hwnd,LineNo,ColNo)
Label1.Caption=LineNo
Label2.Caption=ColNo
EndSub
PrivateSubText1_MouseDown(ButtonAsInteger,ShiftAsInteger,XAsSingle,YAsSingle)
DimLineNoAsLong,ColNoAsLong
CallGetCaretPos(Text1.hwnd,LineNo,ColNo)
Label1.Caption=LineNo
Label2.Caption=ColNo
EndSub
(程序)
運行上面的程序,在TextBox中輸入字符或者按控制鍵來移動光標時,你可以看到屏幕下面的Label中就能顯示出的光標所在的位置。以上程序在Win95,VB5.0下運行通過。
->