返回顶部
首页 > 资讯 > 移动开发 >Flutter实现支付宝集五福手画福字功能
  • 790
分享到

Flutter实现支付宝集五福手画福字功能

2024-04-02 19:04:59 790人浏览 独家记忆
摘要

目录需求实现思路显示笔画轨迹撤销与清空保存到相册完整代码与demo下载需求 包含需求的具体有: 界面随着用户手指的滑动显示走过轨迹,也就是对应的笔画。 点击清空按钮可以清除所有的笔画

需求

包含需求的具体有:

界面随着用户手指的滑动显示走过轨迹,也就是对应的笔画。

点击清空按钮可以清除所有的笔画。

点击撤销按钮可以清除上一步画过的笔画。

保存所写的文字样式到相册。

实现思路

显示笔画轨迹

使用Listener组件对用户手指落下、滑动和收起的动作进行监听,在onPointerDown,onPointerMove,onPointerUp3个监听方法中返回的PointerMoveEvent对象包含了手指所在的位置坐标偏移量localPosition,用户每次滑动时都会记录下轨迹经过的坐标点,这些坐标点连接起来就是一条线。其次,再配合使用CustomPainter进行画布自绘,将所有划过的点的连接成线使用画笔绘制在界面上即可。

搜集坐标点:

Listener(
  child: Container(
    alignment: Alignment.center,
    color: Colors.transparent,
    width: double.infinity,
    height: MediaQuery.of(context).size.height,
  ),
  onPointerDown: (PointerDownEvent event) {
    setState(() {
      
    });
  },
  onPointerMove: (PointerMoveEvent event) {
    setState(() {
      
    });
  },
  onPointerUp: (PointerUpEvent event) {
    setState(() {
      
    });
  },
),

绘制:

@override
void paint(canvas canvas, Size size) {
  myPaint.strokeCap = StrokeCap.round;
  myPaint.strokeWidth = 15.0;
  if (lines.isEmpty) {
    canvas.drawPoints(PointMode.polyGon, [Offset.zero, Offset.zero], myPaint);
  } else {
    for (int k = 0; k < lines.length; k++) {
      for (int i = 0; i < lines[k].length - 1; i++) {
        if (lines[k][i] != Offset.zero && lines[k][i + 1] != Offset.zero) {
          canvas.drawLine(lines[k][i], lines[k][i + 1], myPaint);
        }
      }
    }
  }
}

撤销与清空

看到上面的代码有的人可能会比较疑惑,绘制时为什么这么复杂,还出现了双重循环。这就和撤销功能有关了,先假设不需要撤销功能,其实我们就可以直接把所有笔画的点连接到一起进行绘制就可以了,但是一旦引入了撤销功能,就要记录每一笔笔画,福字笔画是13画,那么理论上是需要记录13个笔画的,才能保证每次撤销时都能正常退回上一次画过的笔迹,所以第一反应就是使用集合将每一次笔画记录下来。而上面也说了每一个笔画其实也是多个坐标点的集合,所以所有笔画就是一个坐标点集合的集合,即:

/// 所有笔画划线集合
List<List<Offset>> _lines = [];

另外,也不难想到,我们可以轻易通过手指按下和手指手指的方法回调来区分笔画开始和结束。在两个方法中进行笔画的add和更新。

onPointerDown: (PointerDownEvent event) {
  setState(() {
    _event = event;
    _points.add(_event?.localPosition ?? Offset.zero);
    _lines.add(_points);
  });
},
onPointerMove: (PointerMoveEvent event) {
  setState(() {
    _event = event;
    _points.add(_event?.localPosition ?? Offset.zero);
    _lines.last = _points;
  });
},
onPointerUp: (PointerUpEvent event) {
  setState(() {
    _event = event;
    _points.add(Offset.zero);
    _lines.last = _points;
  });
  _points = [];
},

而前面说的双重遍历这时也比较好理解了:

  • 第一层循环是遍历所有的笔画,遍历次数就是福字的笔画数。
  • 第二层循环是每一个笔画包括的好多个坐标点,遍历出来使用drawLine方法绘制到界面上形成一条线。

这样在进行撤销操作时,调用list的removeLast方法移除最后一项再刷新界面就能实现退回一笔的效果了,清空就是清空笔画集合。

保存到相册

保存相册主要是引入了两个插件库:permission_handlerimage_gallery_saver,一个用来获取存储权限,一个用来保存到相册。 使用RepaintBoundary组件将画布包裹起来,并指定key,在点击保存时按顺序调用如下方法先获取截图后保存即可:

RenderRepaintBoundary boundary =
    key.currentContext!.findRenderObject() as RenderRepaintBoundary;
var image = await boundary.toImage(pixelRatio: 3.0);
ByteData? byteData = await image.toByteData(fORMat: ImageByteFormat.png);
_postBytes = byteData?.buffer.asUint8List();
var result = await ImageGallerySaver.saveImage(_postBytes!);

完整代码与demo下载

GitHub地址

安卓手机扫码下载

到此这篇关于Flutter实现支付宝集五福手画福字功能的文章就介绍到这了,更多相关Flutter画福字内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Flutter实现支付宝集五福手画福字功能

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

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

猜你喜欢
  • Flutter实现支付宝集五福手画福字功能
    目录需求实现思路显示笔画轨迹撤销与清空保存到相册完整代码与demo下载需求 包含需求的具体有: 界面随着用户手指的滑动显示走过轨迹,也就是对应的笔画。 点击清空按钮可以清除所有的笔画...
    99+
    2024-04-02
  • Android 支付宝支付功能封装实现
      在做Android支付的时候肯定会用到支付宝支付, 根据官方给出的demo做起来非常费劲,所以我们需要一次简单的封装。封装的代码也很简单,是将官网给的demo提取出一个...
    99+
    2022-06-06
    封装 支付宝 Android
  • Vue如何实现支付宝支付功能
    这篇文章主要介绍了Vue如何实现支付宝支付功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。先给大家上个效果图: <div&...
    99+
    2024-04-02
  • Android实现支付宝手势密码功能
    今天就给大家分享android实现支付宝手势密码,很常见,像现在用微信支付,支付宝支付的时候都要自己设置的4位PIN码,然后输入PIN码后立即调用支付接口去支付,毫无疑问的安全...
    99+
    2022-06-06
    支付宝 手势 Android
  • uniapp如何实现支付宝支付的功能
    随着移动互联网的飞速发展,人们越来越依赖于手机支付。而支付宝是其中使用最广泛的支付方式之一。在移动应用中,如果要进行支付宝支付的功能开发,那么使用uniapp框架就是一个非常好的选择。本文将介绍uniapp如何实现支付宝支付的功能。一、准备...
    99+
    2023-05-14
  • UniApp + SpringBoot 实现支付宝支付和退款功能
    目录开发准备支付宝支付开发后端部分前端部分支付宝退款开发后端部分上篇介绍了UniApp + SpringBoot 实现微信支付和退款功能,喜欢的朋友可以点击查看。 开发准备 一台用于...
    99+
    2024-04-02
  • SpringBoot实现简易支付宝网页支付功能
           该文章描述了一个基于SpringBoot程序的支付宝支付demo,由于是个人开发者而非企业,因此设...
    99+
    2024-04-02
  • vue项目中的支付功能实现(微信支付和支付宝支付)
    目录项目中常见的支付方式    支付宝支付微信支付项目中常见的支付方式     支付宝支付  &nbs...
    99+
    2024-04-02
  • Android中怎么接入支付宝实现支付功能
    本篇文章为大家展示了Android中怎么接入支付宝实现支付功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.登录官网他的官网就是蚂蚁金服的开放平台了,我们可以访问 蚂蚁金服开放平台 ,并且注册账...
    99+
    2023-05-31
    android
  • Ecshop实现的支付宝手机网页支付功能免费版示例
    本文实例讲述了Ecshop实现的支付宝手机网页支付功能。分享给大家供大家参考,具体如下: Ecshop手机网页版本支持在网上找了很多需要花钱购买了,在这里小编整理了一个Ecshop 支付宝手机网页支付免费版供大家参考. ...
    99+
    2022-06-12
    Ecshop 支付宝 手机 网页 支付功能 免费版
  • 怎么用Java也实现微信和支付宝支付功能
    这篇文章主要介绍“怎么用Java也实现微信和支付宝支付功能”,在日常操作中,相信很多人在怎么用Java也实现微信和支付宝支付功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • 如何进行vue项目中的支付功能实现(微信支付和支付宝支付)
    如何进行vue项目中的支付功能实现(微信支付和支付宝支付),针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。项目中常见的支付方式    支付宝支付...
    99+
    2023-06-22
  • Android自定义View实现支付宝支付成功-极速get花式Path炫酷动画
    本文手把手教你图片->SVG->Path的姿势.。 从此酷炫Path动画,如此简单。 效果先随便上几个图,以后你找到的图有多精彩,gif就有多精彩: 随便搜了一个铅...
    99+
    2022-06-06
    path get view 支付宝 动画 Android
  • 怎么用PHP实现支付宝和微信扫码在线支付的功能
    本篇内容介绍了“怎么用PHP实现支付宝和微信扫码在线支付的功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2024-04-02
  • 如何在Python项目中利用Django框架实现一个支付宝付款功能
    今天就跟大家聊聊有关如何在Python项目中利用Django框架实现一个支付宝付款功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。建立一个Django项目然后在里面创建一个应用,如...
    99+
    2023-06-06
  • Android波纹扩散效果之仿支付宝咻一咻功能实现波纹扩散特效
    今年春节晚会没看尽兴,被支付宝集福给添了一段插曲,朋友们都在那数定时间段不停的咻一咻,哇,我咻到一个敬业福,不可能的,哈哈。那么咻一咻功能基于程序代码是怎么实现的呢?下面编程网...
    99+
    2022-06-06
    咻一咻 支付宝 Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作