|
|
(11 intermediate revisions by one user not shown) |
Line 1: |
Line 1: |
| These notes can be organized later. | | These notes can be organized later. |
− |
| |
− | === Open a Form From Another Form ===
| |
− |
| |
− | Open the form called frmCompanies
| |
− | frmCompanies.Show
| |
− | Open it so that the parent form cannot be clicked. To suspend execution of the first form until after the second form is done with, add the keyword constant vbModal as an argument to the Show method.
| |
− | frmCompanies.Show vbModal
| |
− | The Hide method of a form removes the form from the screen (makes it invisible), but the form still remains in memory.
| |
− | frmCompanies.Hide
| |
− | Me.Hide
| |
− | Hide
| |
− | You can load a form in memory and not display it.
| |
− | Load frmCompanies
| |
− | Unload form from memory (which also closes it)
| |
− | Unload Me
| |
− | Example
| |
− | Private Sub Form_Unload(Cancel As Integer)
| |
− | If MsgBox("Are you sure you want to quit?", vbYesNo + vbQuestion, "Unload Test") = vbNo Then
| |
− | Cancel = 1
| |
− | End If
| |
− | End Sub
| |
− |
| |
− | === From Dimensions and Twip Units ===
| |
− |
| |
− | The default unit is the twip, which is 1/1440 of an inch for height, width, top, and left.
| |
− |
| |
− | There are 15 twips per pixel.
| |
− |
| |
− | Pixels to Twip:
| |
− | W = W * Screen.TwipsPerPixelX
| |
− | H = H * Screen.TwipsPerPixelY
| |
− | Twips to Pixel:
| |
− | W = W / Screen.TwipsPerPixelX
| |
− | H = H / Screen.TwipsPerPixelY
| |
− |
| |
− | === Resizing Forms ===
| |
− |
| |
− | * Width: Specifies the width of the control. The default unit is the twip, which is 1/1440 of an inch.
| |
− | * Height: Specifies the height of the control. The default unit is the twip, which is 1/1440 of an inch.
| |
− | * Left: Specifies the distance between the internal left edge of a control and the left edge of its containter.The default unit is the twip, which is 1/1440 of an inch.
| |
− | * Top: Specifies the distance between the internal top edge of a control and the top edge of its containter.The default unit is the twip, which is 1/1440 of an inch.
| |
− | <BR>
| |
− | * ScaleWidth: The width of the client area.
| |
− | * ScaleHeight: The height of the client area.
| |
− | * ScaleLeft: Coordinate horizontal of upper left client area.
| |
− | * ScaleTop: Coordinate vertical of upper left client area.
| |
− | <BR>
| |
− | * ClientWidth:
| |
− | * ClientHeight:
| |
− | * ClientLeft:
| |
− | * ClientTop:
| |
− |
| |
− | === TabStrip Control ===
| |
− |
| |
− | Tabs are not containers! In design time you cannot just select a tab and drop a control on it, assigning a different control to each tab. It just isn't how tabs work.
| |
− |
| |
− | You must trap the click event and determine which tab is being clicked.
| |
− | Private Sub TabStrip1_Click()
| |
− | SelectedTab = TabStrip1.SelectedItem.Index
| |
− | End Sub
| |
− |
| |
− | Setting the default tab
| |
− |
| |
− | Private Sub Form_Load()
| |
− | 'default to first tab (note: indexing starts at 1 - this is how control is designed)
| |
− | TabStrip1.Tabs(1).Selected = True
| |
− | End Sub
| |
− |
| |
− | Another Example
| |
− |
| |
− | Private Sub TabStrip1_Click
| |
− | TabFrame(TabStrip1.SelectedItem.Index-1).Zorder 0
| |
− | End Sub
| |
− |
| |
− | Tabs That Are Containers:
| |
− |
| |
− | If you wish to use tabs that are containers, look at SStab, which is in the component Microsoft Tabbed Dialog Control 6.0 (SP5). The .OCX is TABCTL32.ocx.
| |
− |
| |
− | === Adding Controls to Tabs ===
| |
− |
| |
− | # Add and setup the tabstrip control with the number of tabs desired.
| |
− | # Add 1 frame control for each tab. Make them each the same height and width. Name each with something like fraFirstTab, fraSecondTab, etc.
| |
− | # Add the controls that you want to appear when the first tab is clicked to fraFirstTab. Repeat this for each remaining tab (use fraSecondTab for the second tab, etc.)
| |
− | # set the Top and Left properties for all frames to the same value so that it appears within the tabstrip control. You may need to adjust the tabstrip height and width to accomidate this.
| |
− | # Set the Visible property for all frame to True.
| |
− | # Select fraFirstTabe and insure that it is on top of the ZOrder. Do this by Selecting Format -> Order and see what options are available. If "Bring to Front" is grayed out and "Send to Back to in black, then its ok, If not, click "Bring to Front".
| |
− | # Add the following code to the Click event procedure of your tabstrip control:
| |
− | Select Case TabStrip1.SelectedItem.Index
| |
− | Case 1: fraFirstTab.ZOrder 0
| |
− | Case 2: fraSecondTab.ZOrder 0
| |
− | ' add 1 CASE statement for each tab. Change the frame control name to correspond to the tab that has been selected.
| |
− | End Select
| |
− | :8. What SHOULD happen is the the frame that corresponds to the tab selected is moved to the top of the ZOrder, overlaying the other frames.
| |
| | | |
| === Select Case (Switch) === | | === Select Case (Switch) === |
Line 129: |
Line 36: |
| End Select | | End Select |
| | | |
− | === CommonDialog === | + | === Public Declarations === |
| + | |
| + | Public strCurrentTool As String |
| + | |
| + | Public fMainForm As frmQAB |
| + | |
| + | Public cn As ADODB.Connection |
| + | |
| + | Public rsCompanies As ADODB.Recordset |
| + | |
| + | Public Const dbtContact = "contact" |
| + | |
| | | |
| | | |
These notes can be organized later.
CASE in Visual BASIC does not "fall through" like in C.