blob: 2fc093bd4c142726ad8b2d666906bbbff8d5ef94 (
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
// Get the rectangular box of a given element
SVG.RBox = function(element) {
var e, zoom
, box = {}
/* initialize zero box */
this.x = 0
this.y = 0
this.width = 0
this.height = 0
if (element) {
e = element.doc().parent
zoom = element.doc().viewbox().zoom
/* actual, native bounding box */
box = element.node.getBoundingClientRect()
/* get screen offset */
this.x = box.left
this.y = box.top
/* subtract parent offset */
this.x -= e.offsetLeft
this.y -= e.offsetTop
while (e = e.offsetParent) {
this.x -= e.offsetLeft
this.y -= e.offsetTop
}
/* calculate cumulative zoom from svg documents */
e = element
while (e = e.parent) {
if (e.type == 'svg' && e.viewbox) {
zoom *= e.viewbox().zoom
this.x -= e.x() || 0
this.y -= e.y() || 0
}
}
}
/* recalculate viewbox distortion */
this.x /= zoom
this.y /= zoom
this.width = box.width /= zoom
this.height = box.height /= zoom
/* offset by window scroll position, because getBoundingClientRect changes when window is scrolled */
this.x += typeof window.scrollX === 'number' ? window.scrollX : window.pageXOffset
this.y += typeof window.scrollY === 'number' ? window.scrollY : window.pageYOffset
/* add center, right and bottom */
boxProperties(this)
}
//
SVG.extend(SVG.RBox, {
// merge rect box with another, return a new instance
merge: function(box) {
var b = new SVG.RBox()
/* merge box */
b.x = Math.min(this.x, box.x)
b.y = Math.min(this.y, box.y)
b.width = Math.max(this.x + this.width, box.x + box.width) - b.x
b.height = Math.max(this.y + this.height, box.y + box.height) - b.y
/* add center, right and bottom */
boxProperties(b)
return b
}
})
|