用户登录  |  用户注册
首 页商业源码原创产品编程论坛
当前位置:PB创新网文章中心编程技巧VisualBasic

自动改变控件大小

减小字体 增大字体 作者:佚名  来源:本站整理  发布时间:2009-03-16 19:49:53
当 窗 体 大 小 改 变 时, 如 何 动 态 的 改 变 控 件 的 大 小 是 许 多VB
程 序 员 头 痛 的 事。 有 的 人 设 置 窗 体Resizable 但 却 不 改 变 控
件 的 大 小; 有 的 人 则 根 据 控 件 的 绝 对 位 置 与 窗 口 大 小 相
加 减 的 办 法 来 重 新 定 位 控 件 与 改 变 大 小, 这 种 办 法 比 较
繁 琐, 且 不 可 重 用; 当 然 也 有 人 则 限 定 窗 口 干 脆 不 让 改 变。
有 没 有 一 种 简 便 易 行 的 办 法 ? 答 案 是 肯 定 的, 下 面 给 出
一 个 一 劳 永 逸 的 办 法, 源 程 序 如 下:

Option Explicit

Private FormOldWidth As Long ''保存窗体的原始宽度
Private FormOldHeight As Long ''保存窗体的原始高度


''在调用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 ''读取控件的原始位置与大小
TempPos = InStr(StartPos, Obj.Tag, " ", vbTextCompare)
If TempPos > 0 Then
Pos(i) = Mid(Obj.Tag, StartPos, TempPos - StartPos)
StartPos = TempPos + 1 Else Pos(i) = 0
End If

''根据控件的原始位置及窗体改变大小 的比例对控件重新定位与改变大小

Obj.Move Pos(0) * ScaleX, Pos(1) * ScaleY, Pos(2) * ScaleX, Pos(3) *
ScaleY

Next i

Next Obj

On Error GoTo 0

End Sub

Private Sub Form_Load()

Call ResizeInit(Me) ''在程序装入时必须加入

End Sub

Private Sub Form_Resize()

Call ResizeForm(Me) ''确保窗体改变时控件随之改变

End Sub

本 例 中 给 出 了 二 个 函 数:ResizeInit 和ResizeForm, 在 调 用
ResizeForm 之 前 必 须 先 调 用ResizeInit。 你 可 以 将 本 程 序 拷 到
窗 体 代 码 段 里, 然 后 在 窗 体 里 加 入 任 意 控 件 即 可 进 行 测
试。

Tags:

作者:佚名

文章评论评论内容只代表网友观点,与本站立场无关!

   评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
PB创新网ourmis.com】Copyright © 2000-2009 . All Rights Reserved .
页面执行时间:24,890.63000 毫秒
Email:ourmis@126.com QQ:2322888 蜀ICP备05006790号