Hier ein Tipp, entstanden im Forum, mit dem man ein Byte-Array um 90° drehen kann... Der meiste Code ist lediglich zur Darstellung, die Hauptaufgabe erledigt die Funktion RotateArrayByte(). Option Explicit ' Unser Array Dim A(5, 5) As Byte Private Sub Form_Load() Dim e1 As Long Dim e2 As Long ' Einstellungen Me.AutoRedraw = True Me.ScaleMode = vbPixels Me.DrawWidth = 10 ' Array mit zufälligen Werten füllen Randomize Timer For e1 = LBound(A, 1) To UBound(A, 1) For e2 = LBound(A, 2) To UBound(A, 2) A(e1, e2) = Rnd * 10 Next e2, e1 ' Array vorher ausgeben DrawArray 10 ' Rotieren RotateArrayByte A ' Nachher ausgeben DrawArray 100 End Sub Sub RotateArrayByte(RArray As Variant) Dim e1 As Long Dim e2 As Long Dim Arr2() As Byte ' Erst mal SecondHand-Array zulegen ReDim Arr2(LBound(RArray, 1) To UBound(RArray, 1), _ LBound(RArray, 2) To UBound(RArray, 2)) As Byte ' Drehen um 90° For e1 = LBound(RArray, 1) To UBound(RArray, 1) For e2 = LBound(RArray, 2) To UBound(RArray, 2) Arr2(UBound(RArray, 2) - e2, e1) = RArray(e1, e2) Next e2, e1 ' Zurückkopieren in Originalarray For e1 = LBound(RArray, 1) To UBound(RArray, 1) For e2 = LBound(RArray, 2) To UBound(RArray, 2) RArray(e1, e2) = Arr2(e1, e2) Next e2, e1 End Sub Sub DrawArray(PosX As Long) ' Nur zur Kontroll! Dim e1 As Long Dim e2 As Long Dim C As Long For e1 = LBound(A, 1) To UBound(A, 1) For e2 = LBound(A, 2) To UBound(A, 2) If A(e1, e2) = 3 Then C = vbRed Else C = vbWhite / 10 * A(e1, e2) End If Me.PSet (PosX + 10 * e1, 10 + 10 * e2), C Next e2, e1 End Sub Dieser Tipp wurde bereits 16.344 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
TOP! Unser Nr. 1 Neu! sevDataGrid 3.0 Mehrspaltige Listen, mit oder ohne DB-Anbindung. Autom. Sortierung, Editieren von Spalteninhalten oder das interaktive Hinzufügen von Datenzeilen sind ebenso möglich wie das Erstellen eines Web-Reports. Tipp des Monats April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 TOP Entwickler-Paket TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1605.50 EUR... |
||||||||||||||||
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. |