diff options
author | wout <wout@impinc.co.uk> | 2017-02-22 12:10:20 +0100 |
---|---|---|
committer | wout <wout@impinc.co.uk> | 2017-02-22 12:10:22 +0100 |
commit | ceaf24d5a25bc815148d10eaea3112eb6ecf8488 (patch) | |
tree | 434abfeed06d9a124698299f0781478d8cdd9664 /bench/tests/10000-rects.js | |
parent | 669c10a76ebd164c147d7f896fa162784c0b49df (diff) | |
download | svg.js-ceaf24d5a25bc815148d10eaea3112eb6ecf8488.tar.gz svg.js-ceaf24d5a25bc815148d10eaea3112eb6ecf8488.zip |
Added gradient tests
Diffstat (limited to 'bench/tests/10000-rects.js')
-rw-r--r-- | bench/tests/10000-rects.js | 60 |
1 files changed, 59 insertions, 1 deletions
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 + }) + } + }) +}) + + + + + + + + |