skia2/experimental/Intersection/op.htm
caryclark@google.com db0b3e099f shape ops work in progress
git-svn-id: http://skia.googlecode.com/svn/trunk@6929 2bbb7eff-a529-9590-31e7-b0007b416f81
2012-12-21 21:34:36 +00:00

3669 lines
105 KiB
HTML

<!-- path visualizer -->
<html>
<head>
<div style="height:0">
<div id="testSimplifyQuadratic1">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 1);
path.close();
path.moveTo(1, 0);
path.quadTo(0, 0, 0, 1);
path.close();
testSimplify(path, true, out, bitmap);
}
</div>
<div id="testSimplifyQuadratic2">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(20, 0, 20, 20);
path.close();
path.moveTo(20, 0);
path.quadTo(0, 0, 0, 20);
path.close();
testSimplify(path, true, out, bitmap);
}
</div>
<div id="testSimplifyQuadratic3">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(20, 0, 20, 20);
path.close();
path.moveTo(0, 20);
path.quadTo(0, 0, 20, 0);
path.close();
testSimplify(path, true, out, bitmap);
}
</div>
<div id="testSimplifyQuadratic4">
SkPath path, out;
path.moveTo(0, 20);
path.quadTo(20, 0, 40, 20);
path.close();
path.moveTo(40, 10);
path.quadTo(20, 30, 0, 10);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic5">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(0, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(0, 0, 0, 1);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic6">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(1, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic7">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 2);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic8">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(0, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 2);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic9">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(1, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 2, 2);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic10">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(0, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 1);
path.quadTo(1, 1, 1, 2);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic11">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(0, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(2, 1);
path.quadTo(2, 2, 3, 3);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic12">
SkPath path, out;
path.moveTo(0, 0);
path.lineTo(0, 2);
path.lineTo(0, 0);
path.close();
path.moveTo(3, 0);
path.quadTo(1, 1, 0, 2);
path.lineTo(3, 0);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic13">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(1, 1);
path.lineTo(0, 0);
path.close();
path.moveTo(0, 0);
path.quadTo(3, 0, 1, 1);
path.lineTo(0, 0);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic14">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(1, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(0, 1, 2, 1);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic15">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 3);
path.lineTo(3, 3);
path.close();
path.moveTo(0, 1);
path.lineTo(1, 1);
path.quadTo(0, 3, 3, 3);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic16">
SkPath path, out;
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic17">
SkPath path, out;
path.moveTo(8, 8);
path.quadTo(10, 10, 8, -10);
path.close();
path.moveTo(8, 8);
path.quadTo(12, 12, 14, 4);
path.close();
path.moveTo(8, 8);
path.quadTo(9, 9, 10, 8);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
}
</div>
<div id="testSimplifyQuadratic18">
SkPath path, out;
path.moveTo(8.0000000000000071, 8.0000000000000071);
path.quadTo(8.7289570079366854, 8.7289570079366889, 9.3914917259458743, 9.0593802763083691);
path.close();
path.moveTo(8.0000000000000142, 8.0000000000000142);
path.quadTo(8.1250000000000107, 8.1250000000000071, 8.2500000000000071, 8.2187500000000053);
path.close();
testSimplify(path, true, out, bitmap);
drawAsciiPaths(path, out, true);
</div>
<div id="testSimplifyQuadratic19">
SkPath path, simple;
path.moveTo(0,4);
path.lineTo(6,4);
path.lineTo(3,1);
path.close();
path.moveTo(2,3);
path.lineTo(3,2);
path.lineTo(4,3);
path.close();
testSimplifyx(path);
</div>
<div id="testSimplifyQuadratic20">
SkPath path, simple;
path.moveTo(0,4);
path.lineTo(6,4);
path.lineTo(3,1);
path.close();
path.moveTo(2,3);
path.lineTo(4,3);
path.lineTo(3,2);
path.close();
testSimplifyx(path);
</div>
<div id="testSimplifyQuadratic21">
SkPath path, simple;
path.moveTo(0,4);
path.lineTo(8,4);
path.lineTo(4,0);
path.close();
path.moveTo(2,2);
path.lineTo(3,3);
path.lineTo(4,2);
path.close();
testSimplifyx(path);
</div>
<div id="testLine6">
SkPath path, simple;
path.moveTo(0,0);
path.lineTo(4,0);
path.lineTo(2,2);
path.close();
path.moveTo(2,0);
path.lineTo(6,0);
path.lineTo(4,2);
path.close();
testSimplifyx(path);
</div>
<div id="testLine7">
SkPath path, simple;
path.moveTo(0,0);
path.lineTo(4,0);
path.lineTo(2,2);
path.close();
path.moveTo(6,0);
path.lineTo(2,0);
path.lineTo(4,2);
path.close();
testSimplifyx(path);
</div>
<div id="testLine7b">
path.moveTo(0,0);
path.lineTo(4,0);
path.close();
path.moveTo(6,0);
path.lineTo(2,0);
path.lineTo(4,2);
path.close();
</div>
<div id="testLine9">
SkPath path, simple;
path.moveTo(0,4);
path.lineTo(4,4);
path.lineTo(2,2);
path.close();
path.moveTo(6,4);
path.lineTo(2,4);
path.lineTo(4,2);
path.close();
testSimplifyx(path);
</div>
<div id="testLine12">
path.moveTo(0,4);
path.lineTo(6,4);
path.lineTo(3,1);
path.close();
path.moveTo(2,3);
path.lineTo(3,2);
path.lineTo(4,3);
path.close();
</div>
<div id="testLine13">
path.moveTo(6,4);
path.lineTo(0,4);
path.lineTo(3,1);
path.close();
path.moveTo(3,2);
path.lineTo(2,3);
path.lineTo(4,3);
path.close();
</div>
<div id="testLine17">
SkPath path, simple;
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 12, 13, 13, SkPath::kCW_Direction);
testSimplifyx(path);
</div>
<div id="testLine19">
SkPath path, simple;
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(12, 16, 21, 21, SkPath::kCW_Direction);
testSimplifyx(path);
</div>
<div id="testLine22">
path.addRect(0, 12, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 12, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine24">
path.addRect(0, 18, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 12, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine28">
SkPath path, simple;
path.addRect(0, 6, 12, 12, SkPath::kCW_Direction);
path.addRect(0, 0, 9, 9, SkPath::kCW_Direction);
testSimplifyx(path);
</div>
<div id="testLine29">
SkPath path, simple;
path.addRect(0, 18, 12, 12, SkPath::kCW_Direction);
path.addRect(12, 12, 21, 21, SkPath::kCW_Direction);
testSimplifyx(path);
</div>
<div id="testLine30">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 4, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine31">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(0, 4, 9, 9, SkPath::kCW_Direction);
</div>
<div id="testLine32">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 12, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine33">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 16, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine34">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 6, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 12, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine35">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(6, 0, 18, 18, SkPath::kCW_Direction);
path.addRect(4, 16, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine36">
path.addRect(0, 10, 20, 20, SkPath::kCW_Direction);
path.addRect(6, 12, 18, 18, SkPath::kCW_Direction);
path.addRect(4, 16, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine37">
path.addRect(0, 20, 20, 20, SkPath::kCW_Direction);
path.addRect(18, 24, 30, 30, SkPath::kCW_Direction);
path.addRect(0, 0, 9, 9, SkPath::kCW_Direction);
</div>
<div id="testLine38">
path.addRect(10, 0, 30, 30, SkPath::kCW_Direction);
path.addRect(6, 12, 18, 18, SkPath::kCW_Direction);
path.addRect(12, 12, 21, 21, SkPath::kCW_Direction);
</div>
<div id="testLine39">
path.addRect(10, 0, 30, 30, SkPath::kCW_Direction);
path.addRect(12, 6, 24, 24, SkPath::kCW_Direction);
path.addRect(12, 4, 21, 21, SkPath::kCW_Direction);
</div>
<div id="testLine40">
path.addRect(10, 0, 30, 30, SkPath::kCW_Direction);
path.addRect(12, 18, 24, 24, SkPath::kCW_Direction);
path.addRect(4, 16, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine41">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(18, 24, 30, 30, SkPath::kCW_Direction);
path.addRect(12, 0, 21, 21, SkPath::kCW_Direction);
</div>
<div id="testLine42">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(8, 16, 17, 17, SkPath::kCW_Direction);
</div>
<div id="testLine43">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(6, 24, 18, 18, SkPath::kCW_Direction);
path.addRect(0, 32, 9, 36, SkPath::kCCW_Direction);
</div>
<div id="testLine44">
path.addRect(10, 40, 30, 30, SkPath::kCW_Direction);
path.addRect(18, 0, 30, 30, SkPath::kCW_Direction);
path.addRect(18, 32, 27, 36, SkPath::kCCW_Direction);
</div>
<div id="testLine45">
path.addRect(10, 0, 30, 30, SkPath::kCW_Direction);
path.addRect(18, 0, 30, 30, SkPath::kCW_Direction);
path.addRect(24, 32, 33, 36, SkPath::kCW_Direction);
</div>
<div id="testLine46">
path.addRect(10, 40, 30, 30, SkPath::kCW_Direction);
path.addRect(24, 0, 36, 36, SkPath::kCW_Direction);
path.addRect(24, 32, 33, 36, SkPath::kCW_Direction);
</div>
<div id="testLine47">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(0, 0, 9, 9, SkPath::kCCW_Direction);
</div>
<div id="testLine48">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 6, 12, 12, SkPath::kCW_Direction);
path.addRect(0, 0, 9, 9, SkPath::kCCW_Direction);
</div>
<div id="testLine49">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(0, 0, 9, 9, SkPath::kCW_Direction);
</div>
<div id="testLine50">
path.addRect(10, 30, 30, 30, SkPath::kCW_Direction);
path.addRect(24, 20, 36, 30, SkPath::kCW_Direction);
</div>
<div id="testLine51">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 12, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 12, 13, 13, SkPath::kCCW_Direction);
</div>
<div id="testLine52">
path.addRect(0, 30, 20, 20, SkPath::kCW_Direction);
path.addRect(6, 20, 18, 30, SkPath::kCW_Direction);
path.addRect(32, 0, 36, 41, SkPath::kCW_Direction);
</div>
<div id="testLine53">
path.addRect(10, 30, 30, 30, SkPath::kCW_Direction);
path.addRect(12, 20, 24, 30, SkPath::kCW_Direction);
path.addRect(12, 32, 21, 36, SkPath::kCCW_Direction);
</div>
<div id="testLine54">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(6, 0, 18, 18, SkPath::kCW_Direction);
path.addRect(8, 4, 17, 17, SkPath::kCCW_Direction);
</div>
<div id="testLine55">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(6, 6, 18, 18, SkPath::kCW_Direction);
path.addRect(4, 4, 13, 13, SkPath::kCCW_Direction);
</div>
<div id="testLine56">
path.addRect(0, 20, 20, 20, SkPath::kCW_Direction);
path.addRect(18, 20, 30, 30, SkPath::kCW_Direction);
path.addRect(12, 0, 21, 21, SkPath::kCCW_Direction);
</div>
<div id="testLine57">
path.addRect(20, 0, 40, 40, SkPath::kCW_Direction);
path.addRect(20, 0, 30, 40, SkPath::kCW_Direction);
path.addRect(12, 0, 21, 21, SkPath::kCCW_Direction);
</div>
<div id="testLine58">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 0, 12, 12, SkPath::kCCW_Direction);
path.addRect(0, 12, 9, 9, SkPath::kCCW_Direction);
</div>
<div id="testLine59">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(6, 6, 18, 18, SkPath::kCCW_Direction);
path.addRect(4, 4, 13, 13, SkPath::kCCW_Direction);
</div>
<div id="testLine60">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(6, 12, 18, 18, SkPath::kCCW_Direction);
path.addRect(4, 12, 13, 13, SkPath::kCCW_Direction);
</div>
<div id="testLine61">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(12, 0, 24, 24, SkPath::kCCW_Direction);
path.addRect(12, 0, 21, 21, SkPath::kCCW_Direction);
</div>
<div id="testLine62">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 12, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 12, 13, 13, SkPath::kCCW_Direction);
</div>
<div id="testLine63">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(0, 10, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 6, 12, 12, SkPath::kCCW_Direction);
path.addRect(0, 32, 9, 36, SkPath::kCCW_Direction);
</div>
<div id="testLine64">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(10, 40, 30, 30, SkPath::kCW_Direction);
path.addRect(18, 6, 30, 30, SkPath::kCW_Direction);
</div>
<div id="testLine65">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(10, 0, 30, 30, SkPath::kCW_Direction);
path.addRect(24, 0, 36, 36, SkPath::kCW_Direction);
path.addRect(32, 6, 36, 41, SkPath::kCCW_Direction);
</div>
<div id="testLine66">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(0, 30, 20, 20, SkPath::kCW_Direction);
path.addRect(12, 20, 24, 30, SkPath::kCW_Direction);
</div>
<div id="testLine67">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(10, 40, 30, 30, SkPath::kCW_Direction);
path.addRect(24, 20, 36, 30, SkPath::kCW_Direction);
path.addRect(32, 0, 36, 41, SkPath::kCW_Direction);
</div>
<div id="testLine68a">
path.addRect(0, 0, 8, 8, SkPath::kCW_Direction);
path.addRect(2, 2, 6, 6, SkPath::kCW_Direction);
path.addRect(1, 2, 4, 2, SkPath::kCW_Direction);
</div>
<div id="testLine68b">
path.addRect(0, 0, 8, 8, SkPath::kCW_Direction);
path.addRect(2, 2, 6, 6, SkPath::kCCW_Direction);
path.addRect(1, 2, 4, 2, SkPath::kCW_Direction);
</div>
<div id="testLine68c">
path.addRect(0, 0, 8, 8, SkPath::kCCW_Direction);
path.addRect(2, 2, 6, 6, SkPath::kCW_Direction);
path.addRect(1, 2, 4, 2, SkPath::kCW_Direction);
</div>
<div id="testLine68d">
path.addRect(0, 0, 8, 8, SkPath::kCCW_Direction);
path.addRect(2, 2, 6, 6, SkPath::kCCW_Direction);
path.addRect(1, 2, 4, 2, SkPath::kCW_Direction);
</div>
<div id="testLine68e">
path.addRect(0, 0, 8, 8, SkPath::kCW_Direction);
path.addRect(0, 0, 8, 8, SkPath::kCW_Direction);
path.addRect(2, 2, 6, 6, SkPath::kCCW_Direction);
path.addRect(1, 2, 2, 2, SkPath::kCW_Direction);
</div>
<div id="testLine68f">
path.addRect(0, 0, 8, 8, SkPath::kCW_Direction);
path.addRect(2, 2, 6, 6, SkPath::kCCW_Direction);
path.addRect(2, 2, 6, 6, SkPath::kCCW_Direction);
path.addRect(1, 2, 2, 2, SkPath::kCW_Direction);
</div>
<div id="testLine69">
path.addRect(0, 20, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 20, 12, 30, SkPath::kCW_Direction);
path.addRect(12, 32, 21, 36, SkPath::kCW_Direction);
</div>
<div id="testLine70">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 24, 12, 12, SkPath::kCW_Direction);
path.addRect(12, 32, 21, 36, SkPath::kCCW_Direction);
</div>
<div id="testLine71">
path.addRect(0, 0, 20, 20, SkPath::kCW_Direction);
path.addRect(12, 0, 24, 24, SkPath::kCW_Direction);
path.addRect(12, 32, 21, 36, SkPath::kCW_Direction);
</div>
<div id="testLine72">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(10, 40, 30, 30, SkPath::kCW_Direction);
path.addRect(6, 20, 18, 30, SkPath::kCW_Direction);
</div>
<div id="testLine73">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(0, 40, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 20, 12, 30, SkPath::kCW_Direction);
path.addRect(0, 0, 9, 9, SkPath::kCCW_Direction);
</div>
<div id="testLine74">
path.addRect(20, 30, 40, 40, SkPath::kCW_Direction);
path.addRect(24, 20, 36, 30, SkPath::kCCW_Direction);
path.addRect(32, 24, 36, 41, SkPath::kCCW_Direction);
</div>
<div id="testLine75">
path.addRect(0, 0, 60, 60, SkPath::kCW_Direction);
path.addRect(10, 0, 30, 30, SkPath::kCCW_Direction);
path.addRect(18, 0, 30, 30, SkPath::kCCW_Direction);
path.addRect(12, 0, 21, 21, SkPath::kCCW_Direction);
</div>
<div id="testLine76">
path.addRect(36, 0, 66, 60, SkPath::kCW_Direction);
path.addRect(10, 20, 40, 30, SkPath::kCW_Direction);
path.addRect(24, 20, 36, 30, SkPath::kCCW_Direction);
path.addRect(32, 6, 36, 41, SkPath::kCCW_Direction);
</div>
<div id="testLine77">
path.addRect(20, 0, 40, 40, SkPath::kCW_Direction);
path.addRect(24, 6, 36, 36, SkPath::kCCW_Direction);
path.addRect(24, 32, 33, 36, SkPath::kCCW_Direction);
</div>
<div id="testLine78">
path.addRect(0, 0, 30, 60, SkPath::kCW_Direction);
path.addRect(10, 20, 30, 30, SkPath::kCCW_Direction);
path.addRect(18, 20, 30, 30, SkPath::kCCW_Direction);
path.addRect(32, 0, 36, 41, SkPath::kCCW_Direction);
</div>
<div id="testLine79">
path.addRect(0, 36, 60, 30, SkPath::kCW_Direction);
path.addRect(10, 30, 40, 30, SkPath::kCW_Direction);
path.addRect(0, 20, 12, 30, SkPath::kCCW_Direction);
path.addRect(0, 32, 9, 36, SkPath::kCCW_Direction);
</div>
<div id="testLine81">
path.addRect(-1, -1, 3, 3, SkPath::kCW_Direction);
path.addRect(0, 0, 1, 1, SkPath::kCW_Direction);
path.addRect(1, 1, 2, 2, SkPath::kCCW_Direction);
</div>
<div id="testDegenerate1">
path.moveTo(0, 0);
path.lineTo(0, 0);
path.lineTo(2, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.lineTo(2, 0);
path.close();
</div>
<div id="testDegenerate2">
path.moveTo(0, 0);
path.lineTo(0, 0);
path.lineTo(0, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.lineTo(0, 1);
path.close();
</div>
<div id="testDegenerate3">
path.moveTo(0, 0);
path.lineTo(2, 0);
path.lineTo(1, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.lineTo(3, 0);
path.close();
</div>
<div id="testDegenerate4">
path.moveTo(0, 0);
path.lineTo(1, 0);
path.lineTo(1, 3);
path.close();
path.moveTo(1, 0);
path.lineTo(1, 1);
path.lineTo(1, 2);
path.close();
</div>
<div id="testNondegenerate1">
path.moveTo(0, 0);
path.lineTo(3, 0);
path.lineTo(1, 3);
path.close();
path.moveTo(1, 1);
path.lineTo(2, 1);
path.lineTo(1, 2);
path.close();
</div>
<div id="testNondegenerate2">
path.moveTo(1, 0);
path.lineTo(0, 1);
path.lineTo(1, 1);
path.close();
path.moveTo(0, 2);
path.lineTo(0, 3);
path.lineTo(1, 2);
path.close();
</div>
<div id="testNondegenerate3">
path.moveTo(0, 0);
path.lineTo(1, 0);
path.lineTo(2, 1);
path.close();
path.moveTo(0, 1);
path.lineTo(1, 1);
path.lineTo(0, 2);
path.close();
</div>
<div id="testNondegenerate4">
path.moveTo(1, 0);
path.lineTo(0, 1);
path.lineTo(1, 2);
path.close();
path.moveTo(0, 2);
path.lineTo(0, 3);
path.lineTo(1, 3);
path.close();
</div>
<div id="testQuadralateral5">
path.moveTo(0, 0);
path.lineTo(0, 0);
path.lineTo(1, 0);
path.lineTo(1, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(2, 2);
path.lineTo(3, 2);
path.lineTo(3, 3);
path.close();
</div>
<div id="testQuadralateral6">
path.moveTo(0, 0);
path.lineTo(0, 0);
path.lineTo(1, 0);
path.lineTo(1, 1);
path.close();
path.moveTo(1, 0);
path.lineTo(2, 0);
path.lineTo(0, 2);
path.lineTo(2, 2);
path.close();
</div>
<div id="testFauxQuadralateral6">
path.moveTo(0, 0);
path.lineTo(1, 0);
path.lineTo(1, 1);
path.close();
path.moveTo(1, 0);
path.lineTo(2, 0);
path.lineTo(1.333, 0.667);
path.close();
path.moveTo(1.333, 0.667);
path.lineTo(0, 2);
path.lineTo(2, 2);
path.close();
</div>
<div id="testFauxQuadralateral6a">
path.moveTo(0, 0);
path.lineTo(3, 0);
path.lineTo(3, 3);
path.close();
path.moveTo(3, 0);
path.lineTo(6, 0);
path.lineTo(4, 2);
path.close();
path.moveTo(4, 2);
path.lineTo(0, 6);
path.lineTo(6, 6);
path.close();
</div>
<div id="testFauxQuadralateral6b">
path.moveTo(0, 0);
path.lineTo(3, 0);
path.lineTo(3, 3);
path.close();
path.moveTo(3, 0);
path.lineTo(6, 0);
path.lineTo(4, 2);
path.close();
path.moveTo(4, 2);
path.lineTo(6, 6);
path.lineTo(0, 6);
path.close();
</div>
<div id="testFauxQuadralateral6c">
path.moveTo(0, 0);
path.lineTo(3, 3);
path.lineTo(3, 0);
path.close();
path.moveTo(3, 0);
path.lineTo(6, 0);
path.lineTo(4, 2);
path.close();
path.moveTo(4, 2);
path.lineTo(0, 6);
path.lineTo(6, 6);
path.close();
</div>
<div id="testFauxQuadralateral6d">
path.moveTo(0, 0);
path.lineTo(3, 3);
path.lineTo(3, 0);
path.close();
path.moveTo(3, 0);
path.lineTo(6, 0);
path.lineTo(4, 2);
path.close();
path.moveTo(4, 2);
path.lineTo(6, 6);
path.lineTo(0, 6);
</div>
<div id="testQuadralateral6a">
path.moveTo(0, 0);
path.lineTo(0, 0);
path.lineTo(3, 0);
path.lineTo(3, 3);
path.close();
path.moveTo(3, 0);
path.lineTo(6, 0);
path.lineTo(0, 6);
path.lineTo(6, 6);
</div>
<div id="testQuadralateral7">
path.moveTo(0, 0);
path.lineTo(0, 0);
path.lineTo(1, 0);
path.lineTo(2, 1);
path.close();
path.moveTo(1, 0);
path.lineTo(1, 1);
path.lineTo(2, 2);
path.lineTo(1, 3);
path.close();
</div>
<div id="testQuadralateral8">
path.moveTo(0, 0);
path.lineTo(3, 1);
path.lineTo(1, 3);
path.lineTo(3, 3);
path.close();
path.moveTo(2, 1);
path.lineTo(0, 2);
path.lineTo(3, 2);
path.lineTo(2, 3);
path.close();
</div>
<div id="testQuadralateral9">
path.moveTo(0, 0);
path.lineTo(1, 0);
path.lineTo(1, 2);
path.lineTo(2, 2);
path.close();
path.moveTo(1, 1);
path.lineTo(2, 1);
path.lineTo(1, 3);
path.lineTo(2, 3);
path.close();
</div>
<div id="testLine1x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 0, 13, 13, SkPath::kCW_Direction);
</div>
<div id="testLine2x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.addRect(0, 20, 20, 20, SkPath::kCW_Direction);
path.addRect(0, 20, 12, 30, SkPath::kCW_Direction);
path.addRect(12, 0, 21, 21, SkPath::kCCW_Direction);
</div>
<div id="testLine3x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.addRect(10, 30, 30, 30, SkPath::kCW_Direction);
path.addRect(18, 20, 30, 30, SkPath::kCCW_Direction);
path.addRect(0, 32, 9, 36, SkPath::kCCW_Direction);
</div>
<div id="testLine4x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.addRect(10, 30, 30, 30, SkPath::kCW_Direction);
path.addRect(24, 20, 36, 30, SkPath::kCCW_Direction);
path.addRect(0, 32, 9, 36, SkPath::kCCW_Direction);
</div>
<div id="testQuadratic1">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(1, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.close();
</div>
<div id="testQuadratic2">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(3, 0);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.close();
</div>
<div id="testQuadratic3">
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(0, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.close();
</div>
<div id="testQuadratic4x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(0, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 2);
path.close();
</div>
<div id="testQuadratic5">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(0, 1, 0, 2);
path.close();
</div>
<div id="testQuadratic6">
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(2, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(2, 0, 0, 1);
path.close();
</div>
<div id="testQuadratic7">
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(3, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(3, 0, 1, 2);
path.close();
</div>
<div id="testQuadratic8">
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(0, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(0, 1, 1, 2);
path.close();
</div>
<div id="testQuadratic9">
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(3, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(1, 2, 3, 2);
path.close();
</div>
<div id="testQuadratic9a">
path.moveTo(1.08000004, 0.720000029);
path.lineTo(0, 0);
path.lineTo(1, 0);
path.lineTo(3, 1);
path.lineTo(1.01568651, 0.338562161);
path.quadTo(1.03542483, 0.541699469, 1.08000004, 0.720000029);
path.close();
path.moveTo(1.08000004, 0.720000029);
path.lineTo(3, 2);
path.quadTo(1.39999998, 2, 1.08000004, 0.720000029);
path.close();
</div>
<div id="testQuadratic10a">
path.moveTo(15.5, 15.5);
path.lineTo(46.5, 15.5);
path.quadTo(0, 31, 0, 46.5);
path.lineTo(15.5, 15.5);
path.close();
</div>
<div id="testQuadratic10b">
path.moveTo(5.16666698, 36.1666641);
path.lineTo(15.5, 15.5);
path.lineTo(46.5, 15.5);
path.quadTo(15.5, 25.8333321, 5.16666698, 36.1666641);
path.close();
path.moveTo(5.16666698, 36.1666641);
path.lineTo(0, 46.5);
path.quadTo(0, 41.3333359, 5.16666698, 36.1666641);
path.close();
</div>
<div id="testQuadratic11a">
path.moveTo(0, 0);
path.lineTo(15.5, 31);
path.lineTo(0, 0);
path.close();
path.moveTo(0, 15.5);
path.lineTo(15.5, 15.5);
path.quadTo(15.5, 15.5, 46.5, 31);
path.lineTo(0, 15.5);
path.close();
</div>
<div id="testQuadratic11b">
path.moveTo(9.30000019, 18.6000004);
path.lineTo(0, 15.5);
path.lineTo(7.75, 15.5);
path.lineTo(15.5, 15.5);
path.lineTo(46.5, 31);
path.lineTo(9.30000019, 18.6000004);
path.close();
</div>
<div id="testQuadratic12">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(1, 3);
path.close();
path.moveTo(1, 0);
path.lineTo(0, 1);
path.quadTo(1, 1, 0, 3);
path.close();
</div>
<div id="testQuadratic13a">
path.moveTo(0, 0);
path.quadTo(0, 0, 15.5, 0);
path.lineTo(15.5, 31);
path.lineTo(0, 0);
path.close();
path.moveTo(0, 0);
path.quadTo(15.5, 46.5, 46.5, 46.5);
path.lineTo(0, 0);
path.close();
</div>
<div id="testQuadratic13b">
path.moveTo(14.8800001, 29.7600002);
path.quadTo(6.20000029, 18.6000004, 0, 0);
path.lineTo(14.8800001, 29.7600002);
path.close();
path.moveTo(15.5, 30.5437222);
path.lineTo(15.5, 31);
path.lineTo(14.8800001, 29.7600002);
path.quadTo(15.1884346, 30.156559, 15.5, 30.5437222);
path.close();
path.moveTo(15.5, 15.5);
path.lineTo(0, 0);
path.lineTo(15.5, 0);
path.lineTo(15.5, 15.5);
path.close();
path.moveTo(15.5, 30.5437222);
path.lineTo(15.5, 15.5);
path.lineTo(46.5, 46.5);
path.quadTo(28.34062, 46.5, 15.5, 30.5437222);
path.close();
</div>
<div id="testQuadratic14">
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(3, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(3, 2, 3, 3);
path.close();
</div>
<div id="testQuadratic15">
path.moveTo(0, 0);
path.quadTo(0, 0, 1, 0);
path.lineTo(1, 3);
path.close();
path.moveTo(1, 0);
path.lineTo(0, 1);
path.quadTo(1, 1, 0, 3);
path.close();
</div>
<div id="testQuadratic16a">
path.moveTo(0, 0);
path.quadTo(0, 0, 31, 0);
path.lineTo(46.5, 31);
path.lineTo(0, 0);
path.close();
path.moveTo(46.5, 15.5);
path.lineTo(0, 31);
path.quadTo(0, 31, 15.5, 31);
path.lineTo(46.5, 15.5);
path.close();
</div>
<div id="testQuadratic16b">
path.moveTo(31, 20.6666679);
path.lineTo(0, 0);
path.lineTo(31, 0);
path.lineTo(39.8571434, 17.7142868);
path.lineTo(31, 20.6666679);
path.close();
path.moveTo(33.214283, 22.1428585);
path.lineTo(15.5, 31);
path.lineTo(0, 31);
path.lineTo(31, 20.6666679);
path.lineTo(33.214283, 22.1428585);
path.close();
path.moveTo(40.2999992, 18.6000004);
path.lineTo(46.5, 31);
path.lineTo(33.214283, 22.1428585);
path.lineTo(40.2999992, 18.6000004);
path.close();
path.moveTo(39.8571434, 17.7142868);
path.lineTo(46.5, 15.5);
path.lineTo(40.2999992, 18.6000004);
path.lineTo(39.8571434, 17.7142868);
path.close();
</div>
<div id="testQuadratic17x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.moveTo(0, 0);
path.quadTo(0, 0, 3, 1);
path.lineTo(0, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(3, 1, 0, 2);
path.close();
</div>
<div id="testQuadratic18">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 1, 1);
path.close();
</div>
<div id="testQuadratic19">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(2, 0, 0, 1);
path.close();
</div>
<div id="testQuadratic20">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.close();
</div>
<div id="testQuadratic21">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 2);
path.close();
</div>
<div id="testQuadratic22">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(0, 1, 2, 1);
path.close();
</div>
<div id="testQuadratic23">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(0, 2, 1, 2);
path.close();
</div>
<div id="testQuadratic24">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(2, 0, 0, 1);
path.close();
</div>
<div id="testQuadratic25">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 1);
path.lineTo(1, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(2, 1, 0, 2);
path.close();
</div>
<div id="testQuadratic26">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 1);
path.lineTo(0, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.close();
</div>
<div id="testQuadratic27">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 1);
path.lineTo(2, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(2, 1, 0, 2);
path.close();
</div>
<div id="testQuadratic28">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 2);
path.quadTo(1, 2, 0, 3);
path.close();
</div>
<div id="testQuadratic29">
path.moveTo(0, 0);
path.quadTo(1, 0, 2, 1);
path.lineTo(0, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.close();
</div>
<div id="testQuadratic30">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 2);
path.lineTo(1, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(0, 1, 1, 2);
path.close();
</div>
<div id="testQuadratic31">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 2);
path.lineTo(1, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(0, 1, 1, 3);
path.close();
</div>
<div id="testQuadratic32">
path.moveTo(0, 0);
path.quadTo(1, 0, 2, 3);
path.lineTo(2, 3);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(3, 1, 0, 2);
path.close();
</div>
<div id="testQuadratic33">
path.moveTo(0, 0);
path.quadTo(2, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 1);
path.quadTo(2, 1, 2, 2);
path.close();
</div>
<div id="testQuadratic34">
path.moveTo(0, 0);
path.quadTo(2, 0, 0, 1);
path.lineTo(0, 1);
path.close();
path.moveTo(1, 0);
path.lineTo(1, 1);
path.quadTo(2, 1, 1, 2);
path.close();
</div>
<div id="testQuadratic35">
path.moveTo(0, 0);
path.quadTo(0, 1, 1, 1);
path.lineTo(1, 3);
path.close();
path.moveTo(2, 0);
path.lineTo(3, 0);
path.quadTo(0, 1, 1, 1);
path.close();
</div>
<div id="testQuadratic36">
path.moveTo(0, 0);
path.quadTo(2, 1, 2, 3);
path.lineTo(2, 3);
path.close();
path.moveTo(3, 1);
path.lineTo(1, 2);
path.quadTo(3, 2, 1, 3);
path.close();
</div>
<div id="testQuadratic37">
path.moveTo(0, 0);
path.quadTo(0, 2, 1, 2);
path.lineTo(1, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(3, 1);
path.quadTo(0, 2, 1, 2);
path.close();
</div>
<div id="testQuadratic38">
path.moveTo(1, 0);
path.quadTo(0, 1, 1, 1);
path.lineTo(1, 1);
path.close();
path.moveTo(1, 0);
path.lineTo(1, 2);
path.quadTo(2, 2, 1, 3);
path.close();
</div>
<div id="testQuadratic39">
path.moveTo(15.5, 0);
path.quadTo(46.5, 15.5, 46.5, 31);
path.lineTo(15.5, 0);
path.close();
path.moveTo(46.5, 15.5);
path.lineTo(0, 31);
path.quadTo(0, 31, 15.5, 31);
path.lineTo(46.5, 15.5);
path.close();
</div>
<div id="testQuadratic39a">
path.moveTo(34.875, 19.375);
path.lineTo(15.5, 0);
path.quadTo(32.9687576, 8.73437881, 40.5937271, 17.4687576);
path.lineTo(34.875, 19.375);
path.close();
path.moveTo(36.1666641, 20.6666679);
path.lineTo(15.5, 31);
path.lineTo(0, 31);
path.lineTo(34.875, 19.375);
path.lineTo(36.1666641, 20.6666679);
path.close();
path.moveTo(41.1812401, 18.15938);
path.quadTo(46.5, 24.5796909, 46.5, 31);
path.lineTo(36.1666641, 20.6666679);
path.lineTo(41.1812401, 18.15938);
path.close();
path.moveTo(40.5937271, 17.4687576);
path.lineTo(46.5, 15.5);
path.lineTo(41.1812401, 18.15938);
path.quadTo(40.8951759, 17.8140678, 40.5937271, 17.4687576);
path.close();
</div>
<div id="testQuadratic40x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.moveTo(2, 0);
path.quadTo(3, 0, 2, 2);
path.lineTo(3, 2);
path.close();
path.moveTo(3, 1);
path.lineTo(0, 2);
path.quadTo(0, 2, 1, 2);
path.close();
</div>
<div id="testQuadratic40xa">
path.moveTo(31, 0);
path.quadTo(41.3333359, 0, 37.8888893, 13.7777777);
path.lineTo(31, 0);
path.close();
path.moveTo(37.8888893, 13.7777777);
path.quadTo(37.2993202, 16.1360455, 36.3061028, 18.8979664);
path.lineTo(0, 31);
path.lineTo(15.5, 31);
path.lineTo(35.5182915, 20.9908543);
path.quadTo(33.7454262, 25.5091457, 31, 31);
path.lineTo(46.5, 31);
path.lineTo(40.2999992, 18.6000004);
path.lineTo(46.5, 15.5);
path.lineTo(39.8571434, 17.7142868);
path.lineTo(37.8888893, 13.7777777);
path.close();
path.moveTo(36.3061028, 18.8979664);
path.quadTo(35.9396667, 19.9169388, 35.5182915, 20.9908543);
path.lineTo(40.2999992, 18.6000004);
path.lineTo(39.8571434, 17.7142868);
path.lineTo(36.3061028, 18.8979664);
</div>
<div id="testQuadratic40xb">
path.moveTo(31, 0);
path.quadTo(46.5, 0, 31, 31);
path.lineTo(46.5, 31);
path.lineTo(31, 0);
path.close();
path.moveTo(46.5, 15.5);
path.lineTo(0, 31);
path.quadTo(0, 31, 15.5, 31);
path.lineTo(46.5, 15.5);
path.close();
</div>
<div id="testQuadratic41o">
path.moveTo(419.33905, 236.377808);
path.quadTo(398.847778, 242.58728, 384.255524, 242.58728);
path.quadTo(359.417633, 242.58728, 343.738708, 226.080429);
path.quadTo(328.059784, 209.573578, 328.059784, 183.286819);
path.quadTo(328.059784, 157.724487, 341.875854, 141.372879);
path.quadTo(355.691956, 125.021263, 377.218109, 125.021263);
path.quadTo(397.605896, 125.021263, 408.731201, 139.51004);
path.quadTo(419.856506, 153.99881, 419.856506, 180.699539);
path.lineTo(419.752991, 187.012497);
path.lineTo(348.861511, 187.012497);
path.quadTo(353.311646, 227.063599, 388.084686, 227.063599);
path.quadTo(400.814117, 227.063599, 419.33905, 220.233185);
path.lineTo(419.33905, 236.377808);
path.close();
path.moveTo(349.792938, 171.695801);
path.lineTo(399.365234, 171.695801);
path.quadTo(399.365234, 140.337967, 375.976227, 140.337967);
path.quadTo(352.483704, 140.337967, 349.792938, 171.695801);
path.close();
path.moveTo(378.682587, 277.360321);
path.lineTo(381.062897, 259.66333);
path.quadTo(398.759888, 268.046112, 415.939423, 268.046112);
path.quadTo(450.402008, 268.046112, 450.402008, 231.513718);
path.lineTo(450.402008, 213.816727);
path.quadTo(439.12146, 237.41272, 413.352142, 237.41272);
path.quadTo(393.171356, 237.41272, 381.269867, 222.716965);
path.quadTo(369.368378, 208.02121, 369.368378, 183.079834);
path.quadTo(369.368378, 157.414017, 382.92572, 141.269379);
path.quadTo(396.483093, 125.124756, 418.009247, 125.124756);
path.quadTo(436.844666, 125.124756, 450.402008, 140.441467);
path.lineTo(450.402008, 127.608543);
path.lineTo(470.89325, 127.608543);
path.lineTo(470.89325, 209.366608);
path.quadTo(470.89325, 235.756866, 468.150757, 248.43454);
path.quadTo(465.408234, 261.112213, 457.853363, 269.184509);
path.quadTo(444.502991, 283.362823, 416.353394, 283.362823);
path.quadTo(396.690063, 283.362823, 378.682587, 277.360321);
path.close();
path.moveTo(450.402008, 201.087311);
path.lineTo(450.402008, 154.412781);
path.quadTo(436.948151, 140.441467, 421.113983, 140.441467);
path.quadTo(407.039185, 140.441467, 399.070374, 151.722);
path.quadTo(391.101532, 163.002533, 391.101532, 182.665863);
path.quadTo(391.101532, 219.612228, 417.07782, 219.612228);
path.quadTo(434.774841, 219.612228, 450.402008, 201.087311);
path.close();
path.moveTo(482.9328, 236.377808);
path.quadTo(462.441528, 242.58728, 447.849274, 242.58728);
path.quadTo(423.011383, 242.58728, 407.332458, 226.080429);
path.quadTo(391.653534, 209.573578, 391.653534, 183.286819);
path.quadTo(391.653534, 157.724487, 405.469604, 141.372879);
path.quadTo(419.285706, 125.021263, 440.811859, 125.021263);
path.quadTo(461.199646, 125.021263, 472.324951, 139.51004);
path.quadTo(483.450256, 153.99881, 483.450256, 180.699539);
path.lineTo(483.346741, 187.012497);
path.lineTo(412.455261, 187.012497);
path.quadTo(416.905396, 227.063599, 451.678436, 227.063599);
path.quadTo(464.407867, 227.063599, 482.9328, 220.233185);
path.lineTo(482.9328, 236.377808);
path.close();
path.moveTo(413.386688, 171.695801);
path.lineTo(462.958984, 171.695801);
path.quadTo(462.958984, 140.337967, 439.569977, 140.337967);
path.quadTo(416.077454, 140.337967, 413.386688, 171.695801);
path.close();
</div>
<div id="testQuadratic41s">
path.moveTo(341.875854, 141.372879);
path.quadTo(355.691956,125.021263, 377.218109,125.021263);
path.quadTo(388.787811,125.021263, 397.374664,129.687164);
path.quadTo(406.565979,125.124756, 418.009247,125.124756);
path.quadTo(423.583374,125.124756, 428.695251,126.466187);
path.quadTo(434.412903,125.021263, 440.811859,125.021263);
path.quadTo(449.427277,125.021263, 456.388672,127.608543);
path.lineTo(470.89325,127.608543);
path.lineTo(470.89325,137.749908);
path.quadTo(471.627319,138.601486, 472.324951,139.51004);
path.quadTo(483.450256,153.99881, 483.450256,180.699539);
path.lineTo(483.346741,187.012497);
path.lineTo(470.89325,187.012497);
path.lineTo(470.89325,209.366608);
path.quadTo(470.89325,217.414856, 470.638184,224.187729);
path.quadTo(476.428223,222.631516, 482.9328,220.233185);
path.lineTo(482.9328,236.377808);
path.quadTo(475.87207,238.517426, 469.511749,239.919785);
path.quadTo(468.946777,244.754791, 468.150757,248.43454);
path.quadTo(465.408234,261.112213, 457.853363,269.184509);
path.quadTo(444.502991,283.362823, 416.353394,283.362823);
path.quadTo(396.690063,283.362823, 378.682587,277.360321);
path.lineTo(381.062897,259.66333);
path.quadTo(398.759888,268.046112, 415.939423,268.046112);
path.quadTo(444.719147,268.046112, 449.464905,242.568665);
path.quadTo(448.648254,242.58728, 447.849274,242.58728);
path.quadTo(433.084625,242.58728, 421.556366,236.754425);
path.quadTo(418.89566,237.203537, 416.046783,237.346252);
path.quadTo(397.661652,242.58728, 384.255524,242.58728);
path.quadTo(359.417633,242.58728, 343.738708,226.080429);
path.quadTo(328.059784,209.573578, 328.059784,183.286819);
path.quadTo(328.059784,157.724487, 341.875854,141.372879);
path.close();
path.moveTo(442.014923, 226.179474);
path.quadTo(445.951935,226.953491, 450.402008,227.049881);
path.lineTo(450.402008,213.816727);
path.quadTo(446.904755,221.132065, 442.014923,226.179474);
path.close();
path.moveTo(395.347717, 206.501785);
path.quadTo(392.200165,197.593536, 391.734406,187.012497);
path.lineTo(391.197113,187.012497);
path.quadTo(391.738647,198.938644, 395.347717,206.501785);
path.close();
path.moveTo(391.808533, 171.695801);
path.lineTo(392.428436,171.695801);
path.quadTo(393.693451,162.656265, 397.02359,154.9935);
path.quadTo(397.023804,154.992996, 397.024048,154.992493);
path.quadTo(393.175995,143.845093, 383.003235,141.177292);
path.quadTo(382.964447,141.223267, 382.92572,141.269379);
</div>
<div id="testQuadratic42o">
path.moveTo(421.962158, 236.285355);
path.quadTo(400.947845, 242.65332, 385.983124, 242.65332);
path.quadTo(360.511261, 242.65332, 344.432129, 225.725143);
path.quadTo(328.352997, 208.796951, 328.352997, 181.839218);
path.quadTo(328.352997, 155.62442, 342.521729, 138.855438);
path.quadTo(356.69046, 122.086449, 378.766083, 122.086449);
path.quadTo(399.674255, 122.086449, 411.083527, 136.945038);
path.quadTo(422.492798, 151.803635, 422.492798, 179.185898);
path.lineTo(422.386688, 185.660004);
path.lineTo(349.685699, 185.660004);
path.quadTo(354.24942, 226.733398, 389.910034, 226.733398);
path.quadTo(402.964386, 226.733398, 421.962158, 219.728638);
path.lineTo(421.962158, 236.285355);
path.close();
path.moveTo(350.6409, 169.952347);
path.lineTo(401.478516, 169.952347);
path.quadTo(401.478516, 137.794098, 377.492493, 137.794098);
path.quadTo(353.40036, 137.794098, 350.6409, 169.952347);
path.close();
path.moveTo(379.213562, 278.313934);
path.lineTo(381.654602, 260.165222);
path.quadTo(399.803314, 268.761993, 417.421356, 268.761993);
path.quadTo(452.763611, 268.761993, 452.763611, 231.297104);
path.lineTo(452.763611, 213.148392);
path.quadTo(441.195129, 237.34668, 414.768036, 237.34668);
path.quadTo(394.072144, 237.34668, 381.866882, 222.275818);
path.quadTo(369.661591, 207.204956, 369.661591, 181.626953);
path.quadTo(369.661591, 155.306015, 383.565002, 138.749298);
path.quadTo(397.468384, 122.192581, 419.544037, 122.192581);
path.quadTo(438.860199, 122.192581, 452.763611, 137.900238);
path.lineTo(452.763611, 124.739769);
path.lineTo(473.777893, 124.739769);
path.lineTo(473.777893, 208.584686);
path.quadTo(473.777893, 235.64856, 470.965363, 248.649826);
path.quadTo(468.152863, 261.651093, 460.405151, 269.929443);
path.quadTo(446.71402, 284.469666, 417.845886, 284.469666);
path.quadTo(397.680664, 284.469666, 379.213562, 278.313934);
path.close();
path.moveTo(452.763611, 200.094055);
path.lineTo(452.763611, 152.228165);
path.quadTo(438.966339, 137.900238, 422.727997, 137.900238);
path.quadTo(408.293945, 137.900238, 400.121704, 149.468719);
path.quadTo(391.949493, 161.037186, 391.949493, 181.202423);
path.quadTo(391.949493, 219.091827, 418.588837, 219.091827);
path.quadTo(436.737549, 219.091827, 452.763611, 200.094055);
path.close();
path.moveTo(485.555908, 236.285355);
path.quadTo(464.541595, 242.65332, 449.576874, 242.65332);
path.quadTo(424.105011, 242.65332, 408.025879, 225.725143);
path.quadTo(391.946747, 208.796951, 391.946747, 181.839218);
path.quadTo(391.946747, 155.62442, 406.115479, 138.855438);
path.quadTo(420.28421, 122.086449, 442.359833, 122.086449);
path.quadTo(463.268005, 122.086449, 474.677277, 136.945038);
path.quadTo(486.086548, 151.803635, 486.086548, 179.185898);
path.lineTo(485.980438, 185.660004);
path.lineTo(413.279449, 185.660004);
path.quadTo(417.84317, 226.733398, 453.503784, 226.733398);
path.quadTo(466.558136, 226.733398, 485.555908, 219.728638);
path.lineTo(485.555908, 236.285355);
path.close();
path.moveTo(414.23465, 169.952347);
path.lineTo(465.072266, 169.952347);
path.quadTo(465.072266, 137.794098, 441.086243, 137.794098);
path.quadTo(416.99411, 137.794098, 414.23465, 169.952347);
path.close();
</div>
<div id="testQuadratic42s">
path.moveTo(342.521729, 138.855438);
path.quadTo(356.69046,122.086449, 378.766083,122.086449);
path.quadTo(390.293488,122.086449, 398.933502,126.603004);
path.quadTo(408.150299,122.192581, 419.544037,122.192581);
path.quadTo(425.108429,122.192581, 430.223633,123.496056);
path.quadTo(435.959412,122.086449, 442.359833,122.086449);
path.quadTo(451.19516,122.086449, 458.334229,124.739769);
path.lineTo(473.777893,124.739769);
path.lineTo(473.777893,135.814713);
path.quadTo(474.234741,136.368698, 474.677277,136.945038);
path.quadTo(486.086548,151.803635, 486.086548,179.185898);
path.lineTo(485.980438,185.660004);
path.lineTo(473.777893,185.660004);
path.lineTo(473.777893,208.584686);
path.quadTo(473.777893,216.745773, 473.522156,223.628113);
path.quadTo(479.207153,222.069519, 485.555908,219.728638);
path.lineTo(485.555908,236.285355);
path.quadTo(478.638306,238.381592, 472.376221,239.787796);
path.quadTo(471.792389,244.826782, 470.965363,248.649826);
path.quadTo(468.152863,261.651093, 460.405151,269.929443);
path.quadTo(446.71402,284.469666, 417.845886,284.469666);
path.quadTo(397.680664,284.469666, 379.213562,278.313934);
path.lineTo(381.654602,260.165222);
path.quadTo(399.803314,268.761993, 417.421356,268.761993);
path.quadTo(446.944275,268.761993, 451.80542,242.619034);
path.quadTo(450.674866,242.65332, 449.576874,242.65332);
path.quadTo(434.524628,242.65332, 422.75238,236.741913);
path.quadTo(420.864227,237.041901, 418.884674,237.193085);
path.quadTo(399.840271,242.65332, 385.983124,242.65332);
path.quadTo(360.511261,242.65332, 344.432129,225.725143);
path.quadTo(328.352997,208.796951, 328.352997,181.839218);
path.quadTo(328.352997,155.62442, 342.521729,138.855438);
path.close();
path.moveTo(383.823944, 138.443222);
path.quadTo(380.900299,137.794098, 377.492493,137.794098);
path.quadTo(353.40036,137.794098, 350.6409,169.952347);
path.lineTo(370.408203,169.952347);
path.quadTo(372.883484,151.469254, 383.565002,138.749298);
path.quadTo(383.694122,138.595551, 383.823944,138.443222);
path.close();
path.moveTo(369.740021, 185.660004);
path.lineTo(349.685699,185.660004);
path.quadTo(353.983734,224.342361, 385.863525,226.594208);
path.quadTo(383.762756,224.616837, 381.866882,222.275818);
path.quadTo(370.639954,208.41301, 369.740021,185.660004);
path.close();
path.moveTo(413.279449, 185.660004);
path.quadTo(415.737305,207.780716, 427.214905,217.987976);
path.quadTo(440.600586,214.512451, 452.763611,200.094055);
path.lineTo(452.763611,185.660004);
</div>
<div id="testQuadratic43o">
path.moveTo(288.755981, 240);
path.lineTo(288.755981, 102.232819);
path.lineTo(315.843994, 102.232819);
path.lineTo(354.009216, 208.816208);
path.lineTo(393.291473, 102.232819);
path.lineTo(417.493835, 102.232819);
path.lineTo(417.493835, 240);
path.lineTo(399.248962, 240);
path.lineTo(399.248962, 127.92453);
path.lineTo(361.269928, 230.784485);
path.lineTo(342.373474, 230.784485);
path.lineTo(305.511444, 127.645271);
path.lineTo(305.511444, 240);
path.lineTo(288.755981, 240);
path.close();
path.moveTo(397.864014, 236.741989);
path.quadTo(379.433014, 242.327148, 366.307892, 242.327148);
path.quadTo(343.967255, 242.327148, 329.864746, 227.479935);
path.quadTo(315.762238, 212.632736, 315.762238, 188.988907);
path.quadTo(315.762238, 165.996674, 328.189209, 151.289093);
path.quadTo(340.61618, 136.581512, 359.978058, 136.581512);
path.quadTo(378.315979, 136.581512, 388.322723, 149.613556);
path.quadTo(398.329468, 162.645584, 398.329468, 186.661758);
path.lineTo(398.236359, 192.339996);
path.lineTo(334.472504, 192.339996);
path.quadTo(338.475189, 228.364258, 369.752075, 228.364258);
path.quadTo(381.20163, 228.364258, 397.864014, 222.220581);
path.lineTo(397.864014, 236.741989);
path.close();
path.moveTo(335.310272, 178.563278);
path.lineTo(379.898438, 178.563278);
path.quadTo(379.898438, 150.358246, 358.861023, 150.358246);
path.quadTo(337.730499, 150.358246, 335.310272, 178.563278);
path.close();
path.moveTo(346.052765, 240);
path.lineTo(346.052765, 138.908661);
path.lineTo(364.390686, 138.908661);
path.lineTo(364.390686, 157.898193);
path.quadTo(375.281769, 136.674606, 396.039917, 136.674606);
path.quadTo(398.832489, 136.674606, 401.904327, 137.140045);
path.lineTo(401.904327, 154.267853);
path.quadTo(397.156952, 152.685394, 393.526611, 152.685394);
path.quadTo(376.119537, 152.685394, 364.390686, 173.350464);
path.lineTo(364.390686, 240);
path.lineTo(346.052765, 240);
path.close();
path.moveTo(362.792297, 273.604034);
path.lineTo(364.933289, 257.68634);
path.quadTo(380.850983, 265.226288, 396.303253, 265.226288);
path.quadTo(427.300842, 265.226288, 427.300842, 232.366959);
path.lineTo(427.300842, 216.449265);
path.quadTo(417.15448, 237.672852, 393.976105, 237.672852);
path.quadTo(375.824341, 237.672852, 365.119446, 224.454651);
path.quadTo(354.414581, 211.23645, 354.414581, 188.802734);
path.quadTo(354.414581, 165.717422, 366.608826, 151.196014);
path.quadTo(378.803101, 136.674606, 398.164948, 136.674606);
path.quadTo(415.106598, 136.674606, 427.300842, 150.451324);
path.lineTo(427.300842, 138.908661);
path.lineTo(445.731873, 138.908661);
path.lineTo(445.731873, 212.446564);
path.quadTo(445.731873, 236.183472, 443.265106, 247.586502);
path.quadTo(440.798309, 258.989532, 434.003052, 266.250244);
path.quadTo(421.994965, 279.002991, 396.675598, 279.002991);
path.quadTo(378.989258, 279.002991, 362.792297, 273.604034);
path.close();
path.moveTo(427.300842, 204.999695);
path.lineTo(427.300842, 163.017929);
path.quadTo(415.199677, 150.451324, 400.95755, 150.451324);
path.quadTo(388.297852, 150.451324, 381.130249, 160.597687);
path.quadTo(373.962616, 170.744064, 373.962616, 188.430389);
path.quadTo(373.962616, 221.662079, 397.327179, 221.662079);
path.quadTo(413.244873, 221.662079, 427.300842, 204.999695);
path.close();
path.moveTo(461.457764, 236.741989);
path.quadTo(443.026764, 242.327148, 429.901642, 242.327148);
path.quadTo(407.561005, 242.327148, 393.458496, 227.479935);
path.quadTo(379.355988, 212.632736, 379.355988, 188.988907);
path.quadTo(379.355988, 165.996674, 391.782959, 151.289093);
path.quadTo(404.20993, 136.581512, 423.571808, 136.581512);
path.quadTo(441.909729, 136.581512, 451.916473, 149.613556);
path.quadTo(461.923218, 162.645584, 461.923218, 186.661758);
path.lineTo(461.830109, 192.339996);
path.lineTo(398.066254, 192.339996);
path.quadTo(402.068939, 228.364258, 433.345825, 228.364258);
path.quadTo(444.79538, 228.364258, 461.457764, 222.220581);
path.lineTo(461.457764, 236.741989);
path.close();
path.moveTo(398.904022, 178.563278);
path.lineTo(443.492188, 178.563278);
path.quadTo(443.492188, 150.358246, 422.454773, 150.358246);
path.quadTo(401.324249, 150.358246, 398.904022, 178.563278);
path.close();
</div>
<div id="testQuadratic43s">
path.moveTo(288.755981, 240);
path.lineTo(288.755981,102.232819);
path.lineTo(315.843994,102.232819);
path.lineTo(331.979736,147.294876);
path.quadTo(343.453125,136.581512, 359.978058,136.581512);
path.quadTo(370.869446,136.581512, 378.822021,141.178574);
path.quadTo(378.893585,141.140915, 378.965302,141.103577);
path.lineTo(393.291473,102.232819);
path.lineTo(417.493835,102.232819);
path.lineTo(417.493835,136.965759);
path.quadTo(420.44223,136.581512, 423.571808,136.581512);
path.quadTo(431.320984,136.581512, 437.582458,138.908661);
path.lineTo(445.731873,138.908661);
path.lineTo(445.731873,143.392502);
path.quadTo(449.143951,146.002823, 451.916473,149.613556);
path.quadTo(461.923218,162.645584, 461.923218,186.661758);
path.lineTo(461.830109,192.339996);
path.lineTo(445.731873,192.339996);
path.lineTo(445.731873,212.446564);
path.quadTo(445.731873,220.39856, 445.455017,226.966339);
path.quadTo(452.7435,225.43367, 461.457764,222.220581);
path.lineTo(461.457764,236.741989);
path.quadTo(452.250824,239.531982, 444.367889,240.928268);
path.quadTo(443.897583,244.662796, 443.265106,247.586502);
path.quadTo(440.798309,258.989532, 434.003052,266.250244);
path.quadTo(421.994965,279.002991, 396.675598,279.002991);
path.quadTo(378.989258,279.002991, 362.792297,273.604034);
path.lineTo(364.933289,257.68634);
path.quadTo(380.850983,265.226288, 396.303253,265.226288);
path.quadTo(422.230743,265.226288, 426.471558,242.237076);
path.quadTo(419.570892,241.869324, 413.503387,240);
path.lineTo(399.248962,240);
path.lineTo(399.248962,237.37915);
path.quadTo(397.047638,237.633072, 394.711517,237.667465);
path.quadTo(378.296356,242.327148, 366.307892,242.327148);
path.quadTo(357.463165,242.327148, 349.909637,240);
path.lineTo(346.052765,240);
path.lineTo(346.052765,238.625916);
path.quadTo(336.926056,234.914124, 329.864746,227.479935);
path.quadTo(315.762238,212.632736, 315.762238,188.988907);
path.quadTo(315.762238,176.540054, 319.405273,166.519882);
path.lineTo(305.511444,127.645271);
path.lineTo(305.511444,240);
path.lineTo(288.755981,240);
path.close();
path.moveTo(375.464813, 192.339996);
path.lineTo(374.267029,195.583939);
path.quadTo(375.987579,214.575378, 387.432068,219.736267);
path.quadTo(380.122528,208.101486, 379.428741,192.339996);
path.lineTo(375.464813,192.339996);
path.close();
path.moveTo(427.300842, 178.563278);
path.lineTo(427.300842,163.017929);
path.quadTo(422.561523,158.096329, 417.493835,155.102234);
path.lineTo(417.493835,178.563278);
path.lineTo(427.300842,178.563278);
path.close();
path.moveTo(427.300842, 192.339996);
path.lineTo(417.493835,192.339996);
path.lineTo(417.493835,214.429169);
path.quadTo(422.505676,210.684036, 427.300842,204.999695);
path.lineTo(427.300842,192.339996);
path.close();
path.moveTo(420.700134, 226.556015);
path.quadTo(423.794342,227.54834, 427.300842,227.996094);
path.lineTo(427.300842,216.449265);
path.quadTo(424.497772,222.312531, 420.700134,226.556015);
path.close();
path.moveTo(368.744965, 228.354782);
path.quadTo(366.836426,226.574738, 365.119446,224.454651);
path.quadTo(364.748657,223.996796, 364.390686,223.527878);
path.lineTo(364.390686,228.077774);
path.quadTo(366.495239,228.312164, 368.744965,228.354782);
path.close();
path.moveTo(399.248962, 199.701065);
path.lineTo(399.248962,192.339996);
path.lineTo(398.236359,192.339996);
path.lineTo(398.066254,192.339996);
path.quadTo(398.498535,196.230621, 399.248962,199.701065);
path.close();
path.moveTo(399.248962, 178.563278);
path.lineTo(399.248962,175.376892);
path.quadTo(399.04483,176.922348, 398.904022,178.563278);
path.lineTo(399.248962,178.563278);
path.close();
path.moveTo(399.248962, 136.688828);
path.lineTo(399.248962,127.92453);
path.lineTo(396.018158,136.674606);
path.quadTo(396.029053,136.674606, 396.039917,136.674606);
path.quadTo(396.513672,136.674606, 396.995453,136.688004);
path.quadTo(397.576904,136.674606, 398.164948,136.674606);
path.quadTo(398.709412,136.674606, 399.248962,136.688828);
path.close();
path.moveTo(346.052765, 178.563278);
path.lineTo(346.052765,154.02713);
path.quadTo(340.97113,157.621338, 338.22525,164.736588);
path.lineTo(343.1763,178.563278);
path.lineTo(346.052765,178.563278);
path.close();
path.moveTo(364.390686, 150.922379);
path.lineTo(364.390686,154.048065);
path.quadTo(365.340851,152.726639, 366.38147,151.468765);
path.quadTo(365.420258,151.14975, 364.390686,150.922379);
path.close();
path.moveTo(367.863586, 152.032623);
path.quadTo(367.144043,151.721848, 366.38147,151.468765);
</div>
<div id="testQuadratic44o">
path.moveTo(354.009216, 208.816208);
path.lineTo(393.291473, 102.232819);
path.lineTo(399.248962, 127.92453);
path.lineTo(361.269928, 230.784485);
path.lineTo(354.009216, 208.816208);
path.close();
path.moveTo(328.189209, 151.289093);
path.quadTo(340.61618, 136.581512, 359.978058, 136.581512);
path.quadTo(378.315979, 136.581512, 388.322723, 149.613556);
path.lineTo(328.189209, 151.289093);
path.close();
path.moveTo(346.052765, 138.908661);
path.lineTo(364.390686, 138.908661);
path.lineTo(364.390686, 157.898193);
path.quadTo(375.281769, 136.674606, 396.039917, 136.674606);
path.lineTo(346.052765, 138.908661);
path.close();
</div>
<div id="testQuadratic44s">
path.moveTo(380.33902, 137.376312);
path.lineTo(393.291473,102.232819);
path.lineTo(399.248962,127.92453);
path.lineTo(396.018158,136.674606);
path.quadTo(396.029053,136.674606, 396.039917,136.674606);
path.lineTo(396.017792,136.675598);
path.lineTo(361.269928,230.784485);
path.lineTo(354.009216,208.816208);
path.lineTo(375.699249,149.965286);
path.lineTo(369.22699,150.14563);
path.quadTo(373.524384,144.511566, 378.917297,141.233871);
path.lineTo(380.33902,137.376312);
path.close();
path.moveTo(380.33902, 137.376312);
path.lineTo(378.917297,141.233856);
path.quadTo(375.048248,138.978912, 370.480499,137.816925);
path.lineTo(380.33902,137.376312);
path.close();
path.moveTo(392.55661, 136.830276);
path.lineTo(380.33902,137.376312);
</div>
<div id="testQuadratic45o">
path.moveTo(315.843994, 102.232819);
path.lineTo(354.009216, 208.816208);
path.lineTo(393.291473, 102.232819);
path.lineTo(399.248962, 127.92453);
path.lineTo(361.269928, 230.784485);
path.lineTo(342.373474, 230.784485);
path.lineTo(305.511444, 127.645271);
path.lineTo(315.843994, 102.232819);
path.close();
path.moveTo(366.307892, 242.327148);
path.quadTo(343.967255, 242.327148, 329.864746, 227.479935);
path.quadTo(315.762238, 212.632736, 315.762238, 188.988907);
path.quadTo(315.762238, 165.996674, 328.189209, 151.289093);
path.quadTo(340.61618, 136.581512, 359.978058, 136.581512);
path.quadTo(378.315979, 136.581512, 388.322723, 149.613556);
path.quadTo(398.329468, 162.645584, 398.329468, 186.661758);
path.lineTo(398.236359, 192.339996);
path.lineTo(334.472504, 192.339996);
path.quadTo(338.475189, 228.364258, 369.752075, 228.364258);
path.quadTo(381.20163, 228.364258, 397.864014, 222.220581);
path.lineTo(366.307892, 242.327148);
path.close();
path.moveTo(335.310272, 178.563278);
path.lineTo(379.898438, 178.563278);
path.quadTo(379.898438, 150.358246, 358.861023, 150.358246);
path.quadTo(337.730499, 150.358246, 335.310272, 178.563278);
path.close();
path.moveTo(346.052765, 240);
path.lineTo(346.052765, 138.908661);
path.lineTo(364.390686, 138.908661);
path.lineTo(364.390686, 157.898193);
path.quadTo(375.281769, 136.674606, 396.039917, 136.674606);
path.lineTo(401.904327, 154.267853);
path.quadTo(397.156952, 152.685394, 393.526611, 152.685394);
path.quadTo(376.119537, 152.685394, 364.390686, 173.350464);
path.lineTo(364.390686, 240);
path.lineTo(346.052765, 240);
path.close();
path.moveTo(396.303253, 265.226288);
path.quadTo(427.300842, 265.226288, 427.300842, 232.366959);
path.lineTo(427.300842, 216.449265);
path.quadTo(417.15448, 237.672852, 393.976105, 237.672852);
path.quadTo(375.824341, 237.672852, 365.119446, 224.454651);
path.quadTo(354.414581, 211.23645, 354.414581, 188.802734);
path.quadTo(354.414581, 165.717422, 366.608826, 151.196014);
path.quadTo(378.803101, 136.674606, 398.164948, 136.674606);
path.lineTo(396.303253, 265.226288);
path.close();
path.moveTo(400.95755, 150.451324);
path.quadTo(388.297852, 150.451324, 381.130249, 160.597687);
path.quadTo(373.962616, 170.744064, 373.962616, 188.430389);
path.quadTo(373.962616, 221.662079, 397.327179, 221.662079);
path.lineTo(400.95755, 150.451324);
path.close();
path.moveTo(429.901642, 242.327148);
path.quadTo(407.561005, 242.327148, 393.458496, 227.479935);
path.quadTo(379.355988, 212.632736, 379.355988, 188.988907);
path.quadTo(379.355988, 165.996674, 391.782959, 151.289093);
path.quadTo(404.20993, 136.581512, 423.571808, 136.581512);
path.lineTo(429.901642, 242.327148);
path.close();
</div>
<div id="testQuadratic45s">
path.moveTo(305.511444, 127.645271);
path.lineTo(315.843994,102.232819);
path.lineTo(331.979736,147.294876);
path.quadTo(343.453125,136.581512, 359.978058,136.581512);
path.quadTo(370.869446,136.581512, 378.822021,141.178574);
path.quadTo(378.893585,141.140915, 378.965302,141.103577);
path.lineTo(393.291473,102.232819);
path.lineTo(399.248962,127.92453);
path.lineTo(396.018158,136.674606);
path.quadTo(396.029053,136.674606, 396.039917,136.674606);
path.lineTo(396.054596,136.718628);
path.quadTo(397.098907,136.674606, 398.164948,136.674606);
path.lineTo(398.076477,142.784256);
path.lineTo(398.697632,144.647751);
path.quadTo(409.233032,136.581512, 423.571808,136.581512);
path.lineTo(429.901642,242.327148);
path.quadTo(428.161621,242.327148, 426.471558,242.237076);
path.quadTo(427.300842,237.741562, 427.300842,232.366959);
path.lineTo(427.300842,216.449265);
path.quadTo(419.710114,232.327133, 404.8255,236.326401);
path.quadTo(400.557983,233.971252, 396.803375,230.691772);
path.lineTo(396.7034,237.596863);
path.quadTo(395.363068,237.672852, 393.976105,237.672852);
path.quadTo(385.309937,237.672852, 378.341187,234.659912);
path.lineTo(366.307892,242.327148);
path.quadTo(357.463165,242.327148, 349.909637,240);
path.lineTo(346.052765,240);
path.lineTo(346.052765,238.625916);
path.quadTo(336.926056,234.914124, 329.864746,227.479935);
path.quadTo(315.762238,212.632736, 315.762238,188.988907);
path.quadTo(315.762238,176.540054, 319.405273,166.519882);
path.lineTo(305.511444,127.645271);
path.close();
path.moveTo(375.464813, 192.339996);
path.lineTo(374.267029,195.583939);
path.quadTo(375.987579,214.575378, 387.432068,219.736267);
path.quadTo(380.122528,208.101486, 379.428741,192.339996);
path.lineTo(375.464813,192.339996);
path.close();
path.moveTo(397.925934, 153.178131);
path.lineTo(397.615479,174.615356);
path.quadTo(398.329468,180.246704, 398.329468,186.661758);
path.lineTo(398.236359,192.339996);
path.lineTo(397.358795,192.339996);
path.lineTo(396.934174,221.659714);
path.quadTo(397.129852,221.662079, 397.327179,221.662079);
path.lineTo(400.781189,153.910889);
path.quadTo(399.295654,153.462463, 397.925934,153.178131);
path.close();
path.moveTo(400.914398, 151.298019);
path.lineTo(400.632721,150.453003);
path.quadTo(400.794678,150.451324, 400.95755,150.451324);
path.lineTo(400.914398,151.298019);
path.close();
path.moveTo(368.744965, 228.354782);
path.quadTo(366.836426,226.574738, 365.119446,224.454651);
path.quadTo(364.748657,223.996796, 364.390686,223.527878);
path.lineTo(364.390686,228.077774);
path.quadTo(366.495239,228.312164, 368.744965,228.354782);
path.close();
path.moveTo(346.052765, 178.563278);
path.lineTo(346.052765,154.02713);
path.quadTo(340.97113,157.621338, 338.22525,164.736588);
path.lineTo(343.1763,178.563278);
path.lineTo(346.052765,178.563278);
path.close();
path.moveTo(364.390686, 150.922379);
path.lineTo(364.390686,154.048065);
path.quadTo(365.340851,152.726639, 366.38147,151.468765);
path.quadTo(365.420258,151.14975, 364.390686,150.922379);
path.close();
path.moveTo(367.863586, 152.032623);
path.quadTo(367.144043,151.721848, 366.38147,151.468765);
</div>
<div id="testQuadratic46o">
path.moveTo(366.608826, 151.196014);
path.quadTo(378.803101, 136.674606, 398.164948, 136.674606);
path.lineTo(354.009216, 208.816208);
path.lineTo(393.291473, 102.232819);
path.lineTo(359.978058, 136.581512);
path.quadTo(378.315979, 136.581512, 388.322723, 149.613556);
path.lineTo(364.390686, 157.898193);
path.quadTo(375.281769, 136.674606, 396.039917, 136.674606);
path.lineTo(350, 120);
path.lineTo(366.608826, 151.196014);
path.close();
</div>
<div id="testQuadratic46s">
path.moveTo(369.285553, 126.984779);
path.lineTo(393.291473,102.232819);
path.lineTo(382.416199,131.740402);
path.lineTo(396.039917,136.674606);
path.quadTo(387.290802,136.674606, 380.294495,140.44487);
path.quadTo(379.623352,140.760971, 378.965302,141.103577);
path.lineTo(378.917297,141.233856);
path.quadTo(378.86972,141.206131, 378.822021,141.178574);
path.quadTo(372.011871,144.761871, 366.608826,151.196014);
path.lineTo(350,120);
path.lineTo(369.285553,126.984779);
path.close();
path.moveTo(374.00174, 154.571106);
path.lineTo(378.917297,141.233871);
path.quadTo(378.917297,141.233871, 378.917297,141.233856);
path.quadTo(384.294891,144.368011, 388.322723,149.613556);
path.lineTo(374.00174,154.571106);
path.close();
path.moveTo(378.917297, 141.233871);
path.quadTo(370.233887,146.511475, 364.390686,157.898193);
path.lineTo(374.00174,154.571106);
path.lineTo(354.009216,208.816208);
path.lineTo(398.164948,136.674606);
path.quadTo(388.299255,136.674606, 380.294495,140.44487);
</div>
<div id="testQuadratic47o">
path.moveTo(343.939362, 212.598053);
path.lineTo(378.457642, 118.940636);
path.lineTo(383.692657, 141.516571);
path.lineTo(350.319519, 231.902115);
path.lineTo(343.939362, 212.598053);
path.close();
path.moveTo(325.429016, 162.047577);
path.quadTo(336.348907, 149.123688, 353.36264, 149.123688);
path.quadTo(369.476624, 149.123688, 378.269806, 160.575241);
path.lineTo(325.429016, 162.047577);
path.close();
path.moveTo(370.867188, 186.014069);
path.quadTo(370.867188, 161.229614, 352.381104, 161.229614);
path.quadTo(333.813202, 161.229614, 331.686493, 186.014069);
path.lineTo(370.867188, 186.014069);
path.close();
path.moveTo(353.161499, 195.011719);
path.quadTo(353.161499, 174.726105, 363.876862, 161.96579);
path.lineTo(353.161499, 195.011719);
path.close();
</div>
<div id="testQuadratic47s">
path.moveTo(366.466309, 151.476364);
path.lineTo(378.457642,118.940636);
path.lineTo(383.692657,141.516571);
path.lineTo(377.159943,159.209305);
path.quadTo(377.728729,159.87059, 378.269806,160.575241);
path.lineTo(376.638824,160.620682);
path.lineTo(370.26593,177.8806);
path.quadTo(368.708496,168.390671, 363.116943,164.309357);
path.lineTo(356.079041,186.014069);
path.lineTo(367.262817,186.014069);
path.lineTo(350.319519,231.902115);
path.lineTo(343.939362,212.598053);
path.lineTo(353.736816,186.014923);
path.lineTo(353.737122,186.014069);
path.lineTo(353.736938,186.014069);
path.quadTo(353.736877,186.014496, 353.736816,186.014923);
path.quadTo(353.161499,190.31131, 353.161499,195.011719);
</div>
<div id="testQuadratic48o">
path.moveTo(366.608826, 151.196014);
path.quadTo(378.803101, 136.674606, 398.164948, 136.674606);
path.lineTo(354.009216, 208.816208);
path.lineTo(393.291473, 102.232819);
path.lineTo(359.978058, 136.581512);
path.quadTo(378.315979, 136.581512, 388.322723, 149.613556);
path.lineTo(364.390686, 157.898193);
path.quadTo(375.281769, 136.674606, 396.039917, 136.674606);
path.lineTo(350, 120);
path.lineTo(366.608826, 151.196014);
path.close();
</div>
<div id="testQuadratic48s">
path.moveTo(369.285553, 126.984779);
path.lineTo(393.291473,102.232819);
path.lineTo(382.416199,131.740402);
path.lineTo(396.039917,136.674606);
path.quadTo(387.290802,136.674606, 380.294495,140.44487);
path.quadTo(379.623352,140.760971, 378.965302,141.103577);
path.lineTo(378.917297,141.233856);
path.quadTo(378.86972,141.206131, 378.822021,141.178574);
path.quadTo(372.011871,144.761871, 366.608826,151.196014);
path.lineTo(350,120);
path.lineTo(369.285553,126.984779);
path.close();
</div>
<div id="testQuadratic49s">
path.moveTo(366.400513, 204.162521);
path.lineTo(411.545044, 81.6732483);
path.lineTo(366.400513, 204.162521);
path.close();
path.moveTo(331.585693, 138.050415);
path.quadTo(345.867188, 121.147957, 368.11853, 121.147957);
path.quadTo(389.193115, 121.147957, 400.693176, 136.124817);
path.lineTo(331.585693, 138.050415);
path.close();
path.moveTo(369.863983, 145.645813);
path.quadTo(382.380371, 121.254936, 406.236359, 121.254936);
path.lineTo(369.863983, 145.645813);
path.close();
path.moveTo(369.970581, 137.94342);
path.quadTo(383.98465, 121.254936, 406.235992, 121.254936);
path.lineTo(369.970581, 137.94342);
path.close();
</div>
<div id="testQuadratic50o">
path.moveTo(366.400513, 204.162521);
path.lineTo(411.545044, 81.6732483);
path.lineTo(366.400513, 204.162521);
path.close();
path.moveTo(331.585693, 138.050415);
path.quadTo(345.867188, 121.147957, 368.11853, 121.147957);
path.quadTo(389.193115, 121.147957, 400.693176, 136.124817);
path.lineTo(331.585693, 138.050415);
path.close();
path.moveTo(369.863983, 145.645813);
path.quadTo(382.380371, 121.254936, 406.236359, 121.254936);
path.lineTo(369.863983, 145.645813);
path.close();
path.moveTo(369.970581, 137.94342);
path.quadTo(383.98465, 121.254936, 406.235992, 121.254936);
path.lineTo(369.970581, 137.94342);
path.close();
</div>
<div id="testQuadratic50s">
path.moveTo(331.585693, 138.050415);
path.quadTo(345.867188,121.147957, 368.11853,121.147957);
path.quadTo(378.797424,121.147957, 387.017914,124.993469);
path.quadTo(391.577667,123.030998, 396.645874,122.098694);
path.quadTo(401.232697,121.254936, 406.235992,121.254936);
path.lineTo(395.061676,126.397095);
path.lineTo(391.979187,127.81559);
path.quadTo(393.010406,128.517273, 393.994415,129.292801);
path.quadTo(394.053131,129.339066, 394.111664,129.385605);
path.lineTo(393.910492,129.520508);
path.lineTo(383.340973,136.608322);
path.lineTo(375.350006,136.830978);
path.quadTo(376.20224,135.708145, 377.092102,134.66626);
path.lineTo(372.197113,136.918823);
</div>
<div id="testQuadratic51">
path.moveTo(369.863983, 145.645813);
path.quadTo(382.380371, 121.254936, 406.236359, 121.254936);
path.lineTo(369.863983, 145.645813);
path.close();
path.moveTo(369.970581, 137.94342);
path.quadTo(383.98465, 121.254936, 406.235992, 121.254936);
path.lineTo(369.970581, 137.94342);
path.close();
</div>
<div id="testQuadratic52o">
path.moveTo(366.400513, 204.162521);
path.lineTo(411.545044, 81.6732483);
path.lineTo(366.400513, 204.162521);
path.close();
path.moveTo(331.585693, 138.050415);
path.quadTo(345.867188, 121.147957, 368.11853, 121.147957);
path.quadTo(389.193115, 121.147957, 400.693176, 136.124817);
path.lineTo(331.585693, 138.050415);
path.close();
path.moveTo(369.863983, 145.645813);
path.quadTo(382.380371, 121.254936, 406.236359, 121.254936);
path.lineTo(369.863983, 145.645813);
path.close();
path.moveTo(369.970581, 137.94342);
path.quadTo(383.98465, 121.254936, 406.235992, 121.254936);
path.lineTo(369.970581, 137.94342);
path.close();
</div>
<div id="testQuadratic52s">
path.moveTo(331.585693, 138.050415);
path.quadTo(345.867188,121.147957, 368.11853,121.147957);
path.quadTo(378.797424,121.147957, 387.017914,124.993469);
path.quadTo(391.577667,123.030998, 396.645874,122.098694);
path.quadTo(401.232697,121.254936, 406.235992,121.254936);
path.close();
path.moveTo(383.340973, 136.608322);
path.lineTo(369.863983,145.645813);
path.quadTo(372.378204,140.746292, 375.350006,136.830978);
path.lineTo(372.197113,136.918823);
path.lineTo(369.970581,137.94342);
path.quadTo(370.390961,137.442825, 370.818756,136.95723);
path.lineTo(331.585693,138.050415);
path.quadTo(345.867188,121.147957, 368.11853,121.147957);
path.quadTo(378.797424,121.147957, 387.017914,124.993469);
path.quadTo(391.577667,123.030998, 396.645874,122.098694);
path.quadTo(401.232697,121.254936, 406.235992,121.254936);
path.close();
path.moveTo(383.340973, 136.608322);
path.lineTo(391.380798,136.384293);
path.lineTo(400.693176,136.124817);
path.quadTo(397.721985,132.255341, 394.111664,129.385605);
path.lineTo(406.236359,121.254936);
path.quadTo(406.236176,121.254936, 406.235992,121.254936);
path.lineTo(406.235992,121.254936);
path.quadTo(401.232697,121.254936, 396.645874,122.098694);
path.quadTo(391.577667,123.030998, 387.017914,124.993469);
path.quadTo(378.797424,121.147957, 368.11853,121.147957);
path.quadTo(345.867188,121.147957, 331.585693,138.050415);
path.lineTo(370.818756,136.95723);
path.quadTo(370.390961,137.442825, 369.970581,137.94342);
path.lineTo(372.197113,136.918823);
path.lineTo(375.350006,136.830978);
path.quadTo(372.378204,140.746292, 369.863983,145.645813);
path.lineTo(383.340973,136.608322);
path.close();
</div>
<div id="testQuadratic52sa">
path.moveTo(331.585693, 138.050415);
path.quadTo(345.867188,121.147957, 368.11853,121.147957);
path.quadTo(378.797424,121.147957, 387.017914,124.993469);
path.quadTo(391.577667,123.030998, 396.645874,122.098694);
path.quadTo(401.232697,121.254936, 406.235992,121.254936);
path.close();
</div>
<div id="testQuadratic52sb">
path.moveTo(383.340973, 136.608322);
path.lineTo(369.863983,145.645813);
path.quadTo(372.378204,140.746292, 375.350006,136.830978);
path.lineTo(372.197113,136.918823);
path.lineTo(369.970581,137.94342);
path.quadTo(370.390961,137.442825, 370.818756,136.95723);
path.lineTo(331.585693,138.050415);
path.quadTo(345.867188,121.147957, 368.11853,121.147957);
path.quadTo(378.797424,121.147957, 387.017914,124.993469);
path.quadTo(391.577667,123.030998, 396.645874,122.098694);
path.quadTo(401.232697,121.254936, 406.235992,121.254936);
path.close();
</div>
<div id="testQuadratic52sc">
path.moveTo(383.340973, 136.608322);
path.lineTo(391.380798,136.384293);
path.lineTo(400.693176,136.124817);
path.quadTo(397.721985,132.255341, 394.111664,129.385605);
path.lineTo(406.236359,121.254936);
path.quadTo(406.236176,121.254936, 406.235992,121.254936);
path.lineTo(406.235992,121.254936);
path.quadTo(401.232697,121.254936, 396.645874,122.098694);
path.quadTo(391.577667,123.030998, 387.017914,124.993469);
path.quadTo(378.797424,121.147957, 368.11853,121.147957);
path.quadTo(345.867188,121.147957, 331.585693,138.050415);
path.lineTo(370.818756,136.95723);
path.quadTo(370.390961,137.442825, 369.970581,137.94342);
path.lineTo(372.197113,136.918823);
path.lineTo(375.350006,136.830978);
path.quadTo(372.378204,140.746292, 369.863983,145.645813);
path.lineTo(383.340973,136.608322);
path.close();
</div>
<div id="testQuadratic53o">
path.moveTo(303.12088, 141.299606);
path.lineTo(330.463562, 217.659027);
path.lineTo(303.12088, 141.299606);
path.close();
path.moveTo(371.919067, 205.854996);
path.lineTo(326.236786, 205.854996);
path.quadTo(329.104431, 231.663818, 351.512085, 231.663818);
path.lineTo(371.919067, 205.854996);
path.close();
</div>
<div id="testQuadratic53s">
path.moveTo(326.236786,205.854996);
path.lineTo(326.236786,205.854996);
path.close();
path.moveTo(371.919067,205.854996);
path.lineTo(326.236786,205.854996);
</div>
<div id="testQuadratic54">
path.moveTo(303.12088, 141.299606);
path.lineTo(330.463562, 217.659027);
path.lineTo(358.606506, 141.299606);
path.lineTo(303.12088, 141.299606);
path.close();
path.moveTo(371.919067, 205.854996);
path.lineTo(326.236786, 205.854996);
path.quadTo(329.104431, 231.663818, 351.512085, 231.663818);
path.lineTo(371.919067, 205.854996);
path.close();
</div>
<div id="testQuadratic55o">
path.moveTo(303.12088, 141.299606);
path.lineTo(330.463562, 217.659027);
path.lineTo(358.606506, 141.299606);
path.lineTo(303.12088, 141.299606);
path.close();
path.moveTo(326.236786, 205.854996);
path.quadTo(329.104431, 231.663818, 351.512085, 231.663818);
path.lineTo(326.236786, 205.854996);
path.close();
</div>
<div id="testQuadratic55s">
path.moveTo(326.236786,205.854996);
path.lineTo(303.12088,141.299606);
path.lineTo(358.606506,141.299606);
path.lineTo(332.468719,212.218475);
path.lineTo(351.512085,231.663818);
path.quadTo(329.104431,231.663818, 326.236786,205.854996);
path.close();
</div>
<div id="testQuadratic56o">
path.moveTo(366.608826, 151.196014);
path.quadTo(378.803101, 136.674606, 398.164948, 136.674606);
path.lineTo(354.009216, 208.816208);
path.lineTo(393.291473, 102.232819);
path.lineTo(359.978058, 136.581512);
path.quadTo(378.315979, 136.581512, 388.322723, 149.613556);
path.lineTo(364.390686, 157.898193);
path.quadTo(375.281769, 136.674606, 396.039917, 136.674606);
path.lineTo(350, 120);
path.lineTo(366.608826, 151.196014);
path.close();
</div>
<div id="testQuadratic56s">
path.moveTo(369.285553,126.984779);
path.lineTo(393.291473,102.232819);
path.lineTo(382.416199,131.740402);
path.lineTo(396.039917,136.674606);
path.quadTo(387.290802,136.674606, 380.294495,140.44487);
path.quadTo(379.623352,140.760971, 378.965302,141.103577);
path.lineTo(378.917297,141.233856);
path.quadTo(378.86972,141.206131, 378.822021,141.178574);
path.quadTo(372.011871,144.761871, 366.608826,151.196014);
path.lineTo(350,120);
path.lineTo(369.285553,126.984779);
path.close();
path.moveTo(378.917297,141.233871);
path.lineTo(378.917297,141.233856);
path.quadTo(378.86972,141.206131, 378.822021,141.178574);
path.quadTo(372.011871,144.761871, 366.608826,151.196014);
</div>
<div id="testQuadratic57o">
path.moveTo(303.12088, 141.299606);
path.lineTo(330.463562, 217.659027);
path.lineTo(358.606506, 141.299606);
path.lineTo(362.874634, 159.705902);
path.lineTo(335.665344, 233.397751);
path.lineTo(322.12738, 233.397751);
path.lineTo(295.718353, 159.505829);
path.lineTo(295.718353, 240);
path.lineTo(303.12088, 141.299606);
path.close();
path.moveTo(322.935669, 231.030273);
path.quadTo(312.832214, 220.393295, 312.832214, 203.454178);
path.quadTo(312.832214, 186.981888, 321.73526, 176.444946);
path.quadTo(330.638306, 165.90802, 344.509705, 165.90802);
path.lineTo(371.919067, 205.854996);
path.lineTo(326.236786, 205.854996);
path.quadTo(329.104431, 231.663818, 351.512085, 231.663818);
path.lineTo(322.935669, 231.030273);
path.close();
path.moveTo(326.837006, 195.984955);
path.lineTo(358.78125, 195.984955);
path.lineTo(343.709442, 175.778046);
path.quadTo(328.570923, 175.778046, 326.837006, 195.984955);
path.close();
</div>
<div id="testQuadratic57s">
path.moveTo(300.708282,173.46756);
path.lineTo(303.12088,141.299606);
path.lineTo(317.770294,182.210785);
path.quadTo(319.462738,179.134506, 321.73526,176.444946);
path.quadTo(330.638306,165.90802, 344.509705,165.90802);
path.lineTo(347.780151,170.674438);
path.lineTo(358.606506,141.299606);
path.lineTo(362.874634,159.705902);
path.lineTo(354.960693,181.139511);
path.lineTo(371.919067,205.854996);
path.lineTo(345.834961,205.854996);
path.lineTo(337.609253,228.13298);
path.quadTo(342.649323,231.302383, 349.843323,231.626816);
path.lineTo(336.429047,231.329422);
path.lineTo(335.665344,233.397751);
path.lineTo(322.12738,233.397751);
path.lineTo(320.050781,227.587433);
path.quadTo(313.982483,219.336182, 313.015503,207.902908);
path.lineTo(300.708282,173.46756);
path.close();
path.moveTo(300.708282,173.46756);
path.lineTo(295.718353,240);
path.lineTo(295.718353,159.505829);
path.lineTo(300.708282,173.46756);
path.close();
path.moveTo(349.843323,231.626816);
path.lineTo(351.512085,231.663818);
path.quadTo(350.663696,231.663818, 349.843323,231.626816);
path.close();
path.moveTo(326.236786,205.854996);
path.lineTo(330.463562,217.659027);
path.lineTo(334.814056,205.854996);
path.lineTo(326.236786,205.854996);
path.close();
path.moveTo(334.814056,205.854996);
path.lineTo(338.451721,195.984955);
path.lineTo(349.479309,195.984955);
path.lineTo(352.559326,187.643173);
path.lineTo(358.78125,195.984955);
</div>
<div id="testQuadratic58o">
path.moveTo(283.714233, 240);
path.lineTo(283.714233, 141.299606);
path.lineTo(303.12088, 141.299606);
path.lineTo(330.463562, 217.659027);
path.lineTo(358.606506, 141.299606);
path.lineTo(362.874634, 159.705902);
path.lineTo(335.665344, 233.397751);
path.lineTo(322.12738, 233.397751);
path.lineTo(295.718353, 159.505829);
path.lineTo(295.718353, 240);
path.lineTo(283.714233, 240);
path.close();
path.moveTo(322.935669, 231.030273);
path.quadTo(312.832214, 220.393295, 312.832214, 203.454178);
path.quadTo(312.832214, 186.981888, 321.73526, 176.444946);
path.quadTo(330.638306, 165.90802, 344.509705, 165.90802);
path.quadTo(357.647522, 165.90802, 364.81665, 175.244537);
path.lineTo(371.919067, 205.854996);
path.lineTo(326.236786, 205.854996);
path.quadTo(329.104431, 231.663818, 351.512085, 231.663818);
path.lineTo(322.935669, 231.030273);
path.close();
path.moveTo(326.837006, 195.984955);
path.lineTo(358.78125, 195.984955);
path.quadTo(358.78125, 175.778046, 343.709442, 175.778046);
path.quadTo(328.570923, 175.778046, 326.837006, 195.984955);
path.close();
</div>
<div id="testQuadratic58s">
path.moveTo(283.714233,240);
path.lineTo(283.714233,141.299606);
path.lineTo(303.12088,141.299606);
path.lineTo(317.770294,182.210785);
path.quadTo(319.462738,179.134506, 321.73526,176.444946);
path.quadTo(330.638306,165.90802, 344.509705,165.90802);
path.quadTo(347.07132,165.90802, 349.406036,166.26297);
path.lineTo(358.606506,141.299606);
path.lineTo(362.874634,159.705902);
path.lineTo(359.116211,169.884979);
path.quadTo(362.326477,172.001541, 364.81665,175.244537);
path.lineTo(371.919067,205.854996);
path.lineTo(345.834961,205.854996);
path.lineTo(337.609253,228.13298);
path.quadTo(342.649323,231.302383, 349.843323,231.626816);
path.lineTo(336.429047,231.329422);
path.lineTo(335.665344,233.397751);
path.lineTo(322.12738,233.397751);
path.lineTo(320.050781,227.587433);
path.quadTo(313.982483,219.336182, 313.015503,207.902908);
path.lineTo(295.718353,159.505829);
path.lineTo(295.718353,240);
path.lineTo(283.714233,240);
path.close();
path.moveTo(349.843323,231.626816);
path.lineTo(351.512085,231.663818);
path.quadTo(350.663696,231.663818, 349.843323,231.626816);
path.close();
path.moveTo(326.236786,205.854996);
path.lineTo(330.463562,217.659027);
path.lineTo(334.814056,205.854996);
path.lineTo(326.236786,205.854996);
path.close();
path.moveTo(334.814056,205.854996);
path.lineTo(338.451721,195.984955);
path.lineTo(349.479309,195.984955);
path.lineTo(355.054535,180.885361);
path.quadTo(358.78125,185.936935, 358.78125,195.984955);
</div>
<div id="testQuadratic58a">
path.moveTo(283.714233,240);
path.lineTo(283.714233,141.299606);
path.lineTo(303.12088,141.299606);
path.lineTo(317.770294,182.210785);
path.quadTo(319.462738,179.134506, 321.73526,176.444946);
path.quadTo(330.638306,165.90802, 344.509705,165.90802);
path.quadTo(347.07132,165.90802, 349.406036,166.26297);
path.lineTo(358.606506,141.299606);
path.lineTo(362.874634,159.705902);
path.lineTo(359.116211,169.884979);
path.quadTo(362.326477,172.001541, 364.81665,175.244537);
path.lineTo(371.919067,205.854996);
path.lineTo(345.834961,205.854996);
path.lineTo(337.609253,228.13298);
path.quadTo(342.649323,231.302383, 349.843323,231.626816);
path.lineTo(336.429047,231.329422);
path.lineTo(335.665344,233.397751);
path.lineTo(322.12738,233.397751);
path.lineTo(320.050781,227.587433);
path.quadTo(313.982483,219.336182, 313.015503,207.902908);
path.lineTo(295.718353,159.505829);
path.lineTo(295.718353,240);
path.lineTo(283.714233,240);
path.close();
path.moveTo(349.843323,231.626816);
path.lineTo(351.512085,231.663818);
path.quadTo(350.663696,231.663818, 349.843323,231.626816);
path.close();
path.moveTo(349.479309,195.984955);
path.lineTo(358.78125,195.984955);
path.quadTo(358.78125,185.936935, 355.054535,180.885361);
path.lineTo(349.479309,195.984955);
path.close();
path.moveTo(345.858368,175.888794);
path.lineTo(338.451721,195.984955);
path.lineTo(326.837006,195.984955);
path.quadTo(328.570923,175.778046, 343.709442,175.778046);
path.quadTo(344.825195,175.778046, 345.858368,175.888794);
path.close();
</div>
<div id="testQuadratic59">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(2, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(2, 0);
path.quadTo(3, 1, 1, 2);
</div>
<div id="testQuadratic59o">
path.moveTo(369.863983, 145.645813);
path.quadTo(382.380371, 121.254936, 406.236359, 121.254936);
path.quadTo(409.445679, 121.254936, 412.975952, 121.789818);
path.lineTo(369.863983, 145.645813);
path.close();
path.moveTo(369.970581, 137.94342);
path.quadTo(383.98465, 121.254936, 406.235992, 121.254936);
path.quadTo(425.705902, 121.254936, 439.71994, 137.087616);
path.lineTo(369.970581, 137.94342);
path.close();
</div>
<div id="testQuadratic59s">
path.moveTo(369.970581,137.94342);
path.quadTo(383.98465,121.254936, 406.235992,121.254936);
path.quadTo(406.237854,121.254936, 406.239746,121.254936);
path.lineTo(406.239532,121.254936);
path.quadTo(409.447418,121.255203, 412.975952,121.789818);
</div>
<div id="testQuadratic60">
path.moveTo(360.416077, 166.795715);
path.quadTo(370.126831, 147.872162, 388.635406, 147.872162);
path.lineTo(360.416077, 166.795715);
path.close();
path.moveTo(353.2948, 194.351074);
path.quadTo(353.2948, 173.767563, 364.167572, 160.819855);
path.quadTo(375.040314, 147.872162, 392.303894, 147.872162);
path.lineTo(353.2948, 194.351074);
path.close();
</div>
<div id="testQuadratic61">
path.moveTo(348.781738, 123.864815);
path.lineTo(369.848602, 123.864815);
path.lineTo(369.848602, 145.680267);
path.quadTo(382.360413, 121.298294, 406.207703, 121.298294);
path.lineTo(348.781738, 123.864815);
path.close();
path.moveTo(369.961151, 137.980698);
path.quadTo(383.970093, 121.298294, 406.213287, 121.298294);
path.lineTo(369.961151, 137.980698);
path.close();
</div>
<div id="testQuadratic62x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(2, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(2, 0);
path.quadTo(3, 1, 1, 2);
path.close();
</div>
<div id="testLine1a">
path.addRect(0, 0, 12, 12, SkPath::kCW_Direction);
path.addRect(4, 0, 13, 13, SkPath::kCCW_Direction);
path.close();
</div>
<div id="testQuadratic63">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(3, 2);
path.close();
path.moveTo(1, 0);
path.lineTo(2, 1);
path.quadTo(2, 1, 2, 2);
path.close();
</div>
<div id="testQuadratic64">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(2, 3);
path.close();
path.moveTo(1, 2);
path.lineTo(2, 2);
path.quadTo(0, 3, 3, 3);
path.close();
</div>
<div id="testQuadratic65">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(3, 2);
path.close();
path.moveTo(2, 1);
path.lineTo(2, 2);
path.quadTo(0, 3, 1, 3);
path.close();
</div>
<div id="testQuadratic66">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 1);
path.lineTo(3, 2);
path.close();
path.moveTo(2, 0);
path.lineTo(1, 1);
path.quadTo(3, 2, 2, 3);
path.close();
</div>
<div id="testQuadratic67x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.moveTo(0, 0);
path.quadTo(0, 0, 2, 1);
path.lineTo(2, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(2, 0);
path.quadTo(1, 1, 3, 2);
path.close();
</div>
<div id="testQuadratic68">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(1, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(0, 1, 2, 1);
path.close();
</div>
<div id="testQuadratic69">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 1);
path.lineTo(3, 2);
path.close();
path.moveTo(2, 0);
path.lineTo(1, 1);
path.quadTo(3, 2, 2, 3);
path.close();
</div>
<div id="testQuadratic70x">
path.setFillType(SkPath::kEvenOdd_FillType);
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 1);
path.lineTo(1, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(0, 1, 2, 1);
path.close();
</div>
<div id="testQuadratic71">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 1);
path.lineTo(3, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(1, 1, 3, 1);
path.close();
</div>
<div id="testQuadratic72">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 2);
path.lineTo(1, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(0, 1, 3, 2);
path.close();
</div>
<div id="testQuadratic73">
path.moveTo(0, 0);
path.quadTo(1, 0, 0, 3);
path.lineTo(0, 3);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(0, 1, 1, 1);
path.close();
</div>
<div id="testQuadratic74">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 3);
path.lineTo(1, 3);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 1);
path.quadTo(3, 2, 2, 3);
path.close();
</div>
<div id="testQuadratic75">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 3);
path.lineTo(2, 3);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 1);
path.quadTo(3, 2, 2, 3);
path.close();
</div>
<div id="testQuadratic76">
path.moveTo(0, 0);
path.quadTo(0, 0, 0, 0);
path.lineTo(2, 3);
path.close();
path.moveTo(1, 0);
path.lineTo(1, 2);
path.quadTo(1, 2, 2, 2);
path.close();
</div>
<div id="testQuadratic77">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 1);
path.lineTo(3, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(0, 1, 3, 2);
path.close();
</div>
<div id="testQuadratic78">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 2);
path.lineTo(3, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(2, 1, 0, 2);
path.close();
</div>
<div id="testQuadratic79">
path.moveTo(0, 0);
path.quadTo(1, 0, 1, 2);
path.lineTo(3, 2);
path.close();
path.moveTo(0, 0);
path.lineTo(1, 0);
path.quadTo(0, 1, 3, 2);
path.close();
</div>
<div id="testQuadratic80">
path.moveTo(0, 0);
path.quadTo(1, 0, 2, 3);
path.lineTo(2, 3);
path.close();
path.moveTo(1, 0);
path.lineTo(3, 0);
path.quadTo(0, 1, 1, 1);
path.close();
</div>
<div id="testQuadratic81">
path.moveTo(0, 0);
path.quadTo(2, 0, 1, 1);
path.lineTo(1, 1);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(2, 1, 0, 2);
path.close();
</div>
<div id="testQuadratic82">
path.moveTo(0, 0);
path.quadTo(2, 0, 1, 1);
path.lineTo(0, 3);
path.close();
path.moveTo(0, 0);
path.lineTo(0, 0);
path.quadTo(2, 1, 0, 2);
path.close();
</div>
</div>
<script type="text/javascript">
var testDivs = [
testQuadratic82,
testQuadratic81,
testQuadratic80,
testQuadratic79,
testQuadratic78,
testQuadratic77,
testQuadratic76,
testQuadratic75,
testQuadratic74,
testQuadratic73,
testQuadratic72,
testQuadratic71,
testQuadratic70x,
testQuadratic69,
testQuadratic68,
testQuadratic67x,
testQuadratic66,
testQuadratic65,
testQuadratic64,
testQuadratic63,
testLine1a,
testQuadratic62x,
testLine81,
testQuadratic61,
testQuadratic60,
testQuadratic59,
testQuadratic59o,
testQuadratic59s,
testQuadratic58o,
testQuadratic58a,
testQuadratic58s,
testQuadratic57o,
testQuadratic57s,
testQuadratic56o,
testQuadratic56s,
testQuadratic55o,
testQuadratic55s,
testQuadratic54,
testQuadratic53o,
testQuadratic53s,
testQuadratic52sa,
testQuadratic52sb,
testQuadratic52sc,
testQuadratic52o,
testQuadratic52s,
testQuadratic51,
testQuadratic50o,
testQuadratic50s,
testQuadratic49s,
testQuadratic48o,
testQuadratic48s,
testQuadratic47o,
testQuadratic47s,
testQuadratic46o,
testQuadratic46s,
testQuadratic45o,
testQuadratic45s,
testQuadratic44o,
testQuadratic44s,
testQuadratic43o,
testQuadratic43s,
testQuadratic42o,
testQuadratic42s,
testQuadratic41o,
testQuadratic41s,
testQuadratic40xb,
testQuadratic40xa,
testQuadratic40x,
testQuadratic39,
testQuadratic39a,
testQuadratic38,
testQuadratic37,
testQuadratic36,
testQuadratic35,
testQuadratic34,
testQuadratic33,
testQuadratic32,
testQuadratic31,
testQuadratic30,
testQuadratic29,
testQuadratic28,
testQuadratic27,
testQuadratic26,
testQuadratic25,
testQuadratic24,
testQuadratic23,
testQuadratic22,
testQuadratic21,
testQuadratic20,
testQuadratic19,
testQuadratic18,
testQuadratic17x,
testQuadratic16b,
testQuadratic16a,
testQuadratic15,
testQuadratic14,
testQuadratic13b,
testQuadratic13a,
testQuadratic12,
testQuadratic11b,
testQuadratic11a,
testQuadratic10b,
testQuadratic10a,
testQuadratic9a,
testQuadratic9,
testQuadratic8,
testQuadratic7,
testQuadratic6,
testQuadratic5,
testQuadratic4x,
testQuadratic3,
testQuadratic2,
testQuadratic1,
testLine4x,
testLine3x,
testLine2x,
testLine1x,
testQuadralateral9,
testQuadralateral8,
testQuadralateral7,
testFauxQuadralateral6d,
testFauxQuadralateral6c,
testFauxQuadralateral6b,
testFauxQuadralateral6a,
testFauxQuadralateral6,
testQuadralateral6a,
testQuadralateral6,
testQuadralateral5,
testNondegenerate4,
testNondegenerate3,
testNondegenerate2,
testNondegenerate1,
testDegenerate4,
testDegenerate3,
testDegenerate2,
testDegenerate1,
testLine79,
testLine78,
testLine77,
testLine76,
testLine75,
testLine74,
testLine73,
testLine72,
testLine71,
testLine70,
testLine69,
testLine68f,
testLine68e,
testLine68d,
testLine68c,
testLine68b,
testLine68a,
testLine67,
testLine66,
testLine65,
testLine64,
testLine63,
testLine62,
testLine61,
testLine60,
testLine59,
testLine58,
testLine57,
testLine56,
testLine55,
testLine54,
testLine53,
testLine52,
testLine51,
testLine50,
testLine49,
testLine48,
testLine47,
testLine46,
testLine45,
testLine44,
testLine43,
testLine42,
testLine41,
testLine40,
testLine39,
testLine38,
testLine37,
testLine36,
testLine35,
testLine34,
testLine33,
testLine32,
testLine31,
testLine30,
testLine29,
testLine28,
testLine24,
testLine22,
testLine19,
testLine17,
testLine13,
testLine12,
testLine9,
testLine7b,
testLine7,
testSimplifyQuadratic21,
testSimplifyQuadratic20,
testSimplifyQuadratic19,
testSimplifyQuadratic18,
testSimplifyQuadratic17,
testSimplifyQuadratic16,
testSimplifyQuadratic15,
testSimplifyQuadratic14,
testSimplifyQuadratic13,
testSimplifyQuadratic12,
testSimplifyQuadratic11,
testSimplifyQuadratic10,
testSimplifyQuadratic9,
testSimplifyQuadratic8,
testSimplifyQuadratic7,
testSimplifyQuadratic6,
testSimplifyQuadratic5,
testSimplifyQuadratic4,
testSimplifyQuadratic3,
testSimplifyQuadratic2,
testSimplifyQuadratic1,
];
var scale, columns, rows, xStart, yStart;
var ticks = 0.1;
var at_x = 13 + 0.5;
var at_y = 13 + 0.5;
var decimal_places = 0; // make this 3 to show more precision
var tests = [];
var testTitles = [];
var testIndex = 0;
var hasXor = false;
var draw_labels = true;
var ctx;
function parse(test, title) {
var contours = [];
var contourStrs = test.split("path.close();");
var pattern = /-?\d+\.*\d*/g;
hasXor = test.split("kEvenOdd_FillType").length > 1;
for (var c in contourStrs) {
var contour = contourStrs[c];
var verbStrs = contour.split("path");
var verbs = [];
for (var v in verbStrs) {
var verbStr = verbStrs[v];
var points = verbStr.match(pattern);
var pts = [];
for (var wd in points) {
var num = parseFloat(points[wd]);
if (isNaN(num)) continue;
pts.push(num);
}
if (pts.length > 0)
verbs.push(pts);
}
if (verbs.length > 0) {
var lastIndex = verbs.length - 1;
var lastVerb = verbs[lastIndex];
var lastLen = lastVerb.length;
if (verbs[0][0] != lastVerb[lastLen - 2] && verbs[0][1] != lastVerb[lastLen - 1]) {
var lastPts = [];
lastPts.push(verbs[0][0]);
lastPts.push(verbs[0][1]);
verbs.push(lastPts);
}
contours.push(verbs);
}
}
if (contours.length > 0) {
tests.push(contours);
testTitles.push(title);
}
}
function parseRect(test, title) {
var contours = [];
var rectStrs = test.split("path.addRect");
var pattern = /-?\d+\.*\d*/g;
hasXor = test.split("kEvenOdd_FillType").length > 1;
for (var r in rectStrs) {
var rect = rectStrs[r];
var sideStrs = rect.match(pattern);
var ccw = rect.split("kCCW_Direction").length > 1;
var sides = [];
for (var wd in sideStrs) {
var num = parseFloat(sideStrs[wd]);
if (isNaN(num)) continue;
sides.push(num);
}
if (sides.length == 0)
continue;
var verbs = [];
var topLeft = [];
topLeft.push(sides[0]); topLeft.push(sides[1]);
var topRight = [];
topRight.push(sides[2]); topRight.push(sides[1]);
var botLeft = [];
botLeft.push(sides[0]); botLeft.push(sides[3]);
var botRight = [];
botRight.push(sides[2]); botRight.push(sides[3]);
verbs.push(topLeft);
if (!ccw) {
verbs.push(topRight);
verbs.push(botRight);
verbs.push(botLeft);
} else {
verbs.push(botLeft);
verbs.push(botRight);
verbs.push(topRight);
}
verbs.push(topLeft);
contours.push(verbs);
}
if (contours.length > 0) {
tests.push(contours);
testTitles.push(title);
}
}
function init(test) {
var canvas = document.getElementById('canvas');
if (!canvas.getContext) return;
canvas.width = window.innerWidth - at_x;
canvas.height = window.innerHeight - at_y;
ctx = canvas.getContext('2d');
var xmin = Infinity;
var xmax = -Infinity;
var ymin = Infinity;
var ymax = -Infinity;
for (var contours in test) {
var contour = test[contours];
for (var verbs in contour) {
var verb = contour[verbs];
var last = verb.length;
for (var idx = 0; idx < last; idx += 2) {
xmin = Math.min(xmin, verb[idx]);
xmax = Math.max(xmax, verb[idx]);
ymin = Math.min(ymin, verb[idx + 1]);
ymax = Math.max(ymax, verb[idx + 1]);
}
}
}
var subscale = 1;
while ((xmax - xmin) * subscale < 0.1 && (ymax - ymin) * subscale < 0.1) {
subscale *= 10;
}
columns = Math.ceil(xmax) - Math.floor(xmin) + 1;
rows = Math.ceil(ymax) - Math.floor(ymin) + 1;
xStart = Math.floor(xmin);
yStart = Math.floor(ymin);
var hscale = ctx.canvas.width / columns / ticks;
var vscale = ctx.canvas.height / rows / ticks;
scale = Math.floor(Math.min(hscale, vscale)) * subscale;
}
function drawPoint(px, py, xoffset, yoffset, unit) {
var label = px.toFixed(decimal_places) + ", " + py.toFixed(decimal_places);
var _px = px * unit + xoffset;
var _py = py * unit + yoffset;
ctx.beginPath();
ctx.arc(_px, _py, 3, 0, Math.PI*2, true);
ctx.closePath();
ctx.fill();
ctx.fillText(label, _px + 5, _py);
}
function draw(test, title, _at_x, _at_y, scale) {
ctx.fillStyle = "rgba(0,0,0, 0.1)";
ctx.font = "normal 50px Arial";
ctx.fillText(title, 50, 50);
ctx.font = "normal 10px Arial";
var unit = scale * ticks;
ctx.lineWidth = 1;
var i;
for (i = 0; i <= rows * ticks; ++i) {
ctx.strokeStyle = (i % ticks) != 0 ? "rgb(160,160,160)" : "black";
ctx.beginPath();
ctx.moveTo(_at_x + 0, _at_y + i * scale);
ctx.lineTo(_at_x + unit * columns, _at_y + i * scale);
ctx.stroke();
}
for (i = 0; i <= columns * ticks; ++i) {
ctx.strokeStyle = (i % ticks) != 0 ? "rgb(160,160,160)" : "black";
ctx.beginPath();
ctx.moveTo(_at_x + i * scale, _at_y + 0);
ctx.lineTo(_at_x + i * scale, _at_y + unit * rows);
ctx.stroke();
}
var xoffset = xStart * -unit + _at_x;
var yoffset = yStart * -unit + _at_y;
ctx.fillStyle = "rgb(40,80,60)"
for (i = 0; i <= columns; i += (1 / ticks))
{
num = (xoffset - _at_x) / -unit + i;
ctx.fillText(num.toFixed(0), i * unit + _at_y - 5, 10);
}
for (i = 0; i <= rows; i += (1 / ticks))
{
num = (yoffset - _at_x) / -unit + i;
ctx.fillText(num.toFixed(0), 0, i * unit + _at_y + 0);
}
ctx.strokeStyle = "red";
var contours, verbs, pts;
ctx.beginPath();
for (contours in test) {
var contour = test[contours];
if (contours == 2) ctx.strokeStyle = "blue";
var first = true;
for (verbs in contour) {
var verb = contour[verbs];
switch (verb.length) {
case 2:
if (first) {
ctx.moveTo(xoffset + verb[0] * unit, yoffset + verb[1] * unit);
first = false;
} else
ctx.lineTo(xoffset + verb[0] * unit, yoffset + verb[1] * unit);
break;
case 4:
ctx.quadraticCurveTo(xoffset + verb[0] * unit, yoffset + verb[1] * unit,
xoffset + verb[2] * unit, yoffset + verb[3] * unit);
break;
case 6:
ctx.bezierCurveTo(xoffset + verb[0] * unit, yoffset + verb[1] * unit,
xoffset + verb[2] * unit, yoffset + verb[3] * unit,
xoffset + verb[4] * unit, yoffset + verb[5] * unit);
break;
}
}
ctx.closePath();
}
if (hasXor) {
ctx.fillType=xor; // how is this done?
}
ctx.stroke();
ctx.fillStyle="rgba(192,192,255, 0.3)";
ctx.fill();
if (!draw_labels) {
return;
}
ctx.fillStyle="blue";
for (contours in test) {
var contour = test[contours];
for (verbs in contour) {
var verb = contour[verbs];
for (i = 0; i < verb.length; i += 2) {
x = verb[i];
y = verb[i + 1];
drawPoint(x, y, xoffset, yoffset, unit);
}
}
}
}
var mouseX = Infinity, mouseY;
function calcXY() {
var e = window.event;
var tgt = e.target || e.srcElement;
var left = tgt.offsetLeft;
var top = tgt.offsetTop;
var unit = scale * ticks;
mouseX = (e.clientX - left - Math.ceil(at_x) + 1) / unit + xStart;
mouseY = (e.clientY - top - Math.ceil(at_y)) / unit + yStart;
}
function handleMouseOver() {
calcXY();
var num = mouseX.toFixed(3) + ", " + mouseY.toFixed(3);
ctx.beginPath();
ctx.rect(300,100,200,10);
ctx.fillStyle="white";
ctx.fill();
ctx.fillStyle="black";
ctx.fillText(num, 300, 108);
}
function handleMouseClick() {
calcXY();
// drawInset();
}
function drawTop() {
init(tests[testIndex]);
redraw();
}
function redraw() {
ctx.beginPath();
ctx.rect(0, 0, ctx.canvas.width, ctx.canvas.height);
ctx.fillStyle="white";
ctx.fill();
draw(tests[testIndex], testTitles[testIndex], at_x, at_y, scale);
// if (insetScale != scale && mouseX != Infinity)
// drawInset();
}
function doKeyPress(evt) {
var char = String.fromCharCode(evt.charCode);
switch (char) {
case 'N':
testIndex += 9;
case 'n':
if (++testIndex >= tests.length)
testIndex = 0;
mouseX = Infinity;
drawTop();
break;
case 'P':
testIndex -= 9;
case 'p':
if (--testIndex < 0)
testIndex = tests.length - 1;
mouseX = Infinity;
drawTop();
break;
case 'T':
case 't':
break;
case '-':
drawTop();
break;
case '=':
case '+':
drawTop();
break;
case 'x':
draw_labels ^= true;
drawTop();
break;
}
}
function start() {
for (i = 0; i < testDivs.length; ++i) {
var title = testDivs[i].id.toString();
var str = testDivs[i].firstChild.data;
if (str.split("addRect").length > 1) {
parseRect(str, title);
} else {
parse(str, title);
}
}
drawTop();
window.addEventListener('keypress', doKeyPress, true);
window.onresize = function() {
drawTop();
}
}
</script>
</head>
<body onLoad="start();">
<canvas id="canvas" width="750" height="500"
onmousemove="handleMouseOver()"
onclick="handleMouseClick()"
></canvas >
</body>
</html>