content/canvas/test/test_2d.line.cap.closed.html

Thu, 15 Jan 2015 21:03:48 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Thu, 15 Jan 2015 21:03:48 +0100
branch
TOR_BUG_9701
changeset 11
deefc01c0e14
permissions
-rw-r--r--

Integrate friendly tips from Tor colleagues to make (or not) 4.5 alpha 3;
This includes removal of overloaded (but unused) methods, and addition of
a overlooked call to DataStruct::SetData(nsISupports, uint32_t, bool.)

michael@0 1 <!DOCTYPE HTML>
michael@0 2 <title>Canvas test: 2d.line.cap.closed</title>
michael@0 3 <!-- Testing: Line caps are not drawn at the corners of an unclosed rectangle -->
michael@0 4 <script src="/tests/SimpleTest/SimpleTest.js"></script>
michael@0 5 <link rel="stylesheet" href="/tests/SimpleTest/test.css">
michael@0 6 <body>
michael@0 7 <canvas id="c" width="100" height="50"><p class="fallback">FAIL (fallback content)</p></canvas>
michael@0 8 <script>
michael@0 9 function isPixel(ctx, x,y, r,g,b,a, pos, colour, d) {
michael@0 10 var pixel = ctx.getImageData(x, y, 1, 1);
michael@0 11 var pr = pixel.data[0],
michael@0 12 pg = pixel.data[1],
michael@0 13 pb = pixel.data[2],
michael@0 14 pa = pixel.data[3];
michael@0 15 ok(r-d <= pr && pr <= r+d &&
michael@0 16 g-d <= pg && pg <= g+d &&
michael@0 17 b-d <= pb && pb <= b+d &&
michael@0 18 a-d <= pa && pa <= a+d,
michael@0 19 "pixel "+pos+" is "+pr+","+pg+","+pb+","+pa+"; expected "+colour+" +/- "+d);
michael@0 20 }
michael@0 21
michael@0 22 SimpleTest.waitForExplicitFinish();
michael@0 23 addLoadEvent(function () {
michael@0 24
michael@0 25 var canvas = document.getElementById('c');
michael@0 26 var ctx = canvas.getContext('2d');
michael@0 27
michael@0 28 ctx.fillStyle = '#0f0';
michael@0 29 ctx.strokeStyle = '#f00';
michael@0 30 ctx.fillRect(0, 0, 100, 50);
michael@0 31
michael@0 32 ctx.lineJoin = 'bevel';
michael@0 33 ctx.lineCap = 'square';
michael@0 34 ctx.lineWidth = 400;
michael@0 35
michael@0 36 ctx.beginPath();
michael@0 37 ctx.moveTo(200, 200);
michael@0 38 ctx.lineTo(200, 1000);
michael@0 39 ctx.lineTo(1000, 1000);
michael@0 40 ctx.lineTo(1000, 200);
michael@0 41 ctx.closePath();
michael@0 42 ctx.stroke();
michael@0 43
michael@0 44 isPixel(ctx, 1,1, 0,255,0,255, "1,1", "0,255,0,255", 0);
michael@0 45 isPixel(ctx, 48,1, 0,255,0,255, "48,1", "0,255,0,255", 0);
michael@0 46 isPixel(ctx, 48,48, 0,255,0,255, "48,48", "0,255,0,255", 0);
michael@0 47 isPixel(ctx, 1,48, 0,255,0,255, "1,48", "0,255,0,255", 0);
michael@0 48
michael@0 49 SimpleTest.finish();
michael@0 50
michael@0 51 });
michael@0 52 </script>
michael@0 53

mercurial