Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 窗体  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701921
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

如何让ACCESS控件支持拖移拖动拖弋

作者:cg1  摘自:access911.net  :cg1  更新日期:2007-8-6  浏览人次:

 

问题:

如何让ACCESS控件支持拖移拖动拖弋。
窗体上有3个白框,1个红框,白框中有数据,如何让 ACCESS FORM 支持鼠标拖弋,把白框拖到红框的同时,白框内的数值就显示在红框中。

 


回答:


代码非常简单,只要在鼠标移动(MouseMove)事件中编程即可。子窗体控件没有鼠标移动事件,可以将子窗体控件放在选项卡控件内或者放一个矩形框控件在子窗体控件外面,在选项卡控件或者矩形框控件的鼠标移动事件中编程即可。


'注意!这里只写了主要代码,要容错请各位网友自己写代码。
'要提供复位功能,可以在 OPEN 事件中用公共变量记录下所有控件得位置,在 TEXT0-3 的MOUSEUP 事件中编程复位即可


'===========================================================
' 过程及函数名:  doCheck
' 版本号      :  --
' 说明        :  被拖移的控件释放时判断其位置,到目标区域内
'                 就进行赋值操作。目前的代码只支持控件被整个
'                 拖进目标控件内部,如果网友需要碰到边就赋值
'                 的功能,请自行修改代码。
' 引用        :  --
' 输入参数    :  s,被拖动的控件;
'                 t,目标控件;
'                 Button,与 MouseUP 事件的同名参数一致
'                 Shift,与 MouseUP 事件的同名参数一致
'                 X,与 MouseUP 事件的同名参数一致
'                 Y,与 MouseUP 事件的同名参数一致
' 输出值      :  --
' 返回值      :  --
' 调用演示    :  doCheck Text2, Text4, Button, Shift, X, Y
' 最后修改日期:  2007-8-6 17:22:00
' 示例地址    :  http://access911.net/?kbid;72FABE1E1BDCEAF3
' 作者        :  cg1
' 网站        :  http://access911.net
' 电子邮件    :  access911@gmail.com
' 版权        :  作者保留一切权力,
'                 请在公布本代码时将本段说明一起公布,谢谢!
'===========================================================

Public Sub doCheck(ByRef s As Control, ByRef t As Control, Button As Integer, Shift As Integer, X As Single, Y As Single)
    If s.Left > t.Left And _
        s.Top > t.Top And _
        s.Top + s.Height < t.Top + t.Height And _
        s.Left + s.Width < t.Left + t.Width Then
        t.Value = s.Value
    End If

End Sub

'===========================================================
' 过程及函数名:  doMove
' 版本号      :  --
' 说明        :  使控件可以被鼠标拖动。这里没有做过多的错误
'                 效验,只是用 On Error Resume Next 屏蔽了,
'                 如果网友需要可以自己写。
' 引用        :  --
' 输入参数    :  t,控件,被拖动的控件;
'                 Button,与 MouseMove 事件的同名参数一致
'                 Shift,与 MouseMove 事件的同名参数一致
'                 X,与 MouseMove 事件的同名参数一致
'                 Y,与 MouseMove 事件的同名参数一致
' 输出值      :  --
' 返回值      :  --
' 调用演示    :  MouseMove Text2, Button, Shift, X, Y
' 最后修改日期:  2007-8-6 17:22:00
' 示例地址    :  http://access911.net/?kbid;72FABE1E1BDCEAF3
' 作者        :  cg1
' 网站        :  http://access911.net
' 电子邮件    :  access911@gmail.com
' 版权        :  作者保留一切权力,
'                 请在公布本代码时将本段说明一起公布,谢谢!
'===========================================================

Public Sub doMove(ByRef t As Control, ByVal Button As Integer, Shift As Integer, X As Single, Y As Single)
On Error Resume Next
    If Button = acLeftButton Then
        t.Left = t.Left + X
        t.Top = t.Top + Y
    End If
End Sub


以上方法在控件的 MouseMove 事件中调用即可
Private Sub Text0_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)
    doMove Text0, Button, Shift, X, Y
End Sub

判断是否被拖进红色控件,在 MouseUp 事件中调用即可
Private Sub Text0_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single)
    doCheck Text0, Text4, Button, Shift, X, Y
End Sub

示例:
http://access911.net/down/eg/eg_CtlDropAndMove.rar
 (16KB)
子窗体控件拖移示例:
http://access911.net/down/eg/eg_ChildFormCtlDropAndMove2.rar
 (15KB)

 

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利