0

0

问题探讨01: 如何使用鼠标滚轮使单元格中的数值增减?

雪夜

雪夜

发布时间:2025-09-14 08:12:02

|

806人浏览过

|

来源于php中文网

原创

要实现鼠标滚轮控制单元格数值的增加和减少,我们需要对现有代码进行修改,使其能够区分鼠标滚轮的前后滚动,并相应地调整单元格中的数值。以下是经过修改的代码,确保它能够实现你所期望的功能:

Public hHook As LongPtr

If VBA7 Then

Public Declare PtrSafe Function SetWindowsHookEx Lib "user32" Alias "SetWindowsHookExA" (ByVal idHook As Long, ByVal lpfn As LongPtr, ByVal hmod As LongPtr, ByVal dwThreadId As Long) As LongPtr
Public Declare PtrSafe Function UnhookWindowsHookEx Lib "user32" (ByVal hhk As LongPtr) As Long
Public Declare PtrSafe Function CallNextHookEx Lib "user32" (ByVal hHook As LongPtr, ByVal ncode As Long, ByVal wParam As LongPtr, lParam As Any) As LongPtr
Public Declare PtrSafe Function GetCurrentThreadId Lib "kernel32" () As Long

End If

Public Const WH_MOUSE = 7 Public Const WM_MOUSEWHEEL = &H20A

Sub BeginHK() '获取当前的线程ID i = GetCurrentThreadId '这里安装的是鼠标钩子 hHook = SetWindowsHookEx(WH_MOUSE, AddressOf HookProc, 0, i) End Sub

'Hook程序 Public Function HookProc(ByVal code As Long, ByVal wParam As LongPtr, ByVal lParam As LongPtr) As LongPtr Dim wks As Worksheet Set wks = Excel.ActiveSheet

'如果code参数<0,则一定要返回CallNextHookEx函数的返回值
If code < 0 Then
    HookProc = CallNextHookEx(hHook, code, wParam, lParam)
    Exit Function
End If

'检查是否是鼠标滚轮事件
If code = HC_ACTION And wParam = WM_MOUSEWHEEL Then
    Dim zDelta As Integer
    zDelta = (wParam And &HFFFF0000) \ &H10000

    Dim activeCell As Range
    Set activeCell = wks.Application.ActiveCell

    '检查活动单元格是否包含数字
    If IsNumeric(activeCell.Value) Then
        If zDelta > 0 Then
            '鼠标滚轮向前滚动,增加0.01
            activeCell.Value = activeCell.Value + 0.01
        ElseIf zDelta < 0 Then
            '鼠标滚轮向后滚动,减少0.01
            activeCell.Value = activeCell.Value - 0.01
        End If
    End If
End If

'继续传递消息给其他钩子
HookProc = CallNextHookEx(hHook, code, wParam, lParam)

End Function

Sub EndHK() '卸载钩子 UnhookWindowsHookEx hHook End Sub

这段代码的主要修改点如下:

  1. 捕获鼠标滚轮事件:我们使用
    WM_MOUSEWHEEL
    常量来识别鼠标滚轮事件。
  2. 获取滚轮方向:通过
    zDelta
    变量来判断滚轮的滚动方向。
    zDelta
    的值大于零表示滚轮向前滚动,小于零表示滚轮向后滚动。
  3. 调整单元格值:根据
    zDelta
    的值,相应地增加或减少单元格中的数值。

使用这个修改后的代码,你应该能够实现鼠标滚轮向前滚动时单元格中的数值增加0.01,向后滚动时减少0.01的功能。

Lifetoon
Lifetoon

免费的AI漫画创作平台

下载

问题探讨01: 如何使用鼠标滚轮使单元格中的数值增减?图1

请注意,使用这段代码时,需要在Excel中运行

BeginHK
子程序来启动钩子,并在完成操作后运行
EndHK
子程序来卸载钩子。如果有任何问题或需要进一步的调整,请随时告知。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1435

2023.10.24

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

519

2023.09.20

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

472

2023.08.10

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

471

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

158

2023.10.07

excel对比两列数据异同
excel对比两列数据异同

Excel作为数据的小型载体,在日常工作中经常会遇到需要核对两列数据的情况,本专题为大家提供excel对比两列数据异同相关的文章,大家可以免费体验。

1364

2023.07.25

excel重复项筛选标色
excel重复项筛选标色

excel的重复项筛选标色功能使我们能够快速找到和处理数据中的重复值。本专题为大家提供excel重复项筛选标色的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.31

excel复制表格怎么复制出来和原来一样大
excel复制表格怎么复制出来和原来一样大

本专题为大家带来excel复制表格怎么复制出来和原来一样大相关文章,帮助大家解决问题。

542

2023.08.02

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.4万人学习

Excel 教程
Excel 教程

共162课时 | 10.2万人学习

PHP基础入门课程
PHP基础入门课程

共33课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号