各位大侠,我是新手,我有一个窗体,里面有Frame1,Text1,我想让这两个控件的大小随窗体的变化而成比例变化,请高手指点,另外,我想做一个类似SQLServer企业管理器的一个窗体,就是在一个MDIForm存在的条件下,再增加一个Form,这两个是一起的,关掉Form,MDIForm还存在,也许我说的不是很清楚,请各位大侠原谅!

解决方案 »

  1.   

    '模块中
    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前先调用0ReSizeInit函数
    Public Sub ResizeForm(FormName As Form,Obj as ConTrol)
      Dim Pos(4) As Double
      Dim i As Long, TempPos As Long, StartPos As Long
      Dim ScaleX As Double, ScaleY As Double
      '在调试时如果出现除数为零错误,是因为没有设定form的初值,请双击form1然后再测试,这个问题绝对不会在编译好的程序中出现
      If FormOldWidth = 0 Then '防止该错误的产生
        Exit Sub
      End If
      ScaleX = FormName.ScaleWidth / FormOldWidth   '保存窗体宽度缩放比例
      ScaleY = FormName.ScaleHeight / FormOldHeight '保存窗体高度缩放比例
      On Error Resume Next
      
        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
      On Error GoTo 0
    End Sub'窗体中
    Private Sub Form_Load()
      call ResizeInit
    End Sub
    Private Sub Form_Resize()
        call ResizeForm(me,frame1)
        call ResizeForm(me,Text1)
    End Sub