flutter - 饼图图表_flutter 选择时的变化

标签 flutter dart pie-chart

我用charts_flutter创建了这样的饼图。文本小部件在使用 selectionModels->changedListener 选择图表时发生变化。

所以我有一个问题,有没有办法改变所选项目的颜色或弧宽,以便用户可以看到他选择了哪个项目。或者还有另一种方式来显示用户选择的项目?

enter image description here

这是代码

class OutcomeChart extends StatefulWidget {
  @override
  _OutcomeChartState createState() => _OutcomeChartState();

  Widget _buildLabel({String label, double money}) {
    return Center(
      child: SizedBox(
        width: 150,
        child: Text(
          '$label\n$money',
          overflow: TextOverflow.ellipsis,
          textAlign: TextAlign.center,
          style: TextStyle(fontSize: 18),
        ),
      ),
    );
  }
}

class _OutcomeChartState extends State<OutcomeChart> {
  String _categoryName = '';
  double _money = 0;

  List<charts.Series<Map, dynamic>> _createSampleData(List<Map> data) {
    return [
      new charts.Series<Map, dynamic>(
        id: 'Sales',
        domainFn: (Map item, _) => item['category_id'],
        measureFn: (Map item, _) => item['money'],
        data: data,
      )
    ];
  }

  void _onSelectionChanged(charts.SelectionModel model) {
    if (model.hasDatumSelection) {
      final selectedDatum = model.selectedDatum.first;

      setState(() {
        _categoryName = selectedDatum.datum['category_name'];
        _money = selectedDatum.datum['money'].toDouble();
      });
    }
  }

  @override
  Widget build(BuildContext context) {
    return Card(
      child: SizedBox(
        height: 450,
        child: Stack(
          children: [
            BlocBuilder<HomePageBloc, HomePageState>(
              builder: (context, state) {
                var data = state is HomePageDataLoaded
                    ? state.outcome
                    : <Map<dynamic, dynamic>>[];

                var widgets = <Widget>[
                  charts.PieChart(
                    _createSampleData(data),
                    defaultInteractions: true,
                    animate: false,
                    behaviors: [
                      new charts.SelectNearest(),
                      charts.DomainHighlighter(),
                    ],
                    selectionModels: [
                      charts.SelectionModelConfig(
                        type: charts.SelectionModelType.info,
                        changedListener: _onSelectionChanged,
                      )
                    ],
                    defaultRenderer: charts.ArcRendererConfig(
                      arcWidth: 60,
                    ),
                  )
                ];

                if (0 == _money) {
                  var sum = 0;
                  data
                      .map((e) => e['money'])
                      .forEach((element) => sum += element);
                  widgets.add(widget._buildLabel(money: sum.toDouble(), label: 'All'));
                } else {
                  widgets.add(
                      widget._buildLabel(money: _money, label: _categoryName));
                }

                return Stack(children: widgets);
              },
            ),
          ],
        ),
      ),
    );
  }
}

最佳答案

我没有找到如何使用charts_flutter库来做到这一点,所以我将其更改为fl_chart 。和here你可以找到一些例子。

关于flutter - 饼图图表_flutter 选择时的变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63727663/

相关文章:

android - 如何在 MPAndroidChart PieChart 中将自定义浮点值设置为 y 轴

excel - 在Excel VBA中更改饼图的切片颜色

android - android中的半饼图

flutter - 文本表单字段内的内联平面按钮

dart - 按下一个 MaterialButton 时更改一个 MaterialButton 的颜色?

flutter - 如果使用 onDoubleTap,InkWell 效果会延迟启动;想要在触摸小部件时立即触发

flutter - 如何在Flutter中本地存储高级内容购买状态?

flutter - 如何检查相机是否在 flutter 中自动对焦?

flutter - 如何为整个 child (除一个 flutter 中的选定 child )禁用点击事件?

flutter - 如何从方法返回两个值