【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 开发笔记
相关推荐
蜡笔小新星7 分钟前
Python Kivy库学习路线
开发语言·网络·经验分享·python·学习
凯子坚持 c7 分钟前
C语言复习概要(三)
c语言·开发语言
无限大.19 分钟前
c语言200例 067
java·c语言·开发语言
余炜yw20 分钟前
【Java序列化器】Java 中常用序列化器的探索与实践
java·开发语言
篝火悟者22 分钟前
问题-python-运行报错-SyntaxError: Non-UTF-8 code starting with ‘\xd5‘ in file 汉字编码问题
开发语言·python
Death20024 分钟前
Qt 中的 QListWidget、QTreeWidget 和 QTableWidget:简化的数据展示控件
c语言·开发语言·c++·qt·c#
六点半88826 分钟前
【C++】速通涉及 “vector” 的经典OJ编程题
开发语言·c++·算法·青少年编程·推荐算法
惜.己26 分钟前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
niu_sama29 分钟前
基于muduo库函数实现protobuf协议的通信
开发语言·qt
不写八个32 分钟前
Qt教程(001):Qt概述与安装
开发语言·qt