agf
asked on
msResize.ocx - Start up Forms under MDIForm...
I Want Start up my forms under mdiForm using the msResize.OCX for resizing fonts,controls etc...
I fixed the forms with "not sizeble" for users but it did not work...
I fixed the forms with "not sizeble" for users but it did not work...
Use this class instead :
'************************* ********** ********** ********** *********
' Name: class_Elastic
' Description:This class can change size and location of controls
' on your form
' 1. Resize form
' 2. Change screen resolution
' By: Mikhail Shmukler
'
' Inputs:None
' Returns:None
' Assumes:1. Add Elastic.cls
'2. Add declaration 'private clsElastic as New class_Elastic'
'3. Insert string like 'clsElastic.init Me' (formload event)
'4. Insert string like 'clsElastic.FormResize Me' (Resize event)
'5. Press 'F5' and resize form ....
'
'************************* ********** ********** ********** *********
Option Explicit
Private iFormHeight As Integer
Private iFormWidth As Integer
Private iNumOfControls As Integer
Private iTop() As Integer
Private iLeft() As Integer
Private iHeight() As Integer
Private iWidth() As Integer
Private iFontSize() As Integer
Private iRightMargin() As Integer
Private bFirstTime As Boolean
Sub Init(FormName As Form, Optional WindState)
Dim I As Integer
Dim WinMax As Boolean
WinMax = Not IsMissing(WindState)
iFormHeight = FormName.Height
iFormWidth = FormName.Width
iNumOfControls = FormName.Controls.Count - 1
bFirstTime = True
ReDim iTop(iNumOfControls)
ReDim iLeft(iNumOfControls)
ReDim iHeight(iNumOfControls)
ReDim iWidth(iNumOfControls)
ReDim iFontSize(iNumOfControls)
ReDim iRightMargin(iNumOfControl s)
On Error Resume Next
For I = 0 To iNumOfControls
If TypeOf FormName.Controls(I) Is Line Then
iTop(I) = FormName.Controls(I).Y1
iLeft(I) = FormName.Controls(I).X1
iHeight(I) = FormName.Controls(I).Y2
iWidth(I) = FormName.Controls(I).X2
Else
iTop(I) = FormName.Controls(I).Top
iLeft(I) = FormName.Controls(I).Left
iHeight(I) = FormName.Controls(I).Heigh t
iWidth(I) = FormName.Controls(I).Width
iFontSize(I) = FormName.FontSize
iRightMargin(I) = FormName.Controls(I).Right Margin
End If
Next
If WinMax Or FormName.WindowState = 2 Then ' maxim
FormName.Height = Screen.Height
FormName.Width = Screen.Width
Else
FormName.Height = FormName.Height * Screen.Height / 7290
FormName.Width = FormName.Width * Screen.Width / 9690
End If
bFirstTime = True
End Sub
Sub FormResize(FormName As Form)
Dim I As Integer
Dim Inc As Integer
Dim CaptionSize As Integer
Dim RatioX As Double
Dim RatioY As Double
Dim SaveRedraw As Long
On Error Resume Next
SaveRedraw = FormName.AutoRedraw
FormName.AutoRedraw = True
If bFirstTime Then
bFirstTime = False
Exit Sub
End If
If FormName.Height < iFormHeight / 2 Then FormName.Height = iFormHeight / 2
If FormName.Width < iFormWidth / 2 Then FormName.Width = iFormWidth / 2
CaptionSize = 400
RatioY = 1# * (iFormHeight - CaptionSize) / (FormName.Height - CaptionSize)
RatioX = 1# * iFormWidth / FormName.Width
On Error Resume Next ' for comboboxes, timeres and other nonsizible controls
For I = 0 To iNumOfControls
If TypeOf FormName.Controls(I) Is Line Then
FormName.Controls(I).Y1 = Int(iTop(I) / RatioY)
FormName.Controls(I).X1 = Int(iLeft(I) / RatioX)
FormName.Controls(I).Y2 = Int(iHeight(I) / RatioY)
FormName.Controls(I).X2 = Int(iWidth(I) / RatioX)
Else
FormName.Controls(I).Top = Int(iTop(I) / RatioY)
FormName.Controls(I).Left = Int(iLeft(I) / RatioX)
FormName.Controls(I).Heigh t = Int(iHeight(I) / RatioY)
FormName.Controls(I).Width = Int(iWidth(I) / RatioX)
FormName.Controls(I).FontS ize = Int(iFontSize(I) / RatioX) + Int(iFontSize(I) / RatioX) Mod 2
FormName.Controls(I).Right Margin = Int(iRightMargin(I) / RatioY)
End If
Next
FormName.AutoRedraw = SaveRedraw
End Sub
'*************************
' Name: class_Elastic
' Description:This class can change size and location of controls
' on your form
' 1. Resize form
' 2. Change screen resolution
' By: Mikhail Shmukler
'
' Inputs:None
' Returns:None
' Assumes:1. Add Elastic.cls
'2. Add declaration 'private clsElastic as New class_Elastic'
'3. Insert string like 'clsElastic.init Me' (formload event)
'4. Insert string like 'clsElastic.FormResize Me' (Resize event)
'5. Press 'F5' and resize form ....
'
'*************************
Option Explicit
Private iFormHeight As Integer
Private iFormWidth As Integer
Private iNumOfControls As Integer
Private iTop() As Integer
Private iLeft() As Integer
Private iHeight() As Integer
Private iWidth() As Integer
Private iFontSize() As Integer
Private iRightMargin() As Integer
Private bFirstTime As Boolean
Sub Init(FormName As Form, Optional WindState)
Dim I As Integer
Dim WinMax As Boolean
WinMax = Not IsMissing(WindState)
iFormHeight = FormName.Height
iFormWidth = FormName.Width
iNumOfControls = FormName.Controls.Count - 1
bFirstTime = True
ReDim iTop(iNumOfControls)
ReDim iLeft(iNumOfControls)
ReDim iHeight(iNumOfControls)
ReDim iWidth(iNumOfControls)
ReDim iFontSize(iNumOfControls)
ReDim iRightMargin(iNumOfControl
On Error Resume Next
For I = 0 To iNumOfControls
If TypeOf FormName.Controls(I) Is Line Then
iTop(I) = FormName.Controls(I).Y1
iLeft(I) = FormName.Controls(I).X1
iHeight(I) = FormName.Controls(I).Y2
iWidth(I) = FormName.Controls(I).X2
Else
iTop(I) = FormName.Controls(I).Top
iLeft(I) = FormName.Controls(I).Left
iHeight(I) = FormName.Controls(I).Heigh
iWidth(I) = FormName.Controls(I).Width
iFontSize(I) = FormName.FontSize
iRightMargin(I) = FormName.Controls(I).Right
End If
Next
If WinMax Or FormName.WindowState = 2 Then ' maxim
FormName.Height = Screen.Height
FormName.Width = Screen.Width
Else
FormName.Height = FormName.Height * Screen.Height / 7290
FormName.Width = FormName.Width * Screen.Width / 9690
End If
bFirstTime = True
End Sub
Sub FormResize(FormName As Form)
Dim I As Integer
Dim Inc As Integer
Dim CaptionSize As Integer
Dim RatioX As Double
Dim RatioY As Double
Dim SaveRedraw As Long
On Error Resume Next
SaveRedraw = FormName.AutoRedraw
FormName.AutoRedraw = True
If bFirstTime Then
bFirstTime = False
Exit Sub
End If
If FormName.Height < iFormHeight / 2 Then FormName.Height = iFormHeight / 2
If FormName.Width < iFormWidth / 2 Then FormName.Width = iFormWidth / 2
CaptionSize = 400
RatioY = 1# * (iFormHeight - CaptionSize) / (FormName.Height - CaptionSize)
RatioX = 1# * iFormWidth / FormName.Width
On Error Resume Next ' for comboboxes, timeres and other nonsizible controls
For I = 0 To iNumOfControls
If TypeOf FormName.Controls(I) Is Line Then
FormName.Controls(I).Y1 = Int(iTop(I) / RatioY)
FormName.Controls(I).X1 = Int(iLeft(I) / RatioX)
FormName.Controls(I).Y2 = Int(iHeight(I) / RatioY)
FormName.Controls(I).X2 = Int(iWidth(I) / RatioX)
Else
FormName.Controls(I).Top = Int(iTop(I) / RatioY)
FormName.Controls(I).Left = Int(iLeft(I) / RatioX)
FormName.Controls(I).Heigh
FormName.Controls(I).Width
FormName.Controls(I).FontS
FormName.Controls(I).Right
End If
Next
FormName.AutoRedraw = SaveRedraw
End Sub
ASKER
Waty, I test Your solution but the forms under MDIForm are resizing greater than was design. For example: I create them in resolution 800X600 and small fonts, but , When I configured Large fonts, was generated a problem. All fonts and Controls are displaying wrongs,unproporcional... Can You send me a source code
fixing fonts for all controls in project when it Starts ?
fixing fonts for all controls in project when it Starts ?
"No sizable" only used to don't let user resize use mouse, but you can use code to resize it or call it's resize event procedure.
ASKER
If the project was design with small fonts, and the user modify
for large fonts all the forms will display unproporcional, ok ?
Please,
Can You send me a source code fixing fonts for all controls in project when it Starts ?
for large fonts all the forms will display unproporcional, ok ?
Please,
Can You send me a source code fixing fonts for all controls in project when it Starts ?
Unluckly, I don' have code to do that, but by modifying the class I gave you, you could do it easily.
ASKER
Waty, thank you ! I will try...
ASKER CERTIFIED SOLUTION
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
'*************************
' Name: class_Elastic
' Description:This class can change size and location of controls
' on your form
' 1. Resize form
' 2. Change screen resolution
' By: Mikhail Shmukler
'
' Inputs:None
' Returns:None
' Assumes:1. Add Elastic.cls
'2. Add declaration 'private clsElastic as New class_Elastic'
'3. Insert string like 'clsElastic.init Me' (formload event)
'4. Insert string like 'clsElastic.FormResize Me' (Resize event)
'5. Press 'F5' and resize form ....
'
'*************************
Option Explicit
Private iFormHeight As Integer
Private iFormWidth As Integer
Private iNumOfControls As Integer
Private iTop() As Integer
Private iLeft() As Integer
Private iHeight() As Integer
Private iWidth() As Integer
Private iFontSize() As Integer
Private iRightMargin() As Integer
Private bFirstTime As Boolean
Sub Init(FormName As Form, Optional WindState)
Dim I As Integer
Dim WinMax As Boolean
WinMax = Not IsMissing(WindState)
iFormHeight = FormName.Height
iFormWidth = FormName.Width
iNumOfControls = FormName.Controls.Count - 1
bFirstTime = True
ReDim iTop(iNumOfControls)
ReDim iLeft(iNumOfControls)
ReDim iHeight(iNumOfControls)
ReDim iWidth(iNumOfControls)
ReDim iFontSize(iNumOfControls)
ReDim iRightMargin(iNumOfControl
On Error Resume Next
For I = 0 To iNumOfControls
If TypeOf FormName.Controls(I) Is Line Then
iTop(I) = FormName.Controls(I).Y1
iLeft(I) = FormName.Controls(I).X1
iHeight(I) = FormName.Controls(I).Y2
iWidth(I) = FormName.Controls(I).X2
Else
iTop(I) = FormName.Controls(I).Top
iLeft(I) = FormName.Controls(I).Left
iHeight(I) = FormName.Controls(I).Heigh
iWidth(I) = FormName.Controls(I).Width
iFontSize(I) = FormName.FontSize
iRightMargin(I) = FormName.Controls(I).Right
End If
Next
If WinMax Or FormName.WindowState = 2 Then ' maxim
FormName.Height = Screen.Height
FormName.Width = Screen.Width
Else
FormName.Height = FormName.Height * Screen.Height / 7290
FormName.Width = FormName.Width * Screen.Width / 9690
End If
bFirstTime = True
End Sub
Sub FormResize(FormName As Form)
Dim I As Integer
Dim Inc As Integer
Dim CaptionSize As Integer
Dim RatioX As Double
Dim RatioY As Double
Dim SaveRedraw As Long
On Error Resume Next
SaveRedraw = FormName.AutoRedraw
FormName.AutoRedraw = True
If bFirstTime Then
bFirstTime = False
Exit Sub
End If
If FormName.Height < iFormHeight / 2 Then FormName.Height = iFormHeight / 2
If FormName.Width < iFormWidth / 2 Then FormName.Width = iFormWidth / 2
CaptionSize = 400
RatioY = 1# * (iFormHeight - CaptionSize) / (FormName.Height - CaptionSize)
RatioX = 1# * iFormWidth / FormName.Width
On Error Resume Next ' for comboboxes, timeres and other nonsizible controls
For I = 0 To iNumOfControls
If TypeOf FormName.Controls(I) Is Line Then
FormName.Controls(I).Y1 = Int(iTop(I) / RatioY)
FormName.Controls(I).X1 = Int(iLeft(I) / RatioX)
FormName.Controls(I).Y2 = Int(iHeight(I) / RatioY)
FormName.Controls(I).X2 = Int(iWidth(I) / RatioX)
Else
FormName.Controls(I).Top = Int(iTop(I) / RatioY)
FormName.Controls(I).Left = Int(iLeft(I) / RatioX)
FormName.Controls(I).Heigh
FormName.Controls(I).Width
FormName.Controls(I).FontS
FormName.Controls(I).Right
End If
Next
FormName.AutoRedraw = SaveRedraw
End Sub