Flutter 实现软鼠标

文章目录


前言

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


一、如何实现?

1、记录鼠标偏移

dart 复制代码
final _offset = ValueNotifier<Offset>(Offset.zero);

2、MouseRegion获取偏移

dart 复制代码
MouseRegion(
        onHover: (event) {
          _offset.value = event.position;
        },)

3、Transform移动图标

dart 复制代码
ValueListenableBuilder(
              valueListenable: _offset,
              builder: (context, value, child) => Transform.translate(
                offset: value,)
                )

二、完整代码

dart 复制代码
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});
  @override
  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),
                ),
              ),
            ),
          ],
        ));
  }
}

三、使用示例

dart 复制代码
class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        body: Center(
          child: SoftMouse(
            child: const SizedBox(),
          ),
        ),
      ),
    );
  }
}

效果预览


总结

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

相关推荐
G_dou_7 小时前
Flutter三方库适配OpenHarmony【color_picker】HSL 调色器项目完整实战
flutter·harmonyos
韩曙亮7 小时前
【Flutter】Flutter 组件 ② ( 组件大小设置 | 固定大小 | 自适应大小 | 填充父容器 | 百分比大小 )
flutter·自适应大小·flutter组件大小·固定大小·填充父容器
G_dou_7 小时前
Flutter三方库适配OpenHarmony【random_number】随机数生成器项目完整实战
flutter·harmonyos
●VON7 小时前
鸿蒙Flutter实战:日期选择器与截止日期高亮提醒
android·flutter·华为·harmonyos·鸿蒙
●VON7 小时前
鸿蒙Flutter实战:Material 3种子色亮暗双主题系统
android·flutter·harmonyos
灰鲸广告联盟8 小时前
新老用户广告价值不同?差异化策略如何实现收益最大化
android·开发语言·flutter·ios
2501_9197490310 小时前
鸿蒙 Flutter 实战:saver_gallery 5.1.0 适配 3.27-ohos 全流程
flutter·华为·harmonyos
●VON11 小时前
鸿蒙Flutter实战:异步回调mounted检查安全实践
flutter·华为·harmonyos·鸿蒙
2601_9496955911 小时前
打印机错误0x00000709怎么办?原因分析及详细修复步骤
计算机外设·电脑
●VON11 小时前
鸿蒙Flutter实战:MethodChannel桥接获取OHOS文件目录
flutter·华为·harmonyos·鸿蒙