热门标签 | HotTags
当前位置:  开发笔记 > 开发工具 > 正文

在子窗体中预览报表-mysql教程

本文适用于:Access2002以上版本(Access2000不支持弹出式报表)在很多的时候,需要在窗体的指定位置预览报表,可是Access并没有提供这样功能,Access报表也不能作为子窗体的形式放在窗体中。那么,如何解决这一问题呢?借助WindowsAPI我们可

本文适用于: 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,点击[加载报表]按钮,你看到什么?报表就在子窗体按件的位置打开了

本文作者:
推荐阅读
  • Windows环境下Oracle数据库迁移实践
    本文详细记录了一次在Windows操作系统下将Oracle数据库的控制文件、数据文件及在线日志文件迁移至外部存储的过程,旨在为后续的集群环境部署做好准备。 ... [详细]
  • 如何高效学习鸿蒙操作系统:开发者指南
    本文探讨了开发者如何更有效地学习鸿蒙操作系统,提供了来自行业专家的建议,包括系统化学习方法、职业规划建议以及具体的开发技巧。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 本文介绍了用户界面(User Interface, UI)的基本概念,以及在iOS应用程序中UIView及其子类的重要性和使用方式。文章详细探讨了UIView如何作为用户交互的核心组件,以及它与其他UI控件和业务逻辑的关系。 ... [详细]
  • 本文探讨了线性表中元素的删除方法,包括顺序表和链表的不同实现策略,以及这些策略在实际应用中的性能分析。 ... [详细]
  • 实现Win10与Linux服务器的SSH无密码登录
    本文介绍了如何在Windows 10环境下使用Git工具,通过配置SSH密钥对,实现与Linux服务器的无密码登录。主要步骤包括生成本地公钥、上传至服务器以及配置服务器端的信任关系。 ... [详细]
  • 本文由chszs撰写,详细介绍了Apache Mina框架的核心开发流程及自定义协议处理方法。文章涵盖从创建IoService实例到协议编解码的具体步骤,适合希望深入了解Mina框架应用的开发者。 ... [详细]
  • 本文探讨了Linux环境下线程私有数据(Thread-Specific Data, TSD)的概念及其重要性,介绍了如何通过TSD技术避免多线程间全局变量冲突的问题,并提供了具体的实现方法和示例代码。 ... [详细]
  • C/C++ 应用程序的安装与卸载解决方案
    本文介绍了如何使用Inno Setup来创建C/C++应用程序的安装程序,包括自动检测并安装所需的运行库,确保应用能够顺利安装和卸载。 ... [详细]
  • 探讨在开发Windows应用程序时,如何高效地管理和存储大量库存及生产需求数据的方法。 ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
  • 本文提供了一个关于AC自动机(Aho-Corasick Algorithm)的详细解析与实现方法,特别针对P3796题目进行了深入探讨。文章不仅涵盖了AC自动机的基本概念,还重点讲解了如何通过构建失败指针(fail pointer)来提高字符串匹配效率。 ... [详细]
  • 本报告记录了嵌入式软件设计课程中的第二次实验,主要探讨了使用KEIL V5开发环境和ST固件库进行GPIO控制及按键响应编程的方法。通过实际操作,加深了对嵌入式系统硬件接口编程的理解。 ... [详细]
  • LeetCode 102 - 二叉树层次遍历详解
    本文详细解析了LeetCode第102题——二叉树的层次遍历问题,提供了C++语言的实现代码,并对算法的核心思想和具体步骤进行了深入讲解。 ... [详细]
  • JavaScript 中引号的多层嵌套使用技巧
    本文详细介绍了在 JavaScript 编程中如何处理引号的多级嵌套问题,包括双引号、单引号以及转义字符的正确使用方法。 ... [详细]
author-avatar
mobiledu2502884633
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有