前端美术课

栏目: Html5 · 发布时间: 6年前

内容简介:同学们应该都学习过或听说过 canvas ,这都不重要,你们以为我要教你们 canvas 的 api 吗?不,这太蠢了,请出今天主角并且你不需要任何 canvas 使用经验就可以轻松上手这款绘图框架,当然你如果不愿意看我在这哔哔,发你一份文档自己去看吧《ZRender官方文档》
【班长】:起立!
【同学】:老师好!
【老师】:大家好,我是新来的前端美术老师,codexu
复制代码

同学们应该都学习过或听说过 canvas ,这都不重要,你们以为我要教你们 canvas 的 api 吗?

不,这太蠢了,请出今天主角 二维绘图引擎 —— ZRender ,如果你听说过大名鼎鼎的 ECharts ,我们今天说的 ZRender 就是它的渲染器。

并且你不需要任何 canvas 使用经验就可以轻松上手这款绘图框架,当然你如果不愿意看我在这哔哔,发你一份文档自己去看吧《ZRender官方文档》

正式上课

安装 ZRender

直接使用 npm 安装,需要源码或使用 <script> 引入的通过 github 下载。

$ npm install zrender
复制代码

那个装不上报错的你就不会试试 cnpm、yarn 吗?不想用?你下个 nrm 然后 nrm use taobao。

引入 ZRender

import ZRender from 'zrender';
复制代码

在 HTML 引入的同学

<script src="./dist/zrender.js"></script>
复制代码

在 html 中写一个容器

<div id="main"></div>
复制代码

初始化 ZRender

初始化一块 300 宽高的画布,如果不传递 init 函数第二个参数,需要为容器设置宽高,画布会自动填满容器。

const zr = ZRender.init(document.getElementById('main'), {
  width: 300,
  height: 300
});
复制代码

我炙热的红心 :heart:

把书翻到《Heart》, ZRender 提供了 20 多种图形,来跟着老师一起写:

const heart = new ZRender.Heart({
  shape: {
      cx: 150,
      cy: 140,
      width: 50,
      height: 70
  },
  style: {
    fill: 'red'
  }
});
zr.add(heart);
复制代码
前端美术课

知识点

  • new ZRender.Heart 初始化一个心形
  • 参数 shape,相对于画布的左上角。
    • cx 圆心横坐标。
    • cy 圆心纵坐标。
  • 参数 style,定义各种样式。
  • 所有图形均继承于zrender.Displayable。
  • 使用画布实例的 add 方法,将定义好的心形挂载在画布上,每一个图形可以理解为PS中的涂层,后加入的图层会在先加入的图层上面。
  • 心脏复苏手术

    【同学】:老师你的心是死的!

    这位同学请出去...其他同学不要受到场外因素的影响。

    我们继续,为我的心绑定”电击“事件,然后执行循环动画。

    heart.on('click', function() {
      this.animate('shape', true)
        .when(100, {
          width: 60,
          height: 80
        })
        .when(600, {
          width: 50,
          height: 70
        })
        .start()
    })
    复制代码

    知识点

    • 之前说过的所有图形继承Displayable ,它又继承于Element,Element 继承自Animatable(动画)、Eventful(事件)。
    • 绑定事件第二个参数请不要使用箭头函数,尽量使用 this 操作动画元素。
    • aniamte 第一个属性是元素对象属性名,例如'shape'、'style'等。
    • aniamte 第二个属性是循环动画,默认为false。
    • 动画写完之后记得执行start()。

    下课

    外面那个同学进来吧。

    留个作业,《治疗好你们自己的那颗黑心》。

    还有闲着没事就不能给老师点颗 star 吗?

    github: github.com/codexu


    以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

    查看所有标签

    猜你喜欢:

    本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

    电子商务:管理与社交网络视角(原书第7版)

    电子商务:管理与社交网络视角(原书第7版)

    (美)埃弗雷姆·特班(Efraim Turban)、戴维.金(David King)、李在奎、梁定澎、德博拉·特班(Deborrah Turban) / 时启亮、陈育君、占丽 / 机械工业出版社 / 2014-1-1 / 79.00元

    本书对电子学习、电子政务、基于web的供应链、协同商务等专题进行了详细的介绍,全书涵盖丰富的资料以及个案,讨论了Web 2.0环境内的产业结构、竞争变化以及对当今社会的影响。另外,本书在消费者行为、协同商务、网络安全、网络交易及客户管理管理、电子商务策略等内容上都有最新的改编,提供读者最新颖的内容,贴近当代电子商务的现实。 本书适合高等院校电子商务及相关专业的本科生、研究生及MBA学员,也可......一起来看看 《电子商务:管理与社交网络视角(原书第7版)》 这本书的介绍吧!

    JSON 在线解析
    JSON 在线解析

    在线 JSON 格式化工具

    XML、JSON 在线转换
    XML、JSON 在线转换

    在线XML、JSON转换工具

    RGB CMYK 转换工具
    RGB CMYK 转换工具

    RGB CMYK 互转工具