VB6.0自动调整窗口布局
有没有VB6.0自动调整窗口的代码?有的是1024X768的,有的电脑是1280x800的布局不知道按哪个分辨率分。大家有什么办法吗?...
有没有VB6.0自动调整窗口的代码?
有的 是1024X768的,有的电脑是1280x800的
布局不知道按哪个分辨率分。
大家有什么办法吗? 展开
有的 是1024X768的,有的电脑是1280x800的
布局不知道按哪个分辨率分。
大家有什么办法吗? 展开
2个回答
展开全部
Public Sub ResizeInit(cForm As Form)
'函数说明:用于窗体加载时初始化
'传入参数:cForm-窗体对象
Dim fWidth As Single '记录当前控件所处于的容器的宽度
Dim fHeight As Single '记录当前控件所处于的容器的高度
Dim fObj As Control
On Error Resume Next
For Each fObj In cForm
fWidth = fObj.Container.Width
fHeight = fObj.Container.Height
fObj.Tag = fWidth & " " & fHeight & " " & fObj.Left & " " & fObj.Top & " " & fObj.Width & " " & fObj.Height
Next
End Sub
Public Sub ResizeForm(cForm As Form)
'函数说明:更改控件位置
'传入参数:cForm-窗体对象
Dim xSingle As Single
Dim ySingle As Single
Dim Pos As Variant
'此句是防止窗体在最大化最小时,出现刷新操作浪费时间(更重要的是我在组态中
'当最大化,最小化时,刷新组态里面的控件会出错,所以加上此句)
If cForm.WindowState <> 0 Then Exit Sub
On Error Resume Next
For Each fObj In cForm
Pos = Split(fObj.Tag, " ")
xSingle = fObj.Container.Width / Pos(0)
ySingle = fObj.Container.Height / Pos(1)
fObj.FontSize = fObj.FontSize / ySingle
If TypeOf fObj Is ComboBox Then '当控件为ComboBox,此控件不能改变高度,单独处理
fObj.Left = Pos(2) * xSingle
fObj.Top = Pos(3) * ySingle
fObj.Width = Pos(4) * xSingle
Else
fObj.Move Pos(2) * xSingle, Pos(3) * ySingle, Pos(4) * xSingle, Pos(5) * ySingle
End If
Next
End Sub
在窗体加载时调用
ResziseInit me
窗体的Resize事件中调用
ResziseForm me
回答的好的话给点分吧!
'函数说明:用于窗体加载时初始化
'传入参数:cForm-窗体对象
Dim fWidth As Single '记录当前控件所处于的容器的宽度
Dim fHeight As Single '记录当前控件所处于的容器的高度
Dim fObj As Control
On Error Resume Next
For Each fObj In cForm
fWidth = fObj.Container.Width
fHeight = fObj.Container.Height
fObj.Tag = fWidth & " " & fHeight & " " & fObj.Left & " " & fObj.Top & " " & fObj.Width & " " & fObj.Height
Next
End Sub
Public Sub ResizeForm(cForm As Form)
'函数说明:更改控件位置
'传入参数:cForm-窗体对象
Dim xSingle As Single
Dim ySingle As Single
Dim Pos As Variant
'此句是防止窗体在最大化最小时,出现刷新操作浪费时间(更重要的是我在组态中
'当最大化,最小化时,刷新组态里面的控件会出错,所以加上此句)
If cForm.WindowState <> 0 Then Exit Sub
On Error Resume Next
For Each fObj In cForm
Pos = Split(fObj.Tag, " ")
xSingle = fObj.Container.Width / Pos(0)
ySingle = fObj.Container.Height / Pos(1)
fObj.FontSize = fObj.FontSize / ySingle
If TypeOf fObj Is ComboBox Then '当控件为ComboBox,此控件不能改变高度,单独处理
fObj.Left = Pos(2) * xSingle
fObj.Top = Pos(3) * ySingle
fObj.Width = Pos(4) * xSingle
Else
fObj.Move Pos(2) * xSingle, Pos(3) * ySingle, Pos(4) * xSingle, Pos(5) * ySingle
End If
Next
End Sub
在窗体加载时调用
ResziseInit me
窗体的Resize事件中调用
ResziseForm me
回答的好的话给点分吧!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询