Wann immer man eine Pfadangabe z.B. in einem Labelcontrol oder einer TextBox anzeigen muss, sollte man prüfen, ob der Pfad vollständig dargestellt werden kann. Ist dies nicht der Fall, sollte der Pfad entsprechend gekürzt werden - allerdings nicht so, dass einfach das Ende der Pfadangabe abgeschnitten wird
Eleganter wäre es, wenn der Pfad "irgendwo" zwischen den einzelnen Ordnern gekürzt würde.
Und so geht's: Public Class Form1 Inherits System.Windows.Forms.Form ' API-Deklarationen Private Declare Auto Function PathCompactPath Lib "shlwapi.dll" ( _ ByVal hDC As IntPtr, _ ByVal pszPath As String, _ ByVal dx As Integer) As Integer Private Declare Auto Function SelectObject Lib "gdi32" ( _ ByVal hdc As IntPtr, _ ByVal hObject As IntPtr) As IntPtr Private Declare Auto Function DeleteObject Lib "gdi32" ( _ ByVal hObject As IntPtr) As Integer ' Pfad optimal kürzen, falls notwendig Public Function CompactPath(ByVal sPath As String, _ ByVal oControl As Control) As String Try ' Breite des Controls Dim nWidth As Integer = oControl.Width - 5 ' Graphics-Objekt erstellen Dim g As Graphics = oControl.CreateGraphics() ' Geräte-Kontext Dim hDC As IntPtr = g.GetHdc() ' Schriftart des Controls berücksichtigen Dim hFont As IntPtr = oControl.Font.ToHfont() Dim oldFont As IntPtr = SelectObject(hDC, hFont) ' API-Funktion aufrufen, um Pfad ggf. zu kürzen PathCompactPath(hDC, sPath, nWidth) ' Handles wieder freigeben DeleteObject(hFont) g.ReleaseHdc(hDC) g.Dispose() Catch ex As Exception End Try Return (sPath) End Function End Class Aufrufbeispiel: Dim sPath As String sPath = "C:\Programme\Gemeinsame Dateien\Microsoft Shared\DAO\DAO360.DLL" Label1.Text = CompactPath(sPath, Label1) Dieser Tipp wurde bereits 13.717 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. |
sevISDN 1.0 Überwachung aller eingehender Anrufe! Die DLL erkennt alle über die CAPI-Schnittstelle eingehenden Anrufe und teilt Ihnen sogar mit, aus welchem Ortsbereich der Anruf stammt. Weitere Highlights: Online-Rufident, Erkennung der Anrufbehandlung u.v.m. Tipp des Monats Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung Neu! sevPopUp 2.0 Dynamische Kontextmenüs! Erstellen Sie mit nur wenigen Zeilen Code Kontextmenüs dynamisch zur Laufzeit. Vordefinierte Styles (XP, Office, OfficeXP, Vista oder Windows 8) erleichtern die Anpassung an die eigenen Anwendung... |
||||||||||||||||
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. |