Sie haben Ihre Anwendung soweit fertig! Was fehlt noch? Der letzte Feinschliff wie z.B. ein Info- oder Begrüßungsfenster. Also noch schnell ein Dialog hinzugefügt, eine PictureBox mit dem Logo drauf und etwas Text mit dem Label-Control dabei - fertig! Doch der Text wirk ein wenig langweilig. Etwas Pepp muss her. Die nachfolgende Klasse demonstriert Ihnen, wie Sie mit dem VB Label ein 3D Label auf der Form platzieren können. Alles was Sie dazu benötigen, sind zwei Label auf der Form. Ein drittes Label kann optional übergeben werden. Den Rest übernimmt die Klasse für Sie. Die Klasse verfügt über folgende Eigenschaften:
Die Aufzählung ShadowFrom stellt Ihnen acht verschiedene Schattenpositionen zur Verfügung:
Die Default-Werte für die LabelFore-, LabelMid- und LabelBackColor-Eigenschaften entsprechen den System 3D-Farben des jeweiligen Zielsystems, so dass der Anwender seine gewohnten Farben erhält. Sie können jedoch die Farben an Ihre Anwendung anpassen. Die Eigenschaften TopGap und LeftGap bestimmen den Abstand des Schattens in Twips. Die Default-Werte sind jeweils 30 Twips. Mit der Methode "Init" werden der Klasse die beiden benötigten Labels übergeben. Das MidLabel kann optional übergeben werden. Anschließend werden die Labels in Form gebracht und der 3D-Effekt gezeichnet. Anlegen der Klasse: ' *********************************************************** ' * ' * 3D Label (Klasse) ' * ' * Diese Klasse zeichnet ein 3D Label auf einer Form. ' * Benötigt werden zwei Label-Controls auf der ' * aufrufenden Form. Die Labels werden der Prozedure ' * "Init" übergeben. Optional kann ein drittes Label ' * als MidLabel übergeben werden. ' * ' * Eigenschaften: ' * - LabelForeColor (Default: vb3DHighlight) ' * - LabelBackColor (Default: vb3DDKShadow) ' * - Optional MidBackColor (Default: vb3DShadow) ' * - TopGap (Schattenversatz Oben, Default: 30 Twips) ' * - LeftGap (Schattenversatz Links, Default: 30 Twips) ' * - ShadowPos (Schattenposition, Enum ShadowFrom) ' * ' * Dezember 2003, VB-Power.net & Roland Wutzke ' * http://www.vb-power.net ' * mailto:snoopy@vb-power.net ' * ' *********************************************************** Option Explicit ' Eigenschaften der Klasse Public LabelForeColor As OLE_COLOR Public LabelBackColor As OLE_COLOR Public LabelMidColor As OLE_COLOR Public TopGap As Long Public LeftGap As Long Public ShadowPos As ShadowFrom ' Position des BackLabel Public Enum ShadowFrom LinksOben MitteOben RechtsOben RechtsMitte LinksMitte LinksUnten MitteUnten RechtsUnten End Enum Private Sub Class_Initialize() ' Eigenschaften vorbesetzen LabelForeColor = vb3DHighlight LabelBackColor = vb3DDKShadow LabelMidColor = vb3DShadow TopGap = 30 LeftGap = 30 ShadowPos = LinksMitte End Sub Public Sub Init(ForeLabel As Label, BackLabel As Label, _ Optional MidLabel As Label) Dim ForeTop As Long Dim ForeLeft As Long Dim MTopGap As Long Dim MLeftGap As Long ' Top und Left in Variable retten ForeTop = ForeLabel.Top ForeLeft = ForeLabel.Left MTopGap = TopGap \ 2 MLeftGap = LeftGap \ 2 ' Farben setzen ForeLabel.ForeColor = LabelForeColor BackLabel.ForeColor = LabelBackColor ' BackStyle setzen ForeLabel.BackStyle = vbTransparent BackLabel.BackStyle = vbTransparent ' Schatten positionieren With BackLabel Select Case ShadowPos Case LinksOben .Top = ForeTop - TopGap .Left = ForeLeft - LeftGap Case MitteOben .Top = ForeTop - TopGap .Left = ForeLeft Case RechtsOben .Top = ForeTop - TopGap .Left = ForeLeft + LeftGap Case RechtsMitte .Top = ForeTop .Left = ForeLeft + LeftGap Case LinksMitte .Top = ForeTop .Left = ForeLeft - LeftGap Case LinksUnten .Top = ForeTop + TopGap .Left = ForeLeft - LeftGap Case MitteUnten .Top = ForeTop + TopGap .Left = ForeLeft Case RechtsUnten .Top = ForeTop + TopGap .Left = ForeLeft + LeftGap End Select End With ' MidLabel vorhanden, dann Anzeigen If Not MidLabel Is Nothing Then ' Farbe MidLabel setzen MidLabel.ForeColor = LabelMidColor ' BackStyle setzen MidLabel.BackStyle = vbTransparent ' In den Hintergrund schieben MidLabel.ZOrder 1 ' Schatten positionieren With MidLabel Select Case ShadowPos Case LinksOben .Top = ForeTop - MTopGap .Left = ForeLeft - MLeftGap Case MitteOben .Top = ForeTop - MTopGap .Left = ForeLeft Case RechtsOben .Top = ForeTop - MTopGap .Left = ForeLeft + MLeftGap Case RechtsMitte .Top = ForeTop .Left = ForeLeft + MLeftGap Case LinksMitte .Top = ForeTop .Left = ForeLeft - MLeftGap Case LinksUnten .Top = ForeTop + MTopGap .Left = ForeLeft - MLeftGap Case MitteUnten .Top = ForeTop + MTopGap .Left = ForeLeft Case RechtsUnten .Top = ForeTop + MTopGap .Left = ForeLeft + MLeftGap End Select End With End If ' Wichtig!!! Label Reihenfolge setzen ForeLabel.ZOrder 0 BackLabel.ZOrder 1 End Sub Wie wird die Klasse genutzt: Option Explicit Private L3d As clsLabel3D Private Sub Form_Load() Dim x As Long ' Klasse instanzieren Set L3d = New clsLabel3D ' Label1 initialisieren With Label1(0) .Caption = "3D Label" .FontName = "Times New Roman" .FontSize = 36 .FontBold = True .AutoSize = True End With ' Instanz von Label1 erzeugen For x = 1 To 2 Load Label1(x) Label1(x).Visible = True Next x ' Klasse initialisieren und Label zeichnen With L3d .LeftGap = 50 .TopGap = 50 .ShadowPos = RechtsOben .Init Label1(0), Label1(1), Label1(2) End With End Sub So, das war´s. Nutzen Sie die Klasse, um ein eigenes ActiveX-Control zu erstellen. Oder bauen Sie diese Klasse einfach in Ihre Projekte ein. Dieser Tipp wurde bereits 21.541 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. |
sevAniGif (VB/VBA) Anzeigen von animierten GIF-Dateien Ab sofort lassen sich auch unter VB6 und VBA (Access ab Version 2000) animierte GIF-Grafiken anzeigen und abspielen, die entweder lokal auf dem System oder auf einem Webserver gespeichert sind. 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. |