vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Blitzschnelles Erstellen von grafischen Diagrammen!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
Re: Listview-Problematik 
Autor: Fraki
Datum: 29.06.13 15:38

Hallo Michael,

für dieses Beispiel benötigst Du eine Form, einen Button, ein ListView, eine ImageList und ein FolderBrowserDialog.

Public Class Form1
 
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As _
      System.EventArgs) Handles Button1.Click
        'Ordnerauswahl
        With Me.FolderBrowserDialog1
            If .ShowDialog = Windows.Forms.DialogResult.OK Then
                'Tabelle füllen
                FillDataTable(.SelectedPath)
                'Bilder aus der ImageList entfernen
                Me.ImageList1.Images.Clear()
 
                With Me.ListView1
                    'Bearbeitung beginnen
                    .BeginUpdate()
                    'event. vorhandene Einträge entfernen
                    .Items.Clear()
                    .View = View.Details
                    .SmallImageList = Me.ImageList1
                    'Spalten erzeugen, wenn nicht vorhanden
                    If .Columns.Count = 0 Then
                        For i As Integer = 0 To 3
                            Select Case i
                                Case 0
                                    .Columns.Add(DT.Columns(i).ColumnName, 40)
                                Case 1
                                    .Columns.Add(DT.Columns(i).ColumnName, 200)
                                Case 2
                                    .Columns.Add(DT.Columns(i).ColumnName, 80, _
                                      HorizontalAlignment.Right)
                                Case Else
                                    .Columns.Add(DT.Columns(i).ColumnName, 80, _
                                      HorizontalAlignment.Center)
                            End Select
                        Next
                    End If
 
                    For i As Integer = 0 To DT.Rows.Count - 1
                        Dim DR As DataRow = DT.Rows(i)
                        Dim ID As Long = DR.Item("ID")
                        Dim FileName As String = DR.Item("FileName")
                        Dim FileSize As Integer = DR.Item("FileSize")
                        Dim FileExtension As String = DR.Item("FileExtension")
                        Dim FullName As String = DR.Item("FullName")
                        'Bild der Datei ermitteln und in ImageList eintragen
                        Dim bmp As System.Drawing.Bitmap = GetFileBitmap( _
                          FullName)
                        Me.ImageList1.Images.Add(bmp)
                        'Neues ListViewItem erstellen (ID.ToString als Text, i 
                        ' als ImageIndex)
                        Dim LVI As New ListViewItem(ID.ToString("00"), i)
                        'Dem Item SubItems zuordnen 
                        LVI.SubItems.Add(FileName)
                        LVI.SubItems.Add(String.Format("{0:#,##0} KB", FileSize _
                          / 1024))
                        LVI.SubItems.Add(FileExtension)
                        'Das ListViewItem dem ListView zuordnen
                        .Items.Add(LVI)
                    Next
                    'Bearbeitung beenden
                    .EndUpdate()
                End With
            Else
                Exit Sub
            End If
        End With
    End Sub
    Private Sub FillDataTable(ByVal Folder As String)
        Dim id As Long = 1
        Dim DR As DataRow = Nothing
        DT = New DataTable("Test")
        With DT
            .Columns.Add("ID", GetType(Long))
            .Columns.Add("FileName", GetType(String))
            .Columns.Add("FileSize", GetType(Long))
            .Columns.Add("FileExtension", GetType(String))
            .Columns.Add("FullName", GetType(String))
        End With
        ' Directory-Object erstellen
        Dim oDir As New System.IO.DirectoryInfo(Folder)
        ' alle Dateien des Ordners
        Dim oFiles As System.IO.FileInfo() = oDir.GetFiles()
        For Each file As System.IO.FileInfo In oFiles
            DR = DT.NewRow
            With DR
                .Item("ID") = id
                .Item("FileName") = file.Name
                .Item("FileSize") = file.Length
                .Item("FileExtension") = file.Extension
                .Item("FullName") = file.FullName
            End With
            DT.Rows.Add(DR)
            id += 1
        Next
    End Sub
    Private Function GetFileBitmap(ByVal FileName As String) As _
      System.Drawing.Bitmap
        'Prüfen ob Datei existiert
        If System.IO.File.Exists(FileName) Then
            'Icon (Symbol) ermitteln...
            Dim oIcon As System.Drawing.Icon = _
              System.Drawing.Icon.ExtractAssociatedIcon(FileName)
            ' ... Bitmap zurückgeben
            Return oIcon.ToBitmap
        Else
            Return Nothing
        End If
    End Function
End Class
Gruß Frank

Beitrag wurde zuletzt am 29.06.13 um 16:07:51 editiert.
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Listview-Problematik1.981michl260128.06.13 16:26
Re: Listview-Problematik1.123Fraki29.06.13 15:38
Re: Listview-Problematik1.084michl260129.06.13 16:17
Re: Listview-Problematik1.187Fraki29.06.13 17:10

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2025 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel