]> source.dussan.org Git - svg.js.git/commitdiff
Added gradient tests
authorwout <wout@impinc.co.uk>
Wed, 22 Feb 2017 11:10:20 +0000 (12:10 +0100)
committerwout <wout@impinc.co.uk>
Wed, 22 Feb 2017 11:10:22 +0000 (12:10 +0100)
bench/svg.bench.js
bench/tests/10000-rects.js

index ade25d8f10f4269eeb3544f06f38bc997f0dfdf9..49ff222ca2dbb043886b00583f3f82c2e7b7b645 100644 (file)
@@ -48,7 +48,7 @@
         this._chain[i].run(this)
       }
     }
-
+    
     // Write result
   , write: function(name, ms) {
       var test = document.createElement('div')
index c39147fa103104b519484c79635a0096f94ef773..dee09b49b5ded471d32b228a49eb063a34caf742 100644 (file)
@@ -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
+      })
+    }
+  })
+})
+
+
+
+
+
+
+
+