Access编程交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • 建立自由的会计日期的报表
  • 用Access轻松打印带相..
  • 解决SELECT TOP ..
  • 如何在任意位置插入记录?
  • 利用ADOX获取Acces..
  • Access建表规范总结(..

最新文章

  • Access用代码创建表
  • access表的设计技巧
  • access实现自动编号从..
  • Access2010出现“..
  • 使用输入掩码控制数据输入格..
  • 索引和主键的异同

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > 数据表 > 表设计
表设计

在子窗体中预览报表

适用于: Access 2002 以上版本(access 2000 不支持弹出式报表)

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


按此在新窗口浏览图片

例程下载:http://www.access-cn.com/UploadFiles/20031229194711700.rar


(报表设计-相关文章技巧链接):
Access判断报表有否数据及打开时让报表最大化
发布人:朱亦文-access faq  
分享到:
点击次数:  更新时间:2005-01-29 10:43:21  【打印此页】  【关闭】
上一条:如何在报表中使用自定义尺寸的纸张  下一条:通过查询返回数据库对象的名称



相关文章

  • • Access用代码创建表
  • • access表的设计技巧
  • • access实现自动编号从1开始排序且不中断
  • • Access2010出现“错误一对多” 调试解决办法
  • • 使用输入掩码控制数据输入格式
  • • 索引和主键的异同
  • • “排队不长,只是很粗”——浅谈化宽为长
  • • Access数据表能做什么

热门文章

  • [2006-11-24] 刷新联接表的函数access数据库
  • [2013-06-28] Access隐藏表中的列access数据库
  • [2017-05-11] 使用输入掩码控制数据输入格式access数据库
  • [2005-02-04] 如何隐藏/显示某个表或者其他数据库对象access数据库
  • [2016-11-24] Access入门新手必修课(十)-Access有效性规则access数据库
  • [2017-04-01] “排队不长,只是很粗”——浅谈化宽为长access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

中山市天鸣科技发展有限公司 版权所有 1999-2023 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2025  www.metinfo.cn