Rubrik: Dateisystem · Ordner & Verzeichnisse | VB-Versionen: VB.NET | 17.07.06 |
Pfad gekürzt anzeigen (.NET) Dieser Tipp verrät, wie sich eine Pfadangabe gekürzt anzeigen lässt, sollte der Pfad nicht in das vorgesehene Control passen. | ||
Autor: Dieter Otter | Bewertung: | Views: 13.688 |
www.tools4vb.de | System: WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
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
Abb.1: Standard: Pfad wird hinten abgeschnitten
Eleganter wäre es, wenn der Pfad "irgendwo" zwischen den einzelnen Ordnern gekürzt würde.
Abb.2: Besser: Kürzung erfolgt zwischen den Ordnernamen
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)