我找到了代码,以便根据列项目中最长的字符串调整 ListViews 列的大小,但我想修改它,以便它也考虑列名称的长度以及调整大小。我有几个列,其中最长的字符串是列名本身。
我一直在谷歌上搜索以尝试解决这个问题,但我真的不明白这里使用的 API。
这个问题的扩展也是,LVM_FIRST
在这里做什么,我似乎无法在我的搜索中找到任何东西。
声明:
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 LVM_FIRST = &H1000
子:
Public Sub LV_AutoSizeColumn(LV As ListView, Optional Column _
As ColumnHeader = Nothing)
Dim C As ColumnHeader
If Column Is Nothing Then
For Each C In LV.ColumnHeaders
SendMessage LV.hWnd, LVM_FIRST + 30, C.Index - 1, -1
Next
Else
SendMessage LV.hWnd, LVM_FIRST + 30, Column.Index - 1, -1
End If
LV.Refresh
End Sub
最佳答案
LVM_FIRST + 30
是 LVM_SETCOLUMNWIDTH
设置给定列的宽度的消息。
-1
是 LVSCW_AUTOSIZE
,它告诉控件根据内容调整大小。如果您切换到 -2
(LVSCW_AUTOSIZE_USEHEADER
),控件将根据标题文本调整大小。
在您的循环中设置两者,注意哪个导致更大的 ColumnHeaders 宽度,然后使用适当的 LVSCW_
参数再次 SendMessage
。
关于vba - Excel VBA 自动调整 ListView 列的大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34138226/