vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
NEU! sevCoolbar 3.0 - Professionelle Toolbars im modernen Design!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
Re: Bildschirmauflösung 
Autor: Earny
Datum: 13.09.08 17:42

Hallo,
ich hatte ein "Bildschirmanpassungsprogramm" für VB6.0. Das habe ich auf VB2005 konvertieren lassen. Dabei entstand der folgende Code, der auch funktioniert. Ich muss nur in der Form_Load-Prozedur jedes Formulars die Prozedur "SetDeviceIndependentWindow(Me)" aufrufen, dann werden alle Formulare und Steuerelemente auf die aktuelle Bildschirmauflösung umgerechnet und alles bleibt bei der ursprünglichen Größe.
Was mir nicht gefällt, sind die VB6.0-Methoden. Falls VB6.0 auf dem Zielrechner nicht mehr vorhanden ist, dürfte das nicht mehr laufen.
Mit den theoretischen Beschreibungen der MSDN-Hilfe komme ich nicht zurecht. Da fehlen mir die Kenntnisse.
Noch eine Frage: Wieso wird "End Function" grün (Warnung) unterstrichen?
Da der Text zu lang war (5kB-Grenze?), habe ich einen Teil des Codes wieder gelöscht.
Hier der Code aus dem Modul:
Option Strict Off
Option Explicit On
Module Bildschirmauflösung
 
    ' Bildschirmauflösung, unter der die Userform erstellt wurde
    Public Const X_RESOLUTION As Short = 1024
    Public Const Y_RESOLUTION As Short = 768
 
    'X = Aktuelle Horizontal-Auflösung/1024
    'Y = Aktuelle Vertikal-Auflösung/768
    Public X As Single
    Public Y As Single
 
    Public Sub SetDeviceIndependentWindow(ByRef FormName As Object)
        ' Diese Prozedur passt die Größe und Anordnung einer Userform
        ' an die jeweilige Auflösung an.
        ' Idee und Grundgerüst von Frank Lubitz
        ' Im Prozeduraufruf muss die zu ändernde Userform angegeben werden
 
        Dim HeightChange As Integer
        Dim WidthChange As Integer
        Dim OldHeight As Integer
        Dim OldWidth As Integer
        Dim ctlControl As System.Windows.Forms.Control
 
        ' Fehlermeldungen abfangen
        On Error GoTo ErrorHandler
        ' Vergrößerungs-/Verkleinerungsfaktor der aktuellen Auflösung
        ' in Bezug auf die ursprüngliche Auflösung
        'X = System.HorizontalResolution / X_RESOLUTION
        'Y = System.VerticalResolution / Y_RESOLUTION
 
        X = VB6.PixelsToTwipsX( _
          System.Windows.Forms.Screen.PrimaryScreen.Bounds.Width) / _
        VB6.TwipsPerPixelX / X_RESOLUTION
        Y = VB6.PixelsToTwipsY( _
          System.Windows.Forms.Screen.PrimaryScreen.Bounds.Height) / _
        VB6.TwipsPerPixelY / Y_RESOLUTION
 
        ' Keine Neuanordung bei identischer Auflösung
        If X = 1 And Y = 1 Then Exit Sub
        ' Alte Einstellungen sichern
        OldHeight = FormName.Height
        OldWidth = FormName.Width
        ' Neue Abmessung der Userform berechnen
        FormName.Height = FormName.Height * Y
        FormName.Width = FormName.Width * X
        ' Änderungen der Abmessungen
        HeightChange = FormName.Height - OldHeight
        WidthChange = FormName.Width - OldWidth
        ' Userform neu positionieren
        FormName.Left = FormName.Left - WidthChange / 2
        FormName.Top = FormName.Top - HeightChange / 2
        ' Alle Controls durchlaufen und ändern
        For Each ctlControl In FormName.Controls
            Debug.Print(ctlControl.Name)
 
            If TypeOf ctlControl Is System.Windows.Forms.TextBox Then
                ControlResize2(ctlControl, X, Y)
            ElseIf TypeOf ctlControl Is System.Windows.Forms.Label Then
                ControlResize2(ctlControl, X, Y)
            ElseIf TypeOf ctlControl Is System.Windows.Forms.CheckBox Then
                ControlResize2(ctlControl, X, Y)
            ElseIf TypeOf ctlControl Is System.Windows.Forms.Button Then
                ControlResize2(ctlControl, X, Y)
            ElseIf TypeOf ctlControl Is System.Windows.Forms.ListBox Then
                ControlResize2(ctlControl, X, Y)
              ElseIf TypeOf ctlControl Is AxXGAUGELib.AxXGauge Then
                ControlResize2(ctlControl, X, Y)
            Else
                ControlResize2(ctlControl, X, Y)
            End If
        Next ctlControl
        Exit Sub
ErrorHandler:
        ' try to handle next control
        Resume Next
 
    End Sub
 
    Function ControlResize2(ByRef Control As System.Windows.Forms.Control, _
    ByRef X As Object, ByRef Y As Object) As Object '
        With Control
            .Font = VB6.FontChangeSize(.Font, .Font.SizeInPoints * X)
            .SetBounds(VB6.TwipsToPixelsX(VB6.PixelsToTwipsX(.Left) * X), _
            VB6.TwipsToPixelsY(VB6.PixelsToTwipsY(.Top) * Y), _
            VB6.TwipsToPixelsX(VB6.PixelsToTwipsX(.Width) * X), _
            VB6.TwipsToPixelsY(VB6.PixelsToTwipsY(.Height) * Y))
        End With
    End Function
 
End Module
Gruß
Earny
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Bildschirmauflösung3.995Earny12.09.08 21:47
Re: Bildschirmauflösung3.463ModeratorRalf Ehlert12.09.08 23:10
Re: Bildschirmauflösung4.711Earny13.09.08 17:42
Re: Bildschirmauflösung3.450Earny13.09.08 19:34
Re: Bildschirmauflösung3.371Julian1313.09.08 22:45
Re: Bildschirmauflösung3.391Earny14.09.08 18:49

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

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

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