⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mdlformsize.bas

📁 <Visual Basic 数据库开发实例精粹(第二版)>一书首先介绍了Visual Basic(简称VB)开发的技巧和重点技术
💻 BAS
字号:
Attribute VB_Name = "mdlFormSize"
Option Explicit

'API声明
Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long
Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (pDest As Any, pSource As Any, ByVal ByteLen As Long)
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

'常数声明
Public Const WM_GETMINMAXINFO = &H24

'类型声明
Type POINTAPI
  x As Long
  y As Long
End Type

Type MINMAXINFO
  ptReserved As POINTAPI
  ptMaxSize As POINTAPI
  ptMaxPosition As POINTAPI
  ptMinTrackSize As POINTAPI
  ptMaxTrackSize As POINTAPI
End Type

Public OldWindowProc As Long

Public Function FormSize_WndMessage(ByVal hwnd As Long, ByVal Msg As Long, ByVal WP As Long, ByVal LP As Long) As Long
  If Msg = WM_GETMINMAXINFO Then
    Dim MinMax As MINMAXINFO
    CopyMemory MinMax, ByVal LP, Len(MinMax)
    MinMax.ptMinTrackSize.x = 760
    MinMax.ptMinTrackSize.y = 575
    MinMax.ptMaxTrackSize.x = 1024
    MinMax.ptMaxTrackSize.y = 768
    CopyMemory ByVal LP, MinMax, Len(MinMax)
    FormSize_WndMessage = 1
    Exit Function
  End If
  FormSize_WndMessage = CallWindowProc(OldWindowProc, hwnd, Msg, WP, LP)
End Function

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -