Project Icon

fusuma

Linux 多点触控手势识别工具实现丰富触控操作

Fusuma 是一款开源的 Linux 多点触控手势识别工具。它支持通过 RubyGems 安装,使用 YAML 配置文件定义手势和操作,提供灵敏度设置和外部触控板自动添加功能。Fusuma 允许用户自定义滑动、缩放、旋转等手势,并通过插件系统扩展功能。这个工具为 Linux 系统带来了类似其他操作系统的丰富触控体验。

Fusuma

Gem 构建状态

Fusuma 是一个多点触控手势识别器。 这个 gem 可以让你的 Linux 系统能够识别滑动或捏合手势,并为它们分配命令。

fusuma_image

襖(Fusuma) 是日本房屋中用来分隔房间的推拉门。

特性

  • 通过 RubyGems 轻松安装
  • 在 YAML 格式中定义手势和操作
  • 手势识别的灵敏度设置(阈值、间隔)
  • 自动添加外部触摸板
  • 通过插件系统扩展功能

安装

授予读取触摸板设备的权限

重要:你必须INPUT组的成员才能通过 Fusuma 读取触摸板。

sudo gpasswd -a $USER input

然后,无需注销或重启即可应用更改。

newgrp input

重要:这会使 /dev/input/ 变为可读,如果出于某些原因(如隐私或安全考虑等,或者可能导致操作系统其他部分出现问题)这对你来说是个问题,请注意这一点。

对于基于 Debian 的发行版(Ubuntu、Debian、Mint、Pop!_OS)

对于基于 Debian 的发行版(Ubuntu、Debian、Mint、Pop!_OS)

1. 安装 libinput-tools

你需要 libinput 1.0 或更高版本。

sudo apt-get install libinput-tools

2. 安装 Ruby

Fusuma 在 Ruby 环境下运行,所以你必须先安装它。

sudo apt-get install ruby

3. 安装 Fusuma

sudo gem install fusuma

4. 安装 xdotool(可选)

用于发送快捷键:

sudo apt-get install xdotool
对于基于 Arch 的发行版(Manjaro、Arch)

对于基于 Arch 的发行版(Manjaro、Arch)

1. 安装 libinput

你需要 libinput 1.0 或更高版本。这在 Manjaro 上很可能已经默认安装了。

sudo pacman -Syu libinput

2. 安装 Ruby

Fusuma 在 Ruby 环境下运行,所以你必须先安装它。

sudo pacman -Syu ruby

3. 安装 Fusuma

注意: 在 Arch Linux 中,默认情况下运行 gem 时,gems 会安装到用户目录(~/.gem/ruby/),而不是系统范围(/usr/lib/ruby/gems/)。这被认为是在 Arch 上管理 gems 的最佳方式,否则可能会与 Pacman 安装的 gems 产生冲突。(来自 Arch Wiki)

要系统范围安装 gems,请参阅 Arch Wiki 上列出的任何方法。

sudo gem install fusuma

4. 安装 xdotool(可选)

用于发送快捷键:

sudo pacman -Syu xdotool

对于真正懒惰的人: 与几乎所有可用作开源软件的东西一样,你可以通过 AUR 中的软件包安装 Fusuma。截至撰写时(2023 年 3 月),你需要的软件包名为 ruby-fusuma

请记住,这个社区构建的软件包在这里并不受官方支持,虽然它可能完成工作,但这并不是预期的安装方式。 以这种方式安装 Fusuma 意味着如果在安装期间或之后出现问题,你将无法获得帮助。 因此,如果通过 AUR 安装后 Fusuma 无法正常工作,请不要在 Github 的 Issues 页面上发布大量问题。 如下所列的 Fusuma 插件也可以通过 AUR 作为可选依赖项安装,命名方式为 ruby-fusuma-替换为插件名称

对于 Fedora

对于 Fedora

1. 安装 libinput-tools

你需要 libinput 1.0 或更高版本。

sudo dnf install libinput

2. 安装 Ruby

Fusuma 在 Ruby 环境下运行,所以你必须先安装它。

sudo dnf install ruby

3. 安装 Fusuma

sudo gem install fusuma

4. 安装 xdotool(可选)

用于发送快捷键:

sudo dnf install xdotool

在 GNOME 中触摸板不工作

确保触摸板事件正在发送到 GNOME 桌面,运行以下命令:

gsettings set org.gnome.desktop.peripherals.touchpad send-events enabled

使用方法

fusuma

更新

sudo gem update fusuma

自定义手势映射

你可以通过创建和编辑 ~/.config/fusuma/config.yml 来自定义手势设置。 注意:如果 ~/.config/fusuma 目录不存在,你需要先创建它。

mkdir -p ~/.config/fusuma        # 创建配置目录
nano ~/.config/fusuma/config.yml # 编辑配置文件

可用的手势

滑动(swipe):

  • 支持 3:4: 手指
  • 支持 left:right:up:down: 方向
  • 支持 begin:update:end: 事件

捏合(pinch):

  • 支持 2:3:4: 手指
  • 支持 in:out: 方向
  • 支持 begin:update:end: 事件

旋转(rotate):

  • 支持 2:3:4: 手指
  • 支持 clockwise:counterclockwise: 方向
  • 支持 begin:update:end: 事件

按住(hold):

  • 需要 libinput 1.19.0 或更高版本
  • 支持 1:2:3:4: 手指
  • 支持 begin:end:cancelled: 事件

关于 YAML 基本语法

  • YAML 中的注释以 # 字符开始。
  • 注释必须与其他标记用空格分隔。
  • 使用空格缩进来表示结构。
  • YAML 文件的缩进不包括制表符。

示例:Ubuntu 的手势映射

滑动:
  3:
    左:
      命令: "xdotool key alt+Right" # 历史前进
    右:
      命令: "xdotool key alt+Left" # 历史后退
    上:
      命令: "xdotool key super" # 活动视图
    下:
      命令: "xdotool key super" # 活动视图
  4:
    左:
      命令: "xdotool key ctrl+alt+Down" # 切换到下一个工作区
    右:
      命令: "xdotool key ctrl+alt+Up" # 切换到上一个工作区
    上:
      命令: "xdotool key ctrl+alt+Down" # 切换到下一个工作区
    下:
      命令: "xdotool key ctrl+alt+Up" # 切换到上一个工作区
捏合:
  向内:
    命令: "xdotool keydown ctrl click 4 keyup ctrl" # 放大
  向外:
    命令: "xdotool keydown ctrl click 5 keyup ctrl" # 缩小
按住:
  4:
    命令: "xdotool key super" # 活动视图

config.yml 更多示例

以下 wiki 页面可以由任何人编辑。

如果你有不错的配置,请与大家分享你的 ~/.config/fusuma/config.yml

阈值和间隔

如果 command: 属性为空,则不会执行滑动/捏合/按住的命令。

threshold: 是对滑动/捏合/按住的灵敏度。默认值为 1。 如果滑动的阈值是 0.5,则滑动距离缩短一半。

interval: 是滑动/捏合/按住之间的延迟。默认值为 1。 如果滑动的间隔是 0.5,则识别下一次滑动的间隔缩短一半。

threshold: / interval: 设置示例

滑动:
  3:
    左:
      命令: 'xdotool key alt+Right' # 阈值: 0.5, 间隔: 0.75
      阈值: 0.5
    右:
      命令: 'xdotool key alt+Left' # 阈值: 0.5, 间隔: 0.75
      阈值: 0.5
    上:
      命令: 'xdotool key super' # 阈值: 1, 间隔: 0.75
    下:
      命令: 'xdotool key super' # 阈值: 1, 间隔: 0.75
捏合:
  2:
    向内:
      命令: "xdotool keydown ctrl click 4 keyup ctrl" # 阈值: 0.5, 间隔: 0.5
    向外:
      命令: "xdotool keydown ctrl click 5 keyup ctrl" # 阈值: 0.5, 间隔: 0.5

阈值:
  捏合: 0.5

间隔:
  滑动: 0.75
  捏合: 0.5

threshold:interval: 有三个优先级。 各个方向(左/右/下/上 → 阈值/间隔)下的单独 threshold:interval: 设置比全局设置(根目录下)具有更高的优先级。

  1. 方向中的子元素(左/右/下/上 → 阈值/间隔)
  2. 根目录下的子元素(阈值/间隔 → 滑动/捏合/按住)
  3. 默认值(= 1)

用于分配命令的 command: 属性

在 fusuma 0.4 版本中,command: 属性可用! 你可以为每个手势分配任何命令。

shortcut: 属性已弃用它在 fusuma 1.0 版本中被移除。 你需要将其替换为 command: 属性。

滑动:
  3:
    左:
-      快捷键: 'alt+Left'
+      命令: 'xdotool key alt+Left'
    右:
-      快捷键: 'alt+Right'
+      命令: 'xdotool key alt+Right'

关于 xdotool

注意:xdotool 存在一些问题

xdotool 的替代方案

选项

  • -c, --config=路径/到/文件 : 使用替代配置文件
  • -d, --daemon : 守护进程化
  • -l, --list-devices : 列出可用设备
  • -v, --verbose : 显示运行 fusuma 的详细结果
  • --version : 显示 fusuma 版本
  • --log-file=路径/到/文件 : 设置日志文件路径

通过设备名称指定触摸板

设置以下选项,仅为指定的触摸板设备识别多点触控手势。

插件:
  过滤器:
    libinput_device_filter:
      保留设备名称:
        - "内置触摸板名称"
        - "外部触摸板名称"

自启动(gnome-session-properties)

  1. 使用 which fusuma 检查您安装 fusuma 的路径
  2. 打开 gnome-session-properties
  3. 添加 Fusuma,并在命令输入栏中输入上述检查到的路径位置
  4. 在命令输入栏的末尾添加 -d 选项

Fusuma 插件

以下功能以插件形式提供:

  • 添加新的手势或组合
  • 针对特定 Linux 发行版的功能
  • 为不同应用程序设置不同的手势

可用插件

Fusuma 插件采用 fusuma-plugin-XXXXX 的命名约定,并托管在 RubyGems 上。

名称版本简介
fusuma-plugin-sendkeyGem模拟键盘事件(兼容 Wayland)
fusuma-plugin-wmctrlGem管理窗口和工作区
fusuma-plugin-keypressGem检测按键组合和触摸板手势
fusuma-plugin-appmatcherGem配置特定应用程序的手势
fusuma-plugin-thumbsenseGem仅在轻触时将按键重新映射为点击

安装 Fusuma 插件

# 安装 fusuma-plugin-XXXX
sudo gem install fusuma-plugin-XXXXX
# 更新
sudo gem list fusuma-plugin- | cut -d' ' -f1 | xargs --no-run-if-empty sudo gem update

教程视频

使用 Fusuma 在 Linux 中实现多点触控触摸板手势
使用 Fusuma 在 Linux 中实现多点触控触摸板手势,作者:Eric Adams

支持

我是一名日本的自由职业工程师,在完成日常工作或假期时开发这些产品。 目前,我用于开源贡献的时间不足。 如果您喜欢我的工作并想要贡献成为赞助者,我将能够更专注于我的项目。

贡献

欢迎在 GitHub 上提交错误报告和拉取请求:https://github.com/iberianpig/fusuma。本项目旨在成为一个安全、友好的协作空间,贡献者应遵守[贡献者公约](http://contributor-covenant.org)行为准则。

许可证

该 gem 以开源方式提供,遵循 MIT 许可证 条款。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号