Nando1l
Red Team Member
2
MONTHS
2 2 MONTHS OF SERVICE
LEVEL 1
300 XP
Today, I will teach you how to drag/drop an external file to the ListView by using Visual Basic 2008. You can drag/drop the external images that you like in the ListView and you can also preview the images that you have selected in the ListView.
Let’s begin:
Open Visual Basic 2008, create a new Windows Application and drag a ListView and a PictureBox and do the Form just like this.
Double click the Form and declares all the variable that are needed above the Form1_Load
.
After that, do the following code to fire it on the first load.
Then, do this following code for creating a method of the drag and drop events in the ListView.
Lastly, do this following code for the selecting events of the ListView. When you select the image in the ListView, it will then preview in the PictureBox.
Output:
Let’s begin:
Open Visual Basic 2008, create a new Windows Application and drag a ListView and a PictureBox and do the Form just like this.
data:image/s3,"s3://crabby-images/9d9af/9d9afbae8ae8880c632fc34e1d826aa18e661e70" alt="firstform_11.png"
Double click the Form and declares all the variable that are needed above the Form1_Load
.
- Private
lstviewItem As
ListViewItem 'MAKE THE LISTVIEWITEM OBJECT
- Private
lstviewItemImageList As
New
ImageList 'MAKE THE IMAGELIST OBJECT
After that, do the following code to fire it on the first load.
- Private
Sub
Form1_Load(
ByVal
sender As
Object
, ByVal
e As
System.
EventArgs
)
Handles
MyBase
.
Load
- 'TO OUR IMAGELIST OBJECT, SET THE IMAGELIST FOR THE LISTVIEW
- ListView1.
SmallImageList
=
lstviewItemImageList
- With
ListView1
- 'SET THE AllowDrop PROPERTIES OF THE LISTVIEW
- .
AllowDrop
=
True
- 'SET THE View PROPERTIES OF THE LISTVIEW
- .
View
=
View.
Details
- 'ADD A COLUNMS TO THE LISTVIEW
- .
Columns
.
Add
(
"File"
)
- 'SET THE WIDTH OF THE COLUMN THAT FITS TO THE SIZE OF THE LISTVIEW
- ListView1.
Columns
(
0
)
.
Width
=
150
- End
With
- 'SET THE SizeMode PROPERTIES OF THE PICTUREBOX
- PictureBox1.
SizeMode
=
PictureBoxSizeMode.
StretchImage
- End
Sub
Then, do this following code for creating a method of the drag and drop events in the ListView.
- Private
Sub
listviewDragDrop(
ByVal
sender As
System.
Object
, ByVal
e As
System.
Windows
.
Forms
.
DragEventArgs
)
Handles
ListView1.
DragDrop
- Try
- 'SET AN ARRAY VARIABLE
- Dim
file As
Array
- 'GET AN ARRAY OF THE FILES THAT ARE BEING DRAGGED IN
- file =
CType
(
e.
Data
.
GetData
(
DataFormats.
FileDrop
)
, Array)
- 'LOOP THE ARRAY FILE
- For
i As
Integer
=
0
To
file.
Length
-
1
- lstviewItem =
New
ListViewItem(
file.
GetValue
(
i)
.
ToString
)
- Try
- 'ADDING THE IMAGE TO THE IMAGELIST OBJECT. AND
- 'SET THE NEWLY ADDED IMAGE IN THE LISTVIEWITEMS IMAGEINDEX.
- lstviewItem.
ImageIndex
=
lstviewItemImageList.
Images
.
Add
(
Image.
FromFile
(
lstviewItem.
Text
)
, Color.
Transparent
)
- 'ADDING THE LISTVIEWITEM TO LISTVIEW
- ListView1.
Items
.
Add
(
lstviewItem)
- Catch
ome As
OutOfMemoryException
- 'WHEN THE IMAGE.FROMFILE METHOD FAILES THE ERROR WILL OCCURS
- '(WHEN YOU DRAG A NONREADABLE IMAGE FILE)
- MsgBox
(
"Not valid image file: "
&
lstviewItem.
Text
)
- Catch
ex As
Exception
- 'CATCH ANY ERRORS
- MsgBox
(
"Error: "
&
ex.
Message
)
- End
Try
- Next
- Catch
ex As
Exception
- 'CATCH ANY ERRORS IN THE SUB
- MsgBox
(
"Error: "
&
ex.
Message
)
- End
Try
- End
Sub
Lastly, do this following code for the selecting events of the ListView. When you select the image in the ListView, it will then preview in the PictureBox.
- Private
Sub
listview1_SelectedIndexChanged(
ByVal
sender As
System.
Object
, ByVal
e As
System.
EventArgs
)
Handles
ListView1.
SelectedIndexChanged
- If
ListView1.
SelectedItems
.
Count
=
0
Then
Return
- Try
- 'WHEN THE IMAGE FILE AND PATH IS SELECTED
- 'IT WILL LOAD TO THE PICTURBOX SO THAT THE IMAGE WILL PREVIEW
- PictureBox1.
Image
=
Image.
FromFile
(
ListView1.
SelectedItems
(
0
)
.
Text
)
- Me
.
Text
=
ListView1.
SelectedItems
(
0
)
.
Text
- Catch
ome As
OutOfMemoryException
- 'THIS ERROR OCCURS WHEN THE SELECTED IMAGE IS NOT READABLE
- MsgBox
(
"Could not open preview: "
&
ListView1.
SelectedItems
(
0
)
.
Text
)
- Catch
ex As
Exception
- 'CATCH ANY ERRORS
- MsgBox
(
"Error: "
&
ex.
Message
)
- End
Try
- End
Sub
Output:
data:image/s3,"s3://crabby-images/4a7d6/4a7d66454b22aae133f15cb71e67d1892f0e2fb5" alt="ouput.png"