VB窗口最大化&控件大小跟随窗体大小变化而变化

'加载窗体
Private Sub Form_Load()
    '获取每个控件大小比例
    ReDim ap(0 To Me.Controls.Count - 1)
    GetControlsSize Form_物流信息
    '窗口最大化
    Me.Left = 0
    Me.Top = 0
    Me.Width = ScreenWidth
    Me.Height = ScreenHeight
End Sub

'窗体尺寸改变时
Private Sub Form_Resize()
    Dim i As Integer
    On Error GoTo uerror
    For i = 0 To Controls.Count - 1
        Controls(i).Move ap(i).lp * Me.ScaleWidth, ap(i).tp * Me.ScaleHeight, ap(i).wp * Me.ScaleWidth, ap(i).hp * Me.ScaleHeight
        If Not Me.Controls(i).Name Like "ListView*" Then
            Controls(i).Font.Size = ap(i).fp * (Controls(i).Width * Controls(i).Height)
        End If
    Next i
    Exit Sub
uerror:
    Resume Next
End Sub


'屏幕宽
Function ScreenWidth() As Long
    ScreenWidth = GetSystemMetrics32(0) * 15
End Function
'屏幕高,去除底部状态栏高度
Function ScreenHeight() As Long
    ScreenHeight = (GetSystemMetrics32(1) - 40) * 15
End Function

'定义窗体过程
Public Sub GetControlsSize(ByVal fm As Form)
    On Error GoTo uerror   '跳过无width属性控件
    With fm
        For i = 0 To .Controls.Count - 1
            ap(i).wp = .Controls(i).Width / .ScaleWidth
            ap(i).hp = .Controls(i).Height / .ScaleHeight
            ap(i).lp = .Controls(i).Left / .ScaleWidth
            ap(i).tp = .Controls(i).Top / .ScaleHeight
            ap(i).fp = .Controls(i).Font.Size / (.Controls(i).Width * .Controls(i).Height)
        Next i
    End With
    Exit Sub
uerror:
    Resume Next
End Sub

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值