aboutsummaryrefslogtreecommitdiffstats
path: root/src/clip.js
blob: 9b106b49aa77b5b2391ec68f3aa7fcc2c3d5113f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// initialize id sequence
var clipID = 0;

SVG.Clip = function Clip() {
  this.constructor.call(this, SVG.create('clipPath'));
  this.id = 'svgjs_clip_' + (clipID++);
  this.attr('id', this.id);
};

// inherit from SVG.Element
SVG.Clip.prototype = new SVG.Element();

// include the container object
SVG.extend(SVG.Clip, SVG.Container);

// add clipping functionality to element
SVG.extend(SVG.Element, {
  
  // clip element using another element
  clip: function(b) {
    var p = this.parent.defs().clip();
    b(p);

    return this.clipTo(p);
  },

  // distribute clipping path to svg element
  clipTo: function(p) {
    return this.attr('clip-path', 'url(#' + p.id + ')');
  }
  
});

// add def-specific functions
SVG.extend(SVG.Defs, {
  
  // define clippath
  clip: function() {
    var e = new SVG.Clip();
    this.add(e);

    return e;
  }
  
});