Office中国论坛/Access中国论坛

标题: 怎样实现类似excel中批注功能或效果 [打印本页]

作者: WHQa1028    时间: 2007-5-20 18:34
标题: 怎样实现类似excel中批注功能或效果
我的思路是在一个数据字段后加一个批注字段,在窗体的中把批注字段的内容用某种控件隐藏。在鼠标移到数据内容是自动显示批注内容
作者: andymark    时间: 2007-5-20 19:14
  不需要另用其他控件,直接把批注的值赋予控件的ControlTipText
作者: WHQa1028    时间: 2007-5-20 23:57
以下是引用andymark在2007-5-20 11:14:00的发言:
  不需要另用其他控件,直接把批注的值赋予控件的ControlTipText

没有control tip text的控件嘛?我是2003的
作者: eyewitnes    时间: 2007-5-21 18:31
以下是引用WHQa1028在2007-5-20 15:57:00的发言:



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

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

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


作者: goto2008    时间: 2007-5-22 17:08
很有意思的一个问题。


作者: lihaizhu    时间: 2007-5-22 19:11
做一个窗体,用一个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编辑过]






欢迎光临 Office中国论坛/Access中国论坛 (http://www.office-cn.net/) Powered by Discuz! X3.3