nadesiko3 3.3.49 → 3.3.52

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