-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtest.mjs
131 lines (99 loc) · 3.6 KB
/
test.mjs
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
import t from 'tape'
import normalize from './index.mjs'
import parse from 'parse-svg-path'
t('line-to', t => {
t.deepEqual(
normalize(parse('L100 100')),
parse('C0,0 100,100 100,100')
)
t.deepEqual(
normalize(parse('L50 50 100 0')),
parse('C0,0 50,50 50,50 C50,50 100,0 100,0')
)
t.deepEqual(
normalize(parse('H50 100')),
parse('C0,0 50,0 50,0 C50,0 100,0 100,0')
)
t.deepEqual(
normalize(parse('V50 100')),
parse('C0,0 0,50 0,50 C0,50 0,100 0,100')
)
t.end()
})
t('curve-to', t => {
t.deepEqual(
normalize(parse('M10 150 C10 10 150 10 150 150')),
parse('M10,150C10,10,150,10,150,150')
)
t.deepEqual(
normalize(parse('M0 120 Q60 0 120 120')),
parse('M0,120C40,40,80,40,120,120')
)
t.deepEqual(
normalize(parse('M10 80 C10 10 75 10 75 80 S150 150 150 80')),
parse('M10,80C10,10,75,10,75,80C75,150,150,150,150,80')
)
t.deepEqual(
normalize(parse('M0 60 Q30 0 60 60 T120 60')),
parse('M0,60C20,20,40,20,60,60C80,100,100,100,120,60')
)
t.deepEqual(
normalize(parse('M30 30 Q50 50 84 50 S124 73 107 92 T127 122')),
parse('M30,30C43.33333333333333,43.33333333333333,61.33333333333333,50,84,50C84,50,124,73,107,92C107,92,113.66666666666666,102,127,122')
)
t.end()
})
t('close-path', t => {
t.deepEqual(
normalize(parse('L100 0 100 100Z')),
parse('C0,0,100,0,100,0C100,0,100,100,100,100C100,100,0,0,0,0')
)
t.end()
})
t('arc-to', t => {
t.deepEqual(
r(normalize(parse('M10 80 A150 150 0 0 0 150 80'))),
r(parse('M 10 80C 53.80473794537901 103.1133445143787 106.19526205462094 103.1133445143787 149.99999999999997 80.00000000000003'))
)
// half circle clockwise
t.deepEqual(
r(normalize(parse('M10 80 A50 50 0 0 1 150 80'))),
r(parse('M 10 80C 10 41.340067511844474 41.34006751184445 10.000000000000014 79.99999999999999 10C 118.65993248815552 10 150 41.34006751184445 150 79.99999999999999'))
)
// half circle anticlockwise
t.deepEqual(
r(normalize(parse('M10 80 A50 50 0 1 0 150 80'))),
r(parse('M 10 80C 10.000000000000014 118.65993248815553 41.340067511844474 150 80 150C 118.65993248815553 150 150 118.65993248815553 150 80'))
)
// circle
t.deepEqual(
r(normalize(parse('M10 80 A50 50 0 0 1 150 80 A50 50 0 0 1 10 80'))),
r(parse('M 10 80C 10 41.340067511844474 41.34006751184445 10.000000000000014 79.99999999999999 10C 118.65993248815552 10 150 41.34006751184445 150 79.99999999999999C 150 118.65993248815553 118.65993248815553 150 80 150C 41.340067511844474 150 10.000000000000014 118.65993248815553 10 80.00000000000001'))
)
t.deepEqual(
normalize(parse('M10 80 A150 75 30 0 0 150 80')),
parse('M 10 80C 72.04149682761658 108.21761044823509 129.85079028483736 108.21761044823509 150 79.99999999999999')
)
// the null curve
t.deepEqual(
normalize(parse('M10 80 A50 50 0 0 1 10 80')),
parse('M10,80')
)
t.end()
})
function r(arr) { return arr.map(function (arr) { return [arr[0]].concat(arr.slice(1).map(round)) }) }
function round(v) { return Math.round(v) }
//show parsed curve in the doc
function show(src) {
let path = src.map(seg => seg.join(' ')).join('')
let el = document.body.appendChild(document.createElement('div'))
let svgNS = 'http://www.w3.org/2000/svg'
el.innerHTML = `<svg id="mySVG" width="400" height="400" xmlns="${svgNS}" xmlns:xlink="http://www.w3.org/1999/xlink"/>`
let svg = el.firstChild
let pathEl = svg.appendChild(document.createElementNS(svgNS, 'path'))
pathEl.setAttribute('d', path)
pathEl.style.strokeWidth = '2px';
pathEl.style.stroke = 'black';
pathEl.style.fill = 'transparent';
return src
}