-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.html
78 lines (72 loc) · 4.38 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<!DOCTYPE html>
<html lang="en-US">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>PolyGoneRound</title>
<meta name="author" content="99-Knots"/>
<meta name="description" content="Easily create custom polygons with rounded corners and generate SVG code." />
<link rel="icon" href="favicon.ico" type="image/x-icon" />
<link rel="stylesheet" href="style.css">
<script src="polygons.js" defer></script>
</head>
<body>
<header>
<img class="icon" src="icon.svg" />
<span>PolyGoneRound</span>
<a href="https://github.com/99-Knots/PolyGoneRound" title="visit the GitHub repo">
<svg class="icon" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><path fill-rule="evenodd" clip-rule="evenodd" d="M48.854 0C21.839 0 0 22 0 49.217c0 21.756 13.993 40.172 33.405 46.69 2.427.49 3.316-1.059 3.316-2.362 0-1.141-.08-5.052-.08-9.127-13.59 2.934-16.42-5.867-16.42-5.867-2.184-5.704-5.42-7.17-5.42-7.17-4.448-3.015.324-3.015.324-3.015 4.934.326 7.523 5.052 7.523 5.052 4.367 7.496 11.404 5.378 14.235 4.074.404-3.178 1.699-5.378 3.074-6.6-10.839-1.141-22.243-5.378-22.243-24.283 0-5.378 1.94-9.778 5.014-13.2-.485-1.222-2.184-6.275.486-13.038 0 0 4.125-1.304 13.426 5.052a46.97 46.97 0 0 1 12.214-1.63c4.125 0 8.33.571 12.213 1.63 9.302-6.356 13.427-5.052 13.427-5.052 2.67 6.763.97 11.816.485 13.038 3.155 3.422 5.015 7.822 5.015 13.2 0 18.905-11.404 23.06-22.324 24.283 1.78 1.548 3.316 4.481 3.316 9.126 0 6.6-.08 11.897-.08 13.526 0 1.304.89 2.853 3.316 2.364 19.412-6.52 33.405-24.935 33.405-46.691C97.707 22 75.788 0 48.854 0z" /></svg>
</a>
</header>
<div class="container">
<div class="canvas-container">
<svg id="canvas" class="canvas" xmlns="http://www.w3.org/2000/svg">
<defs>
<circle id="point-marker" cx="0" cy="0" r="5"/>
</defs>
<g class="canvas-group">
<path fill="#0000ff" d="M0,0" />
</g>
<polygon stroke="#0006" strokeStyle="dashed" fill="none" points="0,0" />
</svg>
</div>
<div id="controls" class="controls">
<label id="radius-lbl" class="col-1" for="radius-sld">radius: </label>
<span class="col-2 control-grouped slider-container">
<input id="radius-sld" type="range" min="0" max="100" value="50">
<input id="radius-edt" aria-labelledby="radius-lbl" class="coord" type="number" min="0" max="100" value="50">
</span>
<label class="col-1" for="radius-limit-chk">consistent radius: </label>
<span class="control-grouped">
<input class="col-2" id="radius-limit-chk" type="checkbox" name="limit radius">
</span>
<label class="col-1" for="line-vis-chk">show outline: </label>
<span class="control-grouped">
<input class="col-2" id="line-vis-chk" type="checkbox" name="line visibility" checked>
</span>
<label class="col-1" for="color-pick">color: </label>
<input class="col-2" id="color-pick" type="color" value="#6b88ef">
<label class="col-1" for="corner-style-edt">corner style: </label>
<select class="col-2" id="corner-style-edt">
<option value="arc">Arc</option>
<option value="bezier">Bezier</option>
</select>
<label for="ratio-w-edt" class="col-1">aspect ratio:</label>
<span class="col-2 control-grouped">
<input id="ratio-w-edt" aria-label="width component of the ratio" class="col-2" type="number" min="1" value="1">:
<input id="ratio-h-edt" aria-label="height component of the ratio" class="col-2" type="number" min="1" value="1">
</span>
<ul class="col-1-2 point-list" id="point-list"></ul>
<div class="col-1-2 point-buttons">
<button id="add-point-btn" class="col-1">+</button>
<button class="col-1" id="clear-btn">clear</button>
</div>
</div>
<div class="code-container">
<pre><code id="path-code"></code></pre>
<div id="copy-popup" class="popup">Copied code to clipboard!</div>
<button id="copy-code-btn">copy</button>
</div>
</div>
</body>
</html>