VB设置屏幕分辨率

Option Explicit

Public Declare Function ChangeDisplaySettings Lib "user32.dll" Alias "ChangeDisplaySettingsA" (ByRef lpDevMode As DEVMODE, ByVal dwFlags As Long) As Long
Public Declare Function EnumDisplaySettings Lib "user32.dll" Alias "EnumDisplaySettingsA" (ByVal lpszDeviceName As String, ByVal iModeNum As Long, ByRef lpDevMode As DEVMODE) As Long

Const DM_PELSHEIGHT As Long = &H100000
Const DM_PELSWIDTH As Long = &H80000
Const DM_BITSPERPEL As Long = &H40000
Const DM_DISPLAYFREQUENCY As Long = &H400000

Const ENUM_CURRENT_SETTINGS = -1
Const CCHDEVICENAME As Long = 32
Const CCHFORMNAME As Long = 32
Const CDS_TEST = &H4

Private Type DEVMODE
    dmDeviceName As String * CCHDEVICENAME
    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 * CCHFORMNAME
    dmUnusedPadding As Integer
    dmBitsPerPel As Integer
    dmPelsWidth As Long
    dmPelsHeight As Long
    dmDisplayFlags As Long
    dmDisplayFrequency As Long
End Type

Sub Main()
   Dim i     As Long
   Dim strArgs() As String
   Dim width As Long
   Dim height As Long
   strArgs = Split(Command$, " ")
   width = strArgs(0)
   height = strArgs(1)
   i = SetDisplaymode(width, height, 32, 1)
  'i = getDispayMode()
End Sub

''-------------------------------------------------------------------------------------------
''    LngWidth       //屏幕的宽(单位象素)
''    LngHeight      //屏幕的高(单位象素)
''    IntColor       //多少位颜色(e.g 16 or 32)
''    LngFrequency   //屏幕的刷新频率
''
''声明:
''  调用该函数时要确定所设置的值在系统所允许的设置范围内,比如系统的最大刷新频率位80,而你
'' 用把LngFrequency设位85,这样将带来无法预测的后果。
''------------------------------------------------------------------------------------------
Public Function SetDisplaymode(LngWidth As Long, LngHeight As Long, IntColor As Integer, LngFrequency As Long) As Long
  Dim NewDevmode As DEVMODE
  Dim lngP As Long
  Const CDS_UPDATEREGISTRY = 1
  'obtains information
  EnumDisplaySettings 0&, 0&, NewDevmode

  With NewDevmode
   .dmFields = DM_PELSWIDTH Or DM_PELSHEIGHT Or DM_BITSPERPEL Or DM_DISPLAYFREQUENCY
  .dmPelsWidth = LngWidth   '设定成想要的分辨率
  .dmPelsHeight = LngHeight
  ' .dmBitsPerPel = IntColor
   '.dmDisplayFrequency = LngFrequency
  End With
  '永久改变
    SetDisplaymode = ChangeDisplaySettings(NewDevmode, CDS_UPDATEREGISTRY Or CDS_TEST)
 '程序运行时改变
  ' SetDisplaymode = ChangeDisplaySettings(NewDevmode, CDS_TEST)
End Function

Public Function getDispayMode() As Long
 MsgBox Screen.width / Screen.TwipsPerPixelX & "×" & Screen.height / Screen.TwipsPerPixelY
 MsgBox Screen.TwipsPerPixelX & "×" & Screen.TwipsPerPixelY
End Function

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值