设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 2061|回复: 9
打印 上一主题 下一主题

[其它] 怎样实现类似excel中批注功能或效果

[复制链接]
跳转到指定楼层
1#
发表于 2007-5-20 18:34:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我的思路是在一个数据字段后加一个批注字段,在窗体的中把批注字段的内容用某种控件隐藏。在鼠标移到数据内容是自动显示批注内容
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2007-5-20 19:14:00 | 只看该作者
  不需要另用其他控件,直接把批注的值赋予控件的ControlTipText
3#
 楼主| 发表于 2007-5-20 23:57:00 | 只看该作者
以下是引用andymark在2007-5-20 11:14:00的发言:
  不需要另用其他控件,直接把批注的值赋予控件的ControlTipText

没有control tip text的控件嘛?我是2003的
4#
发表于 2007-5-21 18:31:00 | 只看该作者
以下是引用WHQa1028在2007-5-20 15:57:00的发言:



没有control tip text的控件嘛?我是2003的

你用的是中文版吗?...控件属性->其他->控件提示文本
5#
发表于 2007-5-21 20:02:00 | 只看该作者
是属性,不是控件
6#
发表于 2007-5-21 21:26:00 | 只看该作者
如果你有兴趣的话,可以尝试建立一个表,里面记录每个窗体每个控件的功能及说明文字,然后在窗体上创建一个空白标签,当控件的鼠标移动事件发生的时候用函数查找该控件的相关功能及说明文字,并在空白标签中显示出来
7#
发表于 2007-5-22 04:27:00 | 只看该作者
ControlTipText是控件的属性,不是一个控件
8#
发表于 2007-5-22 17:07:00 | 只看该作者
andymark

你好,能做个例子给我们菜鸟看看吗?

9#
发表于 2007-5-22 17:08:00 | 只看该作者
很有意思的一个问题。

10#
发表于 2007-5-22 19:11:00 | 只看该作者
做一个窗体,用一个API使这个窗体半透明,然后用楼上的方法将相关的提示做数据表中,当光标放在相应的栏位时调用窗体.


使窗体透明的相关代码如下:

Option Compare Database
' AnimateWindow是一个窗口打开和关闭时产生动画效果的新函数,因为是一个新的函数, 所以在 API Viewer中是找不到的,必需自己定义:
'  Public Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long
'注释:     具体可以使用的常量及其用法
' Module代码如下

Public Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long
Public Const WS_EX_LAYERED = &H80000
Public Const GWL_EXSTYLE = (-20)
Public Const LWA_ALPHA = &H2 ' Const LWA_ALPHA=&H2 注释:表示把窗体设置成半透明样式
Public Const LWA_COLORKEY = &H1 'Const LWA_COLORKEY=&H1 注释:表示不显示窗体中的透明色
Public Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long
Public Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
'调用方法x = setformcompatible(Me.hwnd, 100)
Public Function setformcompatible(ByVal 窗体句柄 As Long, ByVal 半透明程序0到255 As Long) As Boolean
Dim rtn As Long
rtn = GetWindowLong(窗体句柄, GWL_EXSTYLE) '注释:取的窗口原先的样式
rtn = rtn Or WS_EX_LAYERED '注释:使窗体添加上新的样式WS_EX_LAYERED
SetWindowLong 窗体句柄, GWL_EXSTYLE, rtn '注释:把新的样式赋给窗体
SetLayeredWindowAttributes 窗体句柄, 0, 半透明程序0到255, LWA_ALPHA
setformcompatible = True
'注释:         取值范围0 --255, 为0时就是一个全透明的窗体了
End Function




[此贴子已经被作者于2007-5-22 11:12:54编辑过]

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-9-23 19:21 , Processed in 0.092103 second(s), 34 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表