nadesiko3 3.2.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (283) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +107 -0
  3. package/bin/cnako3 +10 -0
  4. package/bin/cnako3.bat +11 -0
  5. package/bin/nako3server.bat +6 -0
  6. package/demo/ace_editor.html +90 -0
  7. package/demo/ace_editor_tabs.html +162 -0
  8. package/demo/basic.html +71 -0
  9. package/demo/browsers.html +128 -0
  10. package/demo/css/basic.css +3 -0
  11. package/demo/css/common.css +157 -0
  12. package/demo/css/editor.css +8 -0
  13. package/demo/css/flow.css +3 -0
  14. package/demo/css/index.css +3 -0
  15. package/demo/extlib/ace@1.4.12/ace.js +17 -0
  16. package/demo/extlib/ace@1.4.12/ext-code_lens.min.js +1 -0
  17. package/demo/extlib/ace@1.4.12/ext-language_tools.min.js +1 -0
  18. package/demo/extlib/ace@1.4.12/ext-options.min.js +1 -0
  19. package/demo/extlib/ace@1.4.12/ext-settings_menu.js +8 -0
  20. package/demo/extlib/ace@1.4.12/keybinding-vscode.js +8 -0
  21. package/demo/extlib/ace@1.4.12/theme-monokai.js +8 -0
  22. package/demo/extlib/ace@1.4.12/theme-xcode.js +8 -0
  23. package/demo/extlib/chart.js@3.2.1/chart.min.js +13 -0
  24. package/demo/extlib/pure-min.css +11 -0
  25. package/demo/flow.html +97 -0
  26. package/demo/graph.html +53 -0
  27. package/demo/image/nako.png +0 -0
  28. package/demo/image/nakopad-icon256.png +0 -0
  29. package/demo/image/turtle.fla +0 -0
  30. package/demo/image/turtle.png +0 -0
  31. package/demo/index.html +134 -0
  32. package/demo/js/common.js +17 -0
  33. package/demo/js/turtle3d_test.js +44 -0
  34. package/demo/js/turtle_test.js +44 -0
  35. package/demo/runscript.html +47 -0
  36. package/demo/runscript2.html +33 -0
  37. package/demo/turtle.html +58 -0
  38. package/demo/turtle2.html +141 -0
  39. package/demo/turtle3.html +278 -0
  40. package/demo/turtle3d.html +58 -0
  41. package/demo/turtle3d2.html +107 -0
  42. package/demo/version.html +24 -0
  43. package/doc/SETUP.md +172 -0
  44. package/doc/about.md +34 -0
  45. package/doc/browsers.md +60 -0
  46. package/doc/docgen.md +21 -0
  47. package/doc/editor.md +44 -0
  48. package/doc/files.md +37 -0
  49. package/doc/plugins.md +195 -0
  50. package/doc/release.md +78 -0
  51. package/doc/win32.md +57 -0
  52. package/package.json +196 -0
  53. package/release/_hash.txt +65 -0
  54. package/release/_script-tags.txt +13 -0
  55. package/release/command.json +1 -0
  56. package/release/command.json.js +1 -0
  57. package/release/command_cnako3.json +1 -0
  58. package/release/command_list.json +1 -0
  59. package/release/editor.js +2 -0
  60. package/release/editor.js.LICENSE.txt +32 -0
  61. package/release/josi.json +48 -0
  62. package/release/nako_gen_async.js +1 -0
  63. package/release/nako_gen_async.js.LICENSE.txt +595 -0
  64. package/release/plugin_caniuse.js +1 -0
  65. package/release/plugin_caniuse.js.LICENSE.txt +411 -0
  66. package/release/plugin_csv.js +1 -0
  67. package/release/plugin_csv.js.LICENSE.txt +367 -0
  68. package/release/plugin_datetime.js +1 -0
  69. package/release/plugin_datetime.js.LICENSE.txt +471 -0
  70. package/release/plugin_kansuji.js +1 -0
  71. package/release/plugin_kansuji.js.LICENSE.txt +491 -0
  72. package/release/plugin_markup.js +1 -0
  73. package/release/plugin_markup.js.LICENSE.txt +363 -0
  74. package/release/plugin_turtle.js +1 -0
  75. package/release/plugin_turtle.js.LICENSE.txt +435 -0
  76. package/release/plugin_webworker.js +1 -0
  77. package/release/plugin_webworker.js.LICENSE.txt +491 -0
  78. package/release/version.js +2 -0
  79. package/release/version.js.LICENSE.txt +32 -0
  80. package/release/wnako3.js +2 -0
  81. package/release/wnako3.js.LICENSE.txt +1 -0
  82. package/release/wnako3webworker.js +1 -0
  83. package/release/wnako3webworker.js.LICENSE.txt +847 -0
  84. package/release/yoyakugo.json +30 -0
  85. package/src/browsers.md +60 -0
  86. package/src/cnako3.js +466 -0
  87. package/src/commander_ja.js +154 -0
  88. package/src/enako3.js +69 -0
  89. package/src/era.json +22 -0
  90. package/src/index.js +5 -0
  91. package/src/nako3.js +836 -0
  92. package/src/nako3_assert.js +37 -0
  93. package/src/nako3editorfix.sfd +106 -0
  94. package/src/nako3editorfix.woff +0 -0
  95. package/src/nako3server.js +51 -0
  96. package/src/nako_colors.js +86 -0
  97. package/src/nako_errors.js +176 -0
  98. package/src/nako_gen.js +1459 -0
  99. package/src/nako_gen_async.js +1622 -0
  100. package/src/nako_global.js +113 -0
  101. package/src/nako_indent.js +480 -0
  102. package/src/nako_josi_list.js +46 -0
  103. package/src/nako_lex_rules.js +259 -0
  104. package/src/nako_lexer.js +576 -0
  105. package/src/nako_logger.js +138 -0
  106. package/src/nako_parser3.js +1768 -0
  107. package/src/nako_parser_base.js +265 -0
  108. package/src/nako_parser_const.js +37 -0
  109. package/src/nako_prepare.js +293 -0
  110. package/src/nako_reserved_words.js +35 -0
  111. package/src/nako_source_mapping.js +251 -0
  112. package/src/nako_test.js +37 -0
  113. package/src/nako_version.js +8 -0
  114. package/src/plugin_browser.js +191 -0
  115. package/src/plugin_browser_ajax.js +352 -0
  116. package/src/plugin_browser_audio.js +109 -0
  117. package/src/plugin_browser_canvas.js +462 -0
  118. package/src/plugin_browser_chart.js +296 -0
  119. package/src/plugin_browser_color.js +49 -0
  120. package/src/plugin_browser_crypto.js +26 -0
  121. package/src/plugin_browser_dialog.js +53 -0
  122. package/src/plugin_browser_dom_basic.js +322 -0
  123. package/src/plugin_browser_dom_event.js +193 -0
  124. package/src/plugin_browser_dom_parts.js +163 -0
  125. package/src/plugin_browser_geolocation.js +51 -0
  126. package/src/plugin_browser_hotkey.js +25 -0
  127. package/src/plugin_browser_html.js +59 -0
  128. package/src/plugin_browser_in_worker.js +44 -0
  129. package/src/plugin_browser_location.js +21 -0
  130. package/src/plugin_browser_speech.js +111 -0
  131. package/src/plugin_browser_storage.js +121 -0
  132. package/src/plugin_browser_system.js +12 -0
  133. package/src/plugin_browser_websocket.js +73 -0
  134. package/src/plugin_caniuse.js +24 -0
  135. package/src/plugin_csv.js +57 -0
  136. package/src/plugin_datetime.js +414 -0
  137. package/src/plugin_express.js +212 -0
  138. package/src/plugin_kansuji.js +224 -0
  139. package/src/plugin_keigo.js +55 -0
  140. package/src/plugin_markup.js +32 -0
  141. package/src/plugin_math.js +319 -0
  142. package/src/plugin_node.js +1018 -0
  143. package/src/plugin_promise.js +94 -0
  144. package/src/plugin_system.js +2109 -0
  145. package/src/plugin_test.js +38 -0
  146. package/src/plugin_turtle.js +646 -0
  147. package/src/plugin_webworker.js +334 -0
  148. package/src/plugin_weykturtle3d.js +1216 -0
  149. package/src/plugin_worker.js +92 -0
  150. package/src/repl.nako3 +63 -0
  151. package/src/turtle-elephant.png +0 -0
  152. package/src/turtle-panda.png +0 -0
  153. package/src/turtle64.png +0 -0
  154. package/src/wnako3.js +162 -0
  155. package/src/wnako3_editor.css +215 -0
  156. package/src/wnako3_editor.js +1645 -0
  157. package/src/wnako3_editor_marker_red.png +0 -0
  158. package/src/wnako3_editor_marker_red.xcf +0 -0
  159. package/src/wnako3_editor_marker_yellow.png +0 -0
  160. package/src/wnako3_editor_marker_yellow.xcf +0 -0
  161. package/src/wnako3webworker.js +70 -0
  162. package/test/ace_editor/karma.config.js +94 -0
  163. package/test/ace_editor/test/.babelrc.json +3 -0
  164. package/test/ace_editor/test/ace_editor_test.js +178 -0
  165. package/test/ace_editor/test/html/custom_context.html +140 -0
  166. package/test/async/async_basic_test.js +124 -0
  167. package/test/browser/karma.config.js +212 -0
  168. package/test/browser/test/.babelrc.json +3 -0
  169. package/test/browser/test/compare_util.js +50 -0
  170. package/test/browser/test/html/canvas_basic.html +1 -0
  171. package/test/browser/test/html/div_basic.html +2 -0
  172. package/test/browser/test/html/event_dom_form.html +4 -0
  173. package/test/browser/test/html/event_dom_scrolldiv.html +5 -0
  174. package/test/browser/test/image/canvas_test1.png +0 -0
  175. package/test/browser/test/image/canvas_test2.png +0 -0
  176. package/test/browser/test/image/canvas_test3.png +0 -0
  177. package/test/browser/test/image/canvas_test4.png +0 -0
  178. package/test/browser/test/image/canvas_test7.png +0 -0
  179. package/test/browser/test/image/canvas_test8.png +0 -0
  180. package/test/browser/test/image/canvas_test_blank.png +0 -0
  181. package/test/browser/test/image/elephant_kana.png +0 -0
  182. package/test/browser/test/image/panda_kana.png +0 -0
  183. package/test/browser/test/image/turtle_kana.png +0 -0
  184. package/test/browser/test/import_plugin_checker.js +24 -0
  185. package/test/browser/test/plugin_browser_test.js +52 -0
  186. package/test/browser/test/plugin_browser_test_ajax.js +123 -0
  187. package/test/browser/test/plugin_browser_test_color.js +18 -0
  188. package/test/browser/test/plugin_browser_test_dialog.js +72 -0
  189. package/test/browser/test/plugin_browser_test_dom_event.js +598 -0
  190. package/test/browser/test/plugin_browser_test_dom_parts.js +125 -0
  191. package/test/browser/test/plugin_browser_test_system.js +9 -0
  192. package/test/browser/test/plugin_turtle_test.js +817 -0
  193. package/test/browser/test/plugin_webworker_test.js +87 -0
  194. package/test/browser/test/require_test.js +71 -0
  195. package/test/bundled/karma.config.base.js +117 -0
  196. package/test/bundled/karma.config.js +86 -0
  197. package/test/bundled/test/.babelrc.json +3 -0
  198. package/test/bundled/test/bundled_test.js +69 -0
  199. package/test/bundled/test/html/custom_context.html +65 -0
  200. package/test/bundled/test/html/custom_debug.html +66 -0
  201. package/test/bundled/test4b.cmd +52 -0
  202. package/test/bundled/test_base/.babelrc.json +3 -0
  203. package/test/bundled/test_base/_checktool_test.js +25 -0
  204. package/test/bundled/test_base/basic_ajax_test.js +56 -0
  205. package/test/bundled/test_base/basic_async_test.js +18 -0
  206. package/test/bundled/test_base/basic_test.js +153 -0
  207. package/test/bundled/test_base/calc_test.js +132 -0
  208. package/test/bundled/test_base/css/browsers_box.css +114 -0
  209. package/test/bundled/test_base/html/custom_context.html +69 -0
  210. package/test/bundled/test_base/html/custom_debug.html +71 -0
  211. package/test/bundled/test_base/js/browsers_box.js +72 -0
  212. package/test/bundled/test_base/plugin_csv_test.js +37 -0
  213. package/test/bundled/test_base/plugin_datetime_test.js +115 -0
  214. package/test/bundled/test_base/plugin_kansuji_test.js +49 -0
  215. package/test/bundled/test_base/plugin_system_test.js +410 -0
  216. package/test/bundled/test_base/plugin_webworker_test.js +53 -0
  217. package/test/bundled/test_base/resources/ok.txt +1 -0
  218. package/test/bundled/test_base/test_utils.js +191 -0
  219. package/test/common/array_test.js +40 -0
  220. package/test/common/basic_test.js +317 -0
  221. package/test/common/calc_test.js +139 -0
  222. package/test/common/debug_test.js +16 -0
  223. package/test/common/error_test.js +16 -0
  224. package/test/common/flow_test.js +360 -0
  225. package/test/common/func_call.js +136 -0
  226. package/test/common/func_test.js +149 -0
  227. package/test/common/indent_test.js +362 -0
  228. package/test/common/lex_test.js +146 -0
  229. package/test/common/literal_test.js +72 -0
  230. package/test/common/nako_logger_test.js +26 -0
  231. package/test/common/plugin_browser_test.js +24 -0
  232. package/test/common/plugin_browser_ut_audio_test.js +88 -0
  233. package/test/common/plugin_browser_ut_color_test.js +21 -0
  234. package/test/common/plugin_browser_ut_dialog_test.js +100 -0
  235. package/test/common/plugin_browser_ut_html_test.js +13 -0
  236. package/test/common/plugin_browser_ut_system_test.js +10 -0
  237. package/test/common/plugin_csv_test.js +39 -0
  238. package/test/common/plugin_datetime_test.js +120 -0
  239. package/test/common/plugin_kansuji_test.js +59 -0
  240. package/test/common/plugin_promise_test.js +18 -0
  241. package/test/common/plugin_system_test.js +451 -0
  242. package/test/common/prepare_test.js +93 -0
  243. package/test/common/re_test.js +20 -0
  244. package/test/common/variable_scope_test.js +105 -0
  245. package/test/jsconfig.json +19 -0
  246. package/test/karma.config.js +91 -0
  247. package/test/node/add_test.nako3 +1 -0
  248. package/test/node/async_test.js +80 -0
  249. package/test/node/commander_ja_test.js +82 -0
  250. package/test/node/error_message_test.js +244 -0
  251. package/test/node/kai_test.nako3 +6 -0
  252. package/test/node/node_test.js +43 -0
  253. package/test/node/plugin_broken.js.txt +3 -0
  254. package/test/node/plugin_browser_ut_ajax_test.js +355 -0
  255. package/test/node/plugin_browser_ut_location_test.js +32 -0
  256. package/test/node/plugin_markup_test.js +44 -0
  257. package/test/node/plugin_math_test.js +42 -0
  258. package/test/node/plugin_node_test.js +93 -0
  259. package/test/node/plugin_test.js +16 -0
  260. package/test/node/relative_import_test_1.nako3 +1 -0
  261. package/test/node/relative_import_test_2.nako3 +2 -0
  262. package/test/node/require_nako3_test.js +59 -0
  263. package/test/node/requiretest.nako3 +4 -0
  264. package/test/node/requiretest_indirect.nako3 +1 -0
  265. package/test/node/requiretest_name.nako3 +5 -0
  266. package/test/node/runtime_error.nako3 +2 -0
  267. package/test/node/side_effects_test.js +106 -0
  268. package/test/node/sjis.txt +5 -0
  269. package/test/node/syntax_error.nako3 +2 -0
  270. package/test/node/wnako3_editor_test.js +360 -0
  271. package/tools/README.md +7 -0
  272. package/tools/nako3edit/html/edit.html +83 -0
  273. package/tools/nako3edit/html/edit_plugin.js +6 -0
  274. package/tools/nako3edit/html/files.html +49 -0
  275. package/tools/nako3edit/html/nako3edit.css +66 -0
  276. package/tools/nako3edit/index.nako3 +145 -0
  277. package/tools/nako3edit/run.js +12 -0
  278. package/tools/nako3server/html/edit.html +104 -0
  279. package/tools/nako3server/html/edit_plugin.js +6 -0
  280. package/tools/nako3server/html/files.html +53 -0
  281. package/tools/nako3server/html/nako3edit.css +66 -0
  282. package/tools/nako3server/index.nako3 +129 -0
  283. package/tools/nako3server/run.js +12 -0
@@ -0,0 +1,462 @@
1
+ /* eslint-disable quote-props */
2
+ const errMsgCanvasInit = '描画を行うためには、HTML内にcanvasを配置し、idを振って『描画開始』命令に指定します。'
3
+
4
+ module.exports = {
5
+ // @描画
6
+ '描画開始': { // @描画先にCanvas(文字列でクエリの指定も可)を指定して描画API(2D)の利用準備する // @びょうがかいし
7
+ type: 'func',
8
+ josi: [['の', 'へ', 'で']],
9
+ pure: true,
10
+ fn: function (cv, sys) {
11
+ if (typeof cv === 'string')
12
+ {cv = document.querySelector(cv) || document.getElementById(cv)}
13
+
14
+ if (!cv) {throw new Error('『描画開始』でCanvasを取得できませんでした。')}
15
+ sys.__canvas = cv
16
+ sys.__ctx = cv.getContext('2d')
17
+ sys.__fillStyle = 'black'
18
+ sys.__strokeStyle = 'black'
19
+ sys.__v0['描画中キャンバス'] = cv
20
+ sys.__v0['描画中コンテキスト'] = sys.__ctx
21
+ },
22
+ return_none: true
23
+ },
24
+ '描画中キャンバス': {type: 'const', value: null}, // @ びょうがちゅうきゃんばす
25
+ '描画中コンテキスト': {type: 'const', value: null}, // @ びょうがちゅうこんてきすと
26
+ 'キャンバス状態保存': { // @Canvasの状態を保存(save) // @ きゃんばすじょうたいほぞん
27
+ type: 'func',
28
+ josi: [],
29
+ pure: true,
30
+ fn: function (sys) {
31
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
32
+ sys.__ctx.save()
33
+ },
34
+ return_none: true
35
+ },
36
+ 'キャンバス状態復元': { // @Canvasの状態を復元(restore) // @ きゃんばすじょうたいふくげん
37
+ type: 'func',
38
+ josi: [],
39
+ pure: true,
40
+ fn: function (sys) {
41
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
42
+ sys.__ctx.restore()
43
+ },
44
+ return_none: true
45
+ },
46
+ '線色設定': { // @Canvasの線の描画色(lineStyle)を指定する // @ せんいろしてい
47
+ type: 'func',
48
+ josi: [['に', 'へ']],
49
+ pure: true,
50
+ fn: function (v, sys) {
51
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
52
+ sys.__strokeStyle = v
53
+ if (v != '') {
54
+ sys.__ctx.strokeStyle = v
55
+ }
56
+ },
57
+ return_none: true
58
+ },
59
+ '塗色設定': { // @Canvasへの描画色(fillStyle)を指定する // @ ぬりいろしてい
60
+ type: 'func',
61
+ josi: [['に', 'へ']],
62
+ pure: true,
63
+ fn: function (v, sys) {
64
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
65
+ sys.__fillStyle = v
66
+ if (v != '') {
67
+ sys.__ctx.fillStyle = v
68
+ }
69
+ },
70
+ return_none: true
71
+ },
72
+ '線描画': { // @ [x1, y1]から[x2, y2]まで線を描画する // @ せんびょうが
73
+ type: 'func',
74
+ josi: [['から'], ['へ', 'まで']],
75
+ pure: true,
76
+ fn: function (a, b, sys) {
77
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
78
+ sys.__ctx.beginPath()
79
+ sys.__ctx.moveTo(a[0], a[1])
80
+ sys.__ctx.lineTo(b[0], b[1])
81
+ sys.__ctx.stroke()
82
+ },
83
+ return_none: true
84
+ },
85
+ '線太設定': { // @ vに線の太さ設定 // @ せんふとさせってい
86
+ type: 'func',
87
+ josi: [['に', 'へ']],
88
+ pure: true,
89
+ fn: function (v, sys) {
90
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
91
+ sys.__ctx.lineWidth = v
92
+ },
93
+ return_none: true
94
+ },
95
+ '四角描画': { // @ [x, y, w, h]で矩形を描画する // @ しかくびょうが
96
+ type: 'func',
97
+ josi: [['の', 'へ', 'に']],
98
+ pure: true,
99
+ fn: function (b, sys) {
100
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
101
+ if (sys.__fillStyle == '' && sys.__strokeStyle == '') {return}
102
+ sys.__ctx.beginPath()
103
+ sys.__ctx.rect(b[0], b[1], b[2], b[3])
104
+ if (sys.__fillStyle != '') {sys.__ctx.fill()}
105
+ if (sys.__strokeStyle != '') {sys.__ctx.stroke()}
106
+ },
107
+ return_none: true
108
+ },
109
+ '全描画クリア': { // @ 描画中のキャンバスをクリアする。 // @ ぜんびょうがくりあ
110
+ type: 'func',
111
+ josi: [],
112
+ pure: true,
113
+ fn: function (sys) {
114
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
115
+ sys.__ctx.clearRect(0, 0,
116
+ sys.__canvas.width, sys.__canvas.height)
117
+ },
118
+ return_none: true
119
+ },
120
+ '描画クリア': { // @ [x, y, w, h]の範囲を描画クリア。空配列を指定すると『全描画クリア』と同じ。2要素の配列だと[0,0]を省略したのと同じ。 // @ びょうがくりあ
121
+ type: 'func',
122
+ josi: [['の', 'へ', 'に']],
123
+ pure: true,
124
+ fn: function (b, sys) {
125
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
126
+ if (!(b instanceof Array)) { b = [] }
127
+ if (b.length == 0) {
128
+ b = [0, 0, sys.__canvas.width, sys.__canvas.height]
129
+ }
130
+ else if (b.length <= 2) {
131
+ b.unshift(0)
132
+ b.unshift(0)
133
+ }
134
+ sys.__ctx.clearRect(b[0], b[1], b[2], b[3])
135
+ },
136
+ return_none: true
137
+ },
138
+ '円描画': { // @ [x, y]へrの円を描画する // @ えんびょうが
139
+ type: 'func',
140
+ josi: [['へ', 'に'], ['の']],
141
+ pure: true,
142
+ fn: function (xy, r, sys) {
143
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
144
+ if (sys.__fillStyle == '' && sys.__strokeStyle == '') {return}
145
+ sys.__ctx.beginPath()
146
+ sys.__ctx.arc(xy[0], xy[1], r, 0, 2 * Math.PI, false)
147
+ if (sys.__fillStyle != '') {sys.__ctx.fill()}
148
+ if (sys.__strokeStyle != '') {sys.__ctx.stroke()}
149
+ },
150
+ return_none: true
151
+ },
152
+ '楕円描画': { // @ [x, y, x幅, y幅, 回転, 開始角, 終了角, 左回転か]に楕円を描画する // @ だえんびょうが
153
+ type: 'func',
154
+ josi: [['へ', 'に', 'の']],
155
+ pure: true,
156
+ fn: function (args, sys) {
157
+ console.log(args)
158
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
159
+ if (!args) {throw new Error('楕円描画の引数配列が無効です')}
160
+ if (args.length < 4) {throw new Error('楕円描画の引数配列が不足しています')}
161
+ if (args.length < 7) {
162
+ if (!args[4]) {args[4] = 0}
163
+ if (!args[5]) {args[5] = 0}
164
+ if (!args[6]) {args[6] = Math.PI * 2}
165
+ if (!args[7]) {args[7] = true}
166
+ }
167
+ if (sys.__fillStyle == '' && sys.__strokeStyle == '') {return}
168
+ sys.__ctx.beginPath()
169
+ sys.__ctx.ellipse.apply(sys.__ctx, args)
170
+ if (sys.__fillStyle != '') {sys.__ctx.fill()}
171
+ if (sys.__strokeStyle != '') {sys.__ctx.stroke()}
172
+ },
173
+ return_none: true
174
+ },
175
+ '多角形描画': { // @ 座標配列vを指定して多角形を描画する // @ たかっけいびょうが
176
+ type: 'func',
177
+ josi: [['で', 'の', 'を']],
178
+ pure: true,
179
+ fn: function (a, sys) {
180
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
181
+ if (sys.__fillStyle == '' && sys.__strokeStyle == '') {return}
182
+ sys.__ctx.beginPath()
183
+ const p = a[0]
184
+ sys.__ctx.moveTo(p[0], p[1])
185
+ for (let i = 1; i < a.length; i++) {
186
+ const t = a[i];
187
+ sys.__ctx.lineTo(t[0], t[1])
188
+ }
189
+ sys.__ctx.lineTo(p[0], p[1])
190
+ if (sys.__fillStyle != '') {sys.__ctx.fill()}
191
+ if (sys.__strokeStyle != '') {sys.__ctx.stroke()}
192
+ },
193
+ return_none: true
194
+ },
195
+ '画像読': { // @ 画像のURLを読み込んでImageオブジェクトを返す。(URLにdataスキームも指定可能) // @ がぞうよむ
196
+ type: 'func',
197
+ josi: [['の', 'を']],
198
+ pure: true,
199
+ fn: function (url, sys) {
200
+ const img = new window.Image()
201
+ img.src = url
202
+ return img
203
+ }
204
+ },
205
+ '画像逐次読': { // @ 画像のURLを読み込んでImageオブジェクトを返す。また完了時『対象』にも代入する。『逐次実行』構文で使う。 // @ がぞうちくじよむ
206
+ type: 'func',
207
+ josi: [['の', 'を']],
208
+ pure: true,
209
+ fn: function (url, sys) {
210
+ if (sys.resolve === undefined) {throw new Error('『画像逐次読』は『逐次実行』構文で使ってください。')}
211
+ sys.resolveCount++
212
+ const img = new window.Image()
213
+ img.src = url
214
+ img.onload = () => {
215
+ sys.__v0['対象'] = img
216
+ sys.resolve()
217
+ }
218
+ img.onerror = () => {
219
+ sys.__v0['対象'] = ''
220
+ sys.reject()
221
+ }
222
+ return img
223
+ }
224
+ },
225
+ '画像読時': { // @ 画像のURLを読み込んでコールバック関数Fを読み込み、変数『対象』にImageオブジェクトを代入する // @ がぞうよんだとき
226
+ type: 'func',
227
+ josi: [['で'], ['の', 'を']],
228
+ pure: true,
229
+ fn: function (f, url, sys) {
230
+ // 関数オブジェクトを得る
231
+ const func = sys.__findVar(f, null) // 文字列指定なら関数に変換
232
+ // 画像を読む
233
+ const img = new window.Image()
234
+ img.src = url
235
+ img.onload = () => {
236
+ sys.__v0['対象'] = img
237
+ func(sys)
238
+ }
239
+ img.onerror = () => {
240
+ sys.__v0['対象'] = ''
241
+ func(sys)
242
+ }
243
+ },
244
+ return_none: true
245
+ },
246
+ '画像描画': { // @ 画像IMG(またはURL)を描画先座標[x,y]へ描画し、Imageオブジェクトを返す。座標には2,4,8個の引数を指定可能。 // @ がぞうびょうが
247
+ type: 'func',
248
+ josi: [['の', 'を'], ['へ', 'に']],
249
+ pure: true,
250
+ fn: function (img, xy, sys) {
251
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
252
+ const drawFunc = (im, ctx) => {
253
+ if (xy.length === 2){
254
+ ctx.drawImage(im, xy[0], xy[1])
255
+ }
256
+ else if (xy.length === 4) {
257
+ ctx.drawImage(im, xy[0], xy[1], xy[2], xy[3])
258
+ }
259
+ else if (xy.length === 8) {
260
+ ctx.drawImage(im, xy[0], xy[1], xy[2], xy[3], xy[4], xy[5], xy[6], xy[7])
261
+ }
262
+ else {
263
+ throw new Error('『画像描画』の第二引数の配列要素は2,4,8個のいずれかです。')
264
+ }
265
+ }
266
+ if (typeof img === 'string') {
267
+ const image = new window.Image()
268
+ image.src = img
269
+ image.onload = () => {
270
+ drawFunc(image, sys.__ctx)
271
+ }
272
+ return image
273
+ } else {
274
+ drawFunc(img, sys.__ctx)
275
+ return img
276
+ }
277
+ },
278
+ return_none: false
279
+ },
280
+ '画像部分描画': { // @ 画像IMG(またはURL)の座標[sx, sy, sw, sh]を描画先座標[dx, dy, dw, dh]へ描画し、Imageオブジェクトを返す // @ がぞうぶぶんびょうが
281
+ type: 'func',
282
+ josi: [['の'], ['を', 'から'], ['へ', 'に']],
283
+ pure: true,
284
+ fn: function (img, sxy, dxy, sys) {
285
+ const errArgLen =
286
+ '『画像部分描画』に使える引数は画像と、描画する座標へ2つか、' +
287
+ '描画する座標とその位置の4つか、使用する座標と使用する位置と描画する座標と大きさの8つだけです。'
288
+ if(img && sxy){
289
+ if (!Array.isArray(sxy) && Array.isArray(img)){ //逆になっていれば入れ替える
290
+ if (typeof sxy === 'string' || String(sxy.__proto__) === '[object HTMLImageElement]'){
291
+ let sw = img
292
+ img = sxy
293
+ sxy = sw
294
+ }
295
+ }
296
+ }
297
+
298
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
299
+ const drawFunc = (im, ctx) => {
300
+ if (!dxy){
301
+ if(!sxy){
302
+ ctx.drawImage(im)
303
+ }
304
+ else if(sxy.length >= 2){ //もしsxyがあるのにdxyがなかったらdxyを代わりにする
305
+ dxy = sxy
306
+ sxy = undefined
307
+ }
308
+ }
309
+ if (dxy.length === 2)
310
+ {ctx.drawImage(im, dxy[0], dxy[1])}
311
+ else if (dxy.length === 4) {
312
+ if (!sxy) {
313
+ ctx.drawImage(im, dxy[0], dxy[1], dxy[2], dxy[3])
314
+ }
315
+ else if (sxy.length === 4){
316
+ ctx.drawImage(im, sxy[0], sxy[1], sxy[2], sxy[3], dxy[0], dxy[1], dxy[2], dxy[3])
317
+ }
318
+ else {throw new Error(errArgLen)}
319
+ }
320
+ else {throw new Error(errArgLen)}
321
+ }
322
+ if (typeof img === 'string') {
323
+ const image = new window.Image()
324
+ image.src = img
325
+ image.onload = () => {
326
+ drawFunc(image, sys.__ctx)
327
+ }
328
+ return image
329
+ } else {
330
+ drawFunc(img, sys.__ctx)
331
+ return img
332
+ }
333
+ },
334
+ return_none: false
335
+ },
336
+ '描画フォント設定': { // @ 描画フォントを指定する(CSSのフォント設定と同じ 例「36px Aria」)。フォントサイズのみの指定も可。 // @ びょうがふぉんとせってい
337
+ type: 'func',
338
+ josi: [['を', 'の', 'で', 'に']],
339
+ pure: true,
340
+ fn: function (n, sys) {
341
+ // 数値だけならフォントサイズのみの指定
342
+ if (typeof(n) === 'number') {
343
+ n = n + 'px sans-serif'
344
+ }
345
+ // ピクセル数のみの指定なら適当にフォントを足す
346
+ else if (/^[0-9]+(px|em)$/.test(n)) {
347
+ n = n + ' sans-serif'
348
+ }
349
+ sys.__ctx.font = n
350
+ },
351
+ return_none: true
352
+ },
353
+ '文字描画': { // @ [x, y]へテキストSを描画する(描画フォント設定でサイズなど指定) // @ もじびょうが
354
+ type: 'func',
355
+ josi: [['へ', 'に'], ['の', 'を']],
356
+ pure: true,
357
+ fn: function (xy, s, sys) {
358
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
359
+ sys.__ctx.fillText(s, xy[0], xy[1])
360
+ },
361
+ return_none: true
362
+ },
363
+ '文字描画幅取得': { // @ テキストSを指定して文字の描画幅を取得する // @ もじびょうがはばしゅとく
364
+ type: 'func',
365
+ josi: [['の']],
366
+ pure: true,
367
+ fn: function (s, sys) {
368
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
369
+ return sys.__ctx.measureText(s)
370
+ },
371
+ return_none: true
372
+ },
373
+ '描画起点設定': { // @ 描画位置の起点を[x,y]へ設定する(translate) // @ びょうがきてんせってい
374
+ type: 'func',
375
+ josi: [['へ', 'に']],
376
+ pure: true,
377
+ fn: function (xy, sys) {
378
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
379
+ sys.__ctx.translate(xy[0],xy[1])
380
+ },
381
+ return_none: true
382
+ },
383
+ '描画回転': { // @ 描画内容をA度だけ回転する(rotate) // @ びょうがかいてん
384
+ type: 'func',
385
+ josi: [['だけ', 'に', 'へ']],
386
+ pure: true,
387
+ fn: function (a, sys) {
388
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
389
+ sys.__ctx.rotate(a * Math.PI / 180)
390
+ },
391
+ return_none: true
392
+ },
393
+ '描画拡大': { // @ 描画内容を[x方向,y方向]だけ拡大する(scale) // @ びょうがかくだい
394
+ type: 'func',
395
+ josi: [['だけ', 'に', 'へ']],
396
+ pure: true,
397
+ fn: function (xy, sys) {
398
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
399
+ sys.__ctx.scale(xy[0], xy[1])
400
+ },
401
+ return_none: true
402
+ },
403
+ '描画変換マトリクス設定': { // @ 描画内容を[a,b,c,d,e,f]の変換マトリクスに設定。既存内容を破棄して設定(setTransform) // @ びょうがへんかんまとりくすせってい
404
+ type: 'func',
405
+ josi: [['だけ', 'に', 'へ']],
406
+ pure: true,
407
+ fn: function (a, sys) {
408
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
409
+ sys.__ctx.setTransform(a[0],a[1],a[2],a[3],a[4],a[5],a[6])
410
+ },
411
+ return_none: true
412
+ },
413
+ '描画変換マトリクス追加': { // @ 描画内容を[a,b,c,d,e,f]のマトリクスで変換。既存のマトリクスに掛け合わせる(transform) // @ びょうがへんかんまとりくすついか
414
+ type: 'func',
415
+ josi: [['だけ', 'に', 'へ']],
416
+ pure: true,
417
+ fn: function (a, sys) {
418
+ if (!sys.__ctx) {throw new Error(errMsgCanvasInit)}
419
+ sys.__ctx.transform(a[0],a[1],a[2],a[3],a[4],a[5],a[6])
420
+ },
421
+ return_none: true
422
+ },
423
+ '描画データURL変換': { // @ 描画内容をPNG形式のデータURLに変換して得る。 // @ びょうがでーたURLへんかん
424
+ type: 'func',
425
+ josi: [],
426
+ pure: false,
427
+ fn: function (sys) {
428
+ const cv = sys.__v0['描画中キャンバス']
429
+ const url = cv.toDataURL('image/png')
430
+ return url
431
+ }
432
+ },
433
+ '描画ダウンロードリンク作成': { // @ 描画内容をPNG形式のデータURLに変換してDOMに設定する。 // @ びょうがだうんろーどりんくさくせい
434
+ type: 'func',
435
+ josi: [['へ', 'に']],
436
+ pure: false,
437
+ fn: function (dom, sys) {
438
+ if (typeof dom === 'string') { dom = document.querySelector(dom)}
439
+ if (!dom){ throw new Error('『描画ダウンロードリンク作成』でDOMが見当たりません。')}
440
+ const cv = sys.__v0['描画中キャンバス']
441
+ if (!cv){ throw new Error('『描画ダウンロード』で描画中キャンバスが設定されていません。')}
442
+ dom.href = cv.toDataURL('image/png')
443
+ dom.download = 'canvas.png'
444
+ },
445
+ return_none: true
446
+ },
447
+ '描画ダウンロード': { // @ 描画内容をPNG形式のデータURLに変換してダウンロードする。(「クリックした時」などと組み合わせて使う) // @ びょうがだうんろーど
448
+ type: 'func',
449
+ josi: [],
450
+ pure: false,
451
+ fn: function (sys) {
452
+ if (typeof dom === 'string') { dom = document.querySelector(dom)}
453
+ const cv = sys.__v0['描画中キャンバス']
454
+ if (!cv){ throw new Error('『描画ダウンロード』で描画中キャンバスが設定されていません。')}
455
+ const a = document.createElement('a')
456
+ a.href = cv.toDataURL('image/png')
457
+ a.download = 'canvas.png'
458
+ a.click()
459
+ return true
460
+ }
461
+ }
462
+ }