填充的种类 fill
<blockquote>
<p>官方介绍 <a href="http://fabricjs.com/fabric-intro-part-2#gradients" title="Introduction to Fabric.js. Part 2.">Introduction to Fabric.js. Part 2.</a></p>
</blockquote>
<h3>颜色填充 Color</h3>
<pre><code class="language-javascript">//投影
const fillColor = async function (text, options = {}) {
if (typeof text !== 'string' || text === '')
return null
const opt = {
top: 0, left: 0,
fill: '#000',
fontSize: 80,
fontFamily: '华文琥珀',
...options
}
new fabric.Text(text, opt)
}
</code></pre>
<h3>渐变色填充 Gradient</h3>
<pre><code class="language-javascript">
const fillGradient = function (text, options = {}) {
const opt = { ...options }
const oText = new fabric.Text(text, opt)
const height = oText.calcTextHeight()
const width = oText.calcTextWidth()
const gradient = new fabric.Gradient({
type: 'linear', // or 'radial'
gradientUnits: 'pixels', // or 'percentage'
coords: {
// r1: 0, r2: 0, // type: 'radial' only have
x1: opt.left, y1: 0,
x2: opt.left, y2: height
},
colorStops: [
{ offset: 0, color: 'rgb(254, 35, 93)' },
{ offset: 1, color: 'rgb(255, 199, 102)' }
]
})
oText.set('fill', gradient)
return oText
}
</code></pre>
<h3>图案填充 Pattern</h3>
<blockquote>
<p><a href="https://my.oschina.net/u/4297117/blog/4527555" title="js 完成对图片的等比例缩放的方法">js 完成对图片的等比例缩放的方法</a></p>
<p><a href="https://www.it1352.com/884313.html" title="使用fabric.js缩放画布时,像素完美缩放图像(Pixel perfect scaling of images while zooming the canvas with fabric.js)">使用fabric.js缩放画布时,像素完美缩放图像(Pixel perfect scaling of images while zooming the canvas with fabric.js)</a></p>
</blockquote>
<pre><code class="language-javascript">/** 返回Image对象 */
function asyncImage(src) {
console.log(src)
if (!src)
return null
return new Promise(resolve => {
const oImg = new Image()
// 解决跨域污染问题
oImg.crossOrigin = 'anonymous'
oImg.onerror = (res) => {
resolve(null);
console.error(res)
}
oImg.onload = () => {
resolve(oImg)
}
oImg.src = src
}
)
}
//图案填充
const asyncFillPattern = async function (text, options = {}) {
if (typeof text !== 'string' || text === '')
return null
const opt = {
top: 0, left: 0,
fill: '#000',
fontSize: 80,
fontFamily: '华文琥珀',
...options
}
const img = await asyncImage('')
const pattern = new fabric.Pattern({
source: img, repeat: 'repeat'
})
return new fabric.Text(text, {
...opt,
fill: pattern
})
}
</code></pre>