vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Erstellen von dynamischen Kontextmen?s - wann immer Sie sie brauchen!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

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

Allgemeine Diskussionen
ACCESS 2002/XP - Farbtiefe per VBA einstellen 
Autor: aladdin
Datum: 22.06.08 07:17

Guten Tag
Um meine mit Auflösung 1024 x 768 entwickelte ACC-Applikation an eine höhere Auflösung anzupassen, habe ich diese Routine (s. doc.Anhang) eingebaut. Dies funktioniert auch, das Problem ist aber, dass die Farbtiefe dann automatisch abgesetzt wird (auf 8-Bit). Ist es möglich, den Code so ändern, dass anstelle der Frequenz (oder zusätzlich) auch die Farbtiefe per VBA definiert werden kann?
Danke für eure Hilfe!
Aladdin

Private Declare Function EnumDisplaySettings Lib _
        "user32" Alias "EnumDisplaySettingsA" _
       (ByVal lpszDeviceName As Long, _
        ByVal iModeNum As Long, lpDevMode As Any) _
        As Boolean
 
Private Declare Function ChangeDisplaySettings Lib _
        "user32" Alias "ChangeDisplaySettingsA" _
        (lpDevMode As Any, ByVal dwFlags As Long) _
        As Long
 
Private Const CCDEVICENAME = 32
Private Const CCFORMNAME = 32
Private Const DM_PELSWIDTH = &H80000
Private Const DM_PELSHEIGHT = &H100000
Private Const DM_DISPLAYFREQUENCY = &H400000
 
Private Type DEVMODE
  dmDeviceName As String * CCDEVICENAME
  dmSpecVersion As Integer
  dmDriverVersion As Integer
  dmSize As Integer
  dmDriverExtra As Integer
  dmFields As Long
  dmOrientation As Integer
  dmPaperSize As Integer
  dmPaperLength As Integer
  dmPaperWidth As Integer
  dmScale As Integer
  dmCopies As Integer
  dmDefaultSource As Integer
  dmPrintQuality As Integer
  dmColor As Integer
  dmDuplex As Integer
  dmYResolution As Integer
  dmTTOption As Integer
  dmCollate As Integer
  dmFormName As String * CCFORMNAME
  dmUnusedPadding As Integer
  dmBitsPerPel As Integer
  dmPelsWidth As Long
  dmPelsHeight As Long
  dmDisplayFlags As Long
  dmDisplayFrequency As Long
End Type
 
Public Sub ChangeScreenResolution(Optional Width, _
                                  Optional Height, _
                                  Optional Freq)
Dim I As Long, DevM As DEVMODE
  I = 0
  Do
    I = I + 1
  Loop Until Not EnumDisplaySettings(0&, I, DevM)
  With DevM
    If Not IsMissing(Width) Then
      .dmFields = .dmFields Or DM_PELSWIDTH
      .dmPelsWidth = Width
    End If
    If Not IsMissing(Height) Then
      .dmFields = .dmFields Or DM_PELSHEIGHT
      .dmPelsHeight = Height
    End If
    If Not IsMissing(Freq) Then
      .dmFields = .dmFields Or DM_DISPLAYFREQUENCY
      .dmDisplayFrequency = Freq
    End If
  End With
  ChangeDisplaySettings DevM, 0&
End Sub
Aufruf dann z. B.:
ChangeScreenResolution 1024, 768, 75
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
ACCESS 2002/XP - Farbtiefe per VBA einstellen1.035aladdin22.06.08 07:17
Re: ACCESS 2002/XP - Farbtiefe per VBA einstellen607ModeratorDieter22.06.08 09:09

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-2025 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