如何在分辨率不同的机器上安装程序,让程序自动适应?如何编程?
解决方案 »
- VB object
- 在VB里如何导出SQL里select出来的一张整表?
- 请教高手:关于用MSCommon控件控制modem的问题
- 有关UTF-8的问题,进来帮我看看吧。 救你们了。。。
- 问一个数据连接的问题(关于MySQL)
- 请问!为什么一个子窗体的最大才为12000*9000,而且宽是12000,能不能把长和宽调转过来,然宽为9000,长为12000呢?
- 时间与日期的处理问题
- 一个关于vb的小问题
- 如何得到文件的扩展名?
- 改学VB7.0吗?
- FORM问题,谢谢!
- 一个关于SQL与其它数据库导出和导入的问题(select * into [FoxPro 2.5;database=同上].导出表名 from 表),请大家关注。
Private Sub Form_Resize()End Sub
最大的问题是得到当前的分辨率
其实,可以得到screen.width和screen.hight得到当前分辨率剩下的就简单了
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 DoubleScaleX = 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()
ResizeInit Form1
End SubPrivate Sub Form_Resize()
ResizeForm Form1
End Sub
本例在任何调整窗体大小时的时候,都将自动调整一个 TextBox 控件的大小以填充该窗体。要尝试这个例子,可以将代码粘贴到包含 TextBox 的窗体声明部分。 设置 TextBox 控件的 MultiLine 属性为 True,ScrollBars 属性为 3,BorderStyle 属性为 0,然后按F5键并调整窗体大小。Private Sub Form_Load ()
Text1.Text = "" ' 清除文本。
End SubPrivate Sub Form_Resize ()
Text1.Move 0,0, ScaleWidth, ScaleHeight
End Sub