没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
VB 如何使控件位置和大小自动适应窗体变化的三种不同模式
本人发现 VB2008 前版本使控件位置和大小自动适应窗体变化的提问很多。但回答的正确的不多。本人
用 vb6.0 也遇到此问题。认真研究的一下。给出最正确的三种模式给大家借鉴。有更好方法可以在交流。
代码是无需更改的。
第一种。就是最实用的,就是所有控件的 width 和 height 按比例随窗体变化,位置也是当然是按比例哦。
控件的字体不变。如下复制到代码:
'改比例,字体不该。最实用
Option Explicit
Private FormOldWidth As Long '保存窗体的原始宽度
Private FormOldHeight As Long '保存窗体的原始高度
Private Sub Form_Load()
Call ResizeInit(Me) '在程序装入时必须加入
End Sub
Private Sub Form_Resize()
Call ResizeForm(Me) '确保窗体改变时控件随之改变
End Sub
'在调用 ResizeForm 前先调用本函数
Public Sub ResizeInit(FormName As Form)
Dim Obj As Control
FormOldWidth = FormName.ScaleWidth
FormOldHeight = FormName.ScaleHeight
On Error Resume Next
For Each Obj In FormName
Obj.Tag = Obj.Left & " " & Obj.Top & " " & Obj.Width & " " & Obj.Height & " "
Next Obj
On Error GoTo 0
End Sub
'按比例改变表单内各元件的大小,在调用 ReSizeForm 前先调用 ReSizeInit 函数
Public Sub ResizeForm(FormName As Form)
Dim Pos(4) As Double
Dim i As Long, TempPos As Long, StartPos As Long
Dim Obj As Control
Dim ScaleX As Double, ScaleY As Double
ScaleX = FormName.ScaleWidth / FormOldWidth '保存窗体宽度缩放比例
ScaleY = FormName.ScaleHeight / FormOldHeight '保存窗体高度缩放比例
On Error Resume Next
For Each Obj In FormName
StartPos = 1
For i = 0 To 4
资源评论
- yangcced2013-09-22能实现窗体控件自动变化尺寸,有参考意义,值得推荐。
018极速
- 粉丝: 0
- 资源: 1
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功