您现在的位置: 中国男护士网 >> 考试频道 >> 计算机等级 >> 二级辅导 >> ACCESS >> 辅导 >> 正文    
  在子窗体中预览报表 【注册男护士专用博客】          

在子窗体中预览报表

www.nanhushi.com     佚名   不详 

  在这过程中要用到三个 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,点击[加载报表]按钮,你看到什么?报表就在子窗体按件的位置打开了。

 

文章录入:杜斌    责任编辑:杜斌 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     

    联 系 信 息
    QQ:88236621
    电话:15853773350
    E-Mail:malenurse@163.com
    免费发布招聘信息
    做中国最专业男护士门户网站
    最 新 热 门
    最 新 推 荐
    相 关 文 章
    没有相关文章
    专 题 栏 目

      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)                            【进男护士社区逛逛】
    姓 名:
    * 游客填写  ·注册用户 ·忘记密码
    主 页:

    评 分:
    1分 2分 3分 4分 5分
    评论内容:
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表网友个人观点,与本网站立场无关。