Flutter实战-折线图(fl_chart)

1-引入依赖

fl_chart: ^0.35.0  # 折线图

2-源码

import 'package:fl_chart/fl_chart.dart';
import 'package:flutter/material.dart';

void main(){
  runApp(
    MaterialApp(home: LineChartSample2(),)
  );
}

class LineChartSample2 extends StatefulWidget {
  @override
  _LineChartSample2State createState() => _LineChartSample2State();
}

class _LineChartSample2State extends State<LineChartSample2> {
  

  @override
  Widget build(BuildContext context) {
    return Container(
      margin: const EdgeInsets.only(top: 40),
      child: Column(children: [
        Container(
          height: 400,
          child: ListView(
            scrollDirection: Axis.horizontal,
            children: [
              const SizedBox(width: 10,),
              SizedBox(
                width: 400,
                height: 400,
                child:  Stack(
                  children: <Widget>[
                    Container(
                      width: 400,
                      height: 400,
                      decoration: const BoxDecoration(
                          borderRadius: BorderRadius.all(
                            Radius.circular(18),
                          ),
                          color: Color.fromRGBO(124, 124, 126, 1)),
                      child: Padding(
                        padding: const EdgeInsets.all(40),
                        child: LineChart(
                          mainData(),
                        ),
                      ),
                    ),
                    const Positioned(
                      top: 20,
                      left: 20,
                      child: Text(
                        '访问量',
                        style: TextStyle(
                            fontSize: 12, color: Colors.white,decoration: TextDecoration.none),
                      ),
                    )
                  ],
                ),
              ),
            ],
          )
        ),
      ]),
    );
  }
  LineChartData mainData() {
    return LineChartData(
      // 网格自定义 -- gridData
      gridData: FlGridData(
        // show -- 是否显示网格线
        show: false, 
        //drawVerticalLine -- 是否显示垂直方向的网格线
        drawVerticalLine: false,         
      ),
      // titlesData -- 自定义x,y轴的坐标
      titlesData: FlTitlesData(
        // show -- 是否显示x,y轴的坐标标题
        show: true,
        // bottomTitles -- 定义x轴的标题
        bottomTitles: SideTitles(
          showTitles: false,
          // reservedSize: 22,
          // getTextStyles: (value) =>
          // const TextStyle(color: Color(0xff68737d), fontWeight: FontWeight.bold, fontSize: 16),
          // getTitles: (value) {
          //   if(value.toInt()%2==0){
          //     return value.toInt().toString()+'月';
          //   }
          //   return '';
          // },
          // margin: 8,
        ),
        // leftTitles -- 定义y轴的坐标标题
        leftTitles: SideTitles(
          showTitles: true,
          getTextStyles: (value) => const TextStyle(
            color: Colors.white,
            fontWeight: FontWeight.bold,
            fontSize: 15,
          ),
          getTitles: (value) {
            switch (value.toInt()) {
              case 1:
                return '10k';
              case 3:
                return '30k';
              case 5:
                return '50k';
            }
            return '';
          },
          reservedSize: 28,
          margin: 12,
        ),
      ),
      // borderData -- FlBorderData来设置边框的大小和颜色
      borderData:
      FlBorderData(show: false, border: Border.all(color: const Color(0xff37434d), width: 1)),
      minX: 0, // x轴的起点
      maxX: 11, // x轴的终点
      minY: 0, // y轴的起点
      maxY: 6, // y轴的终点
      lineBarsData:linesBarData1(), // lineBarsData -- 对折线进行自定义
      lineTouchData: LineTouchData(
        touchTooltipData: LineTouchTooltipData(
          tooltipBgColor: Colors.amber,          
        )
      )
    );
  }
  List<LineChartBarData> linesBarData1() {
    final LineChartBarData lineChartBarData1 = LineChartBarData(
      // 设置各点的横纵坐标
      spots: [
        FlSpot(0, 3),
        FlSpot(2.6, 2),
        FlSpot(4.9, 5),
        FlSpot(6.8, 3.1),
        FlSpot(8, 4),
        FlSpot(9.5, 3),
        FlSpot(11, 4),
      ],
      // 是否绘制成曲线
      isCurved: true,
      // 曲线的颜色
      colors:[const Color.fromRGBO(255, 255, 255, 1)] ,
      // 曲线的宽度
      barWidth: 2,
      // 确定线帽的形状
      isStrokeCapRound: true,
      // 显示结点
      dotData: FlDotData(
        show: false,
      ),
      // 折线图向下充满颜色
      belowBarData: BarAreaData(
        show: true,
        colors: [
          Color.fromRGBO(255, 255, 255, 0.7),
          Color.fromRGBO(255, 255, 255, 0),
        ],
        gradientColorStops: [0.0, 1.0],
        gradientFrom: const Offset(1,0),//纵向渐变
        gradientTo: const Offset(1,1),
      ),      
    );
    return [lineChartBarData1];
  }
}

运行效果

fl_chart条形图:Flutter实战 -- fl_chart(条形图)-CSDN博客

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
下面是一个使用fl_chart库创建饼图的简单示例: ```dart import 'package:flutter/material.dart'; import 'package:fl_chart/fl_chart.dart'; class PieChartSample extends StatefulWidget { @override _PieChartSampleState createState() => _PieChartSampleState(); } class _PieChartSampleState extends State<PieChartSample> { int touchedIndex; @override Widget build(BuildContext context) { return AspectRatio( aspectRatio: 1, child: PieChart( PieChartData( pieTouchData: PieTouchData(touchCallback: (pieTouchResponse) { setState(() { if (pieTouchResponse.touchInput is FlLongPressEnd || pieTouchResponse.touchInput is FlPanEnd) { touchedIndex = -1; } else { touchedIndex = pieTouchResponse.touchedSectionIndex; } }); }), borderData: FlBorderData(show: false), sectionsSpace: 0, centerSpaceRadius: 40, sections: getSections(), ), ), ); } List<PieChartSectionData> getSections() { return List.generate(4, (i) { final isTouched = i == touchedIndex; final double fontSize = isTouched ? 25 : 16; final double radius = isTouched ? 60 : 50; switch (i) { case 0: return PieChartSectionData( color: Colors.red, value: 40, title: '40%', radius: radius, titleStyle: TextStyle( fontSize: fontSize, fontWeight: FontWeight.bold, color: const Color(0xffffffff), ), ); case 1: return PieChartSectionData( color: Colors.green, value: 30, title: '30%', radius: radius, titleStyle: TextStyle( fontSize: fontSize, fontWeight: FontWeight.bold, color: const Color(0xffffffff), ), ); case 2: return PieChartSectionData( color: Colors.blue, value: 15, title: '15%', radius: radius, titleStyle: TextStyle( fontSize: fontSize, fontWeight: FontWeight.bold, color: const Color(0xffffffff), ), ); case 3: return PieChartSectionData( color: Colors.yellow, value: 15, title: '15%', radius: radius, titleStyle: TextStyle( fontSize: fontSize, fontWeight: FontWeight.bold, color: const Color(0xffffffff), ), ); default: return null; } }); } } ``` 在这个例子中,我们创建了一个PieChartSample类,它继承自StatefulWidget。在build()方法中,我们创建了一个AspectRatio小部件,它将PieChart小部件的宽高比设置为1:1。然后,我们创建了一个PieChart小部件,它接收一个PieChartData对象作为参数。PieChartData对象包含所有的饼图数据,包括饼图的颜色、半径、标题、值等。 在PieChartData对象中,我们使用了PieTouchData对象来处理用户的触摸事件。我们还使用了FlBorderData对象来隐藏边框,使用sectionsSpace属性来设置饼图部分之间的间距,使用centerSpaceRadius属性来设置中心空间的半径。 在getSections()函数中,我们生成了饼图的各个部分。每个部分都由一个PieChartSectionData对象表示,它包括颜色、半径、值、标题和标题样式等属性。我们返回一个包含所有部分的列表,然后将它们传递给PieChartData对象。 最后,我们在PieTouchData对象的touchCallback属性中处理触摸事件。如果用户停止触摸饼图,我们将touchedIndex设置为-1,否则,我们将touchedIndex设置为当前触摸部分的索引。根据touchedIndex的值,我们可以设置饼图部分的半径和标题样式,以突出显示当前触摸的部分。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值