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

概述

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

实现

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 开发笔记

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-06 22:04:06       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-06 22:04:06       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-06 22:04:06       87 阅读
  4. Python语言-面向对象

    2023-12-06 22:04:06       96 阅读

热门阅读

  1. Python发送微信模板消息

    2023-12-06 22:04:06       57 阅读
  2. 阿里云Mysql5.7 数据库恢复 qp.xb文件恢复数据

    2023-12-06 22:04:06       63 阅读
  3. Lab 5: Python Lists, Trees

    2023-12-06 22:04:06       59 阅读
  4. 浅谈Elasticsearch安全和权限管理

    2023-12-06 22:04:06       47 阅读
  5. Ubuntu22.04 安装nvida-docker2和改路径

    2023-12-06 22:04:06       46 阅读
  6. ElasticSearch之cat indices API

    2023-12-06 22:04:06       54 阅读
  7. 【C++刷题】校招笔试编程题第一辑

    2023-12-06 22:04:06       46 阅读
  8. 洛谷P1269 信号放大器(树形数据)

    2023-12-06 22:04:06       42 阅读
  9. 前端中级开发:突破瓶颈,迈向更高峰

    2023-12-06 22:04:06       52 阅读
  10. Django rest froamwork-HyperlinkedModelSerializer

    2023-12-06 22:04:06       56 阅读