summaryrefslogtreecommitdiffstats
path: root/bench
diff options
context:
space:
mode:
authorwout <wout@impinc.co.uk>2017-02-22 12:10:20 +0100
committerwout <wout@impinc.co.uk>2017-02-22 12:10:22 +0100
commitceaf24d5a25bc815148d10eaea3112eb6ecf8488 (patch)
tree434abfeed06d9a124698299f0781478d8cdd9664 /bench
parent669c10a76ebd164c147d7f896fa162784c0b49df (diff)
downloadsvg.js-ceaf24d5a25bc815148d10eaea3112eb6ecf8488.tar.gz
svg.js-ceaf24d5a25bc815148d10eaea3112eb6ecf8488.zip
Added gradient tests
Diffstat (limited to 'bench')
-rw-r--r--bench/svg.bench.js2
-rw-r--r--bench/tests/10000-rects.js60
2 files changed, 60 insertions, 2 deletions
diff --git a/bench/svg.bench.js b/bench/svg.bench.js
index ade25d8..49ff222 100644
--- a/bench/svg.bench.js
+++ b/bench/svg.bench.js
@@ -48,7 +48,7 @@
this._chain[i].run(this)
}
}
-
+
// Write result
, write: function(name, ms) {
var test = document.createElement('div')
diff --git a/bench/tests/10000-rects.js b/bench/tests/10000-rects.js
index c39147f..dee09b4 100644
--- a/bench/tests/10000-rects.js
+++ b/bench/tests/10000-rects.js
@@ -17,6 +17,7 @@ SVG.bench.describe('Generate 10000 rects', function(bench) {
})
})
+
SVG.bench.describe('Generate 10000 rects with fill', function(bench) {
bench.test('using SVG.js v2.4.0', function() {
for (var i = 0; i < 10000; i++)
@@ -37,6 +38,7 @@ SVG.bench.describe('Generate 10000 rects with fill', function(bench) {
})
})
+
SVG.bench.describe('Generate 10000 rects with position and fill', function(bench) {
bench.test('using SVG.js v2.4.0', function() {
for (var i = 0; i < 10000; i++)
@@ -57,4 +59,60 @@ SVG.bench.describe('Generate 10000 rects with position and fill', function(bench
for (var i = 0; i < 10000; i++)
bench.snap.rect(50, 50, 100, 100).attr('fill', '#f06')
})
-}) \ No newline at end of file
+})
+
+
+SVG.bench.describe('Generate 10000 rects with gradient fill', function(bench) {
+ bench.test('using SVG.js v2.4.0', function() {
+ for (var i = 0; i < 10000; i++) {
+ var g = bench.draw.gradient('linear', function(stop) {
+ stop.at(0, '#000')
+ stop.at(0.25, '#f00')
+ stop.at(1, '#fff')
+ })
+
+ bench.draw.rect(100,100).fill(g)
+ }
+ })
+ bench.test('using vanilla js', function() {
+ for (var i = 0; i < 10000; i++) {
+ var g = document.createElementNS(SVG.ns, 'linearGradient')
+ var stop = document.createElementNS(SVG.ns, 'stop')
+ stop.setAttributeNS(null, 'offset', '0%')
+ stop.setAttributeNS(null, 'color', '#000')
+ g.appendChild(stop)
+ stop = document.createElementNS(SVG.ns, 'stop')
+ stop.setAttributeNS(null, 'offset', '25%')
+ stop.setAttributeNS(null, 'color', '#f00')
+ g.appendChild(stop)
+ stop = document.createElementNS(SVG.ns, 'stop')
+ stop.setAttributeNS(null, 'offset', '100%')
+ stop.setAttributeNS(null, 'color', '#fff')
+ g.appendChild(stop)
+ bench.raw.appendChild(g)
+
+ var rect = document.createElementNS(SVG.ns, 'rect')
+ rect.setAttributeNS(null, 'height', 100)
+ rect.setAttributeNS(null, 'width', 100)
+ rect.setAttributeNS(null, 'fill', '#f06')
+ bench.raw.appendChild(rect)
+ }
+ })
+ bench.test('using Snap.svg v0.5.1', function() {
+ for (var i = 0; i < 10000; i++) {
+ var g = bench.snap.gradient("L(0, 0, 100, 100)#000-#f00:25%-#fff")
+
+ bench.snap.rect(50, 50, 100, 100).attr({
+ fill: g
+ })
+ }
+ })
+})
+
+
+
+
+
+
+
+