本文适用于: Access 2002 以上版本 (Access 2000 不支持弹出式 报表 ) 在很多的时候,需要在窗体的指定位置预览 报表 ,可是 Access 并没有提供这样功能,Access 报表 也不能作为子窗体的形式放在窗体中。那么,如何解决这一问题呢?借助 Windows API 我们可
本文适用于: Access 2002 以上版本 (Access 2000 不支持弹出式报表)
在很多的时候,需要在窗体的指定位置预览报表,可是 Access 并没有提供这样功能,Access 报表也不能作为子窗体的形式放在窗体中。那么,如何解决这一问题呢?借助 Windows API 我们可以实现这一功能。
在这过程中要用到三个 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
LockWindowUpdate 函数:锁定当前窗口
GetDesktopWindow 函数:获取当前桌面窗口
SetParent 函数:将窗口放到指定的窗口中
该过程主要原理是通过 SetParent 函数指定报表窗口的户窗口句柄 hWnd 来实现将报表窗口放置在指定口中。由于要用到窗口句柄 hWnd,而在 Access 只有窗体才具有窗口句柄 hWnd,因此我们用一个窗体来作为子窗体使用。在本文中,这个窗体名为 frmBack,具体属性设置如下:
记录选择器:否
滚动条:两者均无
记录选择器:否
导航按钮:无
分隔线:无
自动调整:是
边框样式:无
图片:D:\我的文档\My Pictures\back-1.gif
图片缩放模式:拉伸
其它均为默认值
这样这个窗体既具有窗口句柄 hWnd,又可作为开始的背景使用。
下面开始设计报表,在本文中报表名为 rpt1,按照正常报表进行设计,只有一个属性需要特别设置:
弹出方式:是
下面进行主窗体设计,在本文中窗体名为 frmOpenReportInSubForm,具体属性设置如下:
标题:在子窗体中预览报表
滚动条:两者均无
记录选择器:否
导航按钮:否
分隔线:否
自动调整:是
自动居中:是
边框样式:对话框边框
在窗体放上两个按钮:加载报表 cmdLoadRpt 和关闭报表 cmdCloseRPT,再放一个子窗体控件名为 subRPT,属性设置:
源对象:frmBack
好了,界面设置完毕,开始编写代码:
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,点击[加载报表]按钮,你看到什么?报表就在子窗体按件的位置打开了
本文作者:
Access 验证规则是一种数据验证工具,用于确保数据符合特定条件,防止输入无效数据。设置验证规则的步骤:1. 选择要设置验证规则的字段;2. 打开“字段属性”对话框并切换到“查找”选项卡;3. 在“验证规则”字段中输入验证规则;4. 在“验证文本”字段中输入不符合规则时的错误消息;5. 单击“确定”保存更改。

microsoft access是由微软发布的关系数据库管理系统;它结合了MicrosoftJet Database Engine和图形用户界面两项特点,是Microsoft Office的系统程序之一。

Access 数据库文件的扩展名为 .accdb,自 Microsoft Access 2007 起开始使用,用于识别包含结构化数据的容器文件,如表、查询和窗体。

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。详细介绍:1、引用必要的命名空间,在VB项目中,首先需要引用“System.Data`和`Microsoft.Office.Interop.Access”命名空间,以便使用ADO.NET和Access相关的类和方法,可以在VB项目的引用中添加这些命名等等。

access和trunk端口的区别:1、Access端口用于连接终端设备,提供单个VLAN的接入,而Trunk端口用于连接交换机之间,提供多个VLAN的传输;2、Access端口只传输属于指定VLAN的数据,而Trunk端口可以传输多个VLAN的数据,并使用VLAN标签进行区分。

Microsoft Access 是一款关系型数据库管理系统 (RDBMS),用于存储、管理和分析数据。它主要用于数据管理、导入/导出、查询/报表生成、用户界面设计和应用程序开发。Access 优势包括易用性、集成数据库管理、强大灵活、与 Office 集成和可扩展性。

Vue中如何实现图片的滚动和缩略图预览?在Vue项目中,我们经常需要展示大量的图片,并希望用户能够方便地浏览和预览这些图片。本文将介绍如何使用Vue组件实现图片的滚动和缩略图预览功能。首先,我们需要安装并引入合适的Vue库,以便于实现图片的滚动和缩略图预览。在本例中,我们将使用vue-awesome-swiper和vue-image-preview两个库来实

Access 数据库提供了多种数据类型,用于存储不同类型的数据,包括:文本、数字、日期和时间、布尔、二进制等。其中,文本类型包括 Text、Memo 和 Hyperlink;数字类型包括 Byte、Integer、Long Integer、Single、Double 和 Currency;日期和时间类型包括 Date、Time 和 Date/Time;布尔类型为 Yes/No;二进制类型为 OLE Object 和 Attachment。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

Atom editor mac version download
The most popular open source editor

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SublimeText3 Chinese version
Chinese version, very easy to use
