常见问题:文本框控件的消息及应用

来源:计算机等级考试    发布时间:2012-08-29    计算机等级考试视频    评论


  EM_SETSEL 设置编辑控件中一段选定内容的起点一终点
  下面将介绍文本框控件消息的一些应用:
  下面的函数将返回控件的文本行数,如果控件的文本为空也会返回1。
  Function GetLineCount(CTextBox As TextBox) As Long
  GetLineCount = SendMessage(CTextBox.hWnd, EM_GETLINECOUNT, 0, 0)
  End Function
  下面的函数将返回控件中显示的第一行的行号。
  Function GetFirstVisableLine(CTextBox As TextBox) As Long
  GetFirstVisableLine = SendMessageBynum(CTextBox.hwnd, EM_GETFIRSTVISIBLELINE, 0, 0)
  End Function
  下面的函数将返回控件能显示的行数。
  Function GetVisibleLines(CTextBox As TextBox) As Long
  Dim rc As RECT
  Dim hDC&, lfont&, oldfont&
  Dim di&, lc&
  Dim tm As TEXTMETRIC
  lc = SendMessage(CTextBox.hwnd, EM_GETRECT, 0, rc)
  lfont = SendMessage(CTextBox.hwnd, WM_GETFONT, 0, 0)
  hDC = GetDC(CTextBox.hwnd)
  If lfont <> 0 Then oldfont = SelectObject(hDC, lfont)
  di = GetTextMetrics(hDC, tm)
  If lfont <> 0 Then lfont = SelectObject(hDC, oldfont)
  GetVisibleLines = (rc.bottom - rc.top) / tm.tmHeight
  di = ReleaseDC(CTextBox.hwnd, hDC)
  End Function
  下面的函数能够滚动控件,不过在滚动之前最好判断控件的文本行数和能够显示的行数,以免滚动时发生混乱。函数SendMessageBynum是一个SendMessage函数的安全声明函数,其定义与SendMessage函数完全相同,只是函数名不同。
  Function ScrollTextBox(CTextBox As TextBox, nVal As Long, Optional nVertical As Boolean = True) As Long
  If nVertical Then
  ScrollTextBox = SendMessageBynum(CTextBox.hwnd, EM_LINESCROLL, 0, nVal)
  Else
  ScrollTextBox = SendMessageBynum(CTextBox.hwnd, EM_LINESCROLL, nVal, 0)
  End If
  End Function
  下面的函数能够返回控件指定行的文本。SendMessageBystring与SendMessageBynum类似。
  Function GetLineText(CTextBox As TextBox, LineIndex As Long) As String
  Dim lc&, linechar&
  linechar = SendMessageBynum(CTextBox.hwnd, EM_LINEINDEX, LineIndex, 0)
  lc = SendMessageBynum(CTextBox.hwnd, EM_LINELENGTH, linechar, 0) + 1
  GetLineText = String$(lc + 2, 0)
  Mid$(GetLineText, 1, 1) = Chr(lc And &HFF)
  Mid$(GetLineText, 2, 1) = Chr(lc / &H100)
  lc = SendMessageBystring(CTextBox.hwnd, EM_GETLINE, LineIndex, GetLineText)
  GetLineText = left(GetLineText, lc)
  End Function
  下面的函数可以设置控件的左边距。
  Public Const EM_SETMARGINS& = &HD3
  Public Const EC_LEFTMARGIN& = &H1
  Function SetMargins(CTextBox As TextBox, nVal As Long) As Long
  SetMargins = SendMessageBynum(CTextBox.hwnd, EM_SETMARGINS, EC_LEFTMARGIN, nVal)
  End Function

上一页12下一页

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答