SVG.js 图案使用和use引用

Posted 天马3798

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SVG.js 图案使用和use引用相关的知识,希望对你有一定的参考价值。

一.SVG.Pattern 图案设置

var draw = SVG(\'svg1\').size(300, 300);
//SVG.Pattern 图案设置
var pattern = draw.pattern(20, 20, function (add) {
    add.rect(20, 20).fill(\'#f06\');
    add.rect(10, 10);
    add.rect(10, 10).move(10, 10);
});
//获取url的标识对象,returns \'url(#SvgjsPattern1234)\'
var urlObj = pattern.fill();
console.info(urlObj); //url(#SvgjsPattern1008)

//为圆设置图案,fill() 方法设置或获取图片对象
var circle = draw.circle(100);
circle.move(100, 100)
    .fill(pattern);
//为矩形设置图案
var rect = draw.rect(100, 100);
rect.attr({ fill: pattern });
//修改图案,会覆盖以前的图片
pattern.update(function (add) {
    add.circle(15).center(10, 10);
});

二.SVG.Use  元素的引用

1.

//SVG.Use  元素的引用
//使用元素简单地模拟另一个现有元素。主元素的任何更改将反映在所有使用实例上。
var rect = draw.rect(100, 100).fill(\'#f09\');
var use = draw.use(rect);
use.move(100, 100);
//当rect修改时,use也会跟着修改
rect.animate(1000).fill(\'#f90\');

2.SVG.defs()  的声明定义,当use()再显示

var draw = SVG(\'svg1\').size(300, 300);
//SVG.defs()  的声明定义,当use()再显示
var rect = draw.defs().rect(100, 100).fill(\'#f09\');
var use = draw.use(rect);
use.move(100, 100);
//当rect修改时,use也会跟着修改
rect.animate(1000).fill(\'#f90\');

3.

var draw = SVG(\'svg1\').size(300, 300);
//SVG.use() 使用外部文件
//这种方法是有用的,当你有复杂的图像已经创建。
//需要注意的是,外部图像(在你的领域)可能需要加载的文件与XHR。
var rect=draw.rect(100,100);
console.info(rect);
console.info(rect.node.id);
var use  = draw.use(rect.node.id, \'svg1.svg\')

 

更多:

SVG.js 颜色渐变使用

Svg.js 图片加载

SVG.js 文本绘制整理

以上是关于SVG.js 图案使用和use引用的主要内容,如果未能解决你的问题,请参考以下文章

SVG.js 引用获取整理

SVG.js 笔记

持久片段和查看器

片段对话框对活动的松散引用

ngx-translate实现国际化:this.translate.use()this.translate.get()this.translate.instant()onLangChange(代码片段

去除 GLSL 着色器产生的波纹图案