iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >HTML5中怎么用Canvas实现文字动画特效
  • 549
分享到

HTML5中怎么用Canvas实现文字动画特效

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

本篇内容介绍了“HTML5中怎么用canvas实现文字动画特效”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成

本篇内容介绍了“HTML5中怎么用canvas实现文字动画特效”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

  代码总共一百来行,比较简单,前面说过我的英文字母是用矢量绘制的,用矢量绘制图形的好处非常多,比如图片缩放不会失真,这样在不同的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,//代表左上角坐标x

  0,//代表左上角坐标y

  10,//代表组件的width

  10//代表组件的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个节点对象:

  vars=80;

  arr.forEach(function(obj,index){

  vartext=obj.label;

  name='t'+text;

  window[name]=createnode(obj.image,100+s*index,100);

  });

  functioncreateNode(image,x,y){//节点对象声明

  varnode=newht.Node();//这个类为ht中定义的节点

  node.setSize(0,0);//设置节点大小

  if(image)node.setImage(image);//设置节点图片

  if(x&&y)node.setPosition(x,y);//设置节点摆放位置

  dm.add(node);//将节点添加进数据容器datamodel中

  returnnode;

  }

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

  拓扑图生成

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

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

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

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

  addToDOM=function(){

  varself=this,

  view=self.getView(),//获取底层p

  style=view.style;

  document.body.appendChild(view);//将底层p添加到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的效果就是从无到有,又从有到无。那接下来看看如何“从无到有”。

  文本动画

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

  functionsetSize(node){

  if(node){

  vars=80,

  size=node.getSize().width;//获取节点当前的大小中的宽度,因为我知道宽高都是一样的,所以简写了

  varsw=s-size;

  ht.Default.startAnim({//HT封装的动画函数,内容也是JSON格式的对象

  duration:1000,//动画周期毫秒数

  easing:function(t){returnt*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:

  functionanimateIn(){

  for(leti=0;i<arr.length;i++){

  varname='t'+arr[i];

  animateLetterIn(window[name],i);//这个部分设置动画

  }

  }

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

  functionanimateLetterIn(node,i){

  setTimeout(function(){

  setSize(node);

  },i*200);//这时候这个i取的就是节点对应的i而不是最后一个值了

  if(i===arr.length-1){//当节点为最后一个节点时,设置节点淡出动画

  setTimeout(function(){

  animateOut();//节点淡出动画

  },(arr.length+3)*200);

  }

  }

  HTML5中怎么用Canvas实现文字动画特效

“HTML5中怎么用Canvas实现文字动画特效”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: HTML5中怎么用Canvas实现文字动画特效

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

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

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

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

下载Word文档
猜你喜欢
  • HTML5中怎么用Canvas实现文字动画特效
    本篇内容介绍了“HTML5中怎么用Canvas实现文字动画特效”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2022-10-19
  • 怎么用HTML5 Canvas制作动画特效
    小编给大家分享一下怎么用HTML5 Canvas制作动画特效,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   制作canva...
    99+
    2022-10-19
  • html5中怎么使用canvas绘制文字特效
    这篇文章主要介绍“html5中怎么使用canvas绘制文字特效”,在日常操作中,相信很多人在html5中怎么使用canvas绘制文字特效问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2022-10-19
  • HTML5 canvas怎么实现文字渲染效果
    这篇文章主要介绍“HTML5 canvas怎么实现文字渲染效果”,在日常操作中,相信很多人在HTML5 canvas怎么实现文字渲染效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2022-10-19
  • 怎么用HTML5 Canvas实现烟花绽放动画效果
    这篇文章主要介绍“怎么用HTML5 Canvas实现烟花绽放动画效果”,在日常操作中,相信很多人在怎么用HTML5 Canvas实现烟花绽放动画效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方...
    99+
    2022-10-19
  • HTML5怎么实现动态文字遮罩背景特效
    这篇文章主要介绍“HTML5怎么实现动态文字遮罩背景特效”,在日常操作中,相信很多人在HTML5怎么实现动态文字遮罩背景特效问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”HT...
    99+
    2022-10-19
  • HTML5中怎么用Canvas实现烟花绽放特效
    这篇文章主要介绍“HTML5中怎么用Canvas实现烟花绽放特效”,在日常操作中,相信很多人在HTML5中怎么用Canvas实现烟花绽放特效问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望...
    99+
    2022-10-19
  • HTML5中怎么实现动画效果
    这期内容当中小编将会给大家带来有关HTML5中怎么实现动画效果,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.canvas html代码: 代码如下:<html&...
    99+
    2022-10-19
  • 怎么用css实现3d动画特效
    小编给大家分享一下怎么用css实现3d动画特效,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   属性   perspect...
    99+
    2022-10-19
  • HTML5中怎么用Canvas实现3D水体模拟动画
    这篇文章主要介绍了HTML5中怎么用Canvas实现3D水体模拟动画的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇HTML5中怎么用Canvas实现3D水体模拟动画文章都会有所...
    99+
    2022-10-19
  • HTML5和Canvas怎么实现烟花绽放特效
    这篇文章给大家分享的是有关HTML5和Canvas怎么实现烟花绽放特效的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。效果如下:undefinedundefinedundefined代码如下:XML/HTML Co...
    99+
    2023-06-09
  • 怎么在HTML5中使用canvas实现一个瀑布流文字效果
    今天就跟大家聊聊有关怎么在HTML5中使用canvas实现一个瀑布流文字效果,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。代码如下:<!doctype html>...
    99+
    2023-06-09
  • 怎么用HTML5 Canvas draw方法制作动画效果
    这篇文章主要介绍“怎么用HTML5 Canvas draw方法制作动画效果”,在日常操作中,相信很多人在怎么用HTML5 Canvas draw方法制作动画效果问题上存在疑惑,小编查阅了各式资料,整理出简单...
    99+
    2022-10-19
  • 怎么用html5 canvas实现图片玻璃碎片特效
    本篇内容主要讲解“怎么用html5 canvas实现图片玻璃碎片特效”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用html5 canvas实现图片玻璃碎片...
    99+
    2022-10-19
  • CSS3中怎么实现复选框动画特效
    CSS3中怎么实现复选框动画特效,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。实例代码代码如下:<!DOCTYPE ht...
    99+
    2022-10-19
  • CSS3中怎么实现单选框动画特效
    本篇文章为大家展示了CSS3中怎么实现单选框动画特效,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。<div class="radio-1&...
    99+
    2022-10-19
  • 使用javascript怎么实现一个文字滚动特效
    这篇文章将为大家详细讲解有关使用javascript怎么实现一个文字滚动特效,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。JavaScript是什么JavaScript是一种直译式的脚本语言...
    99+
    2023-06-14
  • HTML5中怎么用Canvas实现超炫酷烟花绽放动画
    这篇文章主要介绍了HTML5中怎么用Canvas实现超炫酷烟花绽放动画的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇HTML5中怎么用Canvas实现超炫酷烟花绽放动画文章都会...
    99+
    2022-10-19
  • html5动画过渡效果怎么实现
    本篇内容介绍了“html5动画过渡效果怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!   1、动...
    99+
    2022-10-19
  • 怎么用纯css3实现炫酷的动画背画特效
    本篇内容介绍了“怎么用纯css3实现炫酷的动画背画特效”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  之...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作