热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何用charts_flutter创建Flutter图表

如何用charts_flutter创建Flutter图表-应用程序中的图表提供了数据的图形显示或图画表示,跨越了行业和应用程序。像Mint这样的移动应用程序使用饼状图来监测消费习惯

应用程序中的图表提供了数据的图形显示或图画表示,跨越了行业和应用程序。像Mint这样的移动应用程序使用饼状图来监测消费习惯,像Strava这样的健身应用程序使用线状图和条状图来分析步幅、心率和海拔高度。

在构建Flutter应用程序时,开发者可以使用由谷歌维护的官方charts_flutter 库来创建这些类型的图表。

在本教程中,我们将学习如何使用charts_flutter 创建一些最常见的图表--线形图、饼图和条形图。

我们将用这些图表来显示一个虚构的Flutter图表开发者社区五年来的增长情况。虽然本教程中的数据是捏造的,但本教程可以很容易地利用真实数据。

前提条件

要学习本教程,您必须具备以下条件。

  • 安装了Flutter
  • 安装了Android Studio或Xcode
  • 对Flutter有一定的了解

创建并设置一个Flutter项目charts_flutter

要创建一个新的Flutter项目,运行以下命令。

flutter create projectName

接下来,在您的代码编辑器中打开这个新项目。如上所述,我们将使用[chart_flutter](https://pub.dev/packages/charts_flutter) ,Flutter的官方库。

要将chart_flutter 导入您的项目,请打开pubspec.yaml 文件并将其添加到依赖项下。

dependencies:
  flutter:
    sdk: flutter

  charts_flutter: ^0.11.0

构建应用程序的脚手架

现在我们有了新的Flutter应用程序所附带的基本代码:一个记录按钮被按下多少次的计数器。

由于我们的条形图应用程序中不需要这个,继续删除在main.dart 页面中发现的代码。删除所有的内容,除了下面的内容。

import ‘package:flutter/material.dart’;
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
            //TODO: implement build
            Return MaterialApp(
            );
     }
}

现在,在我们的构建部件中返回MaterialApp 类,以便我们可以使用Material Design。

创建一个主页

要为我们的应用程序创建一个主页,请导航到lib 文件夹,并创建一个名为home.dart 的新页面。

import 'package:flutter/material.dart';

class HomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Center(
        child: ,
      ),
    );
  }
}

通过import 'package:flutter/material.dart' ,我们就可以导入Material Design。

然后,HomePage 类扩展了statelessWidget ,因为在这个页面上没有状态变化。

BuildContext widget里面,我们返回Scaffold 类,给我们一个基本的Material Design布局结构。我们的条形图将放在子参数的位置,我们将把它放在屏幕主体的中心。

所有这些现在都成为我们应用程序的支架。

随着主页的完成,我们可以在我们的main.dart 文件中指定HomePage ,因为main.dart 将我们应用程序中的所有功能集中在一起。

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: HomePage(), //This is where we specify our homepage
    );
  }
}

有了这段代码,main.dart 就知道每当应用加载时首先显示哪一页。

请注意,将debugShowCheckedModeBanner 设置为false ,就可以从我们的应用程序中删除调试标记。

创建一个Flutter图表应用程序

系列和模型

在我们创建图表应用之前,让我们熟悉一下Flutter图表常用的两个术语:系列和模型。

系列是一组(或系列)的信息,我们可以用它来绘制我们的图表。一个模型是我们的信息的格式,它规定了使用该模型的每个数据项必须具有的属性。

创建一个条形图

为柱状图数据创建一个模型

首先,我们将创建一个柱状图,以显示在过去五年中新增的虚构Flutter图表开发者的数量。换句话说,我们要跟踪虚构的Flutter图表社区的增长情况。

我们的模型,定义了我们的数据格式,包括我们要看的年份,那一年加入Flutter图表社区的开发者数量,以及相应条形图的颜色。

lib 文件夹中,创建一个名为developer_series.dart 的文件。下面,实现我们模型的代码。

import 'package:charts_flutter/flutter.dart' as charts;
import 'package:flutter/foundation.dart';

class DeveloperSeries {
  final int year;
  final int developers;
  final charts.Color barColor;

  DeveloperSeries(
    {
      @required this.year,
      @required this.developers,
      @required this.barColor
    }
  );
}

我们将模型命名为DeveloperSeries ,并指定了每个系列项目必须具备的属性(year,developers, 和barColor )。

为了防止在创建一个类的对象时,该类的参数为空,我们使用了@required 注释,如上面的代码块中所示。

要使用@required 关键字,我们必须导入foundation.dart 包。

为柱状图创建数据

现在我们有了一个条形图数据的模型,让我们继续实际创建一些数据。在主页上,通过添加以下内容为柱状图生成数据。

 import 'package:flutter/material.dart';
import 'package:charts_flutter/flutter.dart' as charts;
import 'package:;lib/developer_series.dart';

class HomePage extends StatelessWidget {
  final List data = [

    DeveloperSeries(
      year: "2017",
      developers: 40000,
      barColor: charts.ColorUtil.fromDartColor(Colors.green),
    ),
    DeveloperSeries(
      year: "2018",
      developers: 5000,
      barColor: charts.ColorUtil.fromDartColor(Colors.green),
    ),
    DeveloperSeries(
      year: "2019",
      developers: 40000,
      barColor: charts.ColorUtil.fromDartColor(Colors.green),
    ),
    DeveloperSeries(
      year: "2020",
      developers: 35000,
      barColor: charts.ColorUtil.fromDartColor(Colors.green),
    ),
    DeveloperSeries(
      year: "2021",
      developers: 45000,
      barColor: charts.ColorUtil.fromDartColor(Colors.green),
    ),
  ];

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Center(
        child: ,
      ),
    );
  }
}

这是一个名为data 的简单列表。列表中的每一个项目都是按照DeveloperSeries 的模型制作的,也就是说每一个项目都有一个年份(year)、开发者的数量(developers)和条形图的颜色(barColor)的属性。

请注意,上面的数据是真实的,所以请随意操作这些数字和颜色。

构建柱状图

我们已经成功地为我们的柱状图创建了数据。现在,让我们来创建条形图本身。为了使我们的项目有条理,我们将把柱状图的代码放在一个单独的文件中。

lib ,创建一个developer_chart.dart 文件。

import 'package:flutter/material.dart';
import 'package:charts_flutter/flutter.dart' as charts;
import 'package:lib/developer_series.dart';

class DeveloperChart extends StatelessWidget {
  final List data;

  DeveloperChart({@required this.data});
  @override
  Widget build(BuildContext context) {
    List> series = [
      charts.Series(
        id: "developers",
        data: data,
        domainFn: (DeveloperSeries series, _) => series.year,
        measureFn: (DeveloperSeries series, _) => series.developers,
        colorFn: (DeveloperSeries series, _) => series.barColor
      )
    ];

    Return charts.Barchart(series, animate: true);
  }

}

通过final List data ,我们定义了一个名为data 的列表,它是我们之前创建的DeveloperSeries 模型形式的数据项的List

列表中的每一个数据项都带有相应的年份、开发人员的数量和条形颜色。

类中的DeveloperChart 构造函数确保在使用条形图类的任何地方,它所需要的数据总是被提供;这是用@required 关键字完成的。

实际的柱状图是在我们的构建部件中创建的。如你所知,所有的柱状图都有几组数据相互对照(在我们的例子中,过去五年和Flutter图表社区获得的开发者数量)。

这些数据组在一起,被称为系列。系列告诉我们Flutter要把哪一组数据放在我们条形图的水平面,哪一组放在垂直面。

然后,我们先前创建的数据列表插入到我们的系列中,并由Flutter适当地使用。

通过List> series ,我们创建了一个名为series 的列表。这个列表的类型为charts.Seriescharts 将Flutter导入我们的项目,Series 函数为Flutter中的柱状图创建系列。

我们刚刚创建的系列是以我们的DeveloperSeries 模型为模型。

我们将在系列中指定的参数包括:id,data,domainFn,measureFn, 和colorFN

  • id 标识了图表
  • data 指向要在柱状图上绘制的项目列表
  • domainFn 指向柱状图水平方向上的数值。
  • measureFn 指向垂直方向上的数值的数量
  • colorFN 指的是条形图的颜色

通过domainFn,measureFn, 和colorFN 函数,我们创建了以Subscriber 系列为参数的函数,创建了它的实例,然后使用这些实例来访问它的不同属性。

developer_chart.dart 文件中的下划线标志着第二个参数是不需要的。

在将我们的系列指向它所需要的所有数据后,我们再使用Flutter的BarChart 函数来创建我们的柱状图。

我们还可以通过简单地将animate 设置为true 来添加一个动画,以获得视觉上的吸引力,这将使图表呈现出一个漂亮的动画。

将柱状图添加到主页上

现在,我们可以将新创建的柱状图添加到我们的主页上并显示。

import 'package:flutter/material.dart';
import 'package:charts_flutter/flutter.dart' as charts;
import 'package:lib/developer_series.dart';
import 'package:lib/developer_chart.dart';

class HomePage extends StatelessWidget {
  // ...

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Center(
        child: DeveloperChart(
          data: data,
        )
      ),
    );
  }
}

在这里,我们只需在我们的页面主体内调用DeveloperChart 类,并将其指向我们要使用的数据。

为了确保我们的图表能够很好地在屏幕上显示,我们将把它放在一个Card ,在它周围包裹一个容器,并给它设置一个高度和一些填充。

…

class DeveloperChart extends StatelessWidget {
  final List data;

  DeveloperChart({@required this.data});
  @override
  Widget build(BuildContext context) {
    List> series = [
      charts.Series(
        id: "developers",
        data: data,
        domainFn: (DeveloperSeries series, _) => series.year,
        measureFn: (DeveloperSeries series, _) => series.developers,
        colorFn: (DeveloperSeries series, _) => series.barColor
      )
    ];

    return Container(
      height: 300,
      padding: EdgeInsets.all(25),
      child: Card(
        child: Padding(
          padding: const EdgeInsets.all(9.0),
          child: Column(
            children: [
              Text(
                "Yearly Growth in the Flutter Community",
                style: Theme.of(context).textTheme.body2,
              ),
              Expanded(
                child: charts.BarChart(series, animate: true),
              )
            ],
          ),
        ),
      ),
    );
  }

}

通过使用expanded widget,我们将我们的柱状图很好地扩展到Card 。上面的Text widget给了我们的柱状图一个标题,让人们知道它是关于什么的。

而且,通过Theme.of(context).textTheme.body2 ,我们将Material Design默认的正文样式应用于我们的标题。

通过padding: const EdgeInsets.all(9.0) ,我们给容纳我们的条形图的卡片在所有边上加了9px的填充。最后,我们将Card 包裹在一个容器中,并给这个容器一个300px的高度和25px的边距。

现在,我们的条形图应该能很好地呈现在我们的屏幕上。

创建饼状图

我们也可以使用charts_flutter 包来创建饼图。事实上,我们上面遵循的程序和我们编写的代码可以创建饼图。

要将我们创建的条形图改为饼图,只需将charts.BarChart(series, animate: true) 改为child:( charts.PieChart(series, animate: true)

然后我们就可以在饼图上添加标签。

Expanded(
          child: charts.PieChart(series,
           defaultRenderer: charts.ArcRendererConfig(
            arcRendererDecorators: [
                     charts.ArcLabelDecorator(
                        labelPosition: charts.ArcLabelPosition.inside)
          ])
           animate: true),
)

ArcRendererConfig 函数可以配置饼图的外观,我们可以使用ArcLabelDecorator 函数为饼图添加标签。

labelPosition 指定将标签放在哪里,是放在里面还是外面;在这种情况下,我们指定标签应该放在外面。

创建折线图

我们可以用创建其他两个图表的同样方法来创建一个折线图。我们只需对我们的数据配置做一个小小的调整。

在我们的系列列表中,List> 变成List> ,因为折线图只对数字起作用。

List> series = [
      charts.Series(
        id: "developers",
        data: data,
        domainFn: (DeveloperSeries series, _) => series.year,
        measureFn: (DeveloperSeries series, _) => series.developers,
        colorFn: (DeveloperSeries series, _) => series.barColor
      )
    ];

现在我们可以把charts.PieChart 改为charts.Linechart ,从而得到我们的折线图。默认情况下,折线图是从原点零开始的。但是我们所关注的年份是从2016年到2021年。因此,这里是如何使我们的折线图跨越这个范围的。

Expanded(
          child: charts.LineChart(series,
           domainAxis: const charts.NumericAxisSpec(
                 tickProviderSpec:
                 charts.BasicNumericTickProviderSpec(zeroBound: false),
                 viewport: charts.NumericExtents(2016.0, 2022.0),
           ),
           animate: true),
)

NumericAxisSpec 函数为图表中的轴设置规格。通过BasicNumericTickProviderSpec 函数,我们将zeroBound 设置为false ,这样我们的图表就不会从原点零开始。

最后,通过NumericExtents 函数,我们设置了我们希望我们的坐标轴所跨越的范围。

总结

本教程的目的是向Flutter开发者展示如何在其应用程序中实现不同的图表。使用谷歌创建的强大的charts_flutter 包,我们能够实现一个柱状图、一个饼状图和一个线形图。

要了解这个包的更多功能,请到pub.dev上查看。


推荐阅读
  • Java 并发编程:RunnableScheduledFuture 接口详解
    本文深入解析了 Java 并发编程中 RunnableScheduledFuture 接口的源代码及其在标准线程池中的应用。 ... [详细]
  • 在多线程并发环境中,普通变量的操作往往是线程不安全的。本文通过一个简单的例子,展示了如何使用 AtomicInteger 类及其核心的 CAS 无锁算法来保证线程安全。 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • 在软件开发过程中,经常需要将多个项目或模块进行集成和调试,尤其是当项目依赖于第三方开源库(如Cordova、CocoaPods)时。本文介绍了如何在Xcode中高效地进行多项目联合调试,分享了一些实用的技巧和最佳实践,帮助开发者解决常见的调试难题,提高开发效率。 ... [详细]
  • 在对WordPress Duplicator插件0.4.4版本的安全评估中,发现其存在跨站脚本(XSS)攻击漏洞。此漏洞可能被利用进行恶意操作,建议用户及时更新至最新版本以确保系统安全。测试方法仅限于安全研究和教学目的,使用时需自行承担风险。漏洞编号:HTB23162。 ... [详细]
  • 尽管我们尽最大努力,任何软件开发过程中都难免会出现缺陷。为了更有效地提升对支持部门的协助与支撑,本文探讨了多种策略和最佳实践,旨在通过改进沟通、增强培训和支持流程来减少这些缺陷的影响,并提高整体服务质量和客户满意度。 ... [详细]
  • 基于iSCSI的SQL Server 2012群集测试(一)SQL群集安装
    一、测试需求介绍与准备公司计划服务器迁移过程计划同时上线SQLServer2012,引入SQLServer2012群集提高高可用性,需要对SQLServ ... [详细]
  • Ihavetwomethodsofgeneratingmdistinctrandomnumbersintherange[0..n-1]我有两种方法在范围[0.n-1]中生 ... [详细]
  • 应用链时代,详解 Avalanche 与 Cosmos 的差异 ... [详细]
  • 本文对比了杜甫《喜晴》的两种英文翻译版本:a. Pleased with Sunny Weather 和 b. Rejoicing in Clearing Weather。a 版由 alexcwlin 翻译并经 Adam Lam 编辑,b 版则由哈佛大学的宇文所安教授 (Prof. Stephen Owen) 翻译。 ... [详细]
  • 2018年在北航听陈博士讲解时,对重入漏洞有了初步了解。最近重温了慢雾科技的相关文章,发现他们对重入漏洞的解释非常清晰明了。 ... [详细]
  • MySQL Decimal 类型的最大值解析及其在数据处理中的应用艺术
    在关系型数据库中,表的设计与SQL语句的编写对性能的影响至关重要,甚至可占到90%以上。本文将重点探讨MySQL中Decimal类型的最大值及其在数据处理中的应用技巧,通过实例分析和优化建议,帮助读者深入理解并掌握这一重要知识点。 ... [详细]
  • 在Windows系统中安装TensorFlow GPU版的详细指南与常见问题解决
    在Windows系统中安装TensorFlow GPU版是许多深度学习初学者面临的挑战。本文详细介绍了安装过程中的每一个步骤,并针对常见的问题提供了有效的解决方案。通过本文的指导,读者可以顺利地完成安装并避免常见的陷阱。 ... [详细]
  • 本文详细解析了Java类加载系统的父子委托机制。在Java程序中,.java源代码文件编译后会生成对应的.class字节码文件,这些字节码文件需要通过类加载器(ClassLoader)进行加载。ClassLoader采用双亲委派模型,确保类的加载过程既高效又安全,避免了类的重复加载和潜在的安全风险。该机制在Java虚拟机中扮演着至关重要的角色,确保了类加载的一致性和可靠性。 ... [详细]
  • Python错误重试让多少开发者头疼?高效解决方案出炉
    ### 优化后的摘要在处理 Python 开发中的错误重试问题时,许多开发者常常感到困扰。为了应对这一挑战,`tenacity` 库提供了一种高效的解决方案。首先,通过 `pip install tenacity` 安装该库。使用时,可以通过简单的规则配置重试策略。例如,可以设置多个重试条件,使用 `|`(或)和 `&`(与)操作符组合不同的参数,从而实现灵活的错误重试机制。此外,`tenacity` 还支持自定义等待时间、重试次数和异常处理,为开发者提供了强大的工具来提高代码的健壮性和可靠性。 ... [详细]
author-avatar
小賑賑_533
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有