当前位置:网站首页>Fabric.js 渐变
Fabric.js 渐变
2022-07-02 05:08:00 【德育处主任】
在 Vue3中使用Fabric.js实现渐变(Gradient)效果,包括径向渐变radial
Fabric.js 简介
用官方的话来讲
Fabric.js
是一个强大而简单的Javascript HTML5 canvas
工具库
简单来说,如果你需要用 canvas
做特效或者做交互,那不妨试试 Fabric.js
这个库,它会使开发更加简单和直观。
Fabric.js 官网Fabric.js npm地址Fabric.js github地址
本文使用的开发环境
本文案例中使用了 Fabric.js 4.6
这个版本。
使用了 Vite
构建 Vue3
项目。
搭建项目
npm init @vitejs/app
选择 Vue3
,之后再根据提示初始化项目即可。
安装 Fabric.js
npm install fabric --save
为什么本文只写渐变?
渐变是 Fabric.js
的基础功能,但网上大部分文章都只写 线性渐变,很少有写到径向渐变的,因为官方好像也没给出径向渐变的例子。
甚至还见过有些文章和评论说 Fabric.js
只支持线性渐变。但这个说法是错的!!!
请看这个案例:【Fabric.js 渐变效果】
没错,本文只想证明在 Fabric.js
4.6版本中是可以实现径向渐变的。
线性渐变 linear
<template> <canvas width="600" height="600" id="canvas" style="border: 1px solid #ccc;"></canvas></template><script setup>import { onMounted } from 'vue'import { fabric } from 'fabric'function init() { let canvas = new fabric.Canvas('canvas') // 实例化fabric,并绑定到canvas元素上 // 圆 let circle = new fabric.Circle({ left: 100, top: 100, radius: 50, }) // 线性渐变 let gradient = new fabric.Gradient({ type: 'linear', // linear or radial gradientUnits: 'pixels', // pixels or pencentage 像素 或者 百分比 coords: { x1: 0, y1: 0, x2: circle.width, y2: 0 }, // 至少2个坐标对(x1,y1和x2,y2)将定义渐变在对象上的扩展方式 colorStops:[ // 定义渐变颜色的数组 { offset: 0, color: 'red' }, { offset: 0.2, color: 'orange' }, { offset: 0.4, color: 'yellow' }, { offset: 0.6, color: 'green' }, { offset: 0.8, color: 'blue' }, { offset: 1, color: 'purple' }, ] }) circle.set('fill', gradient); canvas.add(circle)}onMounted(() => { init()})</script>
径向渐变 radial
<template> <canvas width="600" height="600" id="canvas" style="border: 1px solid #ccc;"></canvas></template><script setup>import { onMounted } from 'vue'import { fabric } from 'fabric'function init() { let canvas = new fabric.Canvas('canvas') // 实例化fabric,并绑定到canvas元素上 // 圆 let circle = new fabric.Circle({ left: 100, top: 100, radius: 50, }) let gradient = new fabric.Gradient({ type: 'radial', coords: { r1: 50, // 该属性仅径向渐变可用,外圆半径 r2: 0, // 该属性仅径向渐变可用,外圆半径 x1: 50, // 焦点的x坐标 y1: 50, // 焦点的y坐标 x2: 50, // 中心点的x坐标 y2: 50, // 中心点的y坐标 }, colorStops: [ { offset: 0, color: '#fee140' }, { offset: 1, color: '#fa709a' } ] }) circle.set('fill', gradient); canvas.add(circle)}onMounted(() => { init()})</script>
r1
、r2
、x1
、y1
、x2
、y2
这几个参数可以自己修改值然后看看效果,自己亲手改一下会理解得更深刻。
仓库地址
点赞 + 关注 + 收藏 = 学会了
边栏推荐
- Creation and destruction of function stack frames
- Leetcode18题 【四数之和】递归解法
- fastText文本分类
- Differential identities (help find mean, variance, and other moments)
- Analyzing the hands-on building tutorial in children's programming
- Hcip day 17
- 数学问题(数论)试除法做质数的判断、分解质因数,筛质数
- 数学知识(欧拉函数)
- No logic is executed after the El form is validated successfully
- 農業生態領域智能機器人的應用
猜你喜欢
LeetCode 241. Design priorities for operational expressions (divide and conquer / mnemonic recursion / dynamic programming)
CubeMx DMA笔记
数据库问题汇总
Line by line explanation of yolox source code of anchor free series network (7) -- obj in head_ loss、Cls_ Loss and reg_ Calculation and reverse transmission of loss I
VMware installation win10 reports an error: operating system not found
LM09丨费雪逆变换反转网格策略
The underlying principle of go map (storage and capacity expansion)
Fabric.js IText设置指定文字的颜色和背景色
Simple and practical accounting software, so that accounts can be checked
Precipitate yourself and stay up late to sort out 100 knowledge points of interface testing professional literacy
随机推荐
Go Chan's underlying principles
Pyechart1.19 national air quality exhibition
Super detailed pycharm tutorial
6.30年终小结,学生时代结束
el-cascader回显只选中不显示的问题
Pyflink writes MySQL examples with JDBC
Summary of database problems
Use of Baidu map
Go GC garbage collection notes (three color mark)
Common errors of dmrman offline backup
C # picture display occupancy problem
06 装饰(Decorator)模式
设置滚动条默认样式 谷歌浏览器
2022阿里巴巴全球数学竞赛 第4题 虎虎生威(盲盒问题、集卡问题)解决思路
Use of typescript classes
Acelems Expressway microgrid energy efficiency management platform and intelligent lighting solution intelligent lighting tunnel
Rhcsa --- work on the third day
将光盘中的cda保存到电脑中
Global and Chinese market of hydrocyclone desander 2022-2028: Research Report on technology, participants, trends, market size and share
DJB Hash