前言

文字是网页中最基本的元素,一般我们在网页上都是展示的静态文字,但是就效果来说,还是比较枯燥的。文字淡入淡出的动画效果在项目中非常实用,如果有某些关键的文字,可以通过这种动态的效果来提醒用户阅读。

动态效果图

http://www.hightopo.com/demo/GraphAnimation/index.html

这个 Demo 是不断重复地设置文字的大小和透明度,这些英文字母也是我自己利用 HT 的矢量绘制的,总的来说效果还是不错的。

代码实现

代码总共一百来行,比较简单,前面说过我的英文字母是用矢量绘制的,用矢量绘制图形的好处非常多,比如图片缩放不会失真,这样在不同的 Retina 显示屏上我也不需要提供不同尺寸的图片;还有就是用 JSON 的方式来描述矢量,格式比较简洁等等。

矢量图片

接下来绘制这些矢量图片(这里只拿出第一个 H 进行说明):

{"width": 10,//设置矢量的宽"height": 10,//设置矢量的高"comps": [//矢量图形的组件Array数组,每个数组对象为一个独立的组件类型,数组的顺序为组件绘制先后顺序{"type": "text",//文本类型"text": "H",//文本内容"color": "rgb(69,69,69)",//文本颜色"align": "center",//文本在矢量中的对齐方式"opacity": {//文本透明度"func": "attr@text.opacity",//设置业务属性,对文本进行透明度的数据绑定"value": 1//如果func中的值为空或者undefined,那么就直接用这个值},"clipDirection": "bottom",//裁切方向为“从上到下”"rect": [//指定组件绘制在矢量中的矩形边界0,//代表左上角坐标x0,//代表左上角坐标y10,//代表组件的width10//代表组件的height]}]
}
复制代码

绘制矢量图形是通过 JSON 格式来书写的,主要的参数有三个:width、height 以及 comps。这三个参数都必须要写上,其中 width 为矢量图形的宽度,height 为矢量图形的高度,comps 里面是一个 Array 数组,数组中是一个个独立的对象,可以对这个对象设置一些预定义参数,也可设置一些可选的参数信息。

这里我将所有的文本信息存储在一个数组中,方便调用:

arr = [{label: 'H', image: 'symbols/H.json'},{label: 'T', image: 'symbols/T.json'},{label: 'f', image: 'symbols/f.json'},{label: 'o', image: 'symbols/o.json'},{label: 'r', image: 'symbols/r.json'},{label: 'W', image: 'symbols/W.json'},{label: 'e', image: 'symbols/e.json'},{label: 'b', image: 'symbols/b.json'},
];
复制代码

第一个 label 对象为矢量图形的名称,第二个 image 对象我们设置的是 json 格式的图片,但是实际上可以为 img、canvas 对象或图片 url 或 base64 字符串。

创建节点对象

对象的图片已经生成,接下来就是创建对象了,这里英文字母总共 8 个,那么我们创建 8 个节点对象:

var s = 80;arr.forEach(function(obj, index) {var text = obj.label;name = 't' + text;window[name] = createNode(obj.image, 100+s*index, 100);});function createNode(image, x, y) {//节点对象声明var node = new ht.Node();//这个类为 ht 中定义的节点node.setSize(0, 0);//设置节点大小if(image) node.setImage(image);//设置节点图片if(x && y) node.setPosition(x, y);//设置节点摆放位置dm.add(node);//将节点添加进数据容器 datamodel 中return node;
}
复制代码

关于上面的 ht.Node 节点的生成,其实这个只是 HT 封装好的类,这个类上面有很多很方便的 API。然后将这个生成的节点添加进数据容器 dm 中,这个数据容器又是整个拓扑图 gv 的数据容器。

拓扑图生成

来看看如何生成这个拓扑图吧:

dm = new ht.DataModel();//数据容器
gv = new ht.graph.GraphView(dm);//拓扑图 通过 gv.getView() 可获得这个拓扑图的底层 div
gv.addToDOM();//将 gv 添加进 body 中
复制代码

实际上 HT 的原理就是在一个 div 中的 canvas 上绘制图形,也就是说这个 gv 就是一个 canvas。

然后通过 getView 获取这个 canvas 的底层 div,这样我们就能将这个 div 添加到 html 页面的任何地方了,addToDOM 的定义如下:

addToDOM = function(){   var self = this,view = self.getView(),   //获取底层divstyle = view.style;document.body.appendChild(view);      //将底层div添加到body中      style.left = '0';//因为 HT 默认将组件的position设置为absolute 所以要设置位置style.right = '0';style.top = '0';style.bottom = '0';      window.addEventListener('resize', function () { self.iv(); }, false);//窗口大小变化触发事件,调用最外层组件invalidate(即iv)函数进行更新。
}
复制代码

现在刷新页面,你会看到一片空白,为什么?因为前面设置节点的大小为 0 啊,怎么会显示,这个 Demo 的效果就是从无到有,又从有到无。那接下来看看如何“从无到有”。

文本动画

就像我刚刚说过的,要想让节点显示,肯定是需要设置节点的大小为我们肉眼可视的范围才会出现,但是我的目的不仅是从无到有,也是从小到大,这个能够一气呵成么?感觉好像代码内容简单,但是代码量却不小的一个任务,我定义了一个函数用来将节点从无到有,从小到大:

function setSize(node) {if(node) {var s = 80,size = node.getSize().width;//获取节点当前的大小中的宽度,因为我知道宽高都是一样的,所以简写了var sw = s - size;ht.Default.startAnim({//HT 封装的动画函数,内容也是 JSON 格式的对象duration: 1000,// 动画周期毫秒数easing: function(t) { return t*t },//动画缓动函数action: function(v, t) {//action函数必须提供,实现动画过程中的属性变化 第一个参数v代表通过easing(t)函数运算后的值,t代表当前动画进行的进度[0~1],一般属性变化根据v参数进行 node.setSize(//设置节点的大小  (有一个缓动的过程 通过 sw*v 实现的)size + sw*v, size + sw*v ); } }); }
}
复制代码

从大到小,从有到无的过程也跟上面类似,我就不赘述了。

要让这些字母按照时间的先后顺序出现和消失,肯定需要用到 setTimeout 方法,要想实现一次的显示消失是非常容易的,但是我在实现的过程掉到了 setTimeout 的一个陷阱中,只能说自己学艺不精吧。因为我们需要给不同的字母设置不同的出现和消失时间,一般比较简单的方法就是设置一个固定的值,然后乘以对应节点专属的 index:

function animateIn() {for(let i = 0; i < arr.length; i++) {var name = 't' + arr[i];animateLetterIn(window[name], i);//这个部分设置动画}
}
复制代码

可是如果我直接在 for 循环中设置 setTimeout 的时间为动态变化的,那么这个动态变化的值肯定是只取 for 循环的最后一个值,所以我将 setTimeout 的方法抽取出来作为一个单独的函数:

function animateLetterIn(node, i) {setTimeout(function() {setSize(node);}, i * 200);//这时候这个 i 取的就是节点对应的 i 而不是最后一个值了if(i === arr.length - 1) {//当节点为最后一个节点时,设置节点淡出动画setTimeout(function() {animateOut();//节点淡出动画}, (arr.length + 3) * 200);}
}
复制代码

节点淡出动画也是类似的方法,只是需要循环调用这些动画函数,这样才能做到无限循环字母的大小控制。

基于 HTML5 Canvas 实现的文字动画特效相关推荐

  1. html 产生烟雾效果,html5 canvas抽象模糊烟雾动画特效

    特效描述:html5 canvas 抽象模糊 烟雾动画特效.html5 canvas绘制彩色模糊的烟雾动画.抽象模糊的烟雾动画特效 代码结构 1. 引入CSS 2. 引入JS 3. HTML代码 vo ...

  2. html画布敲碎的视频,html5 canvas碎纸屑空中飘落动画特效

    特效描述:html5 canvas碎纸屑 空中飘落动画特效.canvas绘制空中飘落的纸屑动画特效. 代码结构 1. HTML代码 "use strict"; var _creat ...

  3. html5 雨滴效果,html5 canvas下雨滴掉落动画特效

    特效描述:html5 canvas 雨滴掉落动画 动画特效.html5 canvas绘制下雨场景动画.雨滴动画. 代码结构 1. 引入JS 2. HTML代码 // TO DO // Remove r ...

  4. php实现下雪场景,html5 canvas逼真下雪场景动画特效

    这是一款效果十分逼真的html5 canvas下雪场景动画特效插件.这款下雪特效是基于Jason Brown的Snowfall jquery plugin的基础上制作的.在Snowfall jquer ...

  5. html语音播放动画,html5 canvas+js音频可视化动画特效

    html5 canvas+js实现的音频可视化动画特效,选择一首本地音频文件播放查看效果. 查看演示 下载资源: 13 次 下载资源 下载积分: 20 积分 js代码 window.onload = ...

  6. android 五彩纸屑动画,HTML5 Canvas五彩纸屑粒子动画特效

    JavaScript 语言: JaveScriptBabelCoffeeScript 确定 const getRandom = (min, max) => { return Math.rando ...

  7. html5 canvas实现雷达扫描动画特效

    先看一下最终效果 实现思路 绘制4个圆 绘制一个十字线 绘制一个扫描的指针 让指针转起来 雷达构造函数 function Radar(){this.renderArr=[];//待渲染对象存储数组th ...

  8. ae制h5文字动画_7款超华丽的HTML5 Canvas文字动画特效

    本文作者html5tricks,转载请注明出处 文字是网页中最为常见的元素之一,当然我们使用最多的就是调整文字的颜色.大小等基本属性.有时候我们在一些活动页面上需要展示特别样式的文字效果,这时候我们就 ...

  9. html5字体动画效果,7款超华丽的HTML5 Canvas文字动画特效

    原标题:7款超华丽的HTML5 Canvas文字动画特效 文字是网页中最为常见的元素之一,当然我们使用最多的就是调整文字的颜色.大小等基本属性.有时候我们在一些活动页面上需要展示特别样式的文字效果,这 ...

最新文章

  1. 基于Pytorch和RDKit建立QSAR模型
  2. (shell脚本编程)linux如何利用脚本执行多条命令以及linux如何执行定时任务
  3. python 特性和方法同名_Python语言特性的梳理
  4. HDU4970 Killing Monsters dp
  5. Windows 技术篇-cmd强制关闭端口、解除端口占用方法,cmd查询端口相关的进程pid并杀死进程实例演示
  6. 解决windows下tomcat端口被占用
  7. 手机轮廓光怎么拍_摄影技巧:怎么拍影子?手机拍照教程
  8. 深入并发包-ConcurrentHashMap
  9. 关于 mac m1 xcode12 编译报错 this target. for architecture arm64等问题解决方案
  10. Python json和simplejson的使用
  11. 如何优雅的给你的APK文件打上签名
  12. 2014,念念不忘 必有回响
  13. cmd中mysql的操作语句_cmd命令行数据库操作语句
  14. 从中序和前序遍历序列构造二叉树
  15. 人脸识别之表情识别(七)--面部表情识别阶段综述
  16. java 随机md5_java常用工具类 Random随机数、MD5加密工具类
  17. 电子商务顾客评论的热点话题分析(转)
  18. ETL和ELT的区别
  19. AVA(aesthetic visual analysis)数据集简介
  20. 算法的特性和设计要求

热门文章

  1. c语言课程设计学生成绩簿,c语言课程设计—学生成绩管理系统
  2. 小程序开发中遇到的问题
  3. 24暴力枚举四平方和
  4. hibernate 高并发下遇到的大坑
  5. Node.js安装及环境配置(windows)
  6. [bzoj1925][Sdoi2010]地精部落
  7. 添加MD5 密码加密
  8. Hive ROW_NUMBER,RANK(),DENSE_RANK()
  9. phpMyAdmin ‘tbl_gis_visualization.php’多个跨站脚本漏洞
  10. Kafka万亿级消息实战干货~持续更新中