ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 10944|回复: 11

[求助] 关于SetTimer函数!在64位运行的问题

[复制链接]

TA的精华主题

TA的得分主题

发表于 2013-8-20 16:40 | 显示全部楼层 |阅读模式
我想做一个数字秒表

复制代码
  1. Option Explicit
复制代码
'窗口中的代码
Private Sub CmdStart_Click()
    timeX = 0
    iTimerID = SetTimer(0, 0, 100, AddressOf OnTimer)
End Sub

Private Sub CmdStop_Click()
    Call KillTimer(0, iTimerID)
End Sub

Private Sub UserForm_Terminate()
    Call KillTimer(0, iTimerID)
End Sub


错误的情况是: 无标题.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-8-20 16:41 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
  1. Option Explicit
  2. Public Declare PtrSafe Function SetTimer Lib "user32" (ByVal hWnd As LongPtr, ByVal nIDEvent As LongPtr, _
  3.                 ByVal uElapse As LongPtr, ByVal lpTimerFunc As LongPtr) As LongPtr
  4. Public Declare PtrSafe Function KillTimer Lib "user32" (ByVal hWnd As LongPtr, ByVal nIDEvent As LongPtr) As LongPtr
  5. Public iTimerID As Long, timeX As Single
复制代码
  1. Public Sub OnTimer()

  2.     timeX = timeX + 0.1
  3.     UserForm1.TextBox1 = Format(timeX, "0.0")
  4. End Sub
复制代码
  1. Sub ShowUserForm()
  2.    UserForm1.Show
  3. End Sub
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-8-20 16:42 | 显示全部楼层
上面那个是模块里面的代码,编译没问题。在64的系统里面

TA的精华主题

TA的得分主题

发表于 2013-8-20 17:23 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-8-21 09:25 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
wpxxsyzx 发表于 2013-8-20 17:23
http://msdn.microsoft.com/library/ee691831.aspx

非常感谢你的回答。版主

TA的精华主题

TA的得分主题

发表于 2018-2-10 10:50 | 显示全部楼层

您好  第一段代码在64位系统中需要怎么编写呀

TA的精华主题

TA的得分主题

发表于 2018-5-30 11:27 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-9-17 11:39 | 显示全部楼层
mutiantong 发表于 2013-8-21 09:25
非常感谢你的回答。版主

楼主解决了,可以发一下完整代码吗?!!!!弄了一个早上了,还是解决不了!一样的问题

TA的精华主题

TA的得分主题

发表于 2018-9-17 16:36 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2019-5-31 11:17 | 显示全部楼层
挖坟,说明一下64位要改的地方'Api兼容32位与64位
#If VBA7 Then
    Public Declare PtrSafe Function SetTimer Lib "user32" ( _
        ByVal hwnd As Long, ByVal nIDEvent As Long, _
        ByVal uElapse As Long, ByVal lpTimerFunc As LongPtr) As Long

    Public Declare PtrSafe Function KillTimer Lib "user32" ( _
        ByVal hwnd As Long, ByVal nIDEvent As LongPtr) As Long
#Else
    Public Declare Function SetTimer Lib "user32" ( _
        ByVal HWnd As Long, ByVal nIDEvent As Long, _
        ByVal uElapse As Long, ByVal lpTimerFunc As Long) As Long

    Public Declare Function KillTimer Lib "user32" ( _
        ByVal HWnd As Long, ByVal nIDEvent As Long) As Long
#End If

Public Timer甲 As Long,Timer乙 As Long'用时定义定时器名称,多个就定义多个

打开定时器:Timer = SetTimer(0, 1, 1000, AddressOf 过程名) 红色是定时器序号,多个的时候不能一样
   打开多个:Timer = SetTimer(0, 2, 1000, AddressOf 过程名) 红色是定时器序号,多个的时候不能一样

关闭定时器:Timer = KillTimer(0, Timer)

                   Timer = KillTimer(0, Timer)
其他说明,0是窗口句柄,在Office中就为0不需要改,第三个参数1000是定时时间,单位是毫秒

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

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-28 08:05 , Processed in 0.051860 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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