Option Explicit
Private Const GWL_WNDPROC = (-4)
Private Const WM_GETMINMAXINFO = &H24
Private Type POINTAPI
x As Long
y As Long
End Type
Private Type MINMAXINFO
ptReserved As POINTAPI
ptMaxSize As POINTAPI
ptMaxPosition As POINTAPI
ptMinTrackSize As POINTAPI
ptMaxTrackSize As POINTAPI
End Type
Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
Private Declare Function CallWindowProc Lib "user32" Alias "CallWindowProcA" (ByVal lpPrevWndFunc As Long, ByVal hwnd As Long, ByVal Msg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)
Private Declare Function DefWindowProc Lib "user32" Alias "DefWindowProcA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
Private Declare Function GetProp Lib "user32" Alias "GetPropA" (ByVal hwnd As Long, ByVal lpString As String) As Long
Private Declare Function SetProp Lib "user32" Alias "SetPropA" (ByVal hwnd As Long, ByVal lpString As String, ByVal hData As Long) As Long
Public Sub SubClass(ByVal hwnd As Long)
Dim lPrevWndProc As Long
If GetProp(hwnd, "MinSizeHandler") <> 0 Then Exit Sub
lPrevWndProc = SetWindowLong(hwnd, GWL_WNDPROC, AddressOf WindowProc)
Call SetProp(hwnd, "MinSizeHandler", lPrevWndProc)
End Sub
Public Sub RemoveSubClass(ByVal hwnd As Long)
If GetProp(hwnd, "MinSizeHandler") = 0 Then Exit Sub
Call SetWindowLong(hwnd, GWL_WNDPROC, GetProp(hwnd, "MinSizeHandler"))
Call SetProp(hwnd, "MinSizeHandler", 0)
End Sub
Private Function WindowProc(ByVal hwnd As Long, ByVal nMsg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
Dim tMINMAX As MINMAXINFO
Dim lPrevWndProc As Long
lPrevWndProc = GetProp(hwnd, "MinSizeHandler")
If nMsg = WM_GETMINMAXINFO Then
Call CallWindowProc(lPrevWndProc, hwnd, nMsg, wParam, lParam)
Call CopyMemory(tMINMAX, ByVal lParam, Len(tMINMAX))
tMINMAX.ptMinTrackSize.x = 200
tMINMAX.ptMinTrackSize.y = 200
Call CopyMemory(ByVal lParam, tMINMAX, Len(tMINMAX))
WindowProc = DefWindowProc(hwnd, nMsg, wParam, lParam)
Else
WindowProc = CallWindowProc(lPrevWndProc, hwnd, nMsg, wParam, lParam)
End If
End Function