iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Flutter怎么绘制曲线,折线图及波浪动效
  • 671
分享到

Flutter怎么绘制曲线,折线图及波浪动效

2023-06-29 16:06:34 671人浏览 安东尼
摘要

这篇文章主要介绍了Flutter怎么绘制曲线,折线图及波浪动效,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。简介之前用 Flutter 的 canvas 画点有趣的图形我们介

这篇文章主要介绍了Flutter怎么绘制曲线,折线图及波浪动效,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

简介

之前用 Flutter 的 canvas 画点有趣的图形我们介绍了使用 CustomPaint 绘制自定义形状,可以看到有了图形的平面绘制数学计算方法,我们可以画出所需的形状。本篇我们来介绍线条类图形的绘制,并且结合 Animation 实现了常见的波浪动效。通过本篇,你可以了解到:

  • 正弦曲线的绘制

  • 利用两条正弦曲线加上 Animation 实现波浪动效

  • 曲线的一般绘制方法

  • 折线图绘制

下面是最终实现的效果图,接下来我们一项一项介绍。

Flutter怎么绘制曲线,折线图及波浪动效

正弦曲线绘制

对于正弦曲线,公式定义如下:y=Asin(2ut+θ)对于在屏幕绘制,由于屏幕的点都是离散的,因此实际就是对正弦曲线进行采样,只要采样间隔足够密集,画出来的效果肉眼上很难区分是离散点之间通过连线完成绘制的。因此,绘制正弦曲线其实就是将正弦曲线的点依次连起来就好了。下面是绘制的实现代码,waveHeight是正弦曲线的振幅,这里我们一个屏幕宽度绘制一个周期,因此使用的是 2 * pi * i / size.width

Path path = Path();path.moveTo(0, center.height);for (double i = 1; i < size.width; i += 1) {  path.lineTo(    i,    center.height +        waveHeight * sin(2 * pi * i / size.width + startAngle * pi * 4),  );}canvas.drawPath(path, paint);

波浪动效

观察波浪动效,实际上是两条正弦曲线,由于移动的速度不一样,给人的感觉是向前涌动一样。控制曲线的移动实际上可以在动画过程中控制正弦曲线的起始角度,即公式中的&theta;变量来实现。我们的动画控制变量 Animation<double>的变化范围是0到1,为了保证动画重复角度的连贯性,保持起始角度在一个动画周期结束后保持一致即可,也就是动画周期结束时要为2&pi;的整数倍,这里我们一个设置了一条正弦取消的周期为4&pi;,另一条是6&pi;。起始角度的周期角度越大,给人感觉的移动速度会越快。下面是两条正弦曲线的绘制代码,这里的startAngle就是 Animation<double>对象在动画过程中的值。这里需要注意一下,由于每次startAngle都会刷新,因此在 CustomPainter 的子类中,需要将 shouldRepaint 返回 true 以支持重绘,如果这个值返回是 false 的话就不会重新绘制。

  void paint(Canvas canvas, Size size) {  var center = Size(size.width / 2, waveHeight * 2);  var paint1 = Paint()..color = Color(0xFF20B0FE);  paint1.strokeWidth = 1.0;  paint1.style = PaintingStyle.stroke;  var paint2 = Paint()..color = Color(0x8020C0E5);  paint2.strokeWidth = 1.0;  paint2.style = PaintingStyle.stroke;  Path path2 = Path();  path2.moveTo(0, center.height);  Path path3 = Path();  path3.moveTo(0, center.height + waveHeight);  for (double i = 1; i < size.width; i += 1) {    path2.lineTo(      i,      center.height +          waveHeight * sin(2 * pi * i / size.width + startAngle * pi * 4),    );    path3.lineTo(      i,      center.height +          waveHeight * sin(2 * pi * i / size.width + startAngle * 6 * pi),    );  }  canvas.drawPath(path2, paint1);  canvas.drawPath(path3, paint2);}

完整代码已经上传至:自定义绘图代码,目录在 basic_paint 目录下的 curves_paint.dart 中。

曲线绘制

有了正弦曲线的绘制知识,其他曲线其实也是一个道理,我们通过数学表达式,通过横坐标计算纵坐标的值,然后形成一系列采样点,再用 Path 对象依次连接这些点就可以实现各类曲线的绘制了。下面是对数曲线的绘制示例代码。

var center = Size(size.width / 2, size.height / 2);var paint = Paint()..color = Color(0xFF2080E5); //2080E5paint.strokeWidth = 1.0;paint.style = PaintingStyle.stroke;Path path = Path();path.moveTo(0, center.height);for (double i = 1; i <= size.width; i += 1) {  path.lineTo(    i - 1,    center.height - 20.0 * log(i),  );}canvas.drawPath(path, paint);

绘制效果如下图。

Flutter怎么绘制曲线,折线图及波浪动效

折线图

折线图在实际开发中会比较常见了,通常会有坐标轴,然后将这个点通过线段连起来,并需要标注点的位置。绘制的原理和曲线是一样的,只是因为折线图的间隔比较大而已。而标注点我们可以通过在折线上绘制圆圈或正方形来实现,我们封装了两个类,一个绘制折线,一个绘制坐标轴。坐标轴的绘制目前实现比较简单,就是由外面传入横轴起止点和纵轴起止点,将横轴和纵轴绘制出来并加上了箭头指示。

// 折线绘制class LineChartPainter extends CustomPainter {  final List<Point<double>> points;  LineChartPainter({Key? key, required this.points}) : super();  @override  void paint(Canvas canvas, Size size) {    var paint = Paint()..color = Color(0xFF2080E5); //2080E5    paint.strokeWidth = 2.0;    paint.style = PaintingStyle.stroke;    var pointPaint = Paint()..color = Color(0xFF20FF65); //2080E5    pointPaint.strokeWidth = 1.0;    pointPaint.style = PaintingStyle.stroke;    Path path = Path();    path.moveTo(points[0].x, points[0].y);    for (var point in points) {      path.lineTo(point.x, point.y);      canvas.drawCircle(Offset(point.x, point.y), 4.0, pointPaint);    }    canvas.drawPath(path, paint);  }  @override  bool shouldRepaint(covariant CustomPainter oldDelegate) {    return false;  }}// 坐标轴绘制class AxisPainter extends CustomPainter {  final Point<double> horizontalStartPoint, horizontalEndPoint;  final Point<double> verticalStartPoint, verticalEndPoint;  AxisPainter({    Key? key,    required this.horizontalStartPoint,    required this.horizontalEndPoint,    required this.verticalStartPoint,    required this.verticalEndPoint,  }) : super();  @override  void paint(Canvas canvas, Size size) {    var paint = Paint()..color = Color(0xFF909090);    paint.strokeWidth = 2.0;    paint.style = PaintingStyle.stroke;    Path horizontalPath = Path();    horizontalPath.moveTo(horizontalStartPoint.x, horizontalStartPoint.y);    horizontalPath.lineTo(horizontalEndPoint.x - 1, horizontalEndPoint.y);    canvas.drawPath(horizontalPath, paint);    Path verticalPath = Path();    verticalPath.moveTo(verticalStartPoint.x, verticalStartPoint.y);    verticalPath.lineTo(verticalEndPoint.x, verticalEndPoint.y + 1);    canvas.drawPath(verticalPath, paint);    paint.style = PaintingStyle.fill;    paint.strokeWidth = 2.0;    final double arrowLength = 12.0;    // 画箭头    Path horizontalArrow = Path();    horizontalArrow.moveTo(horizontalEndPoint.x, horizontalEndPoint.y);    horizontalArrow.lineTo(horizontalEndPoint.x - arrowLength,        horizontalEndPoint.y - arrowLength / 2);    horizontalArrow.lineTo(horizontalEndPoint.x - arrowLength,        horizontalEndPoint.y + arrowLength / 2);    horizontalArrow.close();    canvas.drawPath(horizontalArrow, paint);    // 画箭头    Path verticalArrow = Path();    verticalArrow.moveTo(verticalEndPoint.x, verticalEndPoint.y);    verticalArrow.lineTo(        verticalEndPoint.x - arrowLength / 2, verticalEndPoint.y + arrowLength);    verticalArrow.lineTo(        verticalEndPoint.x + arrowLength / 2, verticalEndPoint.y + arrowLength);    verticalArrow.close();    canvas.drawPath(verticalArrow, paint);  }  @override  bool shouldRepaint(covariant CustomPainter oldDelegate) {    return false;  }}

最终实现的折线图绘制效果如下。

Flutter怎么绘制曲线,折线图及波浪动效

其他说明

对于 CustomPaint 的绘制区域,这里特别说明一下。如果 CustomPaint 是组件树的根节点的话,那么绘制区域是整个屏幕。但是如果CustomPaint 有子元素(即 child 参数不为空),那么会将绘制区域尺寸限制为子元素的大小。本篇的示例中使用了一个列表将三个绘制方式放在了一个页面,为了限制每个绘图的尺寸,都指定了一个 Container作为了 CustomPaint 的子元素,通过这种方式可以指定绘制区域大小,以及设置背景色(例如波浪动效的背景就是使用了 Container 实现了渐变效果)。

感谢你能够认真阅读完这篇文章,希望小编分享的“Flutter怎么绘制曲线,折线图及波浪动效”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: Flutter怎么绘制曲线,折线图及波浪动效

本文链接: https://www.lsjlt.com/news/325805.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Flutter怎么绘制曲线,折线图及波浪动效
    这篇文章主要介绍了Flutter怎么绘制曲线,折线图及波浪动效,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。简介之前用 Flutter 的 Canvas 画点有趣的图形我们介...
    99+
    2023-06-29
  • 详解Flutter如何绘制曲线,折线图及波浪动效
    目录正弦曲线绘制波浪动效曲线绘制折线图其他说明总结简介 上一篇用 Flutter 的 Canvas 画点有趣的图形我们介绍了使用 CustomPaint 绘制自定义形状,可以看到有了...
    99+
    2024-04-02
  • Android 贝塞尔曲线绘制一个波浪球
    目录前言一、绘制 backgroundColor 文本二、构建 circlePath三、绘制波浪线四、取交集五、绘制 foregroundColor 文本六、添加动画七、使用前言 当...
    99+
    2024-04-02
  • 怎么用Android贝塞尔曲线绘制一个波浪球
    本篇内容介绍了“怎么用Android贝塞尔曲线绘制一个波浪球”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!效果如下所示:先来总结下 Wave...
    99+
    2023-06-30
  • android绘制曲线和折线图的方法
    本文实例为大家分享了android绘制曲线和折线图的具体代码,供大家参考,具体内容如下 (曲线)  (折线) 1.CurveView.java package com....
    99+
    2024-04-02
  • python怎么绘制折线图
    在Python中,可以使用Matplotlib库来绘制折线图。下面是一个简单的示例:```pythonimport matplotl...
    99+
    2023-08-19
    python
  • CSS中怎么绘制曲线图形及展示动画
    这篇文章主要介绍CSS中怎么绘制曲线图形及展示动画,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!理解 box-shadow首先,回顾一下box-shadow这个属性。基本属性用法就是给元素创造一层阴影。再简单提一下,...
    99+
    2023-06-15
  • Android怎么绘制双折线图
    本篇内容主要讲解“Android怎么绘制双折线图”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android怎么绘制双折线图”吧!自定义View实现双折线图,可点击,点击后带标签描述,暂未实现拖...
    99+
    2023-06-29
  • Python pyecharts怎么绘制折线图
    这篇文章主要介绍“Python pyecharts怎么绘制折线图”,在日常操作中,相信很多人在Python pyecharts怎么绘制折线图问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”P...
    99+
    2023-06-29
  • Python Matplotlib绘制动图平滑曲线
    目录绘制动图FuncAnimationArtistAnimation使用 scipy.ndimage.gaussian_filter1d() 高斯核类绘制平滑曲线使用 scipy.i...
    99+
    2024-04-02
  • 怎么用android实现贝塞尔曲线之波浪效果
    这篇文章主要介绍“怎么用android实现贝塞尔曲线之波浪效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么用android实现贝塞尔曲线之波浪效果”文章能帮助大家解决问题。1 前言贝塞尔曲线的...
    99+
    2023-07-02
  • C#怎么绘制实时曲线图
    这篇文章将为大家详细讲解有关C#怎么绘制实时曲线图,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:        /...
    99+
    2023-06-29
  • python怎么绘制折线统计图
    在Python中,可以使用matplotlib库来绘制折线统计图。下面是一个简单的示例:```pythonimport matplo...
    99+
    2023-08-18
    python
  • Vue+Echarts实现绘制动态折线图
    目录1 引入Echarts1.1 安装1.2 引入1.3 基本使用2 动态折线图2.1 基本折线图2.2 动态折线图补充1 引入Echarts 1.1 安装 使用如下命令通过 npm...
    99+
    2023-03-19
    Vue Echarts绘制动态折线图 Vue Echarts绘制折线图 Vue Echarts 折线图 Vue Echarts
  • MATLAB怎么用数据绘制曲线图
    要使用MATLAB绘制曲线图,可以按照以下步骤进行:1. 准备数据:首先,准备好要绘制的数据。可以是向量、矩阵或表格数据。2. 创建...
    99+
    2023-10-08
    matlab
  • 怎么使用Android LineChart绘制折线图
    这篇文章主要介绍“怎么使用Android LineChart绘制折线图”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Android LineChart绘制折线图”文章能帮...
    99+
    2023-07-05
  • python怎么绘制折线图和条形图
    今天小编给大家分享一下python怎么绘制折线图和条形图的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。折线图import&n...
    99+
    2023-06-30
  • Android怎么实现动态曲线绘制
    这篇文章主要介绍了Android怎么实现动态曲线绘制的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Android怎么实现动态曲线绘制文章都会有所收获,下面我们一起来看看吧。我们在安卓开发中,有时会用到统计图表的...
    99+
    2023-07-02
  • 如何在CSS中绘制曲线图形及展示动画
    目录理解 box-shadow使用阴影复制图像/投影图像在阴影坐标中运用三角函数三角函数如何在 CSS 中使用三角函数 sin/cos控制颜色及初始方向控制颜色在 css-doodl...
    99+
    2024-04-02
  • WPF+ASP.NETSignalR实现动态折线图的绘制
    目录什么是SignalRSignalR做了什么封装与集成SignalR用途官方网址和源码示例截图服务端项目创建SignalR服务端业务集成SignalR服务端配置客户端项目创建客户端...
    99+
    2023-01-03
    WPF 动态折线图 WPF 折线图 WPF SignalR 折线图
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作