在子窗体中预览报表
在这过程中要用到三个 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 Sub Form_Unload(Cancel As Integer) Private Sub cmdCloseRPT_Click() Private Sub cmdLoadRpt_Click() ' 锁定当前桌面 ' 解锁当前桌面 |
好了,整个设计过程完毕,打开 frmOpenReportInSubForm,点击[加载报表]按钮,你看到什么?报表就在子窗体按件的位置打开了。
例程下载:http://www.access-cn.com/UploadFiles/20031229194711700.rar
(责任编辑:admin)
- ·如何将数据表导出备份到excel表格
- ·在表中用组合框选择备选项目
- ·如何设置表的Caption和Description属性
- ·用Access实现学校课程表的科学管理
- ·在表中设置美元等货币符号的方法
- ·Access建表需注意的问题(建表原则)
- ·Access获取表下个自动增加的ID值【两种
- ·Access光标在文本框的右边
- ·Access格式、掩码、文本有效性的异同
- ·access中的掩码
- ·【技巧】Access时间函数汇总(一)
- ·Access隐藏表中的列
- ·Excel与Access简便联系方法
- ·Word文本文件导入到Access2007与导出的
- ·ACCESS字段中设置默认日期值函数大全
- ·ACCESS的真假:三、往一个表中插入10万