【发布时间】:2016-04-10 09:33:44
【问题描述】:
我的 Access 数据库有一个 autoexec 宏,它可以打开一个主菜单(表单)。所有必要的功能都是菜单(表单)控制的,我想隐藏访问窗口以便只显示表单。我被提到http://www.tek-tips.com/faqs.cfm?fid=2562 但这不适用于更高版本。是否有适用于 Access 2007-2013 的 sn-p?
【问题讨论】:
-
我不确定那是什么,但它确实有效。谢谢
我的 Access 数据库有一个 autoexec 宏,它可以打开一个主菜单(表单)。所有必要的功能都是菜单(表单)控制的,我想隐藏访问窗口以便只显示表单。我被提到http://www.tek-tips.com/faqs.cfm?fid=2562 但这不适用于更高版本。是否有适用于 Access 2007-2013 的 sn-p?
【问题讨论】:
这是我在 Acc 2003 和 2007 应用程序中运行的代码,在 2010 环境中运行:
Private Sub Form_Load()
'Hide Data-Base Window:
DoCmd.SelectObject acTable, , True
DoCmd.RunCommand acCmdWindowHide
'...Other Actions...
end sub
为了在 2007 年及更高版本中隐藏功能区,请使用我找到的这条线 here:
DoCmd.ShowToolbar "Ribbon", acToolbarNo
【讨论】:
看来您的目标是限制数据库用户可以使用的 Access UI 功能。您希望将它们限制为您通过启动表单提供的选项。
在这种情况下,请复制您的 ACCDB 文件并将其文件扩展名更改为 ACCDR。然后,当您从 Windows 资源管理器中打开 ACCDR 时,Access 将以“运行时模式”打开它。运行时模式抑制了大多数标准 UI 选项。例如,导航窗格不显示,甚至无法打开。它还为您提供了一个非常小的功能区版本;大多数标准功能区选项都已消失。
运行时模式还有其他后果,您应该调查一下它是否适合您的需求。一个重要问题是运行时模式会在遇到未处理的错误时退出应用程序。
如果 ACCDR/运行时模式适合您的特定情况,那么它是一种限制数据库 UI 功能的廉价方式。但是,请注意用户可能会复制 ACCDR 并将文件扩展名更改回 ACCDB,因此仅此方法可能无法满足您的安全要求。
【讨论】:
这是我使用到 2016 年的产品:
Option Compare Database
Option Explicit
'''HIDE WINDOW MODULE
'''USE THIS TO ACTIVATE HIDE WINDOW MODULE
''' SixHatHideWindow(SW_SHOWMINIMIZED)
Global Const SW_HIDE = 0
Global Const SW_SHOWNORMAL = 1
Global Const SW_SHOWMINIMIZED = 2
Global Const SW_SHOWMAXIMIZED = 3
Private Declare Function apiShowWindow Lib "user32" Alias "ShowWindow" (ByVal hwnd As Long, ByVal nCmdShow As Long) As Long
Function SixHatHideWindow(nCmdShow As Long)
Dim loX As Long
Dim loForm As Form
On Error Resume Next
Set loForm = Screen.ActiveForm
If Err <> 0 Then
loX = apiShowWindow(hWndAccessApp, nCmdShow)
Err.Clear
End If
If nCmdShow = SW_SHOWMINIMIZED And loForm.Modal = True Then
MsgBox "Cannot minimize Access with " _
& (loForm.Caption + " ") _
& "form on screen"
ElseIf nCmdShow = SW_HIDE And loForm.PopUp <> True Then
MsgBox "Cannot hide Access with " _
& (loForm.Caption + " ") _
& "form on screen"
Else
loX = apiShowWindow(hWndAccessApp, nCmdShow)
End If
SixHatHideWindow = (loX <> 0)
End Function
简单地隐藏窗口:Call SixHatHideWindow(SW_SHOWMINIMIZED)
还请注意:根据哪个版本,即 32 位或 64 位,您可能需要添加 PtrSafe 属性,因此如果您对此有问题,请声明 API 函数,如下所示:Private Declare PtrSafe Function apiShowWindow...
【讨论】:
我试图完成隐藏 Access 应用程序窗口并使用可以从 Outlook 运行的弹出表单。这就是我遇到这篇文章的方式。但我发现,在 Windows 7 64 位上使用 Outlook 2013 64 位,甚至不需要 SixHatHideWindow 函数。在 Outlook 2013 中使用以下代码可以完成相同的操作。 (不要忘记在 VBA 中添加对 Access 对象库的引用。)此过程保存当前活动 Outlook 窗口中的标题,启动 Access 的新隐藏实例(应用程序窗口不可见),打开指定的 Access 数据库,运行指定的窗体(可见),在窗体关闭时退出 Access 实例,并重新激活原始 Outlook 活动窗口。我没有在任何其他环境中测试过这个,也没有使用运行时访问。
这种方法的好处是它不需要在 Access 数据库的表单打开事件中插入任何特殊代码。所有必要的代码都包含在 Outlook VBA 中。数据库表单的弹出和模式属性也不需要在数据库中设置为“是”。
本例中的表单是一个复杂的表单,包含一个选项卡控件和几个子表单。无论表单是从 Access 本身打开还是通过 Outlook 自动打开,一切似乎都可以正常工作。
注意:即使 Access 不可见,SetWindowPos api 也会设置 Access 主窗口的位置和大小。当 Access 关闭时,用户下次打开 Access 时,它将重新打开到由 SetWindowPos api 设置的大小和位置。这对用户来说可能很烦人,因此 SetWindowPos api 将 Access 应用程序窗口设置为全屏大小。下次用户打开 Access 时,它将在他们的屏幕上最大化。可能有更复杂的方法来处理这个问题,但这种方法既快速又简单,而且大多数用户在大多数情况下都使用最大化的 Access。
希望这对某人有所帮助。
Private Declare PtrSafe Function SetWindowPos Lib "user32.dll" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, _
ByVal X As Long, ByVal Y As Long, ByVal cX As Long, ByVal cY As Long, ByVal wFlags As Long) As Long
Private Declare PtrSafe Function GetClientRect Lib "user32" (ByVal hwnd As Long, lpRect As RECT) As Long
Private Declare PtrSafe Function GetDesktopWindow Lib "user32" () As Long
Private Type RECT
Left As Long
Top As Long
Right As Long
Bottom As Long
End Type
Sub OpenAccessFrmProjDetails()
Dim accapp As Access.Application
Dim HoldCaption As String
Dim ScreenRect As RECT
Dim ret As Long
Dim width As Variant
Dim height As Variant
'Get the width and height of the screen in pixels
10 ret = GetClientRect(CLng(GetDesktopWindow()), ScreenRect)
20 width = ScreenRect.Right - ScreenRect.Left
30 height = ScreenRect.Bottom - ScreenRect.Top
'Get Outlook activewindow caption
40 HoldCaption = ActiveWindow.Caption
'Display the Access database form
50 Set accapp = New Access.Application
60 With accapp
70 .opencurrentdatabase ("C:\Users\pmf\Documents\Programming Development\Access Visibility Testing\Hidden.accdb")
80 SetWindowPos .hWndAccessApp, 0, 0, 0, width, height, 0
90 .DoCmd.OpenForm FormName:="frmProjDetails", WindowMode:=acDialog
100 End With
110 Set accapp = Nothing
'Reactivate Outlook
120 AppActivate HoldCaption
110 End Sub
【讨论】:
在
中查看此解决方案我在 acees 2016 中测试了该解决方案对我的工作,并稍作改动
我在模块中插入内容并在手动创建的宏ExcAuto中调用函数VerifyLoadApplication()
接下来,在vba编辑器中编译所有代码->调试->编译并验证所有代码vba中没有空子例程,以避免在acccde中转换acccdb失败
但我在第一次打开 accde 文件时遇到问题,它工作正常,但是对于所有下一个打开的文件,主页和文件选项卡出现
在网上搜索并在本地测试代码并找到此解决方案
'注释两条指令
'CurrentDb.Properties("AllowFullMenus") = False
'CurrentDb.Properties("AllowBuiltInToolbars") = False
'并用这个指令替换
DoCmd.ShowToolbar "Ribbon", acToolbarNo
你可以在代码的第一方中对两个指令做同样的事情,条件为真
【讨论】: