读书人

着急控件大小根据窗体拖动改变的有关问

发布时间: 2012-01-08 22:48:50 作者: rapoo

着急~~~~控件大小根据窗体拖动改变的问题
窗体上有很多控件
窗体拖动同时改变控件大小
但是控件之间的距离不变
请问如何实现?
谢谢~~~
着急~~~~


[解决办法]
用第三方控件吧,非常好用:Resize32.ocx
如果需要我可以发给你
王窗体上一放就行了,一句代码都不用写
[解决办法]
Private Sub Form_Resize()

End Sub
这个事件中自己

[解决办法]
可以使用第三方控件,不如Reseize控件
[解决办法]
Private Sub Form_Resize()

End Sub
这个里面自己写控件的移动 位置之类的代码就行了

[解决办法]
Option Explicit
Private ObjOldWidth As Long '保存窗体的原始宽度
Private ObjOldHeight As Long '保存窗体的原始高度
Private ObjOldFont As Single '保存窗体的原始字体比

'在调用ResizeForm前先调用本函数
Public Sub ResizeInit(FormName As Form)
Dim Obj As Control

ObjOldWidth = FormName.ScaleWidth
ObjOldHeight = FormName.ScaleHeight
ObjOldFont = FormName.Font.Size / ObjOldHeight
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 / ObjOldWidth
'保存窗体宽度缩放比例
ScaleY = FormName.ScaleHeight / ObjOldHeight
'保存窗体高度缩放比例
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
Obj.Font.Size = ObjOldFont * FormName.ScaleHeight
Next i

Next Obj

On Error GoTo 0
End Sub

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

Private Sub Form_Load()
'在程序装入时必须加入
Call ResizeInit(Me)
End Sub



[解决办法]
//窗体拖动同时改变控件大小
但是控件之间的距离不变

这个就是数学问题,先讨论x轴,先算出各个控件的距离之和,记做a,缩放前窗体宽度-a记做b,缩放后窗体宽度-a记做c,c/b就是缩放比例,然后设置控件的left,width,纵向同理


不过,实际上,你要考虑更多的东西,比如说,某些控件运行时是无法改变高度的

读书人网 >VB

热点推荐