| |
VB.NET - Ein- und UmsteigerRe: Control für Jagged Array | | | Autor: Manfred X | Datum: 05.06.13 11:04 |
| Ich verstehe nicht wirklich, was Dein Ziel ist.
Unter dieser Voraussetzung ....
Ich würde für die Anzeige eventuell Richtung Parent-Child-SubChild-Struktur denken.
In einer Listbox (oder einem Datagridview) werden die Knoten per ID (Nummer) aufgelistet.
Nach der Auswahl eines Knotens in der Listbox, werden in einer Datagridview-Spalte
die mit dem gewählten Knoten verknüpften Knoten angezeigt.
Die Zellen der DGV_Spalte können dann farbig markiert werden.
Ob nach einer Auswahl im Datagridview ein weiteres Control erforderlich ist,
in dem z.B. Pfade zwischen zwei Knoten oder ähnliche Informationen aufbereitet
werden, kann ich nicht beurteilen.
Ein Beispiel, wie man eine Parent-Child (Master-Detail) Verknüpfung per Bindingsource
realisiert, findest Du hier:
http://msdn.microsoft.com/de-de/library/c12c1kx4.aspx
Ein Array kann nicht als Datenquelle für Controls fungieren!
Du benötigst eine geeignete Klasse, die per Schlüssel (Knotennummer) jeweils eine
BindingList-Implementierung zur Verfügung stellt, die die zugeordneten
Knoten für die Bindung verfügbar macht.
In WPF gibt es andere Varianten:
http://social.msdn.microsoft.com/Forums/en-US/wpf/thread/8faad1e5-9dd1-4f21-858d-7b1a68835a74
http://www.telerik.com/community/forums/wpf/gridview/bind-to-array-of-arrays.aspx
Oder was simples ....
Public Class frmJaggedArray
Dim data()() As Decimal
Dim WithEvents lbo As New ListBox With {.Parent = Me, .Width = 50}
Dim WithEvents dgv As New DataGridView With {.Parent = Me, .Left = 60}
Private Sub frmJaggedArray_Load(sender As System.Object, _
e As System.EventArgs) Handles MyBase.Load
ReDim data(3)
data(0) = {1.2D, 3.4D}
data(1) = {5.2D, 12.4D, 17.1D}
data(2) = {15.2D, 2.14D, 6.7D, 8.24D}
data(3) = {12.3D, 0.3D}
For i As Integer = 0 To data.Length - 1
lbo.Items.Add(data(i)(0))
Next i
End Sub
Private Sub lbo_SelectedIndexChanged(sender As Object, _
e As System.EventArgs) Handles lbo.SelectedIndexChanged
dgv.Columns.Clear()
If lbo.SelectedIndex = -1 Then Exit Sub
For i As Integer = 1 To data(lbo.SelectedIndex).Length - 1
dgv.Columns.Add("K" & CStr(i), "K" & CStr(i))
Next i
For i As Integer = 1 To data(lbo.SelectedIndex).Length - 1
dgv.Rows(0).Cells(i - 1).Value = data(lbo.SelectedIndex)(i)
Next i
End Sub
End Class
Beitrag wurde zuletzt am 05.06.13 um 11:30:59 editiert. | |
| 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 |
|
|
sevZIP40 Pro DLL
Zippen und Unzippen wie die Profis!
Mit nur wenigen Zeilen Code statten Sie Ihre Anwendungen ab sofort mit schnellen Zip- und Unzip-Funktionen aus. Hierbei lassen sich entweder einzelnen Dateien oder auch gesamte Ordner zippen bzw. entpacken. Weitere InfosTipp des Monats Access-Tools Vol.1
Über 400 MByte Inhalt
Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB
Nur 24,95 EURWeitere Infos
|
|
|
Copyright ©2000-2024 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
|
|