在这过程中要用到三个 Windows API 函数,它们是:
Private Declare Function LockWindowUpdate Lib "user32" (ByVal hwndLock As Long) As Long Private Declare Function GetDesktopWindow Lib "user32" () As Long Private Declare Function SetParent Lib "user32" (ByVal hWndChild As Long, ByVal hWndNewParent As Long) As Long
该过程主要原理是通过 SetParent 函数指定报表窗口的户窗口句柄 hWnd 来实现将报表窗口放置在指定口中。由于要用到窗口句柄 hWnd,而在 Access 只有窗体才具有窗口句柄 hWnd,因此我们用一个窗体来作为子窗体使用。在本文中,这个窗体名为 frmBack,具体属性设置如下:
这样这个窗体既具有窗口句柄 hWnd,又可作为开始的背景使用。
下面开始设计报表,在本文中报表名为 rpt1,按照正常报表进行设计,只有一个属性需要特别设置:
下面进行主窗体设计,在本文中窗体名为 frmOpenReportInSubForm,具体属性设置如下:
在窗体放上两个按钮:加载报表 cmdLoadRpt 和关闭报表 cmdCloseRPT,再放一个子窗体控件名为 subRPT,属性设置:
好了,界面设置完毕,开始编写代码:
Form_frmOpenReportInSubForm 代码如下:
Option Compare Database Option Explicit Private Declare Function LockWindowUpdate Lib "user32" (ByVal hwndLock As Long) As Long Private Declare Function GetDesktopWindow Lib "user32" () As Long Private Declare Function SetParent Lib "user32" (ByVal hWndChild As Long, ByVal hWndNewParent As Long) As Long Private Sub Form_Unload(Cancel As Integer) ' 关闭报表 DoCmd.Close acReport, "rpt1" End Sub Private Sub cmdCloseRPT_Click() ' 关闭报表 DoCmd.Close acReport, "rpt1" End Sub Private Sub cmdLoadRpt_Click() Dim mWnd As Long ' 锁定当前桌面 LockWindowUpdate GetDesktopWindow ' 打开报表 rpt1 DoCmd.OpenReport "rpt1", acViewPreview, , , acWindowNormal ' 获取报表窗体窗口句柄 mWnd = Reports("rpt1").hwnd ' 设置报表的父窗口为子窗体 SetParent mWnd, Me.subRPT.Form.hwnd ' 解锁当前桌面 LockWindowUpdate False ' 选择报表对象,对其进行最大化 DoCmd.SelectObject acReport, "rpt1" DoCmd.Maximize End Sub好了,整个设计过程完毕,打开 frmOpenReportInSubForm,点击[加载报表]按钮,你看到什么?报表就在子窗体按件的位置打开了。
ASP编码教程:如何实现/使用缓存
[ASP]2015年4月15日ASP编码教程:asp缓存的分类
[ASP]2015年4月15日ASP编码教程:何谓ASP缓存/为什么要缓存
[ASP]2015年4月15日ASP编码教程:asp实现的sha1加密解密代码
[ASP]2015年4月15日ASP编码教程:asp执行带参数的sql语句实例
[ASP]2015年4月14日