【Flutter】graphic图表实现tooltip一段时间后自动隐藏

概述

graphic图表中提供了自定义tooltip的事件,可通过selectionsonclear配置手势选项和可识别设备,默认情况下tooltip需要双击隐藏,但这并不符合我们的需求。通过调研发现,若想实现tooltip隔几秒后隐藏,可通过StreamController向chart发送订阅流事件隐藏,这感觉更像是局部刷新

实现

javascript 复制代码
import 'dart:async';
import 'package:flutter/material.dart';

class ChartWidget extends StatefulWidget {
  const ChartWidget({super.key});

  @override
  State<ChartWidget> createState() => _ChartWidgetState();
}

class _ChartWidgetState extends State<ChartWidget> {
  LineChart? callBackValue;

  //流Stream 控制器
  final StreamController<LineChart?> _streamController = StreamController();

  @override
  void dispose() {
    //销毁
    _streamController.close();
    super.dispose();
  }

  @override
  void initState() {
    super.initState();
    //发送消息
    _streamController.add(初始化数据);
  }

  Timer? _timer;
  // tooltip几秒后自动消失
  void _hideTooltip(value) {
    // 如果已经有一个计时器在运行,取消它
    _timer?.cancel();
    // 启动一个新的计时器
    _timer = Timer(const Duration(seconds: 3), () {
      print('3秒后自动消失');
      _streamController.add(value);
    });
  }
  // 自定义tooltip
  List<MarkElement> simpleTooltip(
    Size size,
    Offset anchor,
    Map<int, Tuple> selectedTuples,
  ) {
    _hideTooltip(图表数据);
    // 自定义处理....
  }

  @override
  Widget build(BuildContext context) {
    // //接收消息
    return StreamBuilder<LineChart?>(
      //绑定Stream
      stream: _streamController.stream,
      builder: (BuildContext context, AsyncSnapshot<LineChart?> snapshot) {
        if (snapshot.data == null) {
          return const Center(
            child: CircularProgressIndicator(),
          );
        }
        // 返回chart组件
        return SingleChildScrollView(
            child: Center(
              child: Column(
                children: <Widget>[
                  Container(
                    padding: const EdgeInsets.fromLTRB(20, 40, 20, 5),
                    child: const Text(
                      'Group interactions',
                      style: TextStyle(fontSize: 20),
                    ),
                  ),
                  Container(
                    margin: const EdgeInsets.only(top: 10),
                    width: 450,
                    height: 200,
                    child: Chart(
                      // 手势事件交互流
                      gestureStream: StreamController<GestureEvent>.broadcast(),
                      // 将接收到的数据赋值给图表data
                      data: snapshot.data!,
                      // 其他配置....
                      tooltip: TooltipGuide(
                          renderer: simpleTooltip,
                      ),
                    )
                  ),
                ],
              ),
            ),
          );
      },
    );
  }
}

效果

溯源

  1. github作者回复issues/64
  2. 作者文章Graphic 开发笔记
相关推荐
q567315232 分钟前
Java使用Selenium反爬虫优化方案
java·开发语言·分布式·爬虫·selenium
恋猫de小郭2 分钟前
Flutter 小技巧之:实现 iOS 26 的 “液态玻璃”
android·前端·flutter
程序猿小D7 分钟前
第26节 Node.js 事件
服务器·前端·javascript·node.js·编辑器·ecmascript·vim
hnlucky13 分钟前
安装vue的教程——Windows Node.js Vue项目搭建
前端·javascript·vue.js·windows·node.js
帅次20 分钟前
Flutter Container 组件详解
android·flutter·ios·小程序·kotlin·iphone·xcode
苏_Berlvy28 分钟前
javascript中Cookie、BOM、DOM的使用
javascript
我的div丢了肿么办38 分钟前
ResizeObserver和IntersectionObserver的详细讲解
前端·javascript·vue.js
凌览39 分钟前
斩获 7k Star,这个桌宠项目火了🔥
前端·javascript·后端
勤奋的知更鸟1 小时前
Java性能测试工具列举
java·开发语言·测试工具
YuTaoShao1 小时前
Java八股文——JVM「类加载篇」
java·开发语言·jvm