一个关于 resize事件的问题,拜托帮帮忙

bihai123 2005-12-18 05:51:24
我的背景有一幅图片,图片上有很多信息,因此我为了标志这些信息做了几个IMAGE控件来标记,由于图幅较大显示器不能正常显示,因些在做界面时用的小尺寸,但是当启动窗体执行:maxsize(启动时),背景的图片相应的我设置适应窗体,但是这个时候用于对这个背景图片标注的相关控件的位置就不正确了,我试着写了代码,但是始终不知道怎么样才能正确定义:top left width height等属性,

我该怎么办呢?
...全文
151 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
faysky2 2006-01-04
  • 打赏
  • 举报
回复
northwolves(狼行天下) 给的方法应该能解决了
wenquan836 2006-01-03
  • 打赏
  • 举报
回复
没有理解清楚!! 也许是坐标的问题。

你用到窗体的宽高属性时 在Form_Resize()下面要用 Me.ScaleWidth 或 Me.ScaleHeight
bihai123 2006-01-02
  • 打赏
  • 举报
回复
图形热点?
zou19820704 2006-01-02
  • 打赏
  • 举报
回复
不知道该怎么做,还是一个控件一个控件按比例缩放大小!!
northwolves 2005-12-18
  • 打赏
  • 举报
回复
不过感觉你的问题用图形热点处理更合适,查查相关资料
northwolves 2005-12-18
  • 打赏
  • 举报
回复
这个网上流行的代码可以试试:
Option Explicit
Private InitWidth As Long ' Form 的原始大小
Private InitHeight As Long

Private Sub Form_Load()
InitWidth = ScaleWidth
InitHeight = ScaleHeight
Dim Ctl As Control
' 记录每个 Control 的原始位置、大小、字型大小, 放在 Tag 属性中
On Error Resume Next '确保left, top, width, height, Tag属性没有全有的Control
For Each Ctl In Me '也能正常执行
Ctl.Tag = Ctl.Left & " " & Ctl.Top & " " & Ctl.Width & " " & Ctl.Height & " "
Ctl.Tag = Ctl.Tag & Ctl.FontSize & " "
Next Ctl
On Error GoTo 0
End Sub

Private Sub Form_Resize()
Dim D(4) As Double
Dim I As Long
Dim TempPos As Long
Dim StartPos As Long
Dim Ctl As Control
Dim TempVisible As Boolean
Dim ScaleX As Double
Dim ScaleY As Double

ScaleX = ScaleWidth / InitWidth
ScaleY = ScaleHeight / InitHeight
On Error Resume Next
For Each Ctl In Me
TempVisible = Ctl.Visible
Ctl.Visible = False
StartPos = 1
' 读取 Control 的原始位置、大小、字型大小
For I = 0 To 4
TempPos = InStr(StartPos, Ctl.Tag, " ", vbTextCompare)
If TempPos > 0 Then
D(I) = Mid(Ctl.Tag, StartPos, TempPos - StartPos)
StartPos = TempPos + 1
Else
D(I) = 0
End If
' 根据比例设定 Control 的位置、大小、字型大小
Ctl.Move D(0) * ScaleX, D(1) * ScaleY, D(2) * ScaleX, D(3) * ScaleY
'Ctl.Width = D(2) * ScaleX
'Ctl.Height = D(3) * ScaleY
If ScaleX < ScaleY Then
Ctl.FontSize = D(4) * ScaleX
Else
Ctl.FontSize = D(4) * ScaleY
End If
Next I
Ctl.Visible = TempVisible
Next Ctl
On Error GoTo 0
End Sub

7,763

社区成员

发帖
与我相关
我的任务
社区描述
VB 基础类
社区管理员
  • VB基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧