Writing a File Dialog Box
By Anne-Marie Wright 
Although there is a common dialog box control with VB, it is not always what we want. In this article we will be emulating the file handling part of the old windows 3.1 file dialog box. You can modify this example to suit your particular needs.
To start with we need to create a form with a drivelist, directorylist, filelist, label and a textbox contol, with 2 buttons. (See picture below)
Now we have the form setup, we need to get the controls interacting with each other.
To link the controls together we will use the following properties:
DriveList - Drive 
DirectoryList - Path 
FileList - Path 
Drive Property (information from MSDN)
Returns or sets the selected drive at run time. Not available at design time.
Syntax
drivelist.Drive [= drive]
Remarks
The valid drives for the Drive property include all drives present in or connected to the system when the control is created or refreshed at run time. The default setting of the Drive property is the current drive.
When reading this property setting, the selected drive is returned in one of the following formats:
Floppy disks — "a:" or "b:", and so on 
Fixed media — "c: [volume id]" 
Network connections — "x: \\server\share" 
When setting this property:
Only the first character of the string is significant (the string isn't case-sensitive). 
Changing the setting for the Drive property invokes a Change event. 
Selecting a drive that isn't present causes an error. 
Setting this property also regenerates the drive list, providing a way in code to track network connections added since the control was created. 
If the FileName property is set to a qualified network path without a drive designation, the value of the Drive property is a zero-length string (""), no drive is selected, and the ListIndex property setting is –1.
Note: The Drive property returns a different value from the ListIndex property, which returns the list box selection.
(MSDN April 2000)
Path Property (information from MSDN)
Returns or sets the current path. Not available at design time. For the App object, read-only at run time.
Syntax
object.Path [= pathname]
Remarks
The value of the Path property is a string indicating a path, such as C:\Ob or C:\Windows\System. For a DirListBox or FileListBox control, the default is the current path when the control is created at run time. For the App object, Path specifies the path of the project .VBP file when running the application from the development environment or the path of the .exe file when running the application as an executable file.
Use this property when building an application's file-browsing and manipulation capabilities. Setting the Path property has effects on a control similar to the MS-DOS chdir command — relative paths are allowed with or without a drive specification. Specifying only a drive with a colon (:) selects the current directory on that drive.
The Path property can also be set to a qualified network path without a drive connection using the following syntax:
\\servername\sharename\path
The preceding syntax changes the Drive property to a zero-length string ("").
Changing the value of Path has these effects:
For a DirListBox control, generates a Change event. 
For a FileListBox control, generates a PathChange event. 
Note: For DirListBox, the return value of Path is different from that of List(ListIndex), which returns only the selection.
(MSDN April 2000)
Now we have had a look at the properties below is the code that links it all together
code
Option Explicit
Private Sub DirDialog_Change()
    'Set the filelist path to the same path
    filDialog.Path = DirDialog.Path
End Sub
Private Sub drvDialog_Change()
    'Set the directorylist path to the same drive
    DirDialog.Path = drvDialog.Drive
End Sub
Private Sub filDialog_PathChange()
    'Show the path in the forms caption
    Me.Caption = "Dialog Box - [" & filDialog.Path & "]"
End Sub
Now all we need to do to finish the dialog box is select the filename and program the buttons
Private Sub filDialog_Click()
    'Display the name in the textbox
    txtFilename.Text = filDialog.FileName
End Sub
Private Sub cmdCancel_Click()
    MsgBox "CANCELLED"
    Unload Me
End Sub
Private Sub cmdOK_Click()
    Dim strMessage
    
    'Display various elements that can be returned from the form
    strMessage = "Drive: " & drvDialog.Drive
    strMessage = strMessage & vbCr & "Path: " & DirDialog.Path
    strMessage = strMessage & vbCr & "Filename: " & filDialog.FileName
    strMessage = strMessage & vbCr & "The lot: "
    'Check the path has a paragraph mark at the end
    If Right(filDialog.Path, 1) = "\" Then
        strMessage = strMessage & filDialog.Path & filDialog.FileName
    Else
        strMessage = strMessage & filDialog.Path & "\" & filDialog.FileName
    End If
    MsgBox strMessage
    Unload Me
End Sub
We have to check the file path because if you are looking a the root of a drive then the path will have a directory character at the end of the path ('\').
Now we have created a simple file dialog box. You can download the completed  http://www.vbexplorer.com/VBExplorer/filedialogcode.zip
source: http://www.vbexplorer.com/VBExplorer/VBExplorer.asp
---------------------------------
Related :
UsingCrystalReports6
VerifyUserEmailAddressPHP-1
VerifyUserEmailAddressPHP-2
viewinformationvb2005
WatermarkImagesFlyPHP-1
WatermarkImagesFlyPHP-2
WhatAretheIssues
What-isMySQL
WhatSQLServerExpress
writefileinvb2005
WritingFileDialogBox
SimpleDatabasevb6
SQLServer2005fromVisualBasic6
SQLServer2005withPHP
SQLServerSecurityGuidelines
TransferringFiles
UsingCrystalReports6
Senin, 09 Februari 2009
Langganan:
Posting Komentar (Atom)
 
Tidak ada komentar:
Posting Komentar