|  | <!DOCTYPE html> | 
|  | <!-- DO NOT EDIT! This test has been generated by tools/gentest.py. --> | 
|  | <title>Canvas test: 2d.path.isPointInPath.winding</title> | 
|  | <script src="/resources/testharness.js"></script> | 
|  | <script src="/resources/testharnessreport.js"></script> | 
|  | <script src="/common/canvas-tests.js"></script> | 
|  | <link rel="stylesheet" href="/common/canvas-tests.css"> | 
|  | <body class="show_output"> | 
|  |  | 
|  | <h1>2d.path.isPointInPath.winding</h1> | 
|  | <p class="desc">isPointInPath() uses the non-zero winding number rule</p> | 
|  |  | 
|  |  | 
|  | <p class="output">Actual output:</p> | 
|  | <canvas id="c" class="output" width="100" height="50"><p class="fallback">FAIL (fallback content)</p></canvas> | 
|  |  | 
|  | <ul id="d"></ul> | 
|  | <script> | 
|  | var t = async_test("isPointInPath() uses the non-zero winding number rule"); | 
|  | _addTest(function(canvas, ctx) { | 
|  |  | 
|  | // Create a square ring, using opposite windings to make a hole in the centre | 
|  | ctx.moveTo(0, 0); | 
|  | ctx.lineTo(50, 0); | 
|  | ctx.lineTo(50, 50); | 
|  | ctx.lineTo(0, 50); | 
|  | ctx.lineTo(0, 0); | 
|  | ctx.lineTo(10, 10); | 
|  | ctx.lineTo(10, 40); | 
|  | ctx.lineTo(40, 40); | 
|  | ctx.lineTo(40, 10); | 
|  | ctx.lineTo(10, 10); | 
|  |  | 
|  | _assertSame(ctx.isPointInPath(5, 5), true, "ctx.isPointInPath(5, 5)", "true"); | 
|  | _assertSame(ctx.isPointInPath(25, 5), true, "ctx.isPointInPath(25, 5)", "true"); | 
|  | _assertSame(ctx.isPointInPath(45, 5), true, "ctx.isPointInPath(45, 5)", "true"); | 
|  | _assertSame(ctx.isPointInPath(5, 25), true, "ctx.isPointInPath(5, 25)", "true"); | 
|  | _assertSame(ctx.isPointInPath(25, 25), false, "ctx.isPointInPath(25, 25)", "false"); | 
|  | _assertSame(ctx.isPointInPath(45, 25), true, "ctx.isPointInPath(45, 25)", "true"); | 
|  | _assertSame(ctx.isPointInPath(5, 45), true, "ctx.isPointInPath(5, 45)", "true"); | 
|  | _assertSame(ctx.isPointInPath(25, 45), true, "ctx.isPointInPath(25, 45)", "true"); | 
|  | _assertSame(ctx.isPointInPath(45, 45), true, "ctx.isPointInPath(45, 45)", "true"); | 
|  |  | 
|  |  | 
|  | }); | 
|  | </script> | 
|  |  |