nadesiko3 3.3.49 → 3.3.50

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 (342) 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 +79 -0
  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 +110 -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 +864 -858
  32. package/core/src/nako3.mts +976 -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 +107 -107
  48. package/core/src/nako_global.mts +138 -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 +2439 -2439
  60. package/core/src/nako_parser3.mts +2195 -2195
  61. package/core/src/nako_parser_base.mjs +370 -370
  62. package/core/src/nako_parser_base.mts +370 -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 +25 -25
  73. package/core/src/nako_types.mts +151 -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 +1 -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/wnako3webworker.js +1 -1
  146. package/release/wnako3webworker.js.LICENSE.txt +131 -0
  147. package/src/.DS_Store +0 -0
  148. package/src/browsers.txt +12 -11
  149. package/src/browsers_agents.json +2 -2
  150. package/src/browsers_agents.mjs +1 -1
  151. package/src/cnako3.mjs +17 -17
  152. package/src/cnako3.mts +18 -18
  153. package/src/cnako3mod.mjs +707 -707
  154. package/src/cnako3mod.mts +712 -712
  155. package/src/commander_ja.mjs +164 -164
  156. package/src/commander_ja.mts +161 -161
  157. package/src/enako3.mjs +68 -68
  158. package/src/era.mjs +22 -22
  159. package/src/image_turtle-elephant.mjs +2 -2
  160. package/src/image_turtle-panda.mjs +2 -2
  161. package/src/image_turtle64.mjs +2 -2
  162. package/src/index.mjs +9 -9
  163. package/src/index.mts +10 -10
  164. package/src/nako3editorfix.sfd +106 -106
  165. package/src/nako_version.mjs +8 -8
  166. package/src/nako_version.mts +2 -2
  167. package/src/plugin_browser.mjs +213 -213
  168. package/src/plugin_browser.mts +206 -206
  169. package/src/plugin_browser_ajax.mjs +399 -399
  170. package/src/plugin_browser_audio.mjs +109 -109
  171. package/src/plugin_browser_canvas.mjs +449 -449
  172. package/src/plugin_browser_chart.mjs +294 -294
  173. package/src/plugin_browser_color.mjs +49 -49
  174. package/src/plugin_browser_crypto.mjs +26 -26
  175. package/src/plugin_browser_dialog.mjs +53 -53
  176. package/src/plugin_browser_dom_basic.mjs +336 -336
  177. package/src/plugin_browser_dom_event.mjs +193 -193
  178. package/src/plugin_browser_dom_parts.mjs +396 -396
  179. package/src/plugin_browser_geolocation.mjs +51 -51
  180. package/src/plugin_browser_hotkey.mjs +25 -25
  181. package/src/plugin_browser_html.mjs +59 -59
  182. package/src/plugin_browser_in_worker.mjs +45 -45
  183. package/src/plugin_browser_location.mjs +21 -21
  184. package/src/plugin_browser_speech.mjs +111 -111
  185. package/src/plugin_browser_storage.mjs +121 -121
  186. package/src/plugin_browser_system.mjs +31 -31
  187. package/src/plugin_browser_websocket.mjs +73 -73
  188. package/src/plugin_caniuse.mjs +29 -29
  189. package/src/plugin_datetime.mjs +394 -394
  190. package/src/plugin_httpserver.mjs +277 -277
  191. package/src/plugin_httpserver.mts +286 -286
  192. package/src/plugin_kansuji.mjs +224 -224
  193. package/src/plugin_keigo.mjs +55 -55
  194. package/src/plugin_markup.mjs +32 -32
  195. package/src/plugin_node.mjs +1047 -1047
  196. package/src/plugin_node.mts +980 -980
  197. package/src/plugin_turtle.mjs +647 -647
  198. package/src/plugin_webworker.mjs +334 -334
  199. package/src/plugin_weykturtle3d.mjs +1214 -1214
  200. package/src/plugin_worker.mjs +95 -95
  201. package/src/repl.nako3 +63 -63
  202. package/src/wnako3.mjs +12 -12
  203. package/src/wnako3.mts +11 -11
  204. package/src/wnako3_editor.css +215 -215
  205. package/src/wnako3_editor.mjs +1542 -1542
  206. package/src/wnako3_editor.mts +1658 -1657
  207. package/src/wnako3mod.mjs +213 -213
  208. package/src/wnako3mod.mts +214 -214
  209. package/src/wnako3webworker.mjs +69 -69
  210. package/test/.DS_Store +0 -0
  211. package/test/ace_editor/karma.config.js +94 -94
  212. package/test/ace_editor/test/.babelrc.json +3 -3
  213. package/test/ace_editor/test/ace_editor_test.js +178 -178
  214. package/test/ace_editor/test/html/custom_context.html +139 -139
  215. package/test/async/async_basic_test.mjs +122 -122
  216. package/test/browser/.DS_Store +0 -0
  217. package/test/browser/karma.config.js +221 -221
  218. package/test/browser/test/.babelrc.json +3 -3
  219. package/test/browser/test/compare_util.js +50 -50
  220. package/test/browser/test/html/div_basic.html +2 -2
  221. package/test/browser/test/html/event_dom_form.html +4 -4
  222. package/test/browser/test/html/event_dom_scrolldiv.html +5 -5
  223. package/test/browser/test/import_plugin_checker.js +24 -24
  224. package/test/browser/test/plugin_browser_test.js +51 -51
  225. package/test/browser/test/plugin_browser_test_ajax.js +123 -123
  226. package/test/browser/test/plugin_browser_test_color.js +18 -18
  227. package/test/browser/test/plugin_browser_test_dialog.js +72 -72
  228. package/test/browser/test/plugin_browser_test_dom_event.js +598 -598
  229. package/test/browser/test/plugin_browser_test_dom_parts.js +125 -125
  230. package/test/browser/test/plugin_browser_test_system.js +9 -9
  231. package/test/browser/test/plugin_turtle_test.js +817 -817
  232. package/test/browser/test/plugin_webworker_test.js +86 -86
  233. package/test/browser/test/require_test.js +68 -68
  234. package/test/bundled/.DS_Store +0 -0
  235. package/test/bundled/karma.config.base.js +117 -117
  236. package/test/bundled/karma.config.js +86 -86
  237. package/test/bundled/test/.babelrc.json +3 -3
  238. package/test/bundled/test/bundled_test.js +69 -69
  239. package/test/bundled/test/html/custom_context.html +65 -65
  240. package/test/bundled/test/html/custom_debug.html +66 -66
  241. package/test/bundled/test4b.cmd +52 -52
  242. package/test/bundled/test_base/.DS_Store +0 -0
  243. package/test/bundled/test_base/.babelrc.json +3 -3
  244. package/test/bundled/test_base/_checktool_test.js +25 -25
  245. package/test/bundled/test_base/basic_ajax_test.js +56 -56
  246. package/test/bundled/test_base/basic_async_test.js +18 -18
  247. package/test/bundled/test_base/basic_test.js +153 -153
  248. package/test/bundled/test_base/calc_test.js +132 -132
  249. package/test/bundled/test_base/css/browsers_box.css +114 -114
  250. package/test/bundled/test_base/html/custom_context.html +69 -69
  251. package/test/bundled/test_base/html/custom_debug.html +71 -71
  252. package/test/bundled/test_base/js/browsers_box.js +72 -72
  253. package/test/bundled/test_base/plugin_csv_test.js +37 -37
  254. package/test/bundled/test_base/plugin_datetime_test.js +115 -115
  255. package/test/bundled/test_base/plugin_kansuji_test.js +49 -49
  256. package/test/bundled/test_base/plugin_system_test.js +410 -410
  257. package/test/bundled/test_base/plugin_webworker_test.js +53 -53
  258. package/test/bundled/test_base/test_utils.js +191 -191
  259. package/test/common/.DS_Store +0 -0
  260. package/test/common/plugin_browser_test.mjs +22 -22
  261. package/test/common/plugin_browser_ut_audio_test.mjs +108 -108
  262. package/test/common/plugin_browser_ut_color_test.mjs +21 -21
  263. package/test/common/plugin_browser_ut_dialog_test.mjs +100 -100
  264. package/test/common/plugin_browser_ut_html_test.mjs +13 -13
  265. package/test/common/plugin_browser_ut_system_test.mjs +10 -10
  266. package/test/common/plugin_markup_test.mjs +23 -23
  267. package/test/jsconfig.json +19 -19
  268. package/test/karma.config.js +91 -91
  269. package/test/node/.DS_Store +0 -0
  270. package/test/node/async_test.mjs +96 -96
  271. package/test/node/commander_ja_test.mjs +89 -89
  272. package/test/node/error_message_test.mjs +243 -243
  273. package/test/node/kai_test.nako3 +6 -6
  274. package/test/node/node_test.mjs +60 -60
  275. package/test/node/plugin_broken.js.txt +3 -3
  276. package/test/node/plugin_browser_ut_ajax_test.mjs.todo +357 -357
  277. package/test/node/plugin_browser_ut_location_test.mjs +42 -42
  278. package/test/node/plugin_markup_test.mjs +47 -47
  279. package/test/node/plugin_math_test.mjs +45 -45
  280. package/test/node/plugin_node_test.mjs +98 -98
  281. package/test/node/plugin_test.mjs +44 -44
  282. package/test/node/relative_import_test_1.nako3 +1 -1
  283. package/test/node/relative_import_test_2.nako3 +2 -2
  284. package/test/node/require_nako3_test.mjs +67 -67
  285. package/test/node/requiretest.nako3 +4 -4
  286. package/test/node/requiretest_indirect.nako3 +1 -1
  287. package/test/node/requiretest_name.nako3 +5 -5
  288. package/test/node/runtime_error.nako3 +2 -2
  289. package/test/node/scope1.nako3 +10 -10
  290. package/test/node/scope2.nako3 +12 -12
  291. package/test/node/side_effects_test.mjs +39 -39
  292. package/test/node/sjis.txt +5 -5
  293. package/test/node/syntax_error.nako3 +1 -1
  294. package/test/node/wnako3_editor_test.mjs +384 -384
  295. package/tools/.DS_Store +0 -0
  296. package/tools/README.md +12 -12
  297. package/tools/check_new_version.nako3 +25 -25
  298. package/tools/nako3edit/.DS_Store +0 -0
  299. package/tools/nako3edit/a.sqlite3 +0 -0
  300. package/tools/nako3edit/html/.DS_Store +0 -0
  301. package/tools/nako3edit/html/daisyui/LICENSE +22 -22
  302. package/tools/nako3edit/html/daisyui/version_2.14.1 +1 -1
  303. package/tools/nako3edit/html/edit.html +170 -170
  304. package/tools/nako3edit/html/edit_plugin.js +6 -6
  305. package/tools/nako3edit/html/files.html +125 -125
  306. package/tools/nako3edit/html/nako3edit.css +65 -65
  307. package/tools/nako3edit/index.mjs +248 -248
  308. package/tools/nako3server/index.html +10 -10
  309. package/tools/nako3server/index.mjs +116 -116
  310. package/tools/nako3server/index.nako3 +34 -34
  311. package/core/.editorconfig +0 -6
  312. package/core/.eslintrc.cjs +0 -33
  313. package/core/.github/dependabot.yml +0 -7
  314. package/core/.github/workflows/nodejs.yml +0 -37
  315. package/core/.github/workflows/super-linter.yml +0 -61
  316. package/core/.github/workflows/textlint.yml +0 -199
  317. package/core/index.mts +0 -21
  318. package/core/test/array_test.mjs +0 -34
  319. package/core/test/basic_test.mjs +0 -344
  320. package/core/test/calc_test.mjs +0 -140
  321. package/core/test/core_module_test.mjs +0 -23
  322. package/core/test/debug_test.mjs +0 -16
  323. package/core/test/dncl_test.mjs +0 -94
  324. package/core/test/error_message_test.mjs +0 -210
  325. package/core/test/error_test.mjs +0 -16
  326. package/core/test/flow_test.mjs +0 -373
  327. package/core/test/func_call.mjs +0 -160
  328. package/core/test/func_test.mjs +0 -149
  329. package/core/test/indent_test.mjs +0 -364
  330. package/core/test/lex_test.mjs +0 -168
  331. package/core/test/literal_test.mjs +0 -73
  332. package/core/test/nako_lexer_test.mjs +0 -35
  333. package/core/test/nako_logger_test.mjs +0 -76
  334. package/core/test/nako_logger_test.mts +0 -78
  335. package/core/test/plugin_csv_test.mjs +0 -38
  336. package/core/test/plugin_promise_test.mjs +0 -18
  337. package/core/test/plugin_system_test.mjs +0 -630
  338. package/core/test/prepare_test.mjs +0 -96
  339. package/core/test/re_test.mjs +0 -22
  340. package/core/test/side_effects_test.mjs +0 -92
  341. package/core/test/variable_scope_test.mjs +0 -149
  342. 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
+ }