ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 6294|回复: 4

[分享]获取和设置ACCESS主窗体大小及位置代码

[复制链接]

TA的精华主题

TA的得分主题

发表于 2008-5-2 23:27 | 显示全部楼层 |阅读模式
获取和设置ACCESS主窗体大小及位置代码

'//按 ALT+F11 转到 vba 界面,
'//新建一个模块
'//将以下代码 COPY 进去
'//将光标停在 Function RunTest() 这行
'//按 F5 即可运行
'//运行结束后转到 ACCESS 使用界面,即可看到效果

'-----------------------------------------------
'自定义数据类型,GetAccessWindow的返回值

Public Type AWPix
    Left As Long
    Top As Long
    Width As Long
    Height As Long
End Type

'-----------------------------------------------
'获取、设置 Window状态的API

Public Declare Function FindWindowEx Lib "user32" Alias "FindWindowExA" (ByVal hWnd1 As Long, _
    ByVal hWnd2 As Long, ByVal lpsz1 As String, ByVal lpsz2 As String) As Long
Public Declare Function GetWindowRect Lib "user32" (ByVal hwnd As Long, lpRect As RECT) As Long
Public Declare Function MoveWindow Lib "user32" (ByVal hwnd As Long, ByVal X As Long, _
    ByVal y As Long, ByVal nWidth As Long, ByVal nHeight As Long, ByVal bRepaint As Long) As Long

Public Type RECT '屏幕坐标中随同窗口装载的矩形
    Left As Long
    Top As Long
    Right As Long
    Bottom As Long
End Type

'-----------------------------------------------
'获取分辩率设置的 API

Public Declare Function apiGetDC Lib "user32" Alias "GetDC" (ByVal hwnd As Long) As Long
Public Declare Function apiReleaseDC Lib "user32" Alias "ReleaseDC" (ByVal hwnd As Long, _
    ByVal hdc As Long) As Long
Public Declare Function apiGetDeviceCaps Lib "gdi32" Alias "GetDeviceCaps" (ByVal hdc As Long, _
    ByVal nIndex As Long) As Long
Public Const LOGPIXELSX = 88
Public Const LOGPIXELSY = 90
Public Const DIRECTION_VERTICAL = 1
Public Const DIRECTION_HORIZONTAL = 0


'-----------------------------------------------
'获取窗体缩放状态的 API
'缩放状态

Public Declare Function IsZoomed Lib "user32" (ByVal hwnd As Long) As Long
'是否最小化
Public Declare Function IsIconic Lib "user32" (ByVal hwnd As Long) As Long
'是否可见
Public Declare Function IsWindowVisible Lib "user32" (ByVal hwnd As Long) As Long


'---------------------------------------------
'设置窗体状态的 API

Public Const SW_HIDE = 0            '隐藏
Public Const SW_SHOWNORMAL = 1      '普通(还原)
Public Const SW_SHOWMINIMIZED = 2   '最小化
Public Const SW_SHOWMAXIMIZED = 3   '最大化

Public Declare Function apiShowWindow Lib "user32" _
    Alias "ShowWindow" (ByVal hwnd As Long, _
    ByVal nCmdShow As Long) As Long
'----------------------------------------------

'像素转换成缇,本站以前文章中已经介绍过了。
'    关于单位“缇”与“像素”的转换,以及缇与其他单位(例如:厘米)之间的转换《窗体》
'    http://access911.net/index.asp?u1=a&u2=72FAB41E13DCE9F3
Function PixelsToTwips(rlngPixels As Long, rlngDirection As Long) As Long
On Error GoTo PixelsToTwips_Err
    
    Dim lngDeviceHandle As Long
    Dim lngPixelsPerInch As Long
    lngDeviceHandle = apiGetDC(0)
    If rlngDirection = DIRECTION_HORIZONTAL Then  
'水平X方向
        lngPixelsPerInch = apiGetDeviceCaps(lngDeviceHandle, LOGPIXELSX)
    Else       
'垂直Y方向
        lngPixelsPerInch = apiGetDeviceCaps(lngDeviceHandle, LOGPIXELSY)
    End If
    lngDeviceHandle = apiReleaseDC(0, lngDeviceHandle)
    PixelsToTwips = rlngPixels * 1440 / lngPixelsPerInch
    
PixelsToTwips_Exit:
    On Error Resume Next
    Exit Function
    
PixelsToTwips_Err:
    MsgBox Err.Description, vbExclamation, "access911.net"
    Resume PixelsToTwips_Exit
    
End Function

'像素转换成缇,本站以前文章中已经介绍过了。
'    关于单位“缇”与“像素”的转换,以及缇与其他单位(例如:厘米)之间的转换《窗体》
'    http://access911.net/index.asp?u1=a&u2=72FAB41E13DCE9F3
Function PixelsToTwips(rlngPixels As Long, rlngDirection As Long) As Long
On Error GoTo PixelsToTwips_Err
    
    Dim lngDeviceHandle As Long
    Dim lngPixelsPerInch As Long
    lngDeviceHandle = apiGetDC(0)
    If rlngDirection = DIRECTION_HORIZONTAL Then  
'水平X方向
        lngPixelsPerInch = apiGetDeviceCaps(lngDeviceHandle, LOGPIXELSX)
    Else       
'垂直Y方向
        lngPixelsPerInch = apiGetDeviceCaps(lngDeviceHandle, LOGPIXELSY)
    End If
    lngDeviceHandle = apiReleaseDC(0, lngDeviceHandle)
    PixelsToTwips = rlngPixels * 1440 / lngPixelsPerInch
    
PixelsToTwips_Exit:
    On Error Resume Next
    Exit Function
    
PixelsToTwips_Err:
    MsgBox Err.Description, vbExclamation, "access911.net"
    Resume PixelsToTwips_Exit
    
End Function

'===========================================================
' 过程及函数名:  RunTest
' 版本号      :  --
' 说明        :  本过程只用于演示如何用VBA+WINAPI 控制
'                 Access 主窗体的位置和大小
' 引用        :  --
' 输入参数    :  --
' 输出值      :  --
' 返回值      :  --
' 调用演示    :  RunTest
' 最后修改日期:  2008-1-30 16:36:00
'===========================================================

Function RunTest()
    '显示当前Access主窗体的高度
    Debug.Print GetAccessWindow.Height
    '设置当前Access窗体:
    '宽 553像素,高400像素,距离上边20像素,左边12像素

    SetAccessWindow 12, 20, 553, 400
End Function


'===========================================================
' 过程及函数名:  GetAccessWindow
' 版本号      :  --
' 说明        :  获取 ACCESS 主窗体的大小及位置,获取单位是
'                 像素,如果要转为ACCESS的度量衡单位“Twip缇”
'                 可以用函数 PixelsToTwips 转换。
'                 注意,本函数还定义了一个 Type AWPix
' 引用        :  --
' 输入参数    :  --
' 输出值      :  --
' 返回值      :  返回自定义类型 AWPix 数据。
' 调用演示    :  Debug.Print GetAccessWindow.Height
' 最后修改日期:  2008-1-30 16:36:00
'===========================================================

Function GetAccessWindow() As AWPix
    Dim intWidth As Long, intHeight As Long
    Dim tAWPix As AWPix
    Dim lngRet As Long
    Dim Rc As RECT
    Dim lngHwndMDI As Long
    '获取ACCESS主窗体内嵌子对象的句柄
    lngHwndMDI = FindWindowEx(Application.hWndAccessApp, _
        0&, "MDIClient", "")
    '上边距中不包含工具栏和菜单栏。尝试去掉工具栏看一下结果,然后再加上工具栏再看看结果
    'lngRet = GetWindowRect(lngHwndMDI, Rc)
    
    '获取整个ACCESS窗体最外侧的尺寸,在Win2003+acc2003的情况下最大化时每边都需要+4

    lngRet = GetWindowRect(Application.hWndAccessApp, Rc)
    
    
    
    With tAWPix
        .Top = Rc.Top
        .Left = Rc.Left
        .Height = Rc.Bottom - Rc.Top
        .Width = Rc.Right - Rc.Left
    End With
    
    GetAccessWindow = tAWPix
End Function


'===========================================================
' 过程及函数名:  SetAccessWindow
' 版本号      :  --
' 说明        :  设置 ACCESS 主窗体的大小及位置,设置单位是像素
' 引用        :  --
' 输入参数    :  --
' 输出值      :  --
' 返回值      :  --
' 调用演示    :  SetAccessWindow 0,0,150,566
' 最后修改日期:  2008-1-30 16:36:00
'===========================================================

Function SetAccessWindow(ByVal XLeft As Long, _
    ByVal YTop As Long, _
    ByVal XWidth As Long, _
    ByVal YHeight As Long)
    
    Dim lngHwndMDI As Long
    Dim lngRet As Long
    Dim Rc As RECT
    If IsZoomed(Application.hWndAccessApp) = 1 Or _
        IsIconic(Application.hWndAccessApp) = 1 Then
        apiShowWindow Application.hWndAccessApp, SW_SHOWNORMAL
    End If
    MoveWindow Application.hWndAccessApp, XLeft, YTop, XWidth, YHeight, True
End Function

TA的精华主题

TA的得分主题

发表于 2008-5-3 00:26 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
很详细的资料,感谢提供!

TA的精华主题

TA的得分主题

发表于 2008-5-5 20:16 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
放在哪里?怎么放[em04]

TA的精华主题

TA的得分主题

发表于 2008-8-22 13:15 | 显示全部楼层
就是哦!!!怎么用哦????

TA的精华主题

TA的得分主题

发表于 2011-1-18 16:29 | 显示全部楼层
Access动态设置窗体
占位学习
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2025-1-11 23:00 , Processed in 0.021308 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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