网站首页 > 文章精选 正文
介绍
ZRender 是二维绘图引擎,它提供 Canvas、SVG、VML 等多种渲染方式。ZRender 也是 ECharts 的渲染器。
Github
https://github.com/ecomfe/zrender
安装使用
npm install zrender
在使用 ZRender 前,需要在 HTML 中加载对应 JavaScript 文件:
<script src="./dist/zrender.js"></script>
- 初始化 ZRender
在使用 ZRender 前需要初始化实例,具体方式是传入一个 DOM 容器:
var zr = zrender.init(document.getElementById('main'));
- 在场景中添加元素
ZRender 提供了将近 20 种图形类型,可以在文档 zrender.Displayable 下找到。如果想创建其他图形,也可以通过 zrender.Path.extend 进行扩展。
以创建一个圆为例:
var circle = new zrender.Circle({
shape: {
cx: 150,
cy: 50,
r: 40
},
style: {
fill: 'none',
stroke: '#F00'
}
});
zr.add(circle);
创建了一个圆心在 [150, 50] 位置,半径为 40 像素的圆,并将其添加到画布中。
- 修改图形元素属性
通过 a = new zrender.XXX 方法创建了图形元素之后,可以用 a.shape 等形式获取到创建时输入的属性,但是如果需要对其进行修改,应该使用 a.attr(key, value) 的形式修改,否则不会触发图形的重绘。例子:
var circle = new zrender.Circle({
shape: {
cx: 150,
cy: 50,
r: 40
}
});
zr.add(circle);
console.log(circle.shape.r); // 40
circle.attr('shape', {
r: 50 // 只更新 r。cx、cy 将保持不变。
});
实例代码
<div class="example-container"></div>
<script>
window.onload = function() {
var container = document.getElementsByClassName('example-container')[0];
var zr = zrender.init(container);
var w = zr.getWidth();
var h = zr.getHeight();
var circle = new zrender.Circle({
shape: {
cx: w / 2,
cy: h / 2,
r: 50
},
style: {
fill: '#FF6EBE'
},
draggable: true
});
var heart = new zrender.Heart({
shape: {
cx: w / 2 + 20,
cy: h / 2 - 40,
width: 60,
height: 80
},
draggable: true
});
circle.setClipPath(heart);
zr.add(circle);
var borderA = new zrender.Circle({
shape: {
cx: w / 2,
cy: h / 2,
r: 50
},
style: {
fill: 'transparent',
stroke: '#5ACFFF'
}
});
zr.add(borderA);
var borderB = new zrender.Heart({
shape: {
cx: w / 2 + 20,
cy: h / 2 - 40,
width: 60,
height: 80
},
style: {
fill: 'transparent',
stroke: '#5ACFFF'
}
});
zr.add(borderB);
}
</script>
- 效果
其它示例
截图不清晰可参考官方案例
猜你喜欢
- 2024-12-30 简单的使用SpringBoot整合SpringSecurity
- 2024-12-30 Spring Security 整合OAuth2 springsecurity整合oauth2+jwt+vue
- 2024-12-30 DeepSeek-Coder-V2震撼发布,尝鲜体验
- 2024-12-30 一个数组一行代码,Spring Security就接管了Swagger认证授权
- 2024-12-30 简单漂亮的(图床工具)开源图片上传工具——PicGo
- 2024-12-30 Spring Boot(十一):Spring Security 实现权限控制
- 2024-12-30 绝了!万字搞定 Spring Security,写得太好了
- 2024-12-30 SpringBoot集成Spring Security springboot集成springsecurity
- 2024-12-30 SpringSecurity密码加密方式简介 spring 密码加密
- 2024-12-30 Spring cloud Alibaba 从入门到放弃
- 最近发表
- 标签列表
-
- newcoder (56)
- 字符串的长度是指 (45)
- drawcontours()参数说明 (60)
- unsignedshortint (59)
- postman并发请求 (47)
- python列表删除 (50)
- 左程云什么水平 (56)
- 计算机网络的拓扑结构是指() (45)
- 稳压管的稳压区是工作在什么区 (45)
- 编程题 (64)
- postgresql默认端口 (66)
- 数据库的概念模型独立于 (48)
- 产生系统死锁的原因可能是由于 (51)
- 数据库中只存放视图的 (62)
- 在vi中退出不保存的命令是 (53)
- 哪个命令可以将普通用户转换成超级用户 (49)
- noscript标签的作用 (48)
- 联合利华网申 (49)
- swagger和postman (46)
- 结构化程序设计主要强调 (53)
- 172.1 (57)
- apipostwebsocket (47)
- 唯品会后台 (61)
- 简历助手 (56)
- offshow (61)