Android自定义View实现支付宝支付成功-极速get花式Path炫酷动画

本文手把手教你图片->SVG->Path的姿势.。

从此酷炫Path动画,如此简单。

效果先随便上几个图,以后你找到的图有多精彩,gif就有多精彩:

随便搜了一个铅笔画的图,丢进去

随手复制的二维码icon

来自大佬wing的铁塔

前文回顾

这里简单回顾一下前文,GIF如下图:

PathAnimView接受的唯一数据源是Path(给我一个Path,还你一个动画View)

所以内置了几种将别的资源->Path的方法:

直接传string。(A-Z,0-9 “.” “- ” “)  //根据String 转化成Path setSourcePath(PathParserUtils.getPathFromArrayFloatList(StoreHousePath.getPath("ZhangXuTong", 1.1f, 16))); 定义在R.array.xxx里    //动态设置 从StringArray里取 storeView2.setSourcePath(PathParserUtils.getPathFromStringArray(this, R.array.storehouse, 3)); 简单的SVG(半成品)      //SVG转-》path //还在完善中,我从github上找了如下工具类,发现简单的SVG可以转path,复杂点的 就乱了 /* SvgPathParser svgPathParser = new SvgPathParser(); try { Path path = svgPathParser.parsePath("M1,1 L1,50 L50,50 L50,50 L50,1 Z"); storeView3.setSourcePath(path); } catch (ParseException e) { e.printStackTrace(); }*/

当时我称之为简单的SVG ,因为当时我对SVG也不是很懂,现在经过一段时间的学习和基友们的讨论(wing神,白神,群友等),我才知道我从gayhub上找到的这个工具类,是可以将标准的SVG转换为Android中的Path(android.graphics.Path)的。

之前的痛点

之前我转换失败的,所谓 复杂的SVG,其实是我直接利用AS生成的vector(我称之android svg)。里面对标准SVG进行了一些语法的扩充,才导致我转换的失败。(例如扩充了 S,Q等标记)

例如我们利用AS的工具,直接生成一个Android机器人的icon的Vector,之前我以为这就是SVG数据了,实际上我发现这是对标准SVG进行了扩展,

生成的数据如下:

标红处可以看到,1.5s, s并不在标准的SVG语法中,所以解析会出错。

图片->SVG->Path的正确姿势

那么为什么我今天又敢出来写(zhuang)博(b)客了呢,因为我已经有了解决这个问题的方案。

好,让我们想一下,实际开发中,如果要用Path动画,我们的场景是什么?

嗯,看到一张想要她动的图,或 UI妹子给了你一张,让你自己动的图。

步骤一:图->SVG

利用vmde软件,我们可以轻松完成将图->SVG。(大佬wing提供的方案)

首先我们先get一张喜欢的图,可以从Iconfont里取,下载方式直接不要选SVG,这里的SVG直接使用会有问题,原因不明.我们就选PNG下载即可。

然后打开vmde软件

直接将刚才的PNG图片拖入其中 点击右上角的全自动 点击完成 点击另存,格式记得选择*.svg

其实现在我们已经可以用一些文本编辑工具直接打开SVG,并且复制其中的PathData,以String形式传入PathAnimView即可。

Path path = svgPathParser.parsePath(pathString); storeView3.setSourcePath(path);

嗯,方法其实就这么简单,但是~有很多的图,是有N段PathData的,也就是说复制起来极其麻烦,

而且如果要从中剔除一些不需要的Path,或者改变几个Path的绘制顺序,就更难筛选了。

步骤二:利用工具网站预览Path

于是我就求白神给我做了一个工具页面,它可以完成SVG的解析、预览、并将每段Path分隔开,方便我们复制黏贴。

http://liuyouth.github.io/utils/svg2android/index.html

使用方式也相当简单,直接拖动SVG的图丢进去即可。

解析后的效果图

可以看到,我们可以方便的选取每一段Path,如果我只需要最外面的齿轮,那我只对齿轮部分点击select all即可。

也可以调整顺序,例如我想先绘制外圈,就将外圈的Path放在前面复制进我们的app中。

这里再拿文首第一张妹子图举例:

经过PNG->SVG->预览的步骤后,如下:

vmde给我们生成了海量的path数据,我们只想要其中一部分有用的,

于是通过预览&放大,我只复制了两段Path,效果就如文首了。

关于这个网站,白神已经承诺我,会尽快加上图片预览的放大和一键复制全部Path的功能,大家敬请期待。

手摸手实战:支付宝支付成功动画

其实支付宝支付成功动画相当简单,路径 就是画一个圆 + 一个勾.

路径的获取,可以:

利用本文介绍的图片->SVG->Path 的方法。 也直接用Path的一些draw方法实现。

我们利用本文的办法去实现:

1 拿到这张图

2 PNG丢进vmde

3 SVG丢进工具网页

4 根据预览,依次复制一个圆 + 一个勾的String。

String success = "...PathString";

5 利用SvgPathParser工具类得到Path

Path path = svgPathParser.parsePath(success);

6 设置给PathAnimView.

storeView3.setSourcePath(path);

效果图:

总结

代码传送门:喜欢的话,随手点个star。多谢

https://github.com/mcxtzhang/PathAnimView

现在我们已经可以做到,I have a pic.I have a view. Oh~,Path(Anim)View.

步骤:

一张图 丢进vmde 丢进SVG-Path预览网站 复制需要的Path以String形式传入PathAnimView 酷炫动画

在提取出SVG中的Path数据后,我个人喜欢将比较长的Path,放进values目录下一个新建文件paths.xml中,以以下形式存储:

<string name="xxx"> 复制过来的Path数据</string>

Java代码中如下设置:

String xxx= getString(R.string.xxx); Path path = svgPathParser.parsePath(xxx); storeView.setSourcePath(path);

想了解更详细的使用以及细节,请下载DEMO后查看。

看大神们都有QQ群,
向他们靠齐。
我也建了个QQ搞基交流群:
557266366 。

下文预告

最近略忙,项目电商模块重构,UI升级,于是我撸了一个购物车的控件:

项目中使用的效果

图录花了,我也不管了。。下次博文重新录个图吧,大家重点看购物车伸缩旋转闪转腾挪的动画即可。

代码已经撸完,考虑到了View的回收复用,

并且可以看到在RecyclerView中使用,切换LayoutManager也是没有问题的,

博文在梳理中,预计下周一输出。

心急可先去gayhub查看代码:

https://github.com/mcxtzhang/AnimShopButton

以上所述是小编给大家介绍的Android自定义View实现支付宝支付成功-极速get花式Path炫酷动画,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

时间: 2024-09-19 10:29:15

Android自定义View实现支付宝支付成功-极速get花式Path炫酷动画的相关文章

Android自定义View仿支付宝输入六位密码功能_Android

跟选择银行卡界面类似,也是用一个PopupWindow,不过输入密码界面是一个自定义view,当输入六位密码完成后用回调在Activity中获取到输入的密码并以Toast显示密码.效果图如下: 自定义view布局效果图及代码如下: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/

Android自定义View仿支付宝输入六位密码功能

跟选择银行卡界面类似,也是用一个PopupWindow,不过输入密码界面是一个自定义view,当输入六位密码完成后用回调在Activity中获取到输入的密码并以Toast显示密码.效果图如下: 自定义view布局效果图及代码如下: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/

Android自定义View仿支付宝芝麻信用分仪表盘_Android

先看下iOS的芝麻信用分截图 这是我做的效果,还是有点差距的 支付宝9.9版本芝麻信用分的实现 首先初始化各种画笔,默认的size,padding,小圆点. (因为实在找不到原版芝麻信用的带点模糊效果的小圆点,所以只好用这个代替) //View的默认大小 defaultSize = dp2px(250); //默认Padding大小 arcDistance = dp2px(14); //外层圆环画笔 mMiddleArcPaint = new Paint(Paint.ANTI_ALIAS_FLA

Android自带的webview中加载支付宝成功后没有回调,只停留在了支付宝支付成功页面

问题描述 Android自带的webview中加载支付宝成功后没有回调,只停留在了支付宝支付成功页面 我用Android自带的webview中加载支付宝页面去支付,在js里也配置了回调的return_url,为啥收不着回调呢?只是返回支付宝支付成功的链接,然后就停在支付宝支付完成的页面了. 程序里也设置了这个setJavaScriptEnabled(true); public boolean shouldOverrideUrlLoading(WebView view, String url),在

Android中PathMeasure仿支付宝支付动画

前言 在 Android 自定义 View 中,Path 可能用的比较多,PathMeasure 可能用的比较少,就我而言,以前也没有使用过 PathMeasure 这个 api,看到别人用 PathMeasure 和 ValueAnimator 结合在一起完成了很好的动画效果,于是我也学习下 PathMeasure ,此处记录下. PathMeasure 构造器: forceClosed 含义: // 创建一个 Path 对象 path = new Path(); path.moveTo(20

android自定义view插入xml

问题描述 android自定义view插入xml 自定义View代码如下.我希望把这个view插入到一个layout的xml的文件中.一直出错,错误类型是error inflating class.应该是这个View出的问题package com.example.browserstation; import java.util.Timer;import java.util.TimerTask; import android.content.Context;import android.graph

组合-android自定义view怎样指定自定义view的布局

问题描述 android自定义view怎样指定自定义view的布局 我有现成的布局xml文件,现在想定义一个组合的自定义view,怎样把这个view的布局指定为一个xml文件 解决方案 LayoutInflater.from(mActivity).inflate(R.layout.mainscreen_title, this, true);这样就行了,this是当前的View,而后面这两个参数是将R.layout.mainscreen_title attachToRoot 也就是以当前这个Vie

Android自定义View之使用贝塞尔曲线实现流量进度条

第一次写带图片的博客,多少还是有点紧张,效果不好,请将就着看,前面的图是今天要写的控件的效果图,元素不多,分别是一个按钮和一个自定义的控件. 在此以前,我看过许多的书,比如<Android群英传>.<第一行代码>等,也看了很多大神的博客,但是即便是这样,当我看到这么多代码的时候,一直都没有真正的动手去敲过这些代码,以至于我总是觉得自定义View是一个多么高深莫测的技术,我们这些小白是难以触及的,但是当昨晚看了一篇鸡汤之后,觉得人还是要学会专注,要耐得住寂寞,要沉得住气.所以在未来的

Android自定义View之绘制音乐播放器示波器

周末玩的有点嗨,没更新博客了,今天补上,这个示波器是在大学的时候老师教的,但是出来工作一直没有用到过,渐渐的也就忘记了,现在重新学习一下.来看看效果图: 这里是一个自定义的柱状图,然后有一个按钮,点击按钮的时候,这里柱子会不停的运动,类似于音乐播放器里示波器的跳动. 跟前面几个自定义view的方式类似,重写了onSizeChange()方法和onDraw()方法  先列一下我们要用到的变量 Paint mPaint; mWidth; mRectWidth; mRectHeight; mRectC