Private Declare Function SendMessage Lib "user32 " Alias "SendMessageA" (ByVal hwnd As Long, _ ByVal wMsg As Long, _ ByVal wParam As Long, _ lParam As Any) As Long Private Const LB_SETHORIZONTALEXTENT = &H194-------------------------------------------------------------------------------------------------- Private Sub setListWidth() ‘如果列表框不够宽,则增加水平滚动条 Dim i As Integer Dim List_MaxL As Integer ‘获得选项内容的最大长度 For i = 0 To List1.ListCount - 1 ‘'让list_maxl中保存最长的一条字串 If Len(List1.List(i)) > List_MaxL Then List_MaxL = Len(List1.List(i)) + 2 End If Next i ‘判断是否内容显示不完全,如果是则添加水平滚动条 If Me.TextWidth("AA ") * List_MaxL > List1.Width Then SendMessage List1.hwnd, LB_SETHORIZONTALEXTENT, Me.TextWidth("a") * List_MaxL, ByVal 0& End If End Sub
--------------------------------------------------------------------------------------------------
Private Sub Form_Load() Dim i As Integer ‘为ListBox控件添加选项 For i = 0 To 100 List1.AddItem ("这是,最据jjjjjjjjjjjjjjjjjjjjjjjjjjjjjjj:(第 " + CStr(i)) & "行) " ‘List1.AddItem ( "(第 " + CStr(i)) & "行) " Next i ‘ 设置窗体坐标尺度模式和字体大小 Me.ScaleMode = vbPixels Me.FontSize = List1.FontSize 设置列表框的水平滚动条 Call setListWidth End Sub
时间: 2024-11-11 03:01:52