当前位置: 首页 > news >正文

Flutter 实现软鼠标

文章目录

  • 前言
  • 一、如何实现?
    • 1、记录鼠标偏移
    • 2、MouseRegion获取偏移
    • 3、Transform移动图标
  • 二、完整代码
  • 三、使用示例
  • 总结


前言

flutter在嵌入式系统中运行时,有可能遇到drm鼠标无法使用的情况,但鼠标事件却可以正常接收,此时如果有软鼠标,就可以一定程度解决问题。本文提供了一个软鼠标的简单实现,主要适用于无法使用硬鼠标的场景


一、如何实现?

1、记录鼠标偏移

final _offset = ValueNotifier<Offset>(Offset.zero);

2、MouseRegion获取偏移

MouseRegion(onHover: (event) {_offset.value = event.position;},)

3、Transform移动图标

ValueListenableBuilder(valueListenable: _offset,builder: (context, value, child) => Transform.translate(offset: value,))

二、完整代码

import 'package:flutter/material.dart';class SoftMouse extends StatelessWidget {final _offset = ValueNotifier<Offset>(Offset.zero);final Widget child;final Widget? cursor;//自定义鼠标样式SoftMouse({super.key, required this.child, this.cursor});Widget build(BuildContext context) {return MouseRegion(cursor: SystemMouseCursors.none,onHover: (event) {_offset.value = event.position;},child: Stack(children: [child,ValueListenableBuilder(valueListenable: _offset,builder: (context, value, child) => Transform.translate(offset: value,child: Align(alignment: Alignment.topLeft,child: cursor ?? const Icon(Icons.mouse),),),),],));}
}

三、使用示例

class MyApp extends StatelessWidget {const MyApp({super.key});Widget build(BuildContext context) {return MaterialApp(home: Scaffold(body: Center(child: SoftMouse(child: const SizedBox(),),),),);}
}

效果预览

在这里插入图片描述


总结

以上就是今天要讲的内容,本文实现的软鼠标还是比较简单的,当然软鼠标对性能还是有一定的影响的,比如在linux中,每次移动都会触发交换缓存进行drm显示。

http://www.lryc.cn/news/378251.html

相关文章:

  • 使用 MLRun 和 MinIO 设置开发机器
  • 资质申请表详解:填写《建筑幕墙工程设计专项资质申请表》的要点
  • 华为手机怎么找回删除的照片?掌握3个方法,恢复不是梦
  • 数据结构试题 20-21
  • vscode插件开发之 - TestController
  • QBitArray使用详解
  • 基于Python的自然语言处理项目 ChatTTS 推荐
  • 论 To B 产品:从概念到市场实践
  • 如何通过自定义模块DIY出专属个性化的CSDN主页?一招教你搞定!
  • [BSidesCF 2020]Had a bad day1
  • 从媒体网站的频道划分看媒体邀约的分类?
  • Day40
  • linux基础 - 内核的基础概念
  • centos7系统使用docker-compose安装部署jenkins
  • 传染病报卡内容——丙型
  • 本地快速部署大语言模型开发平台Dify并实现远程访问保姆级教程
  • 《Cloud Native Data Center Networking》(云原生数据中心网络设计)读书笔记 -- 02 Clos拓扑
  • VUE3版本新特性
  • 【Oracle篇】Oracle数据库坏块处理:rman修复坏块实践与案例分析(第七篇,总共八篇)
  • 学懂C#编程:从一个简单的例子理解事件处理
  • 深入理解指针(2)
  • C#.Net筑基-集合知识全解
  • AI PPT生成器,一键在线智能生成PPT工具
  • stm32学习笔记---零基础入门介绍2
  • 搭建取图系统app源码开发,满足广泛应用需求
  • 语音质量评价方法之MOS
  • gorm简介
  • MySQL:SELECT list is not in GROUP BY clause 报错 解决方案
  • IPython的使用技巧
  • Spring Boot 多线程例子