剖析讲解VB.NET分辩率案例
创始人
2024-06-09 21:30:25
0

使用VB.NET开发的程序员知道很容易获得显示器的分辩率,但是,要改变VB.NET分辩率是一件很让人头疼的事。由于VB.NET的类库没有将enumdisplaysettings 和ChangeDisplaySettings这两个API函数进行封装,但是我们得调用它们函数,相对于VB6来说,VB.NET调用API函数是有一些小的改动!

下面,我们就尝试一下在VB.NET分辩率调试,使用这两个api函数。

新建一个项目,在form1上添加两个按钮,一个名为btngetdisp,将其text属性设置为“得到分辩率”;另一个按钮名为btnsetdisp,text属性为“设置分辩率”。然后在代码窗口里添加以下代码:

  1. private Const CCDEVICENAME As Short = 32 
  2. private Const CCFORMNAME As Short = 32 
  3. private Const DM_PELSWIDTH As Integer = &H80000  
  4. private Const DM_PELSHEIGHT As Integer = &H100000  
  5. '刷新频率常量  
  6. private Const DM_DISPLAYFREQUENCY As Integer = &H400000  
  7. '调用API函数  
  8. private Declare Function EnumDisplaySettings Lib "user32" Alias "EnumDisplaySettingsA" (ByVal lpszDeviceName As Integer, ByVal iModeNum As Integer, ByRef lpDevMode As DEVMODE) As Boolean  
  9. '调用api函数  
  10. private Declare Function ChangeDisplaySettings Lib "user32" Alias "ChangeDisplaySettingsA" (ByRef lpDevMode As DEVMODE, ByVal dwflags As Integer) As Integer  
  11. '定义结构  
  12. private Structure DEVMODE  
  13. (ccdevicename), System.Runtime.InteropServices.MarshalAs(System.Runtime.InteropServices.UnmanagedType.ByValTStr, SizeConst:=CCDEVICENAME)> Public dmDeviceName  
  14. As  
  15. String  
  16. dim dmSpecVersion As Short  
  17. dim dmDriverVersion As Short  
  18. dim dmSize As Short  
  19. dim dmDriverExtra As Short  
  20. dim dmFields As Integer  
  21. dim dmOrientation As Short  
  22. dim dmPaperSize As Short  
  23. dim dmPaperLength As Short  
  24. dim dmPaperWidth As Short  
  25. dim dmScale As Short  
  26. dim dmCopies As Short  
  27. dim dmDefaultSource As Short  
  28. dim dmPrintQuality As Short  
  29. dim dmColor As Short  
  30. dim dmDuplex As Short  
  31. dim dmYResolution As Short  
  32. dim dmTTOption As Short  
  33. dim dmCollate As Short  
  34. (ccformname), System.Runtime.InteropServices.MarshalAs(System.Runtime.InteropServices.UnmanagedType.ByValTStr, SizeConst:=CCFORMNAME)> Public dmFormName As String  
  35. dim dmUnusedPadding As Short  
  36. dim dmBitsPerPel As Short  
  37. dim dmPelsWidth As Integer  
  38. dim dmPelsHeight As Integer  
  39. dim dmDisplayFlags As Integer  
  40. dim dmDisplayFrequency As Integer  
  41. end Structure   
  42. '改变分辩率过程,参数一宽度,参数二高度  
  43. private Sub ChangeDisp(ByRef iWidth As Single, ByRef iHeight As Single)  
  44. dim blnWorked As Boolean  
  45. dim i As Integer  
  46. dim DevM As Form1.DEVMODE  
  47. i = 0 
  48. do  
  49. blnworked = EnumDisplaySettings(0, i, DevM)  
  50. ii = i + 1  
  51. loop Until (blnWorked = False)  
  52. with DevM  
  53. .dmfields = DM_PELSWIDTH Or DM_PELSHEIGHT Or DM_DISPLAYFREQUENCY  
  54. .dmpelswidth = iWidth 
  55. .dmpelsheight = iHeight 
  56. '刷新频率为85  
  57. .dmdisplayfrequency = 85   
  58. end With  
  59. call ChangeDisplaySettings(DevM, 0)  
  60. end Sub  
  61. private Sub btnGetDisp_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnGetDisp.Click  
  62. dim X As Short = System.Windows.Forms.Screen.PrimaryScreen.Bounds.Width  
  63. dim Y As Short = System.Windows.Forms.Screen.PrimaryScreen.Bounds.Height  
  64. msgbox("您的显示器分辨率是" & X & " X " & Y)  
  65. end Sub  
  66. private Sub btnSetDisp_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnSetDisp.Click  
  67. if MsgBox("您确认要将显示器分辨率改为1024x768吗?", MsgBoxStyle.OKCancel, "系统消息") = MsgBoxResult.OK Then  
  68. '调用改变分辩率过程  
  69. changedisp(1024, 768)  
  70. end If  
  71. end Sub 

程序运行所示,点击设置VB.NET分辩率,将会把显示器分辨率改为1024x768,刷新频率为85,是不是很简单?

【编辑推荐】

  1. 实例讲述VB.NET使用Log4Net
  2. 三分钟学会VB.NET转换形态
  3. VB.NET获取硬盘信息四大法宝
  4. 讲述VB.NET调用Excel的好处
  5. 简单例子概述VB.NET新窗体

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...