设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

1234
返回列表 发新帖
楼主: linda0418
打印 上一主题 下一主题

[窗体] 大哥:还是关于如何让窗体适应不同分辨率![求助]

[复制链接]
31#
发表于 2008-7-28 17:25:28 | 只看该作者
谢谢斑竹
32#
发表于 2008-7-28 17:30:03 | 只看该作者
在感谢一次
33#
发表于 2008-7-28 18:04:38 | 只看该作者
原帖由 tz-chf 于 2007-9-11 10:56 发表


这个方法比较好,开销也小,原汁原味。有没有原代码?


Private Declare Function GetSystemMetrics Lib "user32" (ByVal nIndex As Long) As Long
Private Declare Function EnumDisplaySettings Lib "user32" Alias _
"EnumDisplaySettingsA" (ByVal lpszDeviceName As Long, _
ByVal iModeNum As Long, lpDevMode As Any) As Long
Private Declare Function ChangeDisplaySettings Lib "user32" Alias _
"ChangeDisplaySettingsA" (lpDevMode As Any, ByVal dwflags As Long) As Long
Private Declare Function ExitWindowsEx Lib "user32" (ByVal uFlags As Long, _
ByVal dwReserved As Long) As Long
Const EWX_REBOOT = 2
Const CCDEVICENAME = 32
Const CCFORMNAME = 32
Const DM_PELSWIDTH = &H80000
Const DM_PELSHEIGHT = &H100000
Const DISP_CHANGE_SUCCESSFUL = 0
Const DISP_CHANGE_RESTART = 1
Const CDS_UPDATEREGISTRY = 1
Const SM_CXSCREEN = 0
Const SM_CYSCREEN = 1
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
Private DevM As DEVMODE
Dim XVal As Long, YVal As Long, Z As Long
Private Sub DisplaySetting()
Dim i As Long
Dim b As Long
Dim ans As Long
Dim a As Long
a = EnumDisplaySettings(0, 0, DevM)
DevM.dmFields = DM_PELSWIDTH Or DM_PELSHEIGHT
DevM.dmPelsWidth = XVal
DevM.dmPelsHeight = YVal
b = ChangeDisplaySettings(DevM, 0)
If b = DISP_CHANGE_RESTART Then
ans = MsgBox("要重开机设定才能完成,重开?", vbOKCancel)
If ans = 1 Then
b = ChangeDisplaySettings(DevM, CDS_UPDATEREGISTRY)
Call ExitWindowsEx(EWX_REBOOT, 0)
End If
Else
If b <> DISP_CHANGE_SUCCESSFUL Then
Call MsgBox("设定有误", vbCritical)
End If
End If
End Sub
Private Sub Form_Load()
Dim MBN As Integer, x As Long, y As Long
   y = GetSystemMetrics(SM_CYSCREEN)
   x = GetSystemMetrics(SM_CXSCREEN)
   If Not x = 1024 Then
      MBN = MsgBox("您的屏幕分辨率为" & x & "×" & y & ",而程序的最佳显示分辨率为1024×768。" _
          & Chr(13) + Chr(10) & "*  如果需要程序自动重新设置分辨率,请单击“确定”按钮。" _
          & Chr(13) + Chr(10) & "*  如果退出程序自己重新设置分辨率,请单击“取消”按钮。", vbOKCancel + vbExclamation, "提示...")
      If MBN = 1 Then
         XVal = 1024
         YVal = 768
         Call DisplaySetting
         XVal = x
         YVal = y
         Z = 1
         
      Else
         Application.Quit
        
      End If
   
   End If
End Sub
Private Sub Form_Unload(Cancel As Integer)
Dim MBN As Integer
   If Z = 1 Then
      MBN = MsgBox("是否恢复原来的屏幕分辨率?" _
          & Chr(13) + Chr(10) & "*  如果需要程序自动恢复分辨率,请单击“确定”按钮。" _
          & Chr(13) + Chr(10) & "*  如果退出程序自己恢复分辨率,请单击“取消”按钮。", vbOKCancel + vbExclamation, "提示...")
      If MBN = 1 Then
         Call DisplaySetting
      Else
         Application.Quit
      End If
   End If
End Sub
============================
以上代码可以放在你的启动窗体中就可以了。
我记得 游戏 "红色警戒" 以前的单机版本就是强行更改你的分辨率为800*600,退出的时候又改回了用户的分辨率

上述代码中:程序设计时分辨率为1024*768 ,如果你设计时的分辨率不同于1024*768的话,适当修改代码就可以了。

一旦修改分辨率成功后,后面运行就不用管了,不必每次都去调用。

[ 本帖最后由 wu8313 于 2008-7-28 21:53 编辑 ]
34#
发表于 2008-7-28 22:24:10 | 只看该作者
下来看看...
35#
发表于 2008-8-31 23:16:28 | 只看该作者
[:50] [:50] [:50] [:50]
36#
发表于 2008-12-5 16:48:21 | 只看该作者

学习!!!

学习!!!

点击这里给我发消息

37#
发表于 2011-7-16 13:23:09 | 只看该作者
在ACCESS2010下,这个问题就很好办了。
38#
发表于 2011-7-15 13:05:57 | 只看该作者
看看
39#
发表于 2011-4-25 13:38:24 | 只看该作者
学习了,谢谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-13 15:07 , Processed in 0.076955 second(s), 31 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表