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.
- package/LICENSE +21 -0
- package/README.md +107 -0
- package/bin/cnako3 +10 -0
- package/bin/cnako3.bat +11 -0
- package/bin/nako3server.bat +6 -0
- package/demo/ace_editor.html +90 -0
- package/demo/ace_editor_tabs.html +162 -0
- package/demo/basic.html +71 -0
- package/demo/browsers.html +128 -0
- package/demo/css/basic.css +3 -0
- package/demo/css/common.css +157 -0
- package/demo/css/editor.css +8 -0
- package/demo/css/flow.css +3 -0
- package/demo/css/index.css +3 -0
- package/demo/extlib/ace@1.4.12/ace.js +17 -0
- package/demo/extlib/ace@1.4.12/ext-code_lens.min.js +1 -0
- package/demo/extlib/ace@1.4.12/ext-language_tools.min.js +1 -0
- package/demo/extlib/ace@1.4.12/ext-options.min.js +1 -0
- package/demo/extlib/ace@1.4.12/ext-settings_menu.js +8 -0
- package/demo/extlib/ace@1.4.12/keybinding-vscode.js +8 -0
- package/demo/extlib/ace@1.4.12/theme-monokai.js +8 -0
- package/demo/extlib/ace@1.4.12/theme-xcode.js +8 -0
- package/demo/extlib/chart.js@3.2.1/chart.min.js +13 -0
- package/demo/extlib/pure-min.css +11 -0
- package/demo/flow.html +97 -0
- package/demo/graph.html +53 -0
- package/demo/image/nako.png +0 -0
- package/demo/image/nakopad-icon256.png +0 -0
- package/demo/image/turtle.fla +0 -0
- package/demo/image/turtle.png +0 -0
- package/demo/index.html +134 -0
- package/demo/js/common.js +17 -0
- package/demo/js/turtle3d_test.js +44 -0
- package/demo/js/turtle_test.js +44 -0
- package/demo/runscript.html +47 -0
- package/demo/runscript2.html +33 -0
- package/demo/turtle.html +58 -0
- package/demo/turtle2.html +141 -0
- package/demo/turtle3.html +278 -0
- package/demo/turtle3d.html +58 -0
- package/demo/turtle3d2.html +107 -0
- package/demo/version.html +24 -0
- package/doc/SETUP.md +172 -0
- package/doc/about.md +34 -0
- package/doc/browsers.md +60 -0
- package/doc/docgen.md +21 -0
- package/doc/editor.md +44 -0
- package/doc/files.md +37 -0
- package/doc/plugins.md +195 -0
- package/doc/release.md +78 -0
- package/doc/win32.md +57 -0
- package/package.json +196 -0
- package/release/_hash.txt +65 -0
- package/release/_script-tags.txt +13 -0
- package/release/command.json +1 -0
- package/release/command.json.js +1 -0
- package/release/command_cnako3.json +1 -0
- package/release/command_list.json +1 -0
- package/release/editor.js +2 -0
- package/release/editor.js.LICENSE.txt +32 -0
- package/release/josi.json +48 -0
- package/release/nako_gen_async.js +1 -0
- package/release/nako_gen_async.js.LICENSE.txt +595 -0
- package/release/plugin_caniuse.js +1 -0
- package/release/plugin_caniuse.js.LICENSE.txt +411 -0
- package/release/plugin_csv.js +1 -0
- package/release/plugin_csv.js.LICENSE.txt +367 -0
- package/release/plugin_datetime.js +1 -0
- package/release/plugin_datetime.js.LICENSE.txt +471 -0
- package/release/plugin_kansuji.js +1 -0
- package/release/plugin_kansuji.js.LICENSE.txt +491 -0
- package/release/plugin_markup.js +1 -0
- package/release/plugin_markup.js.LICENSE.txt +363 -0
- package/release/plugin_turtle.js +1 -0
- package/release/plugin_turtle.js.LICENSE.txt +435 -0
- package/release/plugin_webworker.js +1 -0
- package/release/plugin_webworker.js.LICENSE.txt +491 -0
- package/release/version.js +2 -0
- package/release/version.js.LICENSE.txt +32 -0
- package/release/wnako3.js +2 -0
- package/release/wnako3.js.LICENSE.txt +1 -0
- package/release/wnako3webworker.js +1 -0
- package/release/wnako3webworker.js.LICENSE.txt +847 -0
- package/release/yoyakugo.json +30 -0
- package/src/browsers.md +60 -0
- package/src/cnako3.js +466 -0
- package/src/commander_ja.js +154 -0
- package/src/enako3.js +69 -0
- package/src/era.json +22 -0
- package/src/index.js +5 -0
- package/src/nako3.js +836 -0
- package/src/nako3_assert.js +37 -0
- package/src/nako3editorfix.sfd +106 -0
- package/src/nako3editorfix.woff +0 -0
- package/src/nako3server.js +51 -0
- package/src/nako_colors.js +86 -0
- package/src/nako_errors.js +176 -0
- package/src/nako_gen.js +1459 -0
- package/src/nako_gen_async.js +1622 -0
- package/src/nako_global.js +113 -0
- package/src/nako_indent.js +480 -0
- package/src/nako_josi_list.js +46 -0
- package/src/nako_lex_rules.js +259 -0
- package/src/nako_lexer.js +576 -0
- package/src/nako_logger.js +138 -0
- package/src/nako_parser3.js +1768 -0
- package/src/nako_parser_base.js +265 -0
- package/src/nako_parser_const.js +37 -0
- package/src/nako_prepare.js +293 -0
- package/src/nako_reserved_words.js +35 -0
- package/src/nako_source_mapping.js +251 -0
- package/src/nako_test.js +37 -0
- package/src/nako_version.js +8 -0
- package/src/plugin_browser.js +191 -0
- package/src/plugin_browser_ajax.js +352 -0
- package/src/plugin_browser_audio.js +109 -0
- package/src/plugin_browser_canvas.js +462 -0
- package/src/plugin_browser_chart.js +296 -0
- package/src/plugin_browser_color.js +49 -0
- package/src/plugin_browser_crypto.js +26 -0
- package/src/plugin_browser_dialog.js +53 -0
- package/src/plugin_browser_dom_basic.js +322 -0
- package/src/plugin_browser_dom_event.js +193 -0
- package/src/plugin_browser_dom_parts.js +163 -0
- package/src/plugin_browser_geolocation.js +51 -0
- package/src/plugin_browser_hotkey.js +25 -0
- package/src/plugin_browser_html.js +59 -0
- package/src/plugin_browser_in_worker.js +44 -0
- package/src/plugin_browser_location.js +21 -0
- package/src/plugin_browser_speech.js +111 -0
- package/src/plugin_browser_storage.js +121 -0
- package/src/plugin_browser_system.js +12 -0
- package/src/plugin_browser_websocket.js +73 -0
- package/src/plugin_caniuse.js +24 -0
- package/src/plugin_csv.js +57 -0
- package/src/plugin_datetime.js +414 -0
- package/src/plugin_express.js +212 -0
- package/src/plugin_kansuji.js +224 -0
- package/src/plugin_keigo.js +55 -0
- package/src/plugin_markup.js +32 -0
- package/src/plugin_math.js +319 -0
- package/src/plugin_node.js +1018 -0
- package/src/plugin_promise.js +94 -0
- package/src/plugin_system.js +2109 -0
- package/src/plugin_test.js +38 -0
- package/src/plugin_turtle.js +646 -0
- package/src/plugin_webworker.js +334 -0
- package/src/plugin_weykturtle3d.js +1216 -0
- package/src/plugin_worker.js +92 -0
- package/src/repl.nako3 +63 -0
- package/src/turtle-elephant.png +0 -0
- package/src/turtle-panda.png +0 -0
- package/src/turtle64.png +0 -0
- package/src/wnako3.js +162 -0
- package/src/wnako3_editor.css +215 -0
- package/src/wnako3_editor.js +1645 -0
- package/src/wnako3_editor_marker_red.png +0 -0
- package/src/wnako3_editor_marker_red.xcf +0 -0
- package/src/wnako3_editor_marker_yellow.png +0 -0
- package/src/wnako3_editor_marker_yellow.xcf +0 -0
- package/src/wnako3webworker.js +70 -0
- package/test/ace_editor/karma.config.js +94 -0
- package/test/ace_editor/test/.babelrc.json +3 -0
- package/test/ace_editor/test/ace_editor_test.js +178 -0
- package/test/ace_editor/test/html/custom_context.html +140 -0
- package/test/async/async_basic_test.js +124 -0
- package/test/browser/karma.config.js +212 -0
- package/test/browser/test/.babelrc.json +3 -0
- package/test/browser/test/compare_util.js +50 -0
- package/test/browser/test/html/canvas_basic.html +1 -0
- package/test/browser/test/html/div_basic.html +2 -0
- package/test/browser/test/html/event_dom_form.html +4 -0
- package/test/browser/test/html/event_dom_scrolldiv.html +5 -0
- package/test/browser/test/image/canvas_test1.png +0 -0
- package/test/browser/test/image/canvas_test2.png +0 -0
- package/test/browser/test/image/canvas_test3.png +0 -0
- package/test/browser/test/image/canvas_test4.png +0 -0
- package/test/browser/test/image/canvas_test7.png +0 -0
- package/test/browser/test/image/canvas_test8.png +0 -0
- package/test/browser/test/image/canvas_test_blank.png +0 -0
- package/test/browser/test/image/elephant_kana.png +0 -0
- package/test/browser/test/image/panda_kana.png +0 -0
- package/test/browser/test/image/turtle_kana.png +0 -0
- package/test/browser/test/import_plugin_checker.js +24 -0
- package/test/browser/test/plugin_browser_test.js +52 -0
- package/test/browser/test/plugin_browser_test_ajax.js +123 -0
- package/test/browser/test/plugin_browser_test_color.js +18 -0
- package/test/browser/test/plugin_browser_test_dialog.js +72 -0
- package/test/browser/test/plugin_browser_test_dom_event.js +598 -0
- package/test/browser/test/plugin_browser_test_dom_parts.js +125 -0
- package/test/browser/test/plugin_browser_test_system.js +9 -0
- package/test/browser/test/plugin_turtle_test.js +817 -0
- package/test/browser/test/plugin_webworker_test.js +87 -0
- package/test/browser/test/require_test.js +71 -0
- package/test/bundled/karma.config.base.js +117 -0
- package/test/bundled/karma.config.js +86 -0
- package/test/bundled/test/.babelrc.json +3 -0
- package/test/bundled/test/bundled_test.js +69 -0
- package/test/bundled/test/html/custom_context.html +65 -0
- package/test/bundled/test/html/custom_debug.html +66 -0
- package/test/bundled/test4b.cmd +52 -0
- package/test/bundled/test_base/.babelrc.json +3 -0
- package/test/bundled/test_base/_checktool_test.js +25 -0
- package/test/bundled/test_base/basic_ajax_test.js +56 -0
- package/test/bundled/test_base/basic_async_test.js +18 -0
- package/test/bundled/test_base/basic_test.js +153 -0
- package/test/bundled/test_base/calc_test.js +132 -0
- package/test/bundled/test_base/css/browsers_box.css +114 -0
- package/test/bundled/test_base/html/custom_context.html +69 -0
- package/test/bundled/test_base/html/custom_debug.html +71 -0
- package/test/bundled/test_base/js/browsers_box.js +72 -0
- package/test/bundled/test_base/plugin_csv_test.js +37 -0
- package/test/bundled/test_base/plugin_datetime_test.js +115 -0
- package/test/bundled/test_base/plugin_kansuji_test.js +49 -0
- package/test/bundled/test_base/plugin_system_test.js +410 -0
- package/test/bundled/test_base/plugin_webworker_test.js +53 -0
- package/test/bundled/test_base/resources/ok.txt +1 -0
- package/test/bundled/test_base/test_utils.js +191 -0
- package/test/common/array_test.js +40 -0
- package/test/common/basic_test.js +317 -0
- package/test/common/calc_test.js +139 -0
- package/test/common/debug_test.js +16 -0
- package/test/common/error_test.js +16 -0
- package/test/common/flow_test.js +360 -0
- package/test/common/func_call.js +136 -0
- package/test/common/func_test.js +149 -0
- package/test/common/indent_test.js +362 -0
- package/test/common/lex_test.js +146 -0
- package/test/common/literal_test.js +72 -0
- package/test/common/nako_logger_test.js +26 -0
- package/test/common/plugin_browser_test.js +24 -0
- package/test/common/plugin_browser_ut_audio_test.js +88 -0
- package/test/common/plugin_browser_ut_color_test.js +21 -0
- package/test/common/plugin_browser_ut_dialog_test.js +100 -0
- package/test/common/plugin_browser_ut_html_test.js +13 -0
- package/test/common/plugin_browser_ut_system_test.js +10 -0
- package/test/common/plugin_csv_test.js +39 -0
- package/test/common/plugin_datetime_test.js +120 -0
- package/test/common/plugin_kansuji_test.js +59 -0
- package/test/common/plugin_promise_test.js +18 -0
- package/test/common/plugin_system_test.js +451 -0
- package/test/common/prepare_test.js +93 -0
- package/test/common/re_test.js +20 -0
- package/test/common/variable_scope_test.js +105 -0
- package/test/jsconfig.json +19 -0
- package/test/karma.config.js +91 -0
- package/test/node/add_test.nako3 +1 -0
- package/test/node/async_test.js +80 -0
- package/test/node/commander_ja_test.js +82 -0
- package/test/node/error_message_test.js +244 -0
- package/test/node/kai_test.nako3 +6 -0
- package/test/node/node_test.js +43 -0
- package/test/node/plugin_broken.js.txt +3 -0
- package/test/node/plugin_browser_ut_ajax_test.js +355 -0
- package/test/node/plugin_browser_ut_location_test.js +32 -0
- package/test/node/plugin_markup_test.js +44 -0
- package/test/node/plugin_math_test.js +42 -0
- package/test/node/plugin_node_test.js +93 -0
- package/test/node/plugin_test.js +16 -0
- package/test/node/relative_import_test_1.nako3 +1 -0
- package/test/node/relative_import_test_2.nako3 +2 -0
- package/test/node/require_nako3_test.js +59 -0
- package/test/node/requiretest.nako3 +4 -0
- package/test/node/requiretest_indirect.nako3 +1 -0
- package/test/node/requiretest_name.nako3 +5 -0
- package/test/node/runtime_error.nako3 +2 -0
- package/test/node/side_effects_test.js +106 -0
- package/test/node/sjis.txt +5 -0
- package/test/node/syntax_error.nako3 +2 -0
- package/test/node/wnako3_editor_test.js +360 -0
- package/tools/README.md +7 -0
- package/tools/nako3edit/html/edit.html +83 -0
- package/tools/nako3edit/html/edit_plugin.js +6 -0
- package/tools/nako3edit/html/files.html +49 -0
- package/tools/nako3edit/html/nako3edit.css +66 -0
- package/tools/nako3edit/index.nako3 +145 -0
- package/tools/nako3edit/run.js +12 -0
- package/tools/nako3server/html/edit.html +104 -0
- package/tools/nako3server/html/edit_plugin.js +6 -0
- package/tools/nako3server/html/files.html +53 -0
- package/tools/nako3server/html/nako3edit.css +66 -0
- package/tools/nako3server/index.nako3 +129 -0
- package/tools/nako3server/run.js +12 -0
|
@@ -0,0 +1,817 @@
|
|
|
1
|
+
/* global __html__ */
|
|
2
|
+
import { assert } from 'chai'
|
|
3
|
+
import NakoCompiler from 'nako3/nako3.js'
|
|
4
|
+
import { importStatus } from './import_plugin_checker.js'
|
|
5
|
+
import PluginTurtle from 'nako3/plugin_turtle'
|
|
6
|
+
|
|
7
|
+
const htmlPath = 'test/html/'
|
|
8
|
+
const imagePath = '/test/image/'
|
|
9
|
+
|
|
10
|
+
const waitTimer = (second) => {
|
|
11
|
+
return new Promise((resolve) => {
|
|
12
|
+
setTimeout(() => {
|
|
13
|
+
resolve()
|
|
14
|
+
}, second * 1000)
|
|
15
|
+
})
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const setImageSmoothingEnabledToCtx = (ctx, value) => {
|
|
19
|
+
ctx.mozImageSmoothingEnabled = value
|
|
20
|
+
ctx.webkitImageSmoothingEnabled = value
|
|
21
|
+
ctx.msImageSmoothingEnabled = value
|
|
22
|
+
ctx.imageSmoothingEnabled = value
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const getImageDataFromUrl = (url) => {
|
|
26
|
+
return new Promise((resolve, reject) => {
|
|
27
|
+
const img = new Image()
|
|
28
|
+
img.onload = () => {
|
|
29
|
+
img.onload = null
|
|
30
|
+
img.onerror = null
|
|
31
|
+
const canvas = document.createElement('canvas')
|
|
32
|
+
canvas.width = img.width
|
|
33
|
+
canvas.height = img.height
|
|
34
|
+
document.body.appendChild(canvas)
|
|
35
|
+
const ctx = canvas.getContext('2d')
|
|
36
|
+
ctx.clearRect(0, 0, canvas.width, canvas.height)
|
|
37
|
+
ctx.globalCompositeOperation = 'copy'
|
|
38
|
+
setImageSmoothingEnabledToCtx(ctx, false)
|
|
39
|
+
ctx.drawImage(img, 0, 0)
|
|
40
|
+
|
|
41
|
+
resolve(ctx.getImageData(0, 0, canvas.width, canvas.height))
|
|
42
|
+
}
|
|
43
|
+
img.onerror = () => {
|
|
44
|
+
img.onload = null
|
|
45
|
+
img.onerror = null
|
|
46
|
+
reject(new Error('load error'))
|
|
47
|
+
}
|
|
48
|
+
img.src = url
|
|
49
|
+
})
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const getMergedCanvas = (canvasId, turtleIds) => {
|
|
53
|
+
return new Promise((resolve, reject) => {
|
|
54
|
+
const cv = document.getElementById(canvasId)
|
|
55
|
+
|
|
56
|
+
if (cv == null) {
|
|
57
|
+
reject(new Error('fail create canvas'))
|
|
58
|
+
return
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
const rect = cv.getBoundingClientRect()
|
|
62
|
+
const w = parseInt(cv.width, 10)
|
|
63
|
+
const h = parseInt(cv.height, 10)
|
|
64
|
+
const rx = rect.left + window.pageXOffset
|
|
65
|
+
const ry = rect.top + window.pageYOffset
|
|
66
|
+
|
|
67
|
+
const canvas = document.createElement('canvas')
|
|
68
|
+
canvas.width = w
|
|
69
|
+
canvas.height = h
|
|
70
|
+
document.body.appendChild(canvas)
|
|
71
|
+
|
|
72
|
+
const ctx = canvas.getContext('2d')
|
|
73
|
+
ctx.clearRect(0, 0, w, h)
|
|
74
|
+
|
|
75
|
+
const ctxm = cv.getContext('2d')
|
|
76
|
+
const imgdtm = ctxm.getImageData(0, 0, w, h)
|
|
77
|
+
ctx.globalCompositeOperation = 'copy'
|
|
78
|
+
setImageSmoothingEnabledToCtx(ctx, false)
|
|
79
|
+
ctx.putImageData(imgdtm, 0, 0)
|
|
80
|
+
ctx.globalCompositeOperation = 'source-over'
|
|
81
|
+
|
|
82
|
+
turtleIds.forEach(turtleId => {
|
|
83
|
+
const cvt = document.getElementById(turtleId)
|
|
84
|
+
if (cvt) {
|
|
85
|
+
const dx = parseInt(cvt.style.left, 10) - rx
|
|
86
|
+
const dy = parseInt(cvt.style.top, 10) - ry
|
|
87
|
+
ctx.drawImage(cvt, dx, dy)
|
|
88
|
+
}
|
|
89
|
+
})
|
|
90
|
+
|
|
91
|
+
resolve(canvas)
|
|
92
|
+
})
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
const recreateCanvas = src => {
|
|
96
|
+
return new Promise((resolve, reject) => {
|
|
97
|
+
const img = new Image()
|
|
98
|
+
img.onload = () => {
|
|
99
|
+
img.onload = null
|
|
100
|
+
img.onerror = null
|
|
101
|
+
const canvas = document.createElement('canvas')
|
|
102
|
+
canvas.width = img.width
|
|
103
|
+
canvas.height = img.height
|
|
104
|
+
const ctx = canvas.getContext('2d')
|
|
105
|
+
setImageSmoothingEnabledToCtx(ctx, false)
|
|
106
|
+
ctx.clearRect(0, 0, img.width, img.height)
|
|
107
|
+
ctx.globalCompositeOperation = 'copy'
|
|
108
|
+
ctx.drawImage(img, 0, 0)
|
|
109
|
+
ctx.globalCompositeOperation = 'source-over'
|
|
110
|
+
|
|
111
|
+
resolve(canvas)
|
|
112
|
+
}
|
|
113
|
+
img.onerror = () => {
|
|
114
|
+
img.onload = null
|
|
115
|
+
img.onerror = null
|
|
116
|
+
reject(new Error('reload image error'))
|
|
117
|
+
}
|
|
118
|
+
img.src = src.toDataURL('image/png')
|
|
119
|
+
})
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
const getBlobFromCanvas = (canvas, type) => {
|
|
123
|
+
const dataurl = canvas.toDataURL(type)
|
|
124
|
+
const bin = atob(dataurl.replace(/^.*,/, ''))
|
|
125
|
+
const buffer = new Uint8Array(bin.length)
|
|
126
|
+
for (let i = 0, l = bin.length; i < l; i++) {
|
|
127
|
+
buffer[i] = bin.charCodeAt(i)
|
|
128
|
+
}
|
|
129
|
+
const blob = new Blob([buffer.buffer], {
|
|
130
|
+
type: type
|
|
131
|
+
})
|
|
132
|
+
return blob
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
const uploadCanvasImage = async (canvas, filename) => {
|
|
136
|
+
var formData = new FormData()
|
|
137
|
+
const blob = getBlobFromCanvas(canvas, 'image/png')
|
|
138
|
+
formData.append('file', blob, filename)
|
|
139
|
+
const response = await fetch('/custom/uploadimage', {
|
|
140
|
+
method: 'POST',
|
|
141
|
+
body: formData
|
|
142
|
+
})
|
|
143
|
+
const result = await response.text()
|
|
144
|
+
return result
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
describe('plugin_turtle_test', () => {
|
|
148
|
+
let nako = null
|
|
149
|
+
const matchmode = 'lazzy3'
|
|
150
|
+
const cmpImageData = (imgData1, imgData2, invert) => {
|
|
151
|
+
if (typeof invert === 'undefined') { invert = false }
|
|
152
|
+
assert.strictEqual(imgData1.width, imgData2.width, 'images width unmatch')
|
|
153
|
+
assert.strictEqual(imgData1.height, imgData2.height, 'images height unmatch')
|
|
154
|
+
|
|
155
|
+
console.log(`brute match(${matchmode})`)
|
|
156
|
+
let allmatch = true
|
|
157
|
+
let i = 0
|
|
158
|
+
for (let y = 0; y < imgData1.height; y++) {
|
|
159
|
+
for (let x = 0; x < imgData1.width; x++, i += 4) {
|
|
160
|
+
let nomatch = false
|
|
161
|
+
if (matchmode === 'lazzy') {
|
|
162
|
+
if ((imgData2.data[i + 3] !== 0 &&
|
|
163
|
+
(Math.abs(imgData1.data[i + 0] - imgData2.data[i + 0]) > 10 ||
|
|
164
|
+
Math.abs(imgData1.data[i + 1] - imgData2.data[i + 1]) > 10 ||
|
|
165
|
+
Math.abs(imgData1.data[i + 2] - imgData2.data[i + 2]) > 10 ||
|
|
166
|
+
Math.abs(imgData1.data[i + 3] - imgData2.data[i + 3]) > 10)) ||
|
|
167
|
+
(imgData2.data[i + 3] === 0 && imgData1.data[i + 3] > 5)) {
|
|
168
|
+
nomatch = true
|
|
169
|
+
}
|
|
170
|
+
} else
|
|
171
|
+
if (matchmode === 'lazzy2') {
|
|
172
|
+
if (imgData1.data[i + 3] === 255 &&
|
|
173
|
+
imgData2.data[i + 3] === 255 &&
|
|
174
|
+
(Math.abs(imgData1.data[i + 0] - imgData2.data[i + 0]) > 1 ||
|
|
175
|
+
Math.abs(imgData1.data[i + 1] - imgData2.data[i + 1]) > 1 ||
|
|
176
|
+
Math.abs(imgData1.data[i + 2] - imgData2.data[i + 2]) > 1)) {
|
|
177
|
+
// 両画像が不透明なら、差異は各パレットで1まで
|
|
178
|
+
nomatch = true
|
|
179
|
+
} else
|
|
180
|
+
if (imgData1.data[i + 3] === 0 &&
|
|
181
|
+
imgData2.data[i + 3] === 255) {
|
|
182
|
+
// 画像1が完全透明なら、画像2が不透明ではいけない。
|
|
183
|
+
nomatch = true
|
|
184
|
+
} else
|
|
185
|
+
if (imgData1.data[i + 3] === 255 &&
|
|
186
|
+
imgData2.data[i + 3] === 0) {
|
|
187
|
+
// 画像1が不透明なら、画像2が完全透明ではいけない。
|
|
188
|
+
nomatch = true
|
|
189
|
+
}
|
|
190
|
+
} else
|
|
191
|
+
if (matchmode === 'lazzy3') {
|
|
192
|
+
if (imgData1.data[i + 3] === 255 &&
|
|
193
|
+
imgData2.data[i + 3] === 255 &&
|
|
194
|
+
(Math.abs(imgData1.data[i + 0] - imgData2.data[i + 0]) > 48 ||
|
|
195
|
+
Math.abs(imgData1.data[i + 1] - imgData2.data[i + 1]) > 48 ||
|
|
196
|
+
Math.abs(imgData1.data[i + 2] - imgData2.data[i + 2]) > 48)) {
|
|
197
|
+
// 両画像が不透明なら、差異は各パレットで48まで
|
|
198
|
+
nomatch = true
|
|
199
|
+
} else
|
|
200
|
+
if (imgData1.data[i + 3] === 0 &&
|
|
201
|
+
imgData2.data[i + 3] === 255) {
|
|
202
|
+
// 画像1が完全透明なら、画像2が不透明ではいけない。
|
|
203
|
+
nomatch = true
|
|
204
|
+
} else
|
|
205
|
+
if (imgData1.data[i + 3] === 255 &&
|
|
206
|
+
imgData2.data[i + 3] === 0) {
|
|
207
|
+
// 画像1が不透明なら、画像2が完全透明ではいけない。
|
|
208
|
+
nomatch = true
|
|
209
|
+
}
|
|
210
|
+
} else {
|
|
211
|
+
if (imgData1.data[i + 0] !== imgData2.data[i + 0] ||
|
|
212
|
+
imgData1.data[i + 1] !== imgData2.data[i + 1] ||
|
|
213
|
+
imgData1.data[i + 2] !== imgData2.data[i + 2] ||
|
|
214
|
+
imgData1.data[i + 3] !== imgData2.data[i + 3]) {
|
|
215
|
+
nomatch = true
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
if (nomatch) {
|
|
219
|
+
allmatch = false
|
|
220
|
+
if (!invert) {
|
|
221
|
+
console.log('unmacth(' + x + ',' + y + '):' +
|
|
222
|
+
(imgData1.data[i + 0] < 16 ? '0' : '') + (0 + imgData1.data[i + 0]).toString(16) +
|
|
223
|
+
(imgData1.data[i + 1] < 16 ? '0' : '') + (0 + imgData1.data[i + 1]).toString(16) +
|
|
224
|
+
(imgData1.data[i + 2] < 16 ? '0' : '') + (0 + imgData1.data[i + 2]).toString(16) +
|
|
225
|
+
(imgData1.data[i + 3] < 16 ? '0' : '') + (0 + imgData1.data[i + 3]).toString(16) +
|
|
226
|
+
':' +
|
|
227
|
+
(imgData2.data[i + 0] < 16 ? '0' : '') + (0 + imgData2.data[i + 0]).toString(16) +
|
|
228
|
+
(imgData2.data[i + 1] < 16 ? '0' : '') + (0 + imgData2.data[i + 1]).toString(16) +
|
|
229
|
+
(imgData2.data[i + 2] < 16 ? '0' : '') + (0 + imgData2.data[i + 2]).toString(16) +
|
|
230
|
+
(imgData2.data[i + 3] < 16 ? '0' : '') + (0 + imgData2.data[i + 3]).toString(16) +
|
|
231
|
+
',' + i)
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
if (!invert) {
|
|
237
|
+
assert.ok(allmatch, 'image nomatch')
|
|
238
|
+
} else {
|
|
239
|
+
assert.ok(!allmatch, 'image match')
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
afterEach(() => {
|
|
243
|
+
nako = null
|
|
244
|
+
})
|
|
245
|
+
beforeEach(() => {
|
|
246
|
+
nako = new NakoCompiler()
|
|
247
|
+
// const pluginClone = Object.assign({}, PluginTurtle)
|
|
248
|
+
// nako.addPluginFile('PluginTurtle', 'plugin_turtle.js', pluginClone)
|
|
249
|
+
nako.addPluginFile('PluginTurtle', 'plugin_turtle.js', PluginTurtle)
|
|
250
|
+
nako.addFunc('getElementyID', [['の']], (id, sys) => {
|
|
251
|
+
return document.getElementById(id)
|
|
252
|
+
})
|
|
253
|
+
nako.addFunc('smoothオフ', [['の']], (id, sys) => {
|
|
254
|
+
let ctx = null
|
|
255
|
+
if (id >= 0) {
|
|
256
|
+
if (id < sys._turtle.list.length) {
|
|
257
|
+
ctx = sys._turtle.list[id].ctx
|
|
258
|
+
}
|
|
259
|
+
} else {
|
|
260
|
+
ctx = sys._turtle.ctx
|
|
261
|
+
}
|
|
262
|
+
if (ctx) {
|
|
263
|
+
setImageSmoothingEnabledToCtx(ctx, false)
|
|
264
|
+
}
|
|
265
|
+
return id
|
|
266
|
+
})
|
|
267
|
+
})
|
|
268
|
+
|
|
269
|
+
// --- test ---
|
|
270
|
+
it('check env(canvas_basic.html)', () => {
|
|
271
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
272
|
+
const canvasElement = document.getElementById('turtle_cv')
|
|
273
|
+
assert.strictEqual(typeof (canvasElement), 'object')
|
|
274
|
+
})
|
|
275
|
+
|
|
276
|
+
it('auto import for browser', () => {
|
|
277
|
+
const pluginName = 'PluginTurtle'
|
|
278
|
+
const imported = importStatus.hasImport(pluginName)
|
|
279
|
+
assert.ok(imported, 'was import')
|
|
280
|
+
const autoImport = importStatus.getAutoImport(pluginName)
|
|
281
|
+
assert.strictEqual(typeof (autoImport.obj), 'object')
|
|
282
|
+
})
|
|
283
|
+
|
|
284
|
+
it('set origin and direcion', async () => {
|
|
285
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
286
|
+
const imgname = 'canvas_test1.png'
|
|
287
|
+
const code = `カメ描画先=「turtle_cv」
|
|
288
|
+
0にカメ速度設定。
|
|
289
|
+
カメ画像URLは、「turtle.png」
|
|
290
|
+
カメ作成。それのsmoothオフ。-1のsmoothオフ。
|
|
291
|
+
[30,30]にカメ起点移動。
|
|
292
|
+
180にカメ角度設定。
|
|
293
|
+
`
|
|
294
|
+
nako.run(code)
|
|
295
|
+
|
|
296
|
+
await waitTimer(1)
|
|
297
|
+
|
|
298
|
+
const dataPromise = getImageDataFromUrl(imagePath + imgname)
|
|
299
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0'])
|
|
300
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
301
|
+
|
|
302
|
+
const cv2 = await recreateCanvas(cv)
|
|
303
|
+
const w = parseInt(cv2.width, 10)
|
|
304
|
+
const h = parseInt(cv2.height, 10)
|
|
305
|
+
const ctx = cv2.getContext('2d')
|
|
306
|
+
|
|
307
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
308
|
+
|
|
309
|
+
try {
|
|
310
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
311
|
+
if (rslt !== 'OK') {
|
|
312
|
+
console.log('upload result:' + rslt)
|
|
313
|
+
}
|
|
314
|
+
} catch (ex) {
|
|
315
|
+
console.log('upload error')
|
|
316
|
+
console.log(ex)
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
cmpImageData(actData, data)
|
|
320
|
+
}).timeout(5000)
|
|
321
|
+
|
|
322
|
+
it('incorrect canvasid', () => {
|
|
323
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
324
|
+
const code = `カメ描画先=「no_cv」
|
|
325
|
+
0にカメ速度設定。
|
|
326
|
+
カメ作成。
|
|
327
|
+
`
|
|
328
|
+
assert.throws(() => { nako.run(code) }, Error)
|
|
329
|
+
})
|
|
330
|
+
|
|
331
|
+
it('incorrect command', () => {
|
|
332
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
333
|
+
const code = `カメ描画先=「turtle_cv」
|
|
334
|
+
0にカメ速度設定。
|
|
335
|
+
[25,25]にカメ起点移動。
|
|
336
|
+
`
|
|
337
|
+
assert.throws(() => { nako.run(code) }, Error)
|
|
338
|
+
})
|
|
339
|
+
|
|
340
|
+
it('set origin and direcion turtles', async () => {
|
|
341
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
342
|
+
const imgname = 'canvas_test2.png'
|
|
343
|
+
const code = `カメ描画先=「#turtle_cv」
|
|
344
|
+
0にカメ速度設定。
|
|
345
|
+
カメ画像URLは、「turtle.png」
|
|
346
|
+
カメ作成。それのsmoothオフ。-1のsmoothオフ。
|
|
347
|
+
[25,25]にカメ起点移動。
|
|
348
|
+
180にカメ角度設定。
|
|
349
|
+
カメ画像URLは、「turtle-elephant.png」
|
|
350
|
+
カメ作成。それのsmoothオフ。それにカメ操作対象設定。
|
|
351
|
+
[75,25]にカメ起点移動。
|
|
352
|
+
90にカメ角度設定。
|
|
353
|
+
カメ画像URLは、「turtle-panda.png」
|
|
354
|
+
カメ作成。それのsmoothオフ。それにカメ操作対象設定。
|
|
355
|
+
[50,75]にカメ起点移動。
|
|
356
|
+
0にカメ角度設定。
|
|
357
|
+
`
|
|
358
|
+
nako.run(code)
|
|
359
|
+
|
|
360
|
+
await waitTimer(1.8)
|
|
361
|
+
|
|
362
|
+
const dataPromise = getImageDataFromUrl(imagePath + imgname)
|
|
363
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0', '1', '2'])
|
|
364
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
365
|
+
|
|
366
|
+
const cv2 = await recreateCanvas(cv)
|
|
367
|
+
const w = parseInt(cv2.width, 10)
|
|
368
|
+
const h = parseInt(cv2.height, 10)
|
|
369
|
+
const ctx = cv2.getContext('2d')
|
|
370
|
+
|
|
371
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
372
|
+
|
|
373
|
+
try {
|
|
374
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
375
|
+
if (rslt !== 'OK') {
|
|
376
|
+
console.log('upload result:' + rslt)
|
|
377
|
+
}
|
|
378
|
+
} catch (ex) {
|
|
379
|
+
console.log('upload error')
|
|
380
|
+
console.log(ex)
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
cmpImageData(actData, data)
|
|
384
|
+
}).timeout(5000)
|
|
385
|
+
|
|
386
|
+
it('move direct position turtles', async () => {
|
|
387
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
388
|
+
const imgname = 'canvas_test3.png'
|
|
389
|
+
const code = `カメ描画先=「turtle_cv」のgetElementyID
|
|
390
|
+
0にカメ速度設定。
|
|
391
|
+
カメ画像URLは、「turtle.png」
|
|
392
|
+
カメ作成。それのsmoothオフ。-1のsmoothオフ。
|
|
393
|
+
[25,75]にカメ起点移動。
|
|
394
|
+
[25,25]にカメ移動。
|
|
395
|
+
カメ画像URLは、「turtle-elephant.png」
|
|
396
|
+
カメ作成。それのsmoothオフ。それにカメ操作対象設定。
|
|
397
|
+
[25,75]にカメ起点移動。
|
|
398
|
+
[75,75]にカメ移動。
|
|
399
|
+
カメ画像URLは、「turtle-panda.png」
|
|
400
|
+
カメ作成。それのsmoothオフ。それにカメ操作対象設定。
|
|
401
|
+
[25,75]にカメ起点移動。
|
|
402
|
+
[75,25]にカメ移動。
|
|
403
|
+
`
|
|
404
|
+
nako.run(code)
|
|
405
|
+
|
|
406
|
+
await waitTimer(2.0)
|
|
407
|
+
|
|
408
|
+
const dataPromise = getImageDataFromUrl(imagePath + imgname)
|
|
409
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0', '1', '2'])
|
|
410
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
411
|
+
|
|
412
|
+
const cv2 = await recreateCanvas(cv)
|
|
413
|
+
const w = parseInt(cv2.width, 10)
|
|
414
|
+
const h = parseInt(cv2.height, 10)
|
|
415
|
+
const ctx = cv2.getContext('2d')
|
|
416
|
+
|
|
417
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
418
|
+
|
|
419
|
+
try {
|
|
420
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
421
|
+
if (rslt !== 'OK') {
|
|
422
|
+
console.log('upload result:' + rslt)
|
|
423
|
+
}
|
|
424
|
+
} catch (ex) {
|
|
425
|
+
console.log('upload error')
|
|
426
|
+
console.log(ex)
|
|
427
|
+
}
|
|
428
|
+
|
|
429
|
+
cmpImageData(actData, data)
|
|
430
|
+
}).timeout(5000)
|
|
431
|
+
|
|
432
|
+
it('check move,rotate,visible,color,width', async () => {
|
|
433
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
434
|
+
const imgname = 'canvas_test4.png'
|
|
435
|
+
const code = `カメ描画先=「turtle_cv」
|
|
436
|
+
10にカメ速度設定。
|
|
437
|
+
カメ画像URLは、「turtle.png」
|
|
438
|
+
カメ作成。それのsmoothオフ。-1のsmoothオフ。
|
|
439
|
+
[10,10]にカメ起点移動。90にカメ角度設定。
|
|
440
|
+
3にカメペンサイズ設定。
|
|
441
|
+
「#000」にカメペン色設定。
|
|
442
|
+
10だけカメ進む。
|
|
443
|
+
30だけカメ右回転。
|
|
444
|
+
15だけカメ進む。
|
|
445
|
+
45だけカメ左回転。
|
|
446
|
+
0にカメペン設定。
|
|
447
|
+
15だけカメ戻る。
|
|
448
|
+
1にカメペン設定。
|
|
449
|
+
2にカメペンサイズ設定。
|
|
450
|
+
「#F00」にカメペン色設定。
|
|
451
|
+
15だけカメ右回転。
|
|
452
|
+
30だけカメ進む。
|
|
453
|
+
カメ非表示。
|
|
454
|
+
カメ画像URLは、「turtle-elephant.png」
|
|
455
|
+
カメ作成。それのsmoothオフ。それにカメ操作対象設定。
|
|
456
|
+
[75,75]にカメ起点移動。
|
|
457
|
+
カメ非表示。
|
|
458
|
+
カメ表示。
|
|
459
|
+
`
|
|
460
|
+
nako.run(code)
|
|
461
|
+
|
|
462
|
+
await waitTimer(2.0)
|
|
463
|
+
|
|
464
|
+
const dataPromise = getImageDataFromUrl(imagePath + imgname)
|
|
465
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0', '1'])
|
|
466
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
467
|
+
|
|
468
|
+
const cv2 = await recreateCanvas(cv)
|
|
469
|
+
const w = parseInt(cv2.width, 10)
|
|
470
|
+
const h = parseInt(cv2.height, 10)
|
|
471
|
+
const ctx = cv2.getContext('2d')
|
|
472
|
+
|
|
473
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
474
|
+
|
|
475
|
+
try {
|
|
476
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
477
|
+
if (rslt !== 'OK') {
|
|
478
|
+
console.log('upload result:' + rslt)
|
|
479
|
+
}
|
|
480
|
+
} catch (ex) {
|
|
481
|
+
console.log('upload error')
|
|
482
|
+
console.log(ex)
|
|
483
|
+
}
|
|
484
|
+
|
|
485
|
+
cmpImageData(actData, data)
|
|
486
|
+
}).timeout(5000)
|
|
487
|
+
|
|
488
|
+
it('check all clear', async () => {
|
|
489
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
490
|
+
const imgname = 'canvas_test5_wasblank.png'
|
|
491
|
+
const code = `カメ描画先=「turtle_cv」
|
|
492
|
+
0にカメ速度設定。
|
|
493
|
+
カメ画像URLは、「turtle.png」
|
|
494
|
+
カメ作成。それのsmoothオフ。-1のsmoothオフ。
|
|
495
|
+
[25,75]にカメ起点移動。
|
|
496
|
+
[75,25]にカメ移動。
|
|
497
|
+
135だけカメ左回転
|
|
498
|
+
50だけカメ進む
|
|
499
|
+
90だけカメ左回転
|
|
500
|
+
25だけカメ進む
|
|
501
|
+
カメ表示。
|
|
502
|
+
カメ全消去。
|
|
503
|
+
`
|
|
504
|
+
nako.run(code)
|
|
505
|
+
|
|
506
|
+
await waitTimer(1.0)
|
|
507
|
+
|
|
508
|
+
const dataPromise = getImageDataFromUrl(imagePath + 'canvas_test_blank.png')
|
|
509
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0', '1', '2'])
|
|
510
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
511
|
+
|
|
512
|
+
const cv2 = await recreateCanvas(cv)
|
|
513
|
+
const w = parseInt(cv2.width, 10)
|
|
514
|
+
const h = parseInt(cv2.height, 10)
|
|
515
|
+
const ctx = cv2.getContext('2d')
|
|
516
|
+
|
|
517
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
518
|
+
|
|
519
|
+
try {
|
|
520
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
521
|
+
if (rslt !== 'OK') {
|
|
522
|
+
console.log('upload result:' + rslt)
|
|
523
|
+
}
|
|
524
|
+
} catch (ex) {
|
|
525
|
+
console.log('upload error')
|
|
526
|
+
console.log(ex)
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
cmpImageData(actData, data)
|
|
530
|
+
})
|
|
531
|
+
|
|
532
|
+
it('check all clear before use', async () => {
|
|
533
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
534
|
+
const imgname = 'canvas_test6_wasblank.png'
|
|
535
|
+
const code = `カメ描画先=「turtle_cv」
|
|
536
|
+
カメ画像URLは、「turtle.png」
|
|
537
|
+
0にカメ速度設定。
|
|
538
|
+
カメ全消去。
|
|
539
|
+
`
|
|
540
|
+
nako.run(code)
|
|
541
|
+
|
|
542
|
+
await waitTimer(1.0)
|
|
543
|
+
|
|
544
|
+
const dataPromise = getImageDataFromUrl(imagePath + 'canvas_test_blank.png')
|
|
545
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0', '1', '2'])
|
|
546
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
547
|
+
|
|
548
|
+
const cv2 = await recreateCanvas(cv)
|
|
549
|
+
const w = parseInt(cv2.width, 10)
|
|
550
|
+
const h = parseInt(cv2.height, 10)
|
|
551
|
+
const ctx = cv2.getContext('2d')
|
|
552
|
+
|
|
553
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
554
|
+
|
|
555
|
+
try {
|
|
556
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
557
|
+
if (rslt !== 'OK') {
|
|
558
|
+
console.log('upload result:' + rslt)
|
|
559
|
+
}
|
|
560
|
+
} catch (ex) {
|
|
561
|
+
console.log('upload error')
|
|
562
|
+
console.log(ex)
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
cmpImageData(actData, data)
|
|
566
|
+
}).timeout(5000)
|
|
567
|
+
|
|
568
|
+
it('change turtle image delayed', async () => {
|
|
569
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
570
|
+
const imgname = 'canvas_test7.png'
|
|
571
|
+
const code = `カメ描画先=「turtle_cv」
|
|
572
|
+
1にカメ速度設定。
|
|
573
|
+
カメ画像URLは、「turtle.png」
|
|
574
|
+
カメ作成。それのsmoothオフ。-1のsmoothオフ。
|
|
575
|
+
「/custom/delayedimage/turtle-elephant.png」にカメ画像変更
|
|
576
|
+
[50,50]にカメ起点移動。270にカメ角度設定。
|
|
577
|
+
`
|
|
578
|
+
nako.run(code)
|
|
579
|
+
|
|
580
|
+
await waitTimer(2.0)
|
|
581
|
+
|
|
582
|
+
const dataPromise = getImageDataFromUrl(imagePath + imgname)
|
|
583
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0'])
|
|
584
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
585
|
+
|
|
586
|
+
const cv2 = await recreateCanvas(cv)
|
|
587
|
+
const w = parseInt(cv2.width, 10)
|
|
588
|
+
const h = parseInt(cv2.height, 10)
|
|
589
|
+
const ctx = cv2.getContext('2d')
|
|
590
|
+
|
|
591
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
592
|
+
|
|
593
|
+
try {
|
|
594
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
595
|
+
if (rslt !== 'OK') {
|
|
596
|
+
console.log('upload result:' + rslt)
|
|
597
|
+
}
|
|
598
|
+
} catch (ex) {
|
|
599
|
+
console.log('upload error')
|
|
600
|
+
console.log(ex)
|
|
601
|
+
}
|
|
602
|
+
|
|
603
|
+
cmpImageData(actData, data)
|
|
604
|
+
}).timeout(5000)
|
|
605
|
+
|
|
606
|
+
it('change turtle image', async () => {
|
|
607
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
608
|
+
const imgname = 'canvas_test8.png'
|
|
609
|
+
const code = `カメ描画先=「turtle_cv」
|
|
610
|
+
0にカメ速度設定。
|
|
611
|
+
カメ画像URLは、「turtle.png」
|
|
612
|
+
カメ作成。それのsmoothオフ。-1のsmoothオフ。
|
|
613
|
+
[50,50]にカメ起点移動。270にカメ角度設定。
|
|
614
|
+
「turtle-elephant.png」にカメ画像変更
|
|
615
|
+
`
|
|
616
|
+
nako.run(code)
|
|
617
|
+
|
|
618
|
+
await waitTimer(2.0)
|
|
619
|
+
|
|
620
|
+
const dataPromise = getImageDataFromUrl(imagePath + imgname)
|
|
621
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0'])
|
|
622
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
623
|
+
|
|
624
|
+
const cv2 = await recreateCanvas(cv)
|
|
625
|
+
const w = parseInt(cv2.width, 10)
|
|
626
|
+
const h = parseInt(cv2.height, 10)
|
|
627
|
+
const ctx = cv2.getContext('2d')
|
|
628
|
+
|
|
629
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
630
|
+
|
|
631
|
+
try {
|
|
632
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
633
|
+
if (rslt !== 'OK') {
|
|
634
|
+
console.log('upload result:' + rslt)
|
|
635
|
+
}
|
|
636
|
+
} catch (ex) {
|
|
637
|
+
console.log('upload error')
|
|
638
|
+
console.log(ex)
|
|
639
|
+
}
|
|
640
|
+
|
|
641
|
+
cmpImageData(actData, data)
|
|
642
|
+
}).timeout(5000)
|
|
643
|
+
|
|
644
|
+
it('load fail turtle image', async () => {
|
|
645
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
646
|
+
const imgname = 'canvas_test9_wasblank.png'
|
|
647
|
+
const code = `カメ描画先=「turtle_cv」
|
|
648
|
+
0にカメ速度設定。
|
|
649
|
+
カメ画像URLは、「no_exists.png」
|
|
650
|
+
カメ作成。
|
|
651
|
+
[50,50]にカメ起点移動。270にカメ角度設定。
|
|
652
|
+
`
|
|
653
|
+
nako.run(code)
|
|
654
|
+
|
|
655
|
+
await waitTimer(2.0)
|
|
656
|
+
|
|
657
|
+
const dataPromise = getImageDataFromUrl(imagePath + 'canvas_test_blank.png')
|
|
658
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0'])
|
|
659
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
660
|
+
|
|
661
|
+
const cv2 = await recreateCanvas(cv)
|
|
662
|
+
const w = parseInt(cv2.width, 10)
|
|
663
|
+
const h = parseInt(cv2.height, 10)
|
|
664
|
+
const ctx = cv2.getContext('2d')
|
|
665
|
+
|
|
666
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
667
|
+
|
|
668
|
+
try {
|
|
669
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
670
|
+
if (rslt !== 'OK') {
|
|
671
|
+
console.log('upload result:' + rslt)
|
|
672
|
+
}
|
|
673
|
+
} catch (ex) {
|
|
674
|
+
console.log('upload error')
|
|
675
|
+
console.log(ex)
|
|
676
|
+
}
|
|
677
|
+
|
|
678
|
+
cmpImageData(actData, data)
|
|
679
|
+
}).timeout(5000)
|
|
680
|
+
|
|
681
|
+
it('click turtle', async () => {
|
|
682
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
683
|
+
const code = `カメ描画先=「turtle_cv」
|
|
684
|
+
0にカメ速度設定。
|
|
685
|
+
カメ作成。
|
|
686
|
+
[50,50]にカメ起点移動。270にカメ角度設定。
|
|
687
|
+
カメクリック時には、
|
|
688
|
+
対象を報告
|
|
689
|
+
ここまで
|
|
690
|
+
`
|
|
691
|
+
let funcCalled = false
|
|
692
|
+
let target = -1
|
|
693
|
+
nako.addFunc('報告', [['を']], (ttcanvas) => {
|
|
694
|
+
funcCalled = true
|
|
695
|
+
target = ttcanvas
|
|
696
|
+
})
|
|
697
|
+
nako.run(code)
|
|
698
|
+
|
|
699
|
+
await waitTimer(1.0)
|
|
700
|
+
const e = document.getElementById('0')
|
|
701
|
+
if (e) {
|
|
702
|
+
e.click()
|
|
703
|
+
}
|
|
704
|
+
await waitTimer(1.0)
|
|
705
|
+
|
|
706
|
+
assert.ok(funcCalled, 'イベント呼び出し')
|
|
707
|
+
assert.strictEqual(target.id, '0', 'イベント対象のカメID')
|
|
708
|
+
}).timeout(5000)
|
|
709
|
+
|
|
710
|
+
it('turtle image basic(turtle)', async () => {
|
|
711
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
712
|
+
const imgname = 'canvas_test10_wasnotblank.png'
|
|
713
|
+
const code = `カメ描画先=「turtle_cv」
|
|
714
|
+
0にカメ速度設定。
|
|
715
|
+
カメ作成。
|
|
716
|
+
[50,50]にカメ起点移動。90にカメ角度設定。
|
|
717
|
+
`
|
|
718
|
+
nako.run(code)
|
|
719
|
+
|
|
720
|
+
await waitTimer(1.0)
|
|
721
|
+
|
|
722
|
+
const dataPromise = getImageDataFromUrl(imagePath + 'canvas_test_blank.png')
|
|
723
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0'])
|
|
724
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
725
|
+
|
|
726
|
+
const cv2 = await recreateCanvas(cv)
|
|
727
|
+
const w = parseInt(cv2.width, 10)
|
|
728
|
+
const h = parseInt(cv2.height, 10)
|
|
729
|
+
const ctx = cv2.getContext('2d')
|
|
730
|
+
|
|
731
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
732
|
+
|
|
733
|
+
try {
|
|
734
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
735
|
+
if (rslt !== 'OK') {
|
|
736
|
+
console.log('upload result:' + rslt)
|
|
737
|
+
}
|
|
738
|
+
} catch (ex) {
|
|
739
|
+
console.log('upload error')
|
|
740
|
+
console.log(ex)
|
|
741
|
+
}
|
|
742
|
+
|
|
743
|
+
cmpImageData(actData, data, true)
|
|
744
|
+
}).timeout(5000)
|
|
745
|
+
|
|
746
|
+
it('turtle image extend(elephant)', async () => {
|
|
747
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
748
|
+
const imgname = 'canvas_test11_wasnotblank.png'
|
|
749
|
+
const code = `カメ描画先=「turtle_cv」
|
|
750
|
+
0にカメ速度設定。
|
|
751
|
+
ゾウ作成。
|
|
752
|
+
[50,50]にカメ起点移動。270にカメ角度設定。
|
|
753
|
+
`
|
|
754
|
+
nako.run(code)
|
|
755
|
+
|
|
756
|
+
await waitTimer(1.0)
|
|
757
|
+
|
|
758
|
+
const dataPromise = getImageDataFromUrl(imagePath + 'canvas_test_blank.png')
|
|
759
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0'])
|
|
760
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
761
|
+
|
|
762
|
+
const cv2 = await recreateCanvas(cv)
|
|
763
|
+
const w = parseInt(cv2.width, 10)
|
|
764
|
+
const h = parseInt(cv2.height, 10)
|
|
765
|
+
const ctx = cv2.getContext('2d')
|
|
766
|
+
|
|
767
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
768
|
+
|
|
769
|
+
try {
|
|
770
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
771
|
+
if (rslt !== 'OK') {
|
|
772
|
+
console.log('upload result:' + rslt)
|
|
773
|
+
}
|
|
774
|
+
} catch (ex) {
|
|
775
|
+
console.log('upload error')
|
|
776
|
+
console.log(ex)
|
|
777
|
+
}
|
|
778
|
+
|
|
779
|
+
cmpImageData(actData, data, true)
|
|
780
|
+
}).timeout(5000)
|
|
781
|
+
|
|
782
|
+
it('turtle image extend(panda)', async () => {
|
|
783
|
+
document.body.innerHTML = __html__[htmlPath+'canvas_basic.html']
|
|
784
|
+
const imgname = 'canvas_test12_wasnotblank.png'
|
|
785
|
+
const code = `カメ描画先=「turtle_cv」
|
|
786
|
+
0にカメ速度設定。
|
|
787
|
+
パンダ作成。
|
|
788
|
+
[50,50]にカメ起点移動。180にカメ角度設定。
|
|
789
|
+
`
|
|
790
|
+
nako.run(code)
|
|
791
|
+
|
|
792
|
+
await waitTimer(1.0)
|
|
793
|
+
|
|
794
|
+
const dataPromise = getImageDataFromUrl(imagePath + 'canvas_test_blank.png')
|
|
795
|
+
const cvPromise = getMergedCanvas('turtle_cv', ['0'])
|
|
796
|
+
const [data, cv] = await Promise.all([dataPromise, cvPromise])
|
|
797
|
+
|
|
798
|
+
const cv2 = await recreateCanvas(cv)
|
|
799
|
+
const w = parseInt(cv2.width, 10)
|
|
800
|
+
const h = parseInt(cv2.height, 10)
|
|
801
|
+
const ctx = cv2.getContext('2d')
|
|
802
|
+
|
|
803
|
+
const actData = ctx.getImageData(0, 0, w, h)
|
|
804
|
+
|
|
805
|
+
try {
|
|
806
|
+
const rslt = await uploadCanvasImage(cv, imgname)
|
|
807
|
+
if (rslt !== 'OK') {
|
|
808
|
+
console.log('upload result:' + rslt)
|
|
809
|
+
}
|
|
810
|
+
} catch (ex) {
|
|
811
|
+
console.log('upload error')
|
|
812
|
+
console.log(ex)
|
|
813
|
+
}
|
|
814
|
+
|
|
815
|
+
cmpImageData(actData, data, true)
|
|
816
|
+
}).timeout(5000)
|
|
817
|
+
})
|