Improve company productivity with a Business Account.Sign Up

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 919
  • Last Modified:

How to make Continuous form (like in access) with visual basic form.

Dear All,

I'm a VB newbie, is there any information or examples for making continuous form (like in access) with visual basic form...

Please Advise,
Fauzie
0
fbachri
Asked:
fbachri
  • 6
  • 6
1 Solution
 
anvCommented:
hi !!

for creating a continous form in VB.. u need to create a control array for each control that u require to be repeated for every record...
say if we have 2 textboxes and two labels then
dim i!
i=0

set textboxes and labels index property to 0

while not rs.eof 'where rs is the recordset
if i <> 0 then
  Load text1(i)
  Load text2(i)
  Load Label1(i)
  Load Label2(i)

  text1(i).top = text1(i-1).top + 500
  text2(i).top  = text2(i-1).top + 500
  Label1(i).top = Label1(i-1).top + 500
  Label2(i).top = = Label2(i-1).top + 500

  text1(i).visible=true
  text2(i).visible=true
  Label1(i).visible=true
  Label2(i).visible=true

end if


  text1(i) = rs!Name
  text2(i) = rs!Age
  i=i+1
  rs.movenext
wend
0
 
fbachriAuthor Commented:
Dear anv,

Thanks for your advise, it works!...but i still confuse how to combine the form with a horisontal/vertical scrollbar so the form is scrollable.

please advise,
fauzie

0
 
anvCommented:
Add an MDI Form to ur Application..

and set ur continous forms MDI Child property to true..

0
Keep up with what's happening at Experts Exchange!

Sign up to receive Decoded, a new monthly digest with product updates, feature release info, continuing education opportunities, and more.

 
fbachriAuthor Commented:
Dear anv,

I have add an MDI form to my apps. and set my continuos form MDI Child property to true. but unfortunately i have an error message:

Compile Error:

Function or interface marked as restricted, or the function uses an Automation type not Supported in Visual Basic.


Below is the code in my continuous form :
------------------------------------------------
Private Sub Form_Load()
Dim con As New ADODB.Connection
Dim rs As New ADODB.Recordset
Dim i

Me.MDIChild = True                             '<------ set ur continous forms MDI Child property to true
With con
.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" & _
                    "Persist Security Info=False;Data Source=" & _
                    App.Path & "\db3.mdb"
.Open
End With
rs.Open "SELECT * FROM Table1", con, adOpenDynamic, , adCmdText

i = 0
While Not rs.EOF 'where rs is the recordset
If i <> 0 Then
  Load Text1(i)
  Load Text2(i)
  Load Text3(i)

  Text1(i).Top = Text1(i - 1).Top + 500
  Text2(i).Top = Text2(i - 1).Top + 500
  Text3(i).Top = Text2(i - 1).Top + 500

  Text1(i).Visible = True
  Text2(i).Visible = True
  Text3(i).Visible = True
End If
  Text1(i) = rs!tes1
  Text2(i) = rs!tes2
  Text3(i) = rs!tes3
  i = i + 1
  rs.MoveNext
Wend
End Sub


Please advise....
Fauzie




0
 
anvCommented:
you cannot set

MDIChild property at run time this way..

set it True in design time..
0
 
fbachriAuthor Commented:
The continuous form MDI child property has set to true in the design time now. and now what should i write in the scrollbar Vscroll_Change() event to make it work?

Sorry my basic question. i hope you don't mind...

Regards,
Fauzie
0
 
anvCommented:
r u using Scroll bars in the continous form or what??

u dont have to include any scroll bar object in ur continous form..

as now MDI will automatically add scroll bars to the form if size of continous form increases...  also set the continous form's windowstate to normal..at design time..

also for MDI set scrollbars to true..

0
 
fbachriAuthor Commented:
Yes i am using a scroll bar in the continuous form. but now i've delete it. but after following your instruction the mdi form still not display the scrollbar.

maybe you can check my apps. i will send the code to you but i need your email address. what i want is a continuous form just like in access. that it will display a scrollbar when the data show in the form are plenty enough.


Regards,
Fauzie
0
 
anvCommented:
send me the code to

neeru.verma@drishinfo.com
0
 
fbachriAuthor Commented:
Dear anv,

i've send the code to you....

Thanks,
Fauzie
0
 
anvCommented:
add this statement

at the end of form load event

Me.Height = Text1(i - 1).Top + Text1(i - 1).Height

and u'll get the scroll bar..

one more thing..

since there is a limit to the height of child form (which is = 9000)

so better would be if u add a fram control that will contain all the controls that ar ecurrently on the form..

and u'll have use scrolling logic like following..

Private Sub show_scroll()

Dim intScrollMax As Integer

   
    If Not Me.WindowState = vbMinimized Then
        intScrollMax = (pFrame.height - Me.ScaleHeight) + 345  '345 for status bar
       
        'Check if we need a scroll bar
       
        If intScrollMax > 0 Then
            VScroll1.Min = 0
            VScroll1.Max = intScrollMax
            'move the scrollbar
            VScroll1.Move pFrame.width, 0, 255, Me.ScaleHeight - 375
            Me.width = VScroll1.Left + VScroll1.width + 100
            picStatus.width = Me.width
           
            VScroll1.Visible = True
            scroll_shown = True
   
    '            Else
    '                If scroll_shown = True Then
    '                    Me.width = Me.ScaleWidth
    '                    'StatusBar1.width = Me.width
    '                    VScroll1.Visible = False
    '                    scroll_shown = False
    '                End If
    '            End If
        Else
            If scroll_shown = True Then
                Me.width = VScroll1.Left + 100
                picStatus.width = Me.width
                VScroll1.Value = 0
                VScroll1.Visible = False
                scroll_shown = False
               
            End If
        End If
       
        VScroll1.LargeChange = Me.ScaleHeight
        VScroll1.SmallChange = Me.ScaleHeight / 10
        'VScroll1.Value = 0
    End If
   
   
End Sub

Private Sub ScrollFrame()
Static intVal As Integer
Dim intChange As Integer

    intChange = intVal - VScroll1.Value
    pFrame.Top = pFrame.Top + intChange
   ' Debug.Print pFrame.top
    intVal = VScroll1.Value
    'scroll_value = VScroll1.value
   
End Sub

Private Sub VScroll1_Change()

    ScrollFrame

End Sub

Private Sub VScroll1_Scroll()
    ScrollFrame
   
End Sub


'above code was used in one of my projects.. so please change it as per ur requirement..

:))
0
 
fbachriAuthor Commented:
OK...thank you very much for your valuable information.


Regards,
Fauzie
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

  • 6
  • 6
Tackle projects and never again get stuck behind a technical roadblock.
Join Now