index.html 186 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8" />
  5. <title>CocoBlockly X – CocoRobo AI & IoT Module</title>
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <meta http-equiv="Content-Type" content="text/html; scharset=UTF-8">
  8. <meta name="theme-color" content="#2C4FCD">
  9. <link type="text/css" rel="stylesheet" href="libs/materialize.min.css" media="screen,projection">
  10. <link rel="stylesheet" href="libs/codemirror/codemirror.css" />
  11. <link rel="stylesheet" href="libs/font-awesome.min.css" />
  12. <link rel="stylesheet" href="libs/summernote/summernote.css" />
  13. <link rel="stylesheet" href="libs/multi-select.css" />
  14. <link rel="stylesheet" href="src/blockpy.css" />
  15. <link rel="stylesheet" href="index.css" />
  16. <link rel="stylesheet" href="cocoblockly.css" />
  17. <!-- JQuery, D3, Math.js, Bootstrap -->
  18. <!-- <script type="text/javascript" src="libs/jquery.js"></script> -->
  19. <script type="text/javascript" src="uform.js"></script>
  20. <script type="text/javascript" src="js_libs/jquery-2.1.3.min.js"></script>
  21. <script type="text/javascript" src="libs/jquery-ui.min.js"></script>
  22. <script type="text/javascript" src="libs/jquery.hotkeys.js"></script>
  23. <script type="text/javascript" src="libs/jquery.multi-select.js"></script>
  24. <!-- <script type="text/javascript" src="libs/materialize.min.js"></script> -->
  25. <!-- <script src="materialize/js/materialize.js"></script> -->
  26. <script type="text/javascript" src="libs/d3.min.js"></script>
  27. <script type="text/javascript" src="libs/math.0.19.0.min.js"></script>
  28. <!-- <script type="text/javascript" src="libs/bootstrap.min.js"></script>
  29. <script type="text/javascript" src="libs/bootstrap-wysiwyg.js"></script> -->
  30. <script type="text/javascript" src="libs/mindmup-editabletable.js"></script>
  31. <script type="text/javascript" src="libs/codemirror/codemirror.js"></script>
  32. <script type="text/javascript" src="libs/codemirror/python.js"></script>
  33. <script type="text/javascript" src="libs/codemirror/htmlmixed.js"></script>
  34. <script type="text/javascript" src="libs/codemirror/xml.js"></script>
  35. <script type="text/javascript" src="libs/knockout-3.4.0.js"></script>
  36. <script type="text/javascript" src="libs/stringify.js"></script>
  37. <!-- Summernote, a rich text editor -->
  38. <script type="text/javascript" src="libs/summernote/summernote.min.js"></script>
  39. <script type="text/javascript" src="libs/summernote/summernote-ext-hint.js"></script>
  40. <script type="text/javascript" src="libs/summernote/summernote-ext-video.js"></script>
  41. <!-- Blockly -->
  42. <!-- <script type="text/javascript" src="blockly/blockly_uncompressed.js"></script> -->
  43. <!-- <script type="text/javascript" src="blockly/blockly_compressed.js"></script>
  44. <script type="text/javascript" src="src/imported.js"></script>
  45. <script type="text/javascript" src="blockly/blocks_compressed.js"></script>
  46. <script type="text/javascript" src="src/python_to_blockly.js"></script>
  47. <script type="text/javascript" src="blockly/python_compressed.js"></script> -->
  48. <script type="text/javascript" src="blockly/blocks/python/head.js"></script>
  49. <script type="text/javascript" src="blockly/blocks/python/citys.js"></script>
  50. <script type="text/javascript" src="blockly/blocks/python/define_colors.js"></script>
  51. <script type="text/javascript" src="blockly/blocks/python/blockly_compressed.js"></script>
  52. <script type="text/javascript" src="blockly/blocks/python/blocks_compressed.js"></script>
  53. <script type="text/javascript" src="blockly/blocks/python/python_compressed.js"></script>
  54. <script type="text/javascript" src="blockly/blocks/python/blocks_microbit.min.js"></script>
  55. <script type="text/javascript" src="blockly/blocks/python/blocks_mpython.min.js"></script>
  56. <script type="text/javascript" src="blockly/blocks/python/python_microbit.min.js"></script>
  57. <script type="text/javascript" src="blockly/blocks/python/python_mpython.min.js"></script>
  58. <script type="text/javascript" src="src/imported.js"></script>
  59. <script type="text/javascript" src="src/python_to_blockly.js"></script>
  60. <script type="text/javascript" src="blockly/blocks/python/ai.js"></script>
  61. <script type="text/javascript" src="blockly/blocks/python/iot.js"></script>
  62. <script type="text/javascript" src="blockly/blocks/python/esp32.js"></script>
  63. <script type="text/javascript" src="blockly/blocks/python/extension_module.js"></script>
  64. <script type="text/javascript" src="blockly/blocks/python/mainwifi.js"></script>
  65. <script type="text/javascript" src="blockly/blocks/text.js"></script>
  66. <script type="text/javascript" src="blockly/blocks/utility.js"></script>
  67. <!-- <script type="text/javascript" src="blockly/generators/utility.js"></script> -->
  68. <!--
  69. <script type="text/javascript" src="blockly/blocks/math.js"></script>
  70. <script type="text/javascript" src="blockly/generators/python/math.js"></script>-->
  71. <script type="text/javascript" src="blockly/generators/python.js"></script>
  72. <script type="text/javascript" src="blockly/blocks/python/time.js"></script>
  73. <script type="text/javascript" src="blockly/generators/python/time.js"></script>
  74. <script type="text/javascript" src="blockly/blocks/python/mainwifi.js"></script>
  75. <script type="text/javascript" src="blockly/generators/python/mainwifi.js"></script>
  76. <script type="text/javascript" src="blockly/blocks/python/screen.js"></script>
  77. <script type="text/javascript" src="blockly/generators/python/screen.js"></script>
  78. <script type="text/javascript" src="/blockly/msg/index.js"></script>
  79. <script type="text/javascript" src="src/blockly/FileSaver.js"></script>
  80. <script type="text/javascript" src="src/blockly/term.js"></script>
  81. <script type="text/javascript" src="src/blockly/web.js"></script>
  82. <script type="text/javascript" src="src/blockly/load.js"></script>
  83. <script type="text/javascript" src="src/blockly/Devices.js"></script>
  84. <!-- Skulpt -->
  85. <script type="text/javascript" src="skulpt/dist/skulpt.min.js"></script>
  86. <script type="text/javascript" src="skulpt/dist/skulpt-stdlib.js"></script>
  87. <!-- Source Code -->
  88. <script type="text/javascript" src="src/utilities.js"></script>
  89. <script type="text/javascript" src="src/python_errors.js"></script>
  90. <script type="text/javascript" src="src/ast_node_visitor.js"></script>
  91. <script type="text/javascript" src="src/abstract_interpreter.js"></script>
  92. <script type="text/javascript" src="src/pytifa.js"></script>
  93. <script type="text/javascript" src="src/abstract_interpreter_definitions.js"></script>
  94. <script type="text/javascript" src="src/dialog.js"></script>
  95. <script type="text/javascript" src="src/storage.js"></script>
  96. <script type="text/javascript" src="src/printer.js"></script>
  97. <script type="text/javascript" src="src/interface.js"></script>
  98. <script type="text/javascript" src="src/server.js"></script>
  99. <script type="text/javascript" src="src/english.js"></script>
  100. <script type="text/javascript" src="src/corgis.js"></script>
  101. <script type="text/javascript" src="src/history.js"></script>
  102. <script type="text/javascript" src="src/presentation.js"></script>
  103. <script type="text/javascript" src="src/editor.js"></script>
  104. <script type="text/javascript" src="src/feedback.js"></script>
  105. <script type="text/javascript" src="src/toolbar.js"></script>
  106. <script type="text/javascript" src="src/sk_mod_instructor_extended.js"></script>
  107. <script type="text/javascript" src="src/sk_mod_instructor.js"></script>
  108. <script type="text/javascript" src="src/engine.js"></script>
  109. <script type="text/javascript" src="src/main.js"></script>
  110. <!-- FileSaver JS -->
  111. <script src="src/js_libs/FileSaver.min.js"></script>
  112. <!-- JS Diff -->
  113. <script src="src/js_libs/diff.js"></script>
  114. <!-- Prettify JS -->
  115. <script src="src/prettify/prettify.js"></script>
  116. <!-- Lazyload JS -->
  117. <script src="src/lazysize/lazysizes.min.js"></script>
  118. <!-- Socket.io -->
  119. <script src="src/socket.io-client/dist/socket.io.js"></script>
  120. <!-- clipboard -->
  121. <script src="src/clipboard/dist/clipboard.js"></script>
  122. <!-- Event Proxy -->
  123. <script type="text/javascript" src="src/blockly/eventproxy.js"></script>
  124. <!-- jQuery and Materialize JS -->
  125. <!-- <script src="js_libs/jquery-2.1.3.min.js"></script> -->
  126. <script src="materialize/js/materialize.js"></script>
  127. <!-- echarts -->
  128. <script src="./js_libs/echarts.min.js"></script>
  129. <!-- platform.js -->
  130. <!-- Desktop version of Ardublockly JS, needs to be loaded first. -->
  131. <!-- <script src="ardublockly_desktop.js"></script> -->
  132. <script type="text/javascript" src="src/webcam.min.js"></script>
  133. <script src="src/platformjs/platform.js"></script>
  134. <script src="ardublockly_lang.js"></script>
  135. <script src="ardublockly_toolbox.js"></script>
  136. <!-- <script src="ardublockly_blockly.js"></script> -->
  137. <script src="ardublocklyserver_ajax.js"></script>
  138. <script type="text/javascript" src="src/blockly/ardublockly_desktop.js"></script>
  139. <script type="text/javascript" src="src/blockly/ardublockly_design.js"></script>
  140. <script type="text/javascript" src="src/blockly/ardublockly_blockly.js"></script>
  141. <script type="text/javascript" src="src/blockly/ardublockly.js"></script>
  142. <script type="text/javascript" src="src/blockly/cocoblockly.js"></script>
  143. <script src="src/blockly/account.js"></script>
  144. <script src="src/blockly/socket.js"></script>
  145. <script src="src/blockly/machine.js"></script>
  146. <script type="text/javascript" src="./libs/clipboard.min.js"></script>
  147. <script type="text/javascript" src="./index.js"></script>
  148. </head>
  149. <body>
  150. <div id="white-box">
  151. <div id="preloader">
  152. <img src="./images/preloader.gif">
  153. <h4 style="margin:0;">Loading...</h4>
  154. </div>
  155. </div>
  156. <!-- modal -->
  157. <!-- <div class="modals">
  158. <span></span>
  159. </div> -->
  160. <div id="container">
  161. <!-- Horizontal Navigation bar -->
  162. <nav id="nav_" class="nav-fixed arduino_teal" style="overflow:hidden;background-color: #3454D2;">
  163. <div id="nav_shadow" class="shadowbox" style="display:none;"></div>
  164. <div class="nav-wrapper"
  165. style="min-width: 1200px; padding:0px 10px;display: flex;justify-content: space-between;position:static;">
  166. <a id="logo-container" class="brand-logo" style="display: none;">
  167. <span style="font-size:28px;font-family:'GT Walsheim Pro Trial Bold';"
  168. class="app_title translatable_title">CocoBlockly X</span>
  169. <!-- Sketch name editable text field -->
  170. <span class="sketch_name_wrapper" style="position:relative">
  171. <!-- <a id="button_delete" class="lang_resize" style="position:relative">
  172. <img style="height:28px;margin-top:20px" src="./icons/trash.png"> -->
  173. </a>
  174. <ul id="nav-mobile" class="hide-on-med-and-down" style="display: inline-block;">
  175. <!-- <li>
  176. <img style="height: 40px;margin-top: 10px;" class="left nav-icon" src="./icons/logo.png">
  177. </li> -->
  178. <li style="display: block;">
  179. <a id="nav_language" class='dropdown-button lang_resize' data-activates='languages'
  180. style="position:relative;padding: 0 25px;">
  181. <span class="translatable_language" style="display: none;">Language</span>
  182. <img class="left nav-icon" src="/images/language.png" style="width: 30px;height: 50px;">
  183. <i class="down" style="position: relative;top: 30px;left: 2px;float: right;"></i>
  184. </a>
  185. <ul id='languages' class='dropdown-content active'>
  186. <li id="EN" onclick="changeLanguage('en')">
  187. <span>English</span>
  188. </li>
  189. <li id="TC" onclick="changeLanguage('zh-hant')">
  190. <span>繁体中文</span>
  191. </li>
  192. <li id="CN" onclick="changeLanguage('zh-hans')">
  193. <span>简体中文</span>
  194. </li>
  195. </ul>
  196. </li>
  197. <!-- <li>
  198. <span class="vertical-separator"></span>
  199. </li> -->
  200. <li style="display: block;">
  201. <a id="local_storage" class='dropdown-button lang_resize' data-activates='local_saveOrOpen'
  202. style="position:relative;padding: 0 25px;">
  203. <span class="translatable_files">文件</span>
  204. <!-- <img class="left nav-icon" src="./icons/local_storage.png"> -->
  205. </a>
  206. <ul id='local_saveOrOpen' class='dropdown-content' style="top:62px">
  207. <li id="button_load">
  208. <span class="translatable_import_local_file">导入本地文件</span>
  209. </li>
  210. <li id="button_import_cloud">
  211. <span class="translatable_import_cloud_file">导入云端文件</span>
  212. </li>
  213. <li id="button_save">
  214. <span class="translatable_export_local_file">保存到本地</span>
  215. </li>
  216. <li id="button_save_cloud">
  217. <span class="translatable_export_cloud_file">保存到云端</span>
  218. </li>
  219. </ul>
  220. <div id="fileImport" class="btn" style="display:none;">
  221. <input type="file" accept=".py">
  222. </div>
  223. <div id="xmlFileImport" class="btn" style="display:none;">
  224. <input type="file" accept=".xml">
  225. </div>
  226. <div id="pyFileImport" class="btn" style="display:none;">
  227. <input type="file" accept=".py">
  228. </div>
  229. </li>
  230. <li style="display: block;">
  231. <a id="local_connect" class='dropdown-button lang_resize' data-activates='local_connect_select'
  232. style="position:relative;padding: 0 25px;">
  233. <span class="translatable_connect">连接</span>
  234. </a>
  235. <ul id='local_connect_select' class='dropdown-content' style="top:62px">
  236. <li id="plugin_download" href="javaScript:(0)">
  237. <span class="translatable_download_uploader">下载安装程序</span>
  238. </li>
  239. <li id="button_upgrade_firmware">
  240. <span class="translatable_upgrade_firmware">固件升级</span>
  241. </li>
  242. <li id="button_connection_type">
  243. <span class="translatable_connect_method">连接方式</span>
  244. </li>
  245. </ul>
  246. </li>
  247. <li style="display: block;">
  248. <a id="help" class='dropdown-button lang_resize' target="_blank" href="//x-help.cocorobo.cn"
  249. style="position:relative;padding: 0 25px;">
  250. <span class="translatable_help_board">帮助</span>
  251. </a>
  252. <!-- <a id="nav_devices" class='dropdown-button lang_resize' style="position:relative">
  253. <span class="translatable_devices">Devices</span>
  254. <img class="left nav-icon" src="./icons/Devices.png">
  255. </a> -->
  256. </li>
  257. <li>
  258. <div style="margin: 0px 20px 0px 0px;">
  259. <input type="text" value="A.I. Module" id="iot_modules" readonly
  260. class="selectMode_input browser-default"
  261. style="font-size: 0.9rem;border: none;width: 130px;">
  262. <i class="down" style="position: relative;top: -20px;float: right;"></i>
  263. <div class="downbox MouduleBox" id="downboxModule">
  264. <div style="border: none;"><a href="javaScript:(0)" style="color: #424242 !important;"
  265. class="translatable_ai_module">A.I. Module</a></div>
  266. <div style="border: none;"><a href="javaScript:(0)" style="color: #424242 !important;"
  267. class="translatable_iot_module">IoT Module
  268. Mode</a></div>
  269. <div style="border: none;"><a href="/python" style="color: #424242 !important;"
  270. class="translatable_python_full_screen_mode" target="_blank">Cloud
  271. Mode</a></div>
  272. </div>
  273. </div>
  274. </li>
  275. <li class="Mode_select_box">
  276. <div class="ModeSelectBox">
  277. <div class="ModeSelect">
  278. <div style="font-size: 0.9rem;">样例 </div>
  279. <i class="down" style="position: relative;top: -34px;left: 20px;float: right;"></i>
  280. <div class="downbox ModeBox downbox-style">
  281. <div>
  282. <div>人工智能教材程序</div>
  283. <i class="downboxdown"></i>
  284. <div class="Hardware2 HarxA" style="height:auto;top:-35px">
  285. <div class="Hardware9">
  286. <div>三年级</div>
  287. <i class="downboxdown"></i>
  288. <ul class="Hardware4 HarxA">
  289. <li>录制语音指令</li>
  290. <li>语音识别台灯</li>
  291. <!-- <li>人脸识别防盗门</li> -->
  292. </ul>
  293. </div>
  294. <div class="Hardware5">
  295. <div>五年级</div>
  296. <i class="downboxdown"></i>
  297. <ul class="Hardware4 HarxA">
  298. <li>录制语音指令</li>
  299. <li>智能窗帘</li>
  300. <li>水果采摘机器人</li>
  301. <!-- <li>智能质检机器人</li> -->
  302. </ul>
  303. </div>
  304. <div class="Hardware6">
  305. <div>六年级</div>
  306. <i class="downboxdown"></i>
  307. <ul class="Hardware4 HarxA">
  308. <!-- <li>无人驾驶循环小车</li> -->
  309. <li>智能交通信号灯</li>
  310. <li>导盲项链</li>
  311. <!-- <li>二维码包裹分拣机器人</li> -->
  312. </ul>
  313. </div>
  314. <div class="Hardware7">
  315. <div>七年级</div>
  316. <i class="downboxdown"></i>
  317. <ul class="Hardware4 HarxA">
  318. <li>人脸辨识电子警察</li>
  319. </ul>
  320. </div>
  321. <div class="Hardware8">
  322. <div>八年级</div>
  323. <i class="downboxdown"></i>
  324. <ul class="Hardware4 HarxA">
  325. <li>支付台</li>
  326. </ul>
  327. </div>
  328. </div>
  329. </div>
  330. <div>
  331. <div>IoT 模块基础案例</div>
  332. <i class="downboxdown"></i>
  333. <ul class="Hardware2 HarxA">
  334. <li>侧边按键控制蜂鸣器</li>
  335. <li> 侧边按键控制开关 LED</li>
  336. <li> 触摸区域控制 LED</li>
  337. <li> 蜂鸣器警报</li>
  338. <li> 黑暗环境感应光照灯</li>
  339. <li> 倾斜方向感应 LED</li>
  340. <li> 湿度报警器</li>
  341. <li> 摇晃感应 LED</li>
  342. <li> LED 显示光线强度值</li>
  343. </ul>
  344. </div>
  345. <div>
  346. <div>IoT 模块扩展功能案例</div>
  347. <i class="downboxdown"></i>
  348. <ul class="Hardware2 HarxA">
  349. <li>使用 LED 灯屏</li>
  350. <li>使用电机驱动模块</li>
  351. <li>使用游戏手柄 + LED 灯屏</li>
  352. <li>使用游戏手柄 + 屏幕模块</li>
  353. <li>在扩展模块上控制舵机</li>
  354. <li>屏幕显示Hello World</li>
  355. <li>屏幕绘制线条动画</li>
  356. <li>按键控制屏幕直线转动</li>
  357. <li>按键控制颜色切换</li>
  358. <li>计步器</li>
  359. </ul>
  360. </div>
  361. <div>
  362. <div>IoT 模块联网案例</div>
  363. <i class="downboxdown"></i>
  364. <ul class="Hardware2 HarxA">
  365. <li>按键发送光照数据至 CocoCloud</li>
  366. <li>按键发送环境数据至 IFTTT</li>
  367. <li>按键获取光照数据并根据条件亮灯</li>
  368. <li>定时发送环境数据至 CocoCloud</li>
  369. <li>定时接收环境数据并根据条件亮灯</li>
  370. <li>建立 WiFi 热点并显示连接设备数量</li>
  371. <li>局域网环境数据存储 - 服务器端</li>
  372. <li>局域网环境数据获取 - 客户端</li>
  373. <li>连接 WiFi 网络</li>
  374. <li>模块间按钮状态存储 - 服务端</li>
  375. <li>模块间按钮状态接收 - 客户端</li>
  376. <li>模块间进行 WebSocket 实时通信 - 发送端</li>
  377. <li>模块间进行 WebSocket 实时通信 - 接收端</li>
  378. <li>同步网络时间</li>
  379. <li>数字手表显示实时时间</li>
  380. </ul>
  381. </div>
  382. <div>
  383. <div>IoT工作坊上</div>
  384. <i class="downboxdown"></i>
  385. <ul class="Hardware2 HarxA">
  386. <li>01 点亮正中间的LED灯</li>
  387. <li>02 点亮所有LED灯</li>
  388. <li>03 流水灯</li>
  389. <li>04 蜂鸣器警报</li>
  390. <li>05 8-bit音乐</li>
  391. <li>06 串口通讯:按钮开关</li>
  392. <li>07 串口通讯:触摸开关</li>
  393. <li>08 按钮开关蜂鸣器</li>
  394. <li>09 触摸开关灯</li>
  395. <li>10 补光装置</li>
  396. <li>11 湿度报警器</li>
  397. </ul>
  398. </div>
  399. <div>
  400. <div>IoT工作坊下</div>
  401. <i class="downboxdown"></i>
  402. <ul class="Hardware2 HarxA">
  403. <li>12 晃晃灯</li>
  404. <!-- <li>13 连接Wi-Fi</li> -->
  405. <li>14 连接Wi-Fi并显示连接状态</li>
  406. <li>15 建立热点并显示已连接的设备数</li>
  407. <li>16 亮度数据上传与下载</li>
  408. <li>17 舵机来回摆动</li>
  409. <li>19 舵机定时摆动</li>
  410. <li>20 按键控制舵机</li>
  411. <li>18 门(人脸识别)</li>
  412. <li>体验 iot-机械车(语音控制)</li>
  413. <li>体验 iot-机械人(陀螺仪)</li>
  414. <li>体验 iot-机械人(姿态识别)</li>
  415. <li>体验 iot-台灯(语音控制)</li>
  416. </ul>
  417. </div>
  418. <div>
  419. <div>AI 模块机器学习案例</div>
  420. <i class="downboxdown"></i>
  421. <ul class="Hardware2 HarxA">
  422. <li>垃圾分类识别(香港版)</li>
  423. <li>人脸检测</li>
  424. <li>物体识别</li>
  425. <li>人脸检测</li>
  426. <li>物体识别</li>
  427. <li>语音录制</li>
  428. <li>语音识别</li>
  429. <li>MNIST 手写数字识别</li>
  430. </ul>
  431. </div>
  432. <div>
  433. <div>AI 模块基础案例</div>
  434. <i class="downboxdown"></i>
  435. <ul class="Hardware2 HarxA">
  436. <li>按键控制屏幕时针转动</li>
  437. <li style="display:none">按键控制图片改变颜色制式</li>
  438. <li style="display:none">按键控制图片进行反色变化</li>
  439. <li>按键控制颜色切换</li>
  440. <li>迷你相机</li>
  441. <li>屏幕方向旋转</li>
  442. <li>屏幕绘制线条动画</li>
  443. </ul>
  444. </div>
  445. <div>
  446. <div>AI 模块扩展功能案例</div>
  447. <i class="downboxdown"></i>
  448. <ul class="Hardware2 HarxA">
  449. <li>使用 LED 灯屏</li>
  450. <li>使用电机驱动模块</li>
  451. <li>使用游戏手柄 + 屏幕模块</li>
  452. <li>在扩展模块上控制舵机</li>
  453. <li>贪吃蛇</li>
  454. </ul>
  455. </div>
  456. <div>
  457. <div>AI AI 模块视觉案例</div>
  458. <i class="downboxdown"></i>
  459. <ul class="Hardware2 HarxA">
  460. <li>按键改变相机图像的亮度</li>
  461. <li>区域颜色分析</li>
  462. <li>识别 QR 二维码</li>
  463. <li>寻线(黑线)</li>
  464. <li>寻找绿色的圆形</li>
  465. <li>寻找绿色区域并进行追踪</li>
  466. </ul>
  467. </div>
  468. <div>
  469. <div>AI AI 模块影音案例</div>
  470. <i class="downboxdown"></i>
  471. <ul class="Hardware2 HarxA">
  472. <li style="display:none">播放录制的视频档案</li>
  473. <li>播放音乐</li>
  474. <li style="display:none">录制摄像头画面并保存</li>
  475. <li>麦克风声音频谱分析</li>
  476. </ul>
  477. </div>
  478. <div>
  479. <div>AI基础篇案例上</div>
  480. <i class="downboxdown"></i>
  481. <ul class="Hardware2 HarxA">
  482. <li>Hello World</li>
  483. <li>螢幕顯示 Hello World</li>
  484. <li>畫布應用</li>
  485. <li>迷你相機</li>
  486. <li>簡易物體識別</li>
  487. </ul>
  488. </div>
  489. <div>
  490. <div>AI 基础篇案例下</div>
  491. <i class="downboxdown"></i>
  492. <ul class="Hardware2 HarxA">
  493. <li>物體識別進階</li>
  494. <li>人臉檢測</li>
  495. <li>顏色識別</li>
  496. <li>形狀識別(圓形)</li>
  497. <li>形狀識別(矩形)</li>
  498. <li>音頻分析</li>
  499. </ul>
  500. </div>
  501. <div>
  502. <div>AI 扩展使用案例</div>
  503. <i class="downboxdown"></i>
  504. <ul class="Hardware2 HarxA">
  505. <li>私服马达</li>
  506. <li>超声波感测器</li>
  507. <!-- <li>测距仪</li> -->
  508. <li>灯带</li>
  509. <li id="AI_Workshop_III_ex5_Microbit">Microbit</li>
  510. <li id="AI_Workshop_III_ex6_MicrobitFace">人脸检测</li>
  511. <li>电动门</li>
  512. </ul>
  513. </div>
  514. <div>
  515. <div>AI 垃圾分类</div>
  516. <i class="downboxdown"></i>
  517. <ul class="Hardware2 HarxA">
  518. <li>私服马达</li>
  519. <li>超声波感测器</li>
  520. <li>电动门</li>
  521. </ul>
  522. </div>
  523. <div>
  524. <div>AI 自动驾驶</div>
  525. <i class="downboxdown"></i>
  526. <ul class="Hardware2 HarxA">
  527. <li>第一場-路標識別(香港標識)</li>
  528. <li>第二場-巡線(雙線)</li>
  529. <li>第二場-巡線(單線-靠左行駛))</li>
  530. <li>第一場-路標識別(香港標識)</li>
  531. </ul>
  532. </div>
  533. </div>
  534. </div>
  535. </div>
  536. </li>
  537. <!-- help button -->
  538. <!-- <li id="cloudBtn-shares">
  539. <i class="material-icons" style="margin-left:5px;cursor: pointer;">share</i>
  540. </li>
  541. <i id="workspace_screenshot" class="material-icons sketch_name_icon right"
  542. style="margin-left:5px;cursor: pointer;">photo_camera</i>
  543. <i id="button_delete" class="material-icons sketch_name_icon right"
  544. style="margin-left:5px;cursor: pointer;">delete</i> -->
  545. </ul>
  546. <!-- <i id="workspace_screenshot" class="material-icons sketch_name_icon right"
  547. style="margin-left:5px;cursor: pointer;">photo_camera</i> -->
  548. <!-- <i class="material-icons sketch_name_icon right">create</i> -->
  549. <!-- <input id="sketch_name" class="sketch_name" type="text"> -->
  550. <input id="sketch_name_w" class="sketch_name" type="text" name="wifi" style="display:none">
  551. </span>
  552. <!-- </a> -->
  553. <!-- Horizontal Navbar links only shown on large resolutions -->
  554. <ul id="nav-mobile" class="right hide-on-med-and-down nav-mobile-right" style="display: flex;">
  555. <!-- AI Demo -->
  556. <!-- <li>
  557. <a id="AI_experience" class='dropdown-button lang_resize' data-activates='AI_experience_dropdown' style="position:relative">
  558. <span class="translatable_AI_experience">AI</span>
  559. <img class="left nav-icon" src="./icons/nav-ai-experience.png">
  560. </a>
  561. <ul id='AI_experience_dropdown' class='dropdown-content' style="top:62px">
  562. <li id="webcam" class='modal-trigger' href="#webcam_capture_modal">
  563. <span class="translatable_AI_emotion">Emotion Recognotion</span>
  564. </li>
  565. <li class="divider"></li>
  566. <li id="voice-input" class='modal-trigger' href="#voice_input_modal">
  567. <span class="translatable_AI_speech">Speech Recognotion</span>
  568. </li>
  569. </ul>
  570. </li> -->
  571. <!-- help button -->
  572. <li style="display: none;">
  573. <a id="help" style="display:none" class='dropdown-button lang_resize'
  574. data-activates="help_board" style="position:relative">
  575. <!-- <i class="material-icons left" style="margin-right: 5px;font-size: 34px;">help_outline</i> -->
  576. <span class="translatable_help_board">Help</span>
  577. <img class="left nav-icon" src="./icons/nav_help.png">
  578. </a>
  579. <ul id='help_board' class='dropdown-content' style="top:62px">
  580. <li id="">
  581. <a href="http://help.cocorobo.cn/" target="_blank">
  582. <span class="translatable_tutorial">Tutorial</span>
  583. </a>
  584. </li>
  585. <!-- <li class="divider"></li>
  586. <li>
  587. <a href="#tourmode" class="modal-trigger">
  588. <span class="translatable_tour">Start Tour</span>
  589. </a>
  590. </li> -->
  591. <li class="divider"></li>
  592. <!-- <li>
  593. <a href="#env_detect" class="modal-trigger">
  594. <span class="translatable_env_detect">Environment Detect</span>
  595. </a>
  596. </li> -->
  597. <li class="divider"></li>
  598. <li>
  599. <a href="http://help.cocorobo.cn/#/changelog" target="_blank">
  600. <span class="translatable_changelog">Change Log</span>
  601. </a>
  602. </li>
  603. </ul>
  604. </li>
  605. <li style="display:none;">
  606. <select onchange="selectmode(this)" id="mode"
  607. style="outline:0;position:relative;color: #fff;font-weight: 500;width: 175px;height: 35px;border-radius: 30px;background: #fff0;border: 2px solid #fff;margin: 15px 35px 0px 0px;display: block;">
  608. <option value="" style="color: #000;">AI Mode</option>
  609. <option value="" style="color: #000;">Main Mode</option>
  610. </select>
  611. </li>
  612. <li id="cloudBtn-shares">
  613. <i class="material-icons" style="margin-left:5px;cursor: pointer;display: none;">share</i>
  614. </li>
  615. <i id="workspace_screenshot" style="margin-left:5px;cursor: pointer;">
  616. <img src="/images/screenshot.png" style="width: 50px;height: 45px;margin-top:8px;" />
  617. </i>
  618. <i id="button_delete" class="material-icons sketch_name_icon right"
  619. style="margin-left:5px;cursor: pointer;display: none;">delete</i>
  620. <li>
  621. <input id="sketch_name" placeholder="请输入作品名称" class="sketch_name"
  622. style="background: #fff;padding: 4px 10px 4px 20px;color:#222222;width:220px;font-style: initial;"
  623. type="text">
  624. </li>
  625. <li>
  626. <button id="downloadbutton" class="translatable_sketch_save"
  627. style="color: #fff;font-weight: 700;background: #4A6AFF;border: none;font-size: 15px;padding: 13px 20px;height: 40px;">保存</button>
  628. </li>
  629. <!-- App Center demo -->
  630. <!-- <li>
  631. <a id="app_center_title" href="#app_center_modal" class="modal-trigger lang_resize"
  632. style="position:relative">
  633. <span id="app_center_title_demo">
  634. <span class="translatable_labscenter">Labs</span>
  635. <img class="left nav-icon" src="./icons/cocoblockly-navbar_labs-icon.png">
  636. </span>
  637. </a>
  638. </li> -->
  639. <!-- <li>
  640. <a id="nav_learn" class='dropdown-button lang_resize' data-activates="learn_board"
  641. style="position:relative">
  642. <i class="material-icons left" style="margin-right: 5px;font-size: 34px;">help_outline</i>
  643. <span class="translatable_learn_board">Files</span>
  644. <img class="left nav-icon" src="./icons/learn_nav_icon.png">
  645. </a>
  646. <ul id='learn_board' class='dropdown-content'>
  647. <li>
  648. <a href="//edu.cocorobo.cn/" target="_blank">
  649. <span class="translatable_cocoedu">Education Platform</span>
  650. </a>
  651. </li>
  652. <li class="divider"></li>
  653. <li>
  654. <a href="//aihub.cocorobo.cn" target="_blank">
  655. <span class="translatable_learn_principle">Learn AI: Theory</span>
  656. </a>
  657. </li>
  658. <li class="divider"></li>
  659. <li>
  660. <a href="//aihub.cocorobo.cn/vision" target="_blank">
  661. <span class="translatable_learn_vision">Learn AI: Vision</span>
  662. </a>
  663. </li>
  664. <li class="divider"></li>
  665. <li>
  666. <a href="//aihub.cocorobo.cn/speech" target="_blank">
  667. <span class="translatable_learn_speech">Learn AI: Speech</span>
  668. </a>
  669. </li>
  670. <li class="divider"></li>
  671. <li>
  672. <a href="//aihub.cocorobo.cn/text" target="_blank">
  673. <span class="translatable_learn_text">Learn AI: Text</span>
  674. </a>
  675. </li>
  676. <li class="divider"></li>
  677. <li>
  678. <a href="//beta.aihub.cocorobo.cn/art" target="_blank">
  679. <span class="translatable_learn_art">Learn AI: Art</span>
  680. </a>
  681. </li>
  682. </ul>
  683. </li> -->
  684. <!-- <li>
  685. target="_blank"
  686. <a id="help" style="display: none;" class='dropdown-button lang_resize'
  687. href="//x.help.cocorobo.cn" style="position:relative">
  688. <i class="material-icons left" style="margin-right: 5px;font-size: 34px;">help_outline</i>
  689. <span class="translatable_help_board">Help</span>
  690. <img class="left nav-icon" src="./icons/nav_help.png">
  691. </a>
  692. </li> -->
  693. <!-- <li>
  694. <a target="_blank" id="nav_journal" class='dropdown-button lang_resize' href="/md.html"
  695. style="position:relative">
  696. <span class="translatable_journal">日志</span>
  697. <img class="left nav-icon" src="./icons/news.png">
  698. </a>
  699. </li> -->
  700. <!-- <li>
  701. <a id="help" class='dropdown-button lang_resize' target="_blank" href="//x-help.cocorobo.cn"
  702. style="position:relative">
  703. <i class="material-icons left" style="margin-right: 5px;font-size: 34px;">help_outline</i>
  704. <span class="translatable_help_board">Help</span>
  705. <img class="left nav-icon" src="./icons/nav_help.png">
  706. </a>
  707. <a id="nav_devices" class='dropdown-button lang_resize' style="position:relative">
  708. <span class="translatable_devices">Devices</span>
  709. <img class="left nav-icon" src="./icons/Devices.png">
  710. </a>
  711. </li> -->
  712. <!-- <li style="display: block;">
  713. <a id="local_storage" class='dropdown-button lang_resize' data-activates='local_saveOrOpen'
  714. style="position:relative">
  715. <span class="translatable_storage">Files</span>
  716. <img class="left nav-icon" src="./icons/local_storage.png">
  717. </a>
  718. <ul id='local_saveOrOpen' class='dropdown-content' style="top:62px">
  719. <li id="button_cloud" class='modal-trigger' href="#cloud_storage_modal">
  720. <span class="translatable_cloud_storage">Cloud</span>
  721. </li>
  722. <li class="divider"></li>
  723. <li id="button_load">
  724. <span class="translatable_import">Import</span>
  725. </li>
  726. <li class="divider"></li>
  727. <li id="button_save">
  728. <span class="translatable_export">Export</span>
  729. </li>
  730. </ul>
  731. <div id="fileImport" class="btn" style="display:none;">
  732. <input type="file" accept=".py">
  733. </div>
  734. <div id="xmlFileImport" class="btn" style="display:none;">
  735. <input type="file" accept=".xml">
  736. </div>
  737. <div id="pyFileImport" class="btn" style="display:none;">
  738. <input type="file" accept=".py">
  739. </div>
  740. </li> -->
  741. <!-- <li>
  742. <a id="nav_language" class='dropdown-button lang_resize' data-activates='languages'
  743. style="position:relative">
  744. <span class="translatable_language">Language</span>
  745. <img class="left nav-icon" src="./icons/language2.png">
  746. </a>
  747. <ul id='languages' class='dropdown-content active'>
  748. <li onclick="changeLanguage('en')">
  749. <a>English</a>
  750. </li>
  751. <li class="divider"></li>
  752. <li onclick="changeLanguage('zh-hant')">
  753. <a>繁体中文</a>
  754. </li>
  755. <li class="divider"></li>
  756. <li onclick="changeLanguage('zh-hans')">
  757. <a>简体中文</a>
  758. </li>
  759. </ul>
  760. </li> -->
  761. <!-- <li>
  762. <span class="vertical-separator"></span>
  763. </li> -->
  764. <!-- <li>
  765. <a id="nav_account" href="#login_modal" class="modal-trigger lang_resize"
  766. style="position:relative"
  767. onclick="$('#api-key').html(''); $('#api-key').html($('#cloud_events').val()); document.getElementById('api-key').value = $('#cloud_events').val();">
  768. <span id="account_alias"></span>
  769. <button id="account_loginTitle" class="translatable_login_title"
  770. style="color: #fff;font-weight: 500;width: 80px;height: 35px;border-radius: 30px;background: #fff0;border: 2px solid #fff;margin: 0 0 0 15px;">Login</button>
  771. <span id="account_loginTitle" class="translatable_login_title">Login</span>
  772. <img class="nav-icon2 left" src="./icons/user.png">
  773. </a>
  774. </li> -->
  775. <!--<li>
  776. <a id="back_home" class="lang_resize" target="_blank" href="//cocorobo.cn/online/"
  777. style="position:relative">
  778. <img class="nav-icon2" src="./icons/home_icon.png">
  779. </a>
  780. </li> -->
  781. </ul>
  782. </div>
  783. </nav>
  784. <!-- shadow -->
  785. <div id="main_shadow" class="shadowbox" style="display:none;">
  786. <div id="shadow_content" class="shadow_container">
  787. <div class="shadow_top">
  788. <img src="./images/drag_import.png" style="width:200px">
  789. <p class="translatable_drag_import">Drag and drop your file to here</p>
  790. </div>
  791. </div>
  792. </div>
  793. <!-- Content -->
  794. <div id="main_content" style=" width:100%;">
  795. <div id="term" style=" width:100%; height:70%;display:none">
  796. </div>
  797. <div style="height:100%;" id="blockpy-div">
  798. <div>
  799. <div id='blockpy-content'>
  800. <div class="blockpy-editor">
  801. <div class="white blockpy-blocks blockpy-editor-menu"> <img class="fullscreenIcon"
  802. src="./images/icon-fullscreen.svg"> <img class="fullscreenIcon hidden"
  803. src="./images/icon-fullscreen-exit.svg">
  804. <div class='blockly-div' style="width:100%;height:100%;"></div>
  805. </div>
  806. </div>
  807. <div id='sss' style='display:block;overflow: auto;'>
  808. <div id="py-editor" class="blockpy-editor card-panel"
  809. style='height:calc(100% - 245px);display:block;overflow:auto'>
  810. <div class="card-header"
  811. style='position:relative;height: 45px;line-height: 45px;background: #E6F1FF;border-bottom: unset;'>
  812. <!--<span class="header-icon">&lt &gt</span>--> <span id="python_SourceCode" class="header-text translate-code
  813. translatable_pythonSourceCode switch_box switch_select"
  814. style='margin-left: 25px;'>Python
  815. Source Code</span> <span id="Serial_Interaction"
  816. class="header-text translatable_serial_plotter switch_box1">串口数据显示</span>
  817. <span id="Serial_Display"
  818. class="header-text translatable_serial_visualization switch_box2">串口数据可视化</span>
  819. <a class="blockpy-toolbar-edit" style="position:absolute;top: 5px;right:
  820. 110px;"> <img id="edit-off" src="./images/icon-edit.svg"
  821. style="margin-top: 7px;display: block;">
  822. <img id="edit-on" src="./images/icon-edit-on.svg"
  823. style="margin-top: 7px;display: none;">
  824. </a>
  825. <a class="copy_code" style="position:absolute;top: 5px;right: 75px;"
  826. data-clipboard-action="copy">
  827. <img src="./images/icon-view.svg" style="margin-top:7px;"> </a>
  828. <a class="blockpy-toolbar-download" style="position:absolute;top: 5px;right:
  829. 39px;"> <img src="./images/icon-download.svg" style="margin-top: 7px;">
  830. </a>
  831. <a class="blockpy-toolbar-upload" style="position:absolute;top: 5px;right: 5px;">
  832. <img src="./images/icon-upload.svg" style="margin-top: 7px;"> </a>
  833. <img class="fullscreenIcon hidden" src="./images/icon-fullscreen.svg">
  834. <img class="fullscreenIcon hidden" src="./images/icon-fullscreen-exit.svg">
  835. <i id="repl_delete" class="material-icons sketch_name_icon right"
  836. style="margin-left: 20px;cursor: pointer;position: absolute;top: 12px;right: 12px;display:none;">delete</i>
  837. </div>
  838. <div class="card-content"
  839. style="position:relative;height: calc(100% - 45px);overflow:auto;" id="python_box">
  840. <div class="editDiv" id="editDiv" style="top: 0;width: 100%;left: 0;padding: 0;z-index: 0;
  841. right: 0;">
  842. <!-- <span class="translatable_editing">Enable Editing</span>
  843. <span style="display: none;" class="translatable_close_editing">Close
  844. Editing</span> -->
  845. <input type="checkbox" id="toggle-button" style="display: none;">
  846. <!--label中的for跟input的id绑定。作用是在点击label时选中input或者取消选中input-->
  847. <label for="toggle-button" class="button-label" style="display: none;">
  848. <span class="circle"></span>
  849. <span class="text on"></span>
  850. <span class="text off"></span>
  851. </label>
  852. </div>
  853. <div class="blockpy-toolbar" style="position: absolute;top: 0;width: 100%;">
  854. <div class='blockpy-text blockpy-editor-menu'>
  855. <div class='blockpy-text-sidebar'></div>
  856. <textarea readonly class='codemirror-div language-python'></textarea>
  857. </div>
  858. <div class="edit" id="edit"></div>
  859. <!-- <a class="copy_code" style="position:fixed;top:112px;right:25px;z-index:999;cursor:pointer;" data-clipboard-action="copy"> <img src="./images/icon-copy.svg" width="24px"> </a> <div class="blockpy-toolbar-download" style="position:fixed;top:113px;right:55px;z-index:999;cursor:pointer;"> <img src="./images/icon-downward.svg" width="24px"> </div>-->
  860. </div>
  861. </div>
  862. <div class="card-content hidden"
  863. style="position:relative;height: calc(100% - 60px);overflow:auto;padding:5px 10px;background-color: #fff; color: #000;"
  864. id="repl_box">
  865. <div class="editDiv" id="editDiv" style="width: 100%;left: -10px;padding: 0;">
  866. <span class="translatable_serial_plotter serial-active" id="switchSerial1"
  867. onclick="switchSerial('1')" style="display: none;">The
  868. data to print</span>
  869. <span class="translatable_serial_visualization" id="switchSerial2"
  870. onclick="switchSerial('2')" style="display: none;">Visual
  871. display</span>
  872. </div>
  873. <div class="blockpy-toolbar" id="repl_box_content"
  874. style="display:block;padding-top:35px;">
  875. </div>
  876. <div style="width: 100%;height: calc(100% - 50px);display: none;margin: 35px 0 10px 0;position: relative;"
  877. id="echartsShow">
  878. <div id="echartsMain" class="echartsMain"></div>
  879. <div id="echartsMains" style="display: none;">
  880. <span id="echartsMainSpan"></span>
  881. </div>
  882. </div>
  883. </div>
  884. <!-- <a class="copy_code" style="position:absolute;top:160px;right:70px;z-index:999;cursor:pointer;" data-clipboard-action="copy"> <img src="./images/icon-copy.svg" width="24px"> </a> <div class="blockpy-toolbar-download" style="position:absolute;top:160px;right:95px;z-index:999;cursor:pointer;"> <img src="./images/icon-downward.svg" width="24px"> </div> -->
  885. </div>
  886. <div class='blockpy-content-left card-panel card'
  887. style='display: block;background: #f8f8f8;min-height: 245px;position:relative;'>
  888. <div class="card-header" style='height: 60px;line-height: 60px;background: #f1f2f5;'>
  889. <!-- http://help.cocorobo.cn/#/getting-started/info target="_blank"-->
  890. <div style='float:right;display: none;'>
  891. <a class="header-link upload_instruction" style="display: none;" href="#"
  892. data-tooltip-id="61c522fa-be27-2a3e-1f2d-cde212348740">
  893. <img src="./icons/instruction.png">
  894. </a>
  895. <a id="plugin_download" class="header-link" href="javaScript:(0)"
  896. data-tooltip-id="9e546554-688a-01c7-cde3-faaff99b557d"> <img
  897. src="./icons/plugin_download.png">
  898. <img style="position:absolute;height:10px;right:45px;bottom:32px; display:none; "
  899. src="./icons/icon_new.png">
  900. </a>
  901. <a href="#iframe" class="modal-trigger header-link" id="showIframe">
  902. <img src="./icons/firmware.png">
  903. </a>
  904. <!-- <a href="#updatePy" class="modal-trigger header-link">
  905. <img src="./icons/加载.png">
  906. </a> -->
  907. <label class="hidden"><input type="checkbox" class="filled-in" />
  908. <span class="translatable_Adapter_fill_connected filled-in_nocheked"
  909. style="color: #26a69a;font-size: 17px;font-weight: 600;">Adapter is
  910. disconnected</span>
  911. </label>
  912. </div>
  913. <!--<span class="header-icon"><img style="width: 30px;margin: 8px 8px 8px 20px;" src="./images/zhixing.png"> </span>-->
  914. <span class="header-text translate-code translatable_title_device"
  915. style='font-weight: 800;font-size: 20px;margin-left: 25px;'>Device</span>
  916. <div style="display: inline-block;margin-left: 20px;"><select
  917. class="select-connected " id="select-connected">
  918. <option class="select-connected translatable_select_connecteds"
  919. style="color: #000;">The
  920. cable to upload</option>
  921. <option style="color: #000;" class="translatable_no_select_connecteds">
  922. Wireless cable
  923. upload</option>
  924. </select></div>
  925. <div id="discnt_icon" style="display:inline-block;">
  926. <a href="#env_detect" class="modal-trigger"><img
  927. style="height:17px;margin-left:8px;transform:translateY(2px);"
  928. src="./icons/uploader_disconnect.png"></a>
  929. </div>
  930. <div id="cnt_icon" style="display:none;"><img
  931. style="height:17px;margin-left:8px;transform:translateY(2px);"
  932. src="./icons/uploader_connect.png"></div>
  933. <a id="send_string" onclick="sendstring('machine.reset()')" class="waves-effect
  934. waves-light blue disabled" style="margin-right:0.5rem;background-color: #f1f2f5 !important;float: right;margin-top: 10px;">
  935. <!-- <span id="resetDevice">Reset Device</span> -->
  936. <img id="refresh-disabled" src="./images/icon-refresh-disabled.svg" style="margin-top: 7px;display: block;">
  937. <img id="refresh" src="./images/icon-refresh.svg" style="margin-top: 7px;display: none;">
  938. <img id="refresh-press" src="./images/icon-refresh-press.svg" style="margin-top: 7px;display: none;">
  939. </a>
  940. </div>
  941. <!--<div class="card-header"> <span class="header-icon" style="line-height:40px;"><img style="height:30px;vertical-align:middle;" src="./images/icon-aspect.svg"></span> <span class="header-text translate-output">Output Area</span> <img class="fullscreenIcon" src="./images/icon-fullscreen.svg"> <img class="fullscreenIcon hidden" src="./images/icon-fullscreen-exit.svg"> </div>-->
  942. <!--<div class="card-content" style="display:block;grid-template-rows:1fr 50px;"> <div style="border-bottom:1px solid #ddd;padding:8px;overflow:hidden;"> <div style="height:100%;overflow:hidden;"> <div class='blockpy-printer blockpy-printer-default' style="resize:none;height:98%;width:100%;border:1px solid #818181;"> </div> </div> </div>-->
  943. <div class="card-content" style="padding:8px 10px;width:100%">
  944. <div class="row" id="status">
  945. <div class="col s12"><img id="error-btn" class="activator"
  946. src="./icons/error.png">
  947. <span id="status_bar" class="translatable_statusbar">直接将代码上传到电子模块中。</span>
  948. </div>
  949. </div>
  950. <div class="row" id="progress">
  951. <div class="col s12">
  952. <div class="progress" style="margin:7px 0;">
  953. <div class="determinate green" style="width:0%;"></div>
  954. </div>
  955. </div>
  956. </div>
  957. <div class="row btn-network">
  958. <div class="col s6" style="padding-right:1px;">
  959. <div class="select-wrapper initialized"><span class="caret">▼</span><input
  960. type="text" class="select-dropdown" id="select_dropdown"
  961. readonly="true"
  962. data-activates="select-options-eca84f35-6884-7dc4-9d8b-c14115abe698"
  963. value="检测不到连接端口">
  964. <ul id="select-options-eca84f35-6884-7dc4-9d8b-c14115abe698" class="dropdown-content
  965. select-dropdown ">
  966. <li class="disabled "><span>检测不到连接端口</span></li>
  967. </ul><select id="ports"
  968. data-select-id="eca84f35-6884-7dc4-9d8b-c14115abe698"
  969. class="initialized">
  970. <option value="null" disabled="">检测不到连接端口</option>
  971. </select>
  972. </div>
  973. </div>
  974. <div class="col s6">
  975. <div style="float: right;margin-top: 15px;">
  976. <div style="display: inline-block;vertical-align: middle;">
  977. <img id="runSuccess" src="/images/success.png" style="display: none;"/>
  978. <img id="runFail" src="/images/fail.png" style="display: none;"/>
  979. </div>
  980. <div style="display: inline-block;">
  981. <span id="statusMsg"></span>
  982. </div>
  983. </div>
  984. </div>
  985. </div>
  986. <div class="row btn-network hidden">
  987. <div class="col cs6" style="padding-right:1px;width:100%">
  988. <div class="select-wrapper initialized" style='float: left;width: 45%;'>
  989. <input type="text" class="select-dropdown" data-activates=""
  990. id='ipAddress' placeholder="请输入ip地址">
  991. </div>
  992. <div style='display:inline-block'><a onclick='button_click();' class="waves-effect waves-light
  993. btn blue" style="margin-left: 0.5rem;margin-top: 4px;"><span
  994. id="ConnectBtn">Connect
  995. </spanbutton_click></a></div>
  996. </div>
  997. </div>
  998. <div class="row" style="position: absolute;bottom: 15px;width: 98%;margin: 0;">
  999. <div id="uploader-btns" class="col s12">
  1000. <a onclick='sendfile();' id="send_file" class="waves-effect
  1001. waves-light btn blue disabled"
  1002. style="margin-right:0.5rem;padding:0 0.5rem;">
  1003. <i style="cursor: pointer;" class="fa fa-play-circle"
  1004. aria-hidden="true"></i>
  1005. <span id="runCode"></span>
  1006. </a>
  1007. <a onclick="uploadpyfile()" id="uploadpy" class="waves-effect
  1008. waves-light btn blue disabled" style="padding:0 0.5rem;">
  1009. <i style="cursor: pointer;" class="fa fa-upload" aria-hidden="true"></i>
  1010. <span id="uploadFiles"></span>
  1011. </a>
  1012. <div style="float: right;">
  1013. <li style="display: none;">
  1014. <ul id="localsssssaveOrOpen" class="dropdown-content active">
  1015. <li style="padding: 14px 16px;" onclick="uploadfile(true)">
  1016. <a>开机启动可视化菜单界面</a></li>
  1017. <li style="padding: 14px 16px;" onclick="uploadfile(false)">
  1018. <a>开机运行上次的程序</a></li>
  1019. </ul>
  1020. <a id="qiehuanbtn"
  1021. class="qiehuanbtn btn dropdown-trigger blue lang_resize dropdown-button disabled"
  1022. data-activates="localsssssaveOrOpen"><span
  1023. id="runCuploadFilesode">更换启动模式</span><i
  1024. class="material-icons right"
  1025. style="margin-left: 0;">arrow_drop_down</i></a>
  1026. </li>
  1027. <!-- <a id="send_string" onclick="sendstring('machine.reset()')" class="waves-effect
  1028. waves-light btn blue disabled" style="margin-right:0.5rem;"><span
  1029. id="resetDevice">Reset Device</span></a> -->
  1030. </div>
  1031. </div>
  1032. <a onclick="getmcnty()" class="waves-effect waves-light btn blue"
  1033. style="display:none"><span id="gettype">Upload
  1034. files</span></a>
  1035. </div>
  1036. </div>
  1037. <div class="blockpy-toolbar btn-toolbar hidden" style="align-self:center;margin: 20px 8px 0;text-align:
  1038. center;">
  1039. <div class="btn-toolbar-title">直接将代码上传到电子模块中<div></div>
  1040. </div>
  1041. <div class="btn-toolbar-inputbox"><input type="text" name="webrepl_url" id="url"
  1042. placeholder="Select a device"><input type="submit" id='button'
  1043. value='Connect' onclick='button_click(); return false'></div>
  1044. <div class="btn-toolbar-btnbox"></div>
  1045. <!--<button onclick='sendfile();' style='width: 80%;background: #6e83cc !important;margin-top: 15px;font-size: 16px;height:45px' class='waves-effect waves-light btn blue blockpy-run translate-execute'>上傳</button>-->
  1046. <!--<button class='waves-effect waves-light btn blue blockpy-run translate-execute'>UPLOAD</button>-->
  1047. <!-- <button href="#aiymodal" class='waves-effect waves-light btn blue modal-trigger'>run on aiy</button> -->
  1048. <!--<button id="resetAll" class='waves-effect waves-light btn blue translate-reset' style="float:right;">reset</button> <button id="clearOutput" class='waves-effect waves-light btn blue translate-clear' style="float:right;margin-right:5px;">clear</button>-->
  1049. </div>
  1050. <div class="blockpy-toolbar btn-toolbar hidden" style="align-self:center;margin: 20px 8px 0;text-align:
  1051. center;">
  1052. <div class="btn-toolbar-title2">直接将代码上传到电子模块中 <div></div>
  1053. </div>
  1054. <div class="btn-toolbar-inputbox2"><select>
  1055. <option>检测不到连接端口</option>
  1056. </select></div>
  1057. </div>
  1058. <div class="card-reveal grey darken-3 white-text" style="padding:8px 13px;">
  1059. <div class="card-title" style="height:18%;margin-bottom:2px;">
  1060. <span class="translatable_errmsg" style="font-weight:normal;">Error
  1061. Message</span>
  1062. <a id="err-copy" style="display:inline-block;margin-left:26px;"
  1063. data-clipboard-action="copy" data-clipboard-target="#err-msg">
  1064. <i class="material-icons right"
  1065. style="color:#fff;font-size:18px;cursor:pointer;">content_copy</i>
  1066. </a>
  1067. <i class="material-icons right" style="cursor:pointer;">close</i>
  1068. </div>
  1069. <div style="width:100%;height:78%;">
  1070. <textarea readonly id="err-msg"
  1071. style="color:#fff;overflow:visible;font-family:consolas;font-size:14px;height:100%;resize:none;border:none;"></textarea>
  1072. </div>
  1073. </div>
  1074. </div>
  1075. <div class="card plugin_options options_hide">
  1076. <div class="card-content">
  1077. <div>
  1078. <span id="downloadver" style="display:none">1.0.6</span>
  1079. <a download=""
  1080. href="//cocorobo.cn/downloads/CocoBlocklyXUploaderInstallerv1.0.10.pkg"
  1081. target="_black"><img src="./icons/mac-icon.png">Mac </a>
  1082. <a download=""
  1083. href="//cocorobo.cn/downloads/CocoBlocklyXUploaderInstallerv1.0.11.exe"
  1084. target="_black"><img src="./icons/windows-icon.png">Windows </a> </div>
  1085. </div>
  1086. </div>
  1087. </div>
  1088. </div>
  1089. </div>
  1090. <div class='modal blockpy-popup'>
  1091. <div class='modal-content' id='modal-message'>
  1092. <div class='modal-header'>
  1093. <h4 class='modal-title'>Dynamic Content</h4>
  1094. </div>
  1095. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;">
  1096. <div class='modal-body' style='width:100%;min-height:200px;'> </div>
  1097. </div>
  1098. <div class='modal-footer'> <button
  1099. class='waves-effect waves-light btn blue modal-close translate-close'>close</button>
  1100. </div>
  1101. </div>
  1102. <div id="aiymodal" class="modal">
  1103. <div class="modal-content" height="50%">
  1104. <h4>Run on AIY</h4>
  1105. <p>This feature gives you the ability to run your AIY python code directly to the AIY Vision Kit
  1106. or Voice Kit, follow the instruction below:</p>
  1107. <div style="margin-top:30px;"> <b
  1108. style="background-color:#fff; border-radius:25px;padding:
  1109. 10px 20px; box-shadow: 1px 5px 23px -10px rgba(0,0,0,0.59);">Step 1</b> </div>
  1110. <div style="margin-top:30px;"> Run the <b data-position="bottom" data-tooltip="I am a
  1111. tooltip" class="tooltipped">AIY Helper</b>, <a id="AIYdownload"
  1112. style="cursor:pointer;">Download</a> the python code to local, <br />make sure you are
  1113. in the same network with the Google AIY Vision Kit. </div>
  1114. <div style="margin-top:30px;"> <b
  1115. style="background-color:#fff; border-radius:25px;padding:
  1116. 10px 20px; box-shadow: 1px 5px 23px -10px rgba(0,0,0,0.59);">Step 2</b> </div>
  1117. <div class="input-field col s9" style="margin-top:0px;"> Enter the IP Address of your Google
  1118. AIY Kit: <div class="input-field inline"> <input id="aiyip_input" class="validate">
  1119. </div> <a id="aiyModalRun" onclick="functionSSH();" style="margin-left:10px;"
  1120. class="waves-effect blue waves-light btn">Run</a> <a id="aiyModalStop"
  1121. onclick="functionSSHstop();" style="margin-left:10px;" class="waves-effect blue
  1122. waves-light btn">Stop</a>
  1123. <!-- <a id="aiyModalRun" style="margin-left:10px;" class="waves-effect blue waves-light btn">Run</a> -->
  1124. <!-- <a id="aiyModalStop" style="margin-left:10px;" class="waves-effect blue waves-light btn">Stop</a> -->
  1125. </div>
  1126. <div id="modal_preload" style="display:none">
  1127. <div style="position:relative;top:50%;transform:translateY(-50%);height:128px;width:128px;margin:0
  1128. auto;">
  1129. <div class="preloader-wrapper big active" style="top:0;left:0">
  1130. <div class="spinner-layer spinner-blue-only">
  1131. <div class="circle-clipper left">
  1132. <div class="circle"></div>
  1133. </div>
  1134. <div class="gap-patch">
  1135. <div class="circle"></div>
  1136. </div>
  1137. <div class="circle-clipper right">
  1138. <div class="circle" style="border-width: 8px;"></div>
  1139. </div>
  1140. </div>
  1141. </div>
  1142. </div>
  1143. </div>
  1144. </div>
  1145. <div class="modal-footer" style="margin-top:-20px;"> <a href="#!" class="modal-close
  1146. waves-effect waves-green btn-flat">Close</a> </div>
  1147. </div>
  1148. </div>
  1149. <!-- <ul id="icon-tool">
  1150. <li class="card-icon active" onclick="">
  1151. <i class="material-icons media">build</i>
  1152. </li>
  1153. <li id="file-tool" class="card-icon">
  1154. <i class="material-icons media">folder</i>
  1155. </li>
  1156. <li id="lang-tool" class="card-icon">
  1157. <i class="material-icons media">translate</i>
  1158. </li>
  1159. </ul> -->
  1160. <ul id="icon-tool" class="card-icon-area" style="display: none;">
  1161. <li class="card-icon active hidden" onclick="changeSideCard('code')">
  1162. <i class="material-icons media">build</i>
  1163. </li>
  1164. <li class="card-icon hidden" onclick="changeSideCard('monitor')">
  1165. <i class="material-icons ">search</i>
  1166. </li>
  1167. <!-- <li class="card-icon" onclick="changeSideCard('fullmode')">
  1168. <i class="material-icons ">crop_free</i>
  1169. </li> -->
  1170. <li id="bar_python" class="card-icon">
  1171. <a href="/python" target="_blank">
  1172. <img class="bar-icon" src="./icons/python_icon.png" style="height: 30px;">
  1173. </a>
  1174. </li>
  1175. <li id="lang-tool" class="card-icon">
  1176. <i class="material-icons">translate</i>
  1177. </li>
  1178. <li id="apps_center" class="card-icon modal-trigger" href="#app_center_modal" style="display:none;">
  1179. <img class="bar-icon Img-filter" src="./icons/cocoblockly-navbar_labs-icon.png">
  1180. </li>
  1181. <li id="bar_storage" class="card-icon">
  1182. <img class="bar-icon" src="./icons/storage_icon-blockly-widget.png">
  1183. </li>
  1184. <!-- http://help.cocorobo.cn/ target="_blank"-->
  1185. <li id="bar_help" class="card-icon">
  1186. <a href="//x-help.cocorobo.cn" target="_blank">
  1187. <img class="bar-icon" src="./icons/help_icon-blockly-widget.png">
  1188. </a>
  1189. </li>
  1190. <li id="bar_ai" class="card-icon" onclick="$('.MouduleBox')[1].style.display = 'block';">
  1191. <a href="#">
  1192. <img class="bar-icon" src="./icons/AIicon.png">
  1193. </a>
  1194. </li>
  1195. <li id="bar_t" class="card-icon modal-trigger" onclick="$('#ai_tt')[0].style.display = 'block';">
  1196. <a href="#">
  1197. <img class="bar-icon" src="./icons/l.png">
  1198. </a>
  1199. </li>
  1200. </ul>
  1201. <a id='side-lang-trigger' class='dropdown-button' data-activates='side-lang'></a>
  1202. <!-- <div id='side-lang-trigger'>
  1203. <a class='dropdown-trigger' data-target='side-lang'></a>
  1204. </div> -->
  1205. <ul id="side-lang" class='dropdown-content'>
  1206. <li onclick="changeLanguage('en')">
  1207. <a>English</a>
  1208. </li>
  1209. <li class="divider"></li>
  1210. <li onclick="changeLanguage('zh-hant')">
  1211. <a>繁体中文</a>
  1212. </li>
  1213. <li class="divider"></li>
  1214. <li onclick="changeLanguage('zh-hans')">
  1215. <a>简体中文</a>
  1216. </li>
  1217. </ul>
  1218. <a id='side-storage-trigger' class='dropdown-button' data-activates='side-storage'></a>
  1219. <ul id='side-storage' class='dropdown-content'>
  1220. <li class='modal-trigger' href="#cloud_storage_modal" style="display:none;">
  1221. <span class="translatable_cloud_storage">Cloud</span>
  1222. </li>
  1223. <li class="divider"></li>
  1224. <li class='modal-trigger' href="#Storage_import_modal">
  1225. <span class="translatable_localimport">Import</span>
  1226. </li>
  1227. <li class="divider"></li>
  1228. <li class='modal-trigger' href="#Storage_export_modal">
  1229. <span class="translatable_localexport">Export</span>
  1230. </li>
  1231. </ul>
  1232. <div id='side-file-trigger'>
  1233. <a class='dropdown-trigger' data-target="side-file"></a>
  1234. </div>
  1235. <ul id='side-file' class='dropdown-content blockpy-toolbar'>
  1236. <li id="side_button_load">
  1237. <span class="translate_import">Import</span>
  1238. </li>
  1239. <li class="divider"></li>
  1240. <li id="side_button_save">
  1241. <span class="translate_export">Export</span>
  1242. </li>
  1243. </ul>
  1244. </div>
  1245. <!-- <footer id="footer">
  1246. <div style="padding:0 1.5rem">
  1247. <div><span class="translatable_copyright" style="color:#fff;">CocoRobo LTD © 2020 Copyright</span></div>
  1248. <div><span>CocoBlockly X</span></div>
  1249. </div>
  1250. </footer> -->
  1251. <!-- app center modal -->
  1252. <div id="app_center_modal" class="modal modal_closes">
  1253. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1254. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1255. <div id="TM_login"></div>
  1256. <div class="modal-content" style="padding: 20px;">
  1257. <span class="modal_close" style="padding: 15px;">
  1258. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  1259. </span>
  1260. <h4 class="translatable_labs_center_modal_title">CocoBlockly X Labs</h4>
  1261. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;" />
  1262. <div class="row" style="text-align:left;">
  1263. <div style="float:center;" class="col s3">
  1264. <p class="translatable_app_center_all_categories" style="padding-bottom:0px;font-weight: bold">
  1265. All
  1266. Categories:</p>
  1267. <div id="center_categories" class="collection ">
  1268. <a name="center_ai"
  1269. class="collection-item grey-text text-darken-4 active translatable_app_center_ai"
  1270. onclick="ACCategorySelect(1)">Artificial Intelligence</a>
  1271. <a name="center_iot"
  1272. class="collection-item grey-text text-darken-4 translatable_app_center_iot"
  1273. onclick="ACCategorySelect(2)">Internet of Things</a>
  1274. <a name="center_robot"
  1275. class="collection-item grey-text text-darken-4 translatable_app_center_robot"
  1276. onclick="ACCategorySelect(3)">Robot Controller</a>
  1277. <a name="center_science"
  1278. class="collection-item grey-text text-darken-4 translatable_app_center_science"
  1279. onclick="ACCategorySelect(4)">Science Experiements</a>
  1280. <a name="center_game"
  1281. class="collection-item grey-text text-darken-4 translatable_app_center_games"
  1282. onclick="ACCategorySelect(5)">Games</a>
  1283. <a name="center_arvr"
  1284. class="collection-item grey-text text-darken-4 translatable_app_center_arvr"
  1285. onclick="ACCategorySelect(6)">AR/VR</a>
  1286. </div>
  1287. </div>
  1288. <div style="float:center;padding-top:5px; overflow-y:auto;max-height:400px" class="col s9">
  1289. <div id="center_ai" class=" col s12">
  1290. <h5 class="translatable_app_center_ai">Artificial Intelligence</h5>
  1291. <ul class="tabs">
  1292. <li class="tab col s2"><a href="#center_ai_vision"
  1293. class="translatable_app_center_tab_vision active">Vision</a></li>
  1294. <li class="tab col s2"><a href="#center_ai_speech"
  1295. class="translatable_app_center_tab_speech">Speech</a></li>
  1296. <li class="tab col s2"><a href="#center_ai_text"
  1297. class="translatable_app_center_tab_text">Text</a></li>
  1298. </ul>
  1299. <div id="center_ai_vision" class="col s12">
  1300. <div class="row">
  1301. <div style="float:left;" class="col s6">
  1302. <div class="card">
  1303. <div class="card-image waves-effect waves-block waves-light">
  1304. <img class="" src="icons/AppCenter_ai_teachableMachine.jpg"
  1305. style="border: solid 1.2px lightgray;">
  1306. </div>
  1307. <div class="card-content">
  1308. <!-- <span class="AI_card_content">COCOCLOUD APP</span> -->
  1309. <span id="ac-card-title"
  1310. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_Teachabel_Machine">Teachable
  1311. Machine</span>
  1312. <p class="">
  1313. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1314. href="#setting_teacher">Enter</a>
  1315. </p>
  1316. </div>
  1317. </div>
  1318. </div>
  1319. <div style="float:left;" class="col s6">
  1320. <div class="card">
  1321. <div class="card-image waves-effect waves-block waves-light">
  1322. <!-- <img class="activator" src="icons/app-center_ai_emotion.jpg"> -->
  1323. <img class="" src="icons/AppCenter_ai_emotion.jpg">
  1324. </div>
  1325. <div class="card-content">
  1326. <!-- <span class="AI_card_content">COCOCLOUD APP</span> -->
  1327. <span id="ac-card-title emotion_recognition_enter_button"
  1328. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_emotion_recognition">Emotion
  1329. Recognition</span>
  1330. <p class="">
  1331. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1332. href="#setting_webcam_capture_modal">Enter</a>
  1333. </p>
  1334. </div>
  1335. </div>
  1336. </div>
  1337. </div>
  1338. <div class="row">
  1339. <div style="float:left;" class="col s6">
  1340. <div class="card">
  1341. <div class="card-image waves-effect waves-block waves-light">
  1342. <!-- <img class="activator" src="icons/app-center_ai_emotion.jpg"> -->
  1343. <img class="" src="icons/AppCenter_ai_gesture_recognition.jpg">
  1344. </div>
  1345. <div class="card-content">
  1346. <!-- <span class="AI_card_content">COCOCLOUD APP</span> -->
  1347. <span id="ac-card-title emotion_recognition_enter_button"
  1348. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_gesture_recognition translatable_gesturesTitle">Gesture
  1349. Recognition</span>
  1350. <p class="">
  1351. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1352. href="#setting_gesture_recog_modal">Enter</a>
  1353. </p>
  1354. </div>
  1355. </div>
  1356. </div>
  1357. <div style="float:left;" class="col s6">
  1358. <div class="card">
  1359. <div class="card-image waves-effect waves-block waves-light">
  1360. <!-- <img class="activator" src="icons/app-center_ai_emotion.jpg"> -->
  1361. <img class="" src="icons/object_recognition_header.jpg">
  1362. </div>
  1363. <div class="card-content">
  1364. <!-- <span class="AI_card_content">COCOCLOUD APP</span> -->
  1365. <span id="ac-card-title emotion_recognition_enter_button"
  1366. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_object_recognition translatable_objectRecognition">Object
  1367. Recognition</span>
  1368. <p class="">
  1369. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1370. href="#setting_objectRecog">Enter</a>
  1371. </p>
  1372. </div>
  1373. </div>
  1374. </div>
  1375. <div style="float:left;" class="col s6">
  1376. <div class="card">
  1377. <div class="card-image waves-effect waves-block waves-light">
  1378. <!-- <img class="activator" src="icons/app-center_ai_emotion.jpg"> -->
  1379. <img class="" src="icons/posenet_recogition.png">
  1380. </div>
  1381. <div class="card-content">
  1382. <!-- <span class="AI_card_content">COCOCLOUD APP</span> -->
  1383. <span id="ac-card-title emotion_recognition_enter_button"
  1384. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_object_recognition translatable_posenetRecognition">Posenet
  1385. Recognition</span>
  1386. <p class="">
  1387. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1388. href="#setting_posenetRecog">Enter</a>
  1389. </p>
  1390. </div>
  1391. </div>
  1392. </div>
  1393. <div style="float:left;" class="col s6">
  1394. <div class="card">
  1395. <div class="card-image waves-effect waves-block waves-light">
  1396. <img class="" src="images/tm_with_pose.jpg"
  1397. style="border: solid 1.2px lightgray;">
  1398. </div>
  1399. <div class="card-content">
  1400. <!-- <span class="AI_card_content">COCOCLOUD APP</span> -->
  1401. <span id="ac-card-title"
  1402. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_Teachabel_Machine_posenet">Teachable
  1403. Machine (with Pose Recognition)</span>
  1404. <p class="">
  1405. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1406. href="#setting_teacher_ponsenet">Enter</a>
  1407. </p>
  1408. </div>
  1409. </div>
  1410. </div>
  1411. </div>
  1412. </div>
  1413. <div id="center_ai_speech" class="col s12">
  1414. <div style="float:center;" class="col s6">
  1415. <div class="card">
  1416. <div class="card-image waves-effect waves-block waves-light">
  1417. <img class="" src="icons/AppCenter_ai_speech.jpg">
  1418. </div>
  1419. <div class="card-content">
  1420. <!-- <span class="AI_card_content">COCOCLOUD APP</span> -->
  1421. <span id="ac-card-title"
  1422. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_speech_recognition">Speech
  1423. Recognition</span>
  1424. <p class="">
  1425. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1426. href="#voice_input_modal">Enter</a>
  1427. </p>
  1428. </div>
  1429. </div>
  1430. </div>
  1431. </div>
  1432. <div id="center_ai_text" class="col s12">
  1433. <div style="float:center;" class="col s6">
  1434. <div class="card">
  1435. <div class="card-image waves-effect waves-block waves-light">
  1436. <img class="" src="./icons/AppCenter_comingSoon.jpg">
  1437. </div>
  1438. <div class="card-content">
  1439. <span id="ac-card-title"
  1440. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_wait_to_come">Comming
  1441. soon</span>
  1442. <p class="">
  1443. <!-- <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button disabled" href="#">Enter</a> -->
  1444. </p>
  1445. </div>
  1446. </div>
  1447. </div>
  1448. </div>
  1449. </div>
  1450. <div id="center_iot" class=" col s12" style="display:none">
  1451. <h5 class="translatable_app_center_iot">Internet of Things</h5>
  1452. <div style="float:center;" class="col s6">
  1453. <div class="card">
  1454. <div class="card-image waves-effect waves-block waves-light">
  1455. <img class="" src="icons/AppCenter_iot_thingspeak.jpg">
  1456. </div>
  1457. <div class="card-content">
  1458. <!-- <span class="AI_card_content">3RD-PARTY APP</span> -->
  1459. <span id="ac-card-title"
  1460. class="ac-card-title card-title activator grey-text text-darken-4 ">ThingSpeak</span>
  1461. <p class="">
  1462. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1463. href="https://thingspeak.com" target="_blank">Enter</a>
  1464. </p>
  1465. </div>
  1466. </div>
  1467. </div>
  1468. <div style="float:center;" class="col s6">
  1469. <div class="card">
  1470. <div class="card-image waves-effect waves-block waves-light">
  1471. <img class="" src="icons/AppCenter_iot_ifttt.jpg">
  1472. </div>
  1473. <div class="card-content">
  1474. <!-- <span class="AI_card_content">3RD-PARTY APP</span> -->
  1475. <span id="ac-card-title"
  1476. class="ac-card-title card-title activator grey-text text-darken-4 ">IFTTT</span>
  1477. <p class="">
  1478. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1479. href="https://ifttt.com/maker_webhooks" target="_blank">Enter</a>
  1480. </p>
  1481. </div>
  1482. </div>
  1483. </div>
  1484. </div>
  1485. <div id="center_robot" class=" col s12" style="display:none">
  1486. <h5 class="translatable_app_center_robot">Robot Controller</h5>
  1487. <div style="float:center;" class="col s6">
  1488. <div class="card">
  1489. <div class="card-image waves-effect waves-block waves-light">
  1490. <img class="" src="./icons/AppCenter_comingSoon.jpg">
  1491. </div>
  1492. <div class="card-content">
  1493. <span id="ac-card-title"
  1494. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_wait_to_come">Comming
  1495. soon</span>
  1496. <p class="">
  1497. <!-- <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button disabled" href="#">Enter</a> -->
  1498. </p>
  1499. </div>
  1500. </div>
  1501. </div>
  1502. </div>
  1503. <div id="center_science" class="col s12" style="display:none">
  1504. <h5 class="translatable_app_center_science">Science Experiements</h5>
  1505. <div style="float:center;" class="col s6">
  1506. <div class="card">
  1507. <div class="card-image waves-effect waves-block waves-light">
  1508. <img class="" src="./icons/AppCenter_comingSoon.jpg">
  1509. </div>
  1510. <div class="card-content">
  1511. <span id="ac-card-title"
  1512. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_wait_to_come">Comming
  1513. soon</span>
  1514. <p class="">
  1515. <!-- <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button disabled" href="#">Enter</a> -->
  1516. </p>
  1517. </div>
  1518. </div>
  1519. </div>
  1520. </div>
  1521. <div id="center_game" class=" col s12" style="display:none">
  1522. <h5 class="translatable_app_center_games">Interactive Games</h5>
  1523. <div style="float:center;" class="col s6">
  1524. <div class="card">
  1525. <div class="card-image waves-effect waves-block waves-light">
  1526. <img class="" src="./icons/AppCenter_game_floppy-bird.jpg">
  1527. </div>
  1528. <div class="card-content">
  1529. <!-- <span class="AI_card_content">3RD-PARTY APP</span> -->
  1530. <span id="ac-card-title"
  1531. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_game_flappy">Floppy
  1532. bird</span>
  1533. <p class="">
  1534. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button "
  1535. href="https://cocorobo.cn/demo/floppybird/" target="_blank">Enter</a>
  1536. </p>
  1537. </div>
  1538. </div>
  1539. </div>
  1540. <div style="float:center;" class="col s6">
  1541. <div class="card">
  1542. <div class="card-image waves-effect waves-block waves-light">
  1543. <img class="" src="icons/AppCenter_game_space_lamb.jpg">
  1544. </div>
  1545. <div class="card-content">
  1546. <!-- <span class="AI_card_content">3RD-PARTY APP</span> -->
  1547. <span id="ac-card-title"
  1548. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_game_space_lamb">Space
  1549. Lamb</span>
  1550. <p class="">
  1551. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button "
  1552. href="https://spacelamb.12wave.com" target="_blank">Enter</a>
  1553. </p>
  1554. </div>
  1555. </div>
  1556. </div>
  1557. </div>
  1558. <div id="center_arvr" class=" col s12" style="display:none">
  1559. <h5 class="translatable_app_center_arvr">AR/VR</h5>
  1560. <div style="float:center;" class="col s6">
  1561. <div class="card">
  1562. <div class="card-image waves-effect waves-block waves-light">
  1563. <!-- <img class="activator" src="icons/app-center_ai_speech.jpg"> -->
  1564. <img class="" src="icons/AppCenter_comingSoon.jpg">
  1565. </div>
  1566. <div class="card-content">
  1567. <span id="ac-card-title"
  1568. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_wait_to_come">Comming
  1569. soon</span>
  1570. <p class="">
  1571. <!-- <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button disabled" href="#">Enter</a> -->
  1572. </p>
  1573. </div>
  1574. </div>
  1575. </div>
  1576. </div>
  1577. </div>
  1578. </div>
  1579. </div>
  1580. </div>
  1581. <!-- 显示Teachable Machine modal配置弹框 -->
  1582. <div id="setting_teacher" class="modal modal_closes">
  1583. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1584. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1585. <div class="modal-content" style="padding: 20px;">
  1586. <span class="modal_close" style="padding: 15px;">
  1587. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  1588. </span>
  1589. <h4 class="translatable_labs_center_modal_title">CocoBlockly Labs</h4>
  1590. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;" />
  1591. <div style="display:flex;justify-content:space-around;">
  1592. <div class="modal_setting_teacher_left setting_left_all">
  1593. <div class="card-image waves-effect waves-block waves-light">
  1594. <img class="" src="icons/AppCenter_ai_teachableMachine.jpg"
  1595. style="border: solid 1.2px lightgray;width: 100%;">
  1596. </div>
  1597. <div>
  1598. <span id="ac-card-title"
  1599. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_Teachabel_Machine"
  1600. style="font-size: 30px;">Teachable
  1601. Machine</span>
  1602. <p class="translatable_Teachabel_Machin_content">The trend of robot development is
  1603. artificial
  1604. intelligence. Deep learning is the frontier technology of intelligent robot and a new
  1605. topic
  1606. in the field of machine learning.Deep learning technology is widely used in agriculture,
  1607. industry, military, aviation and other fields, and the organic combination with machines
  1608. can
  1609. design intelligent robots with high working efficiency, high real-time and high
  1610. accuracy.
  1611. </p>
  1612. </div>
  1613. </div>
  1614. <div class="modal_setting_teacher_right setting_right_all">
  1615. <div class="translatable_computer_configuration"
  1616. style="background: rgb(33, 150, 243);padding: 5px 10px;color: #fff;border-top-left-radius: 5px;border-top-right-radius: 5px;">
  1617. <span>Computer Configuration Requirements</span>
  1618. </div>
  1619. <div class="setting_border">
  1620. <p><span class="translatable_the_operating_system">Minimum Opearting System
  1621. version</span>:Windows (>Windows7), macOS (>10.11)</p>
  1622. <p><span class="translatable_resolution_of_the">Suggested Resolution
  1623. Supported</span>:1440*768
  1624. </p>
  1625. <p><span class="translatable_memory_capacity">Memory Capacity</span>:8GB-16GB</p>
  1626. <p><span class="translatable_the_hard_disk">The Hard Disk</span>:256GB-512Gb</p>
  1627. <p><span class="translatable_the_graphics_card">The Graphics Card</span>:650M</p>
  1628. <p><span class="translatable_is_need_camera">Do you need a camera</span>:<span
  1629. class="translatable_need">OK</span></p>
  1630. <p><span class="translatable_is_need_microphone">Do you need a microphone</span>:<span
  1631. class="translatable_no_need">NO</span></p>
  1632. </div>
  1633. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1634. href="#Teachable_Machine" style="width: 94%;position: absolute;bottom: 5px;">Enter</a>
  1635. </div>
  1636. </div>
  1637. </div>
  1638. </div>
  1639. <!--Teachable Machine modal-->
  1640. <div id="Teachable_Machine" class="modal TM_class modal_closes">
  1641. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1642. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1643. <div id="TM_login" style="margin-top:10px;top:10%;position:relative"></div>
  1644. <div id="TM_iframe" style="height:100%; width:100%; display:none"></div>
  1645. <div id="teachable_modal" class="object_modal">
  1646. <img src="./gif/loading.gif"
  1647. style="position: absolute;top: calc(50% - 140px);width: 500px;left: calc(50% - 250px);" />
  1648. </div>
  1649. </div>
  1650. <!-- 显示Teachable Machine modal配置弹框 -->
  1651. <div id="setting_teacher_ponsenet" class="modal modal_closes">
  1652. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1653. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1654. <div class="modal-content" style="padding: 20px;">
  1655. <h4 class="translatable_labs_center_modal_title">CocoBlockly Labs</h4>
  1656. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;" />
  1657. <div style="display:flex;justify-content:space-around;">
  1658. <div class="modal_setting_teacher_left setting_left_all">
  1659. <div class="card-image waves-effect waves-block waves-light">
  1660. <img class="" src="images/tm_with_pose.jpg"
  1661. style="border: solid 1.2px lightgray;width: 100%;">
  1662. </div>
  1663. <div>
  1664. <span id="ac-card-title"
  1665. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_Teachabel_Machine_posenet"
  1666. style="font-size: 30px;">Teachable
  1667. Machine</span>
  1668. <p class="translatable_Teachabel_Machin_content">The trend of robot development is
  1669. artificial
  1670. intelligence. Deep learning is the frontier technology of intelligent robot and a new
  1671. topic
  1672. in the field of machine learning.Deep learning technology is widely used in agriculture,
  1673. industry, military, aviation and other fields, and the organic combination with machines
  1674. can
  1675. design intelligent robots with high working efficiency, high real-time and high
  1676. accuracy.
  1677. </p>
  1678. </div>
  1679. </div>
  1680. <div class="modal_setting_teacher_right setting_right_all">
  1681. <div class="translatable_computer_configuration"
  1682. style="background: rgb(33, 150, 243);padding: 5px 10px;color: #fff;border-top-left-radius: 5px;border-top-right-radius: 5px;">
  1683. <span>Computer Configuration Requirements</span>
  1684. </div>
  1685. <div class="setting_border">
  1686. <p><span class="translatable_the_operating_system">Minimum Opearting System
  1687. version</span>:Windows (>Windows7), macOS (>10.11)</p>
  1688. <p><span class="translatable_resolution_of_the">Suggested Resolution
  1689. Supported</span>:1440*768
  1690. </p>
  1691. <p><span class="translatable_memory_capacity">Memory Capacity</span>:8GB-16GB</p>
  1692. <p><span class="translatable_the_hard_disk">The Hard Disk</span>:256GB-512Gb</p>
  1693. <p><span class="translatable_the_graphics_card">The Graphics Card</span>:650M</p>
  1694. <p><span class="translatable_is_need_camera">Do you need a camera</span>:<span
  1695. class="translatable_need">OK</span></p>
  1696. <p><span class="translatable_is_need_microphone">Do you need a microphone</span>:<span
  1697. class="translatable_no_need">NO</span></p>
  1698. </div>
  1699. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1700. href="#Teachable_Machine_ponsenet"
  1701. style="width: 94%;position: absolute;bottom: 5px;">Enter</a>
  1702. </div>
  1703. </div>
  1704. </div>
  1705. </div>
  1706. <!--Teachable Machine modal-->
  1707. <div id="Teachable_Machine_ponsenet" class="modal TM_class modal_closes" style="position:relative">
  1708. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1709. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1710. <div id="TM_posenet_login" style="margin-top:10px;top:10%;position:relative"></div>
  1711. <div id="TM_posenet_iframe" style="height:100%; width:100%;"></div>
  1712. <div id="teachable_posenet_modal" class="object_modal">
  1713. <img src="./gif/loading.gif"
  1714. style="position: absolute;top: calc(50% - 140px);width: 500px;left: calc(50% - 250px);" />
  1715. </div>
  1716. </div>
  1717. <!-- 显示Object Recog_modal modal配置弹框-->
  1718. <div id="setting_objectRecog" class="modal modal_closes">
  1719. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1720. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1721. <div class="modal-content" style="padding: 20px;">
  1722. <span class="modal_close" style="padding: 15px;">
  1723. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  1724. </span>
  1725. <h4 class="translatable_labs_center_modal_title">CocoBlockly Labs</h4>
  1726. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;" />
  1727. <div style="display: flex;justify-content:space-around;">
  1728. <div class="modal_setting_objectRecog_left setting_left_all">
  1729. <div class="card-image waves-effect waves-block waves-light">
  1730. <img class="" src="icons/object_recognition_header.jpg"
  1731. style="border: solid 1.2px lightgray;width: 100%;">
  1732. </div>
  1733. <div>
  1734. <span id="ac-card-title emotion_recognition_enter_button" class="ac-card-title card-title activator grey-text text-darken-4
  1735. translatable_app_center_object_recognition translatable_objectRecognition"
  1736. style="font-size: 30px;">Object
  1737. Recognition</span>
  1738. <p class="translatable_objectRecognition_content">The development trend of object
  1739. recognition is
  1740. artificial intelligence. Object recognition is the frontier technology of intelligent
  1741. recognition and a new subject in the field of recognition.Object recognition technology
  1742. is
  1743. widely used in agriculture, industry, military, aviation and other fields.
  1744. </p>
  1745. </div>
  1746. </div>
  1747. <div class="modal_setting_objectRecog_right setting_right_all" style="width: 48%;">
  1748. <div class="translatable_computer_configuration"
  1749. style="background: rgb(33, 150, 243);padding: 5px 10px;color: #fff;border-top-left-radius: 5px;border-top-right-radius: 5px;">
  1750. <span>Computer Configuration Requirements</span>
  1751. </div>
  1752. <div class="setting_border">
  1753. <p><span class="translatable_the_operating_system">Minimum Opearting System
  1754. version</span>:Windows (>Windows7), macOS (>10.11)</p>
  1755. <p><span class="translatable_resolution_of_the">Suggested Resolution
  1756. Supported</span>:1440*768
  1757. </p>
  1758. <p><span class="translatable_memory_capacity">Memory Capacity</span>:8GB-16GB</p>
  1759. <p><span class="translatable_the_hard_disk">The Hard Disk</span>:256GB-512Gb</p>
  1760. <p><span class="translatable_the_graphics_card">The Graphics Card</span>:650M</p>
  1761. <p><span class="translatable_is_need_camera">Do you need a camera</span>:<span
  1762. class="translatable_need">OK</span></p>
  1763. <p><span class="translatable_is_need_microphone">Do you need a microphone</span>:<span
  1764. class="translatable_no_need">NO</span></p>
  1765. </div>
  1766. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1767. href="#Object_recog_modal" style="width: 94%;position: absolute;bottom: 5px;">Enter</a>
  1768. </div>
  1769. </div>
  1770. </div>
  1771. </div>
  1772. <!--Object Recog_modal modal-->
  1773. <div id="Object_recog_modal" class="modal TM_class modal_closes" style="position:relative">
  1774. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1775. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1776. <div id="TM_login_object" style="margin-top:10px;top:10%;position:relative"></div>
  1777. <div id="TM_iframe_object" style="height:100%; width:100%; display:none"></div>
  1778. <div id="object_modal" class="object_modal">
  1779. <img src="./gif/loading.gif"
  1780. style="position: absolute;top: calc(50% - 140px);width: 500px;left: calc(50% - 250px);" />
  1781. </div>
  1782. </div>
  1783. <!-- 显示posenet Recog_modal modal配置弹框 -->
  1784. <div id="setting_posenetRecog" class="modal modal_closes">
  1785. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1786. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1787. <div class="modal-content" style="padding: 20px;">
  1788. <span class="modal_close" style="padding: 15px;">
  1789. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  1790. </span>
  1791. <h4 class="translatable_labs_center_modal_title">CocoBlockly Labs</h4>
  1792. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;" />
  1793. <div style="display: flex;justify-content:space-around;">
  1794. <div class="modal_setting_objectRecog_left setting_left_all">
  1795. <div class="card-image waves-effect waves-block waves-light">
  1796. <img class="" src="icons/posenet_recogition.png"
  1797. style="border: solid 1.2px lightgray;width: 100%;">
  1798. </div>
  1799. <div>
  1800. <span id="ac-card-title emotion_recognition_enter_button" class="ac-card-title card-title activator grey-text text-darken-4
  1801. translatable_app_center_object_recognition translatable_posenetRecognition"
  1802. style="font-size: 30px;">Posenet
  1803. Recognition</span>
  1804. <p class="translatable_posenetRecognition_content">The development trend of object
  1805. recognition
  1806. is
  1807. artificial intelligence. Object recognition is the frontier technology of intelligent
  1808. recognition and a new subject in the field of recognition.Object recognition technology
  1809. is
  1810. widely used in agriculture, industry, military, aviation and other fields.
  1811. </p>
  1812. </div>
  1813. </div>
  1814. <div class="modal_setting_objectRecog_right setting_right_all" style="width: 48%;">
  1815. <div class="translatable_computer_configuration"
  1816. style="background: rgb(33, 150, 243);padding: 5px 10px;color: #fff;border-top-left-radius: 5px;border-top-right-radius: 5px;">
  1817. <span>Computer Configuration Requirements</span>
  1818. </div>
  1819. <div class="setting_border">
  1820. <p><span class="translatable_the_operating_system">Minimum Opearting System
  1821. version</span>:Windows (>Windows7), macOS (>10.11)</p>
  1822. <p><span class="translatable_resolution_of_the">Suggested Resolution
  1823. Supported</span>:1440*768
  1824. </p>
  1825. <p><span class="translatable_memory_capacity">Memory Capacity</span>:8GB-16GB</p>
  1826. <p><span class="translatable_the_hard_disk">The Hard Disk</span>:256GB-512Gb</p>
  1827. <p><span class="translatable_the_graphics_card">The Graphics Card</span>:650M</p>
  1828. <p><span class="translatable_is_need_camera">Do you need a camera</span>:<span
  1829. class="translatable_need">OK</span></p>
  1830. <p><span class="translatable_is_need_microphone">Do you need a microphone</span>:<span
  1831. class="translatable_no_need">NO</span></p>
  1832. </div>
  1833. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1834. href="#Posent_recog_modal" style="width: 94%;position: absolute;bottom: 5px;">Enter</a>
  1835. </div>
  1836. </div>
  1837. </div>
  1838. </div>
  1839. <!--Object Recog_modal modal-->
  1840. <div id="Posent_recog_modal" class="modal TM_class modal_closes" style="position:relative">
  1841. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1842. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1843. <div id="TM_login_posenet" style="margin-top:10px;top:10%;position:relative"></div>
  1844. <div id="TM_iframe_posenet" style="height:100%; width:100%; display:none"></div>
  1845. <div id="posenet_modal" class="object_modal">
  1846. <img src="./gif/loading.gif"
  1847. style="position: absolute;top: calc(50% - 140px);width: 500px;left: calc(50% - 250px);" />
  1848. </div>
  1849. </div>
  1850. <!-- 显示webcam input modal配置弹框 -->
  1851. <div id="setting_webcam_capture_modal" class="modal modal_closes">
  1852. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  1853. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  1854. <div class="modal-content" style="padding: 20px;">
  1855. <span class="modal_close" style="padding: 15px;">
  1856. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  1857. </span>
  1858. <h4 class="translatable_labs_center_modal_title">CocoBlockly Labs</h4>
  1859. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;" />
  1860. <div style="display:flex;justify-content:space-around;">
  1861. <div class="modal_setting_teacher_left setting_left_all">
  1862. <div class="card-image waves-effect waves-block waves-light">
  1863. <img class="" src="icons/AppCenter_ai_emotion.jpg"
  1864. style="border: solid 1.2px lightgray;width: 100%;">
  1865. </div>
  1866. <div>
  1867. <span id="ac-card-title emotion_recognition_enter_button"
  1868. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_emotion_recognition"
  1869. style="font-size: 30px;">Emotion
  1870. Recognition</span>
  1871. <p class="translatable_webcam_capture_content">The trend of robot development is artificial
  1872. intelligence. Deep learning is the frontier technology of intelligent robot and a new
  1873. topic
  1874. in the field of machine learning.Deep learning technology is widely used in agriculture,
  1875. industry, military, aviation and other fields, and the organic combination with machines
  1876. can
  1877. design intelligent robots with high working efficiency, high real-time and high
  1878. accuracy.
  1879. </p>
  1880. </div>
  1881. </div>
  1882. <div class="modal_setting_teacher_right setting_right_all">
  1883. <div class="translatable_computer_configuration"
  1884. style="background: rgb(33, 150, 243);padding: 5px 10px;color: #fff;border-top-left-radius: 5px;border-top-right-radius: 5px;">
  1885. <span>Computer Configuration Requirements</span>
  1886. </div>
  1887. <div class="setting_border">
  1888. <p><span class="translatable_the_operating_system">Minimum Opearting System
  1889. version</span>:Windows (>Windows7), macOS (>10.11)</p>
  1890. <p><span class="translatable_resolution_of_the">Suggested Resolution
  1891. Supported</span>:1440*768
  1892. </p>
  1893. <p><span class="translatable_memory_capacity">Memory Capacity</span>:8GB-16GB</p>
  1894. <p><span class="translatable_the_hard_disk">The Hard Disk</span>:256GB-512Gb</p>
  1895. <p><span class="translatable_the_graphics_card">The Graphics Card</span>:650M</p>
  1896. <p><span class="translatable_is_need_camera">Do you need a camera</span>:<span
  1897. class="translatable_need">Ok</span></p>
  1898. <p><span class="translatable_is_need_microphone">Do you need a microphone</span>:<span
  1899. class="translatable_no_need">NO</span></p>
  1900. </div>
  1901. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  1902. href="#webcam_capture_modal" style="width: 94%;position: absolute;bottom: 5px;">Enter</a>
  1903. </div>
  1904. </div>
  1905. </div>
  1906. </div>
  1907. <!-- webcam input modal -->
  1908. <div id="webcam_capture_modal" class="modal">
  1909. <div id="emotionRecognitionTitle" class="modal-content">
  1910. <div style="margin-bottom:-10px;margin-top:10px;" class="row">
  1911. <div class="col s8">
  1912. <h4 class="translatable_webcamDemoTitle">Emotion Recognition</h4>
  1913. </div>
  1914. <div style="text-align:right;" class="col s4">
  1915. <a style="cursor: pointer;text-decoration:none; color:rgba(0,0,0.9);"
  1916. id="emotion_recognition_close" class="modal-action modal-close">
  1917. <h4><i class="small material-icons">close</i></h4>
  1918. </a>
  1919. </div>
  1920. </div>
  1921. <!--<div> <span class="translatable_cloudFileTooltip" sytle="margin-left:10px">Type project's name and click save</span></div>-->
  1922. <div class="row">
  1923. <div class="col s12">
  1924. <div class="switch" style="margin-bottom:20px;">
  1925. <label>
  1926. <span class="translatable_emotion_camera_off">Camera Off</span>
  1927. <input id="camera_switch" type="checkbox" onclick="cameraSwitch()">
  1928. <span class="lever "></span><span class="translatable_emotion_camera_on">On</span>
  1929. </label>
  1930. </div>
  1931. </div>
  1932. </div>
  1933. <div class="row" style="text-align:left;">
  1934. <div style="float:center;" class="col s6">
  1935. <p class="translatable_face_webcam" style="margin-top:-20px;">Webcam:</p>
  1936. <div id="webCamera"></div>
  1937. <div class="translatable_emotion_camera_turnon_text" id="webCamPlaceholder">Turn on the Camera
  1938. first
  1939. </div>
  1940. </div>
  1941. <div style="float:center;" class="col s6">
  1942. <p class="translatable_face_latest_snapshot" style="margin-top:-20px;">Last snapshot:</p>
  1943. <div id="emotionResults"></div>
  1944. <div class="translatable_emotion_snapshot_text" id="SnapshotPlaceholder">Your snapshot will be
  1945. here
  1946. </div>
  1947. </div>
  1948. </div>
  1949. <div class="row">
  1950. <div class="col s12">
  1951. <a id="emotionRequestStatus"
  1952. class="disabled waves-effect waves-light btn blue translatable_face_analyze"
  1953. onclick="processImage()">Analyze</a>
  1954. <span id="azureRequestStatusText" style="padding-left:20px;"> </span>
  1955. </div>
  1956. </div>
  1957. <div class="row" style="text-align:left;">
  1958. <div id="emotionResultsAll" class="col s12">
  1959. <span class="translatable_emotion_result_title" id="facialanalysistitle"
  1960. style="font-weight:200;">Facial Analysis:</span>
  1961. <div style="display: flex;flex-wrap: wrap;margin-top: 10px;">
  1962. <p id="emotionResultsAll_property" style="width: 50%;">
  1963. <b class="translatable_emotion_result_age_title">Age:</b>
  1964. <span id="emotionResults_age"
  1965. class="emotionResultsAll_single translatable_emotion_result_default">Nothing
  1966. detected.</span>
  1967. </p>
  1968. <p id="emotionResultsAll_property" style="width: 50%;">
  1969. <b class="translatable_emotion_result_emotion_title">Emotion:</b>
  1970. <span id="emotionResults_emotion"
  1971. class="emotionResultsAll_single translatable_emotion_result_default">Nothing
  1972. detected.</span>
  1973. </p>
  1974. <p id="emotionResultsAll_property" style="width: 50%;">
  1975. <b class="translatable_emotion_result_gender_title">Gender:</b>
  1976. <span id="emotionResults_gender"
  1977. class="emotionResultsAll_single translatable_emotion_result_default">Nothing
  1978. detected.</span>
  1979. </p>
  1980. <p id="emotionResultsAll_property" style="width: 50%;">
  1981. <b class="translatable_emotion_result_glasses_title">Glasses:</b>
  1982. <span id="emotionResults_glasses"
  1983. class="emotionResultsAll_single translatable_emotion_result_default">Nothing
  1984. detected.</span>
  1985. </p>
  1986. <!-- <p id="emotionResultsAll_property" style="width: 50%;">
  1987. <b class="translatable_emotion_result_appearance_title">Appearance:</b>
  1988. <span id="emotionResults_appearance"
  1989. class="emotionResultsAll_single translatable_emotion_result_default">Nothing
  1990. detected.</span>
  1991. </p> -->
  1992. <p id="emotionResultsAll_property" style="width: 50%;">
  1993. <b class="translatable_emotion_result_expression_title">Expression:</b>
  1994. <span id="emotionResults_expression" class="emotionResultsAll_single">Nothing
  1995. detected.</span>
  1996. </p>
  1997. <p id="emotionResultsAll_property"
  1998. style="width: 100%;border-top: 1px solid #ccc;margin-top: 10px;padding-top: 10px;">
  1999. <b class="translatable_emotion_result_expression_title">Emotion:</b>
  2000. <span class="emotionResultsAll_single">smile、laugh、none</span>
  2001. </p>
  2002. <p id="emotionResultsAll_property" style="width: 100%;">
  2003. <b class="translatable_emotion_result_emotion_title">Expression:</b>
  2004. <span
  2005. class="emotionResultsAll_single">angry、disgust、fear、happy、sad、surprise、neutral、pouty、grimace</span>
  2006. </p>
  2007. </div>
  2008. </div>
  2009. <div class="col s12 select_send_way" style="position: relative; margin:12px 0;padding: 0;">
  2010. <span class="select_send_way_color translatable_send_cloud">Send Cloud</span>
  2011. <!-- <span class="translatable_send_module">Send Module</span> -->
  2012. </div>
  2013. </div>
  2014. <div class="row">
  2015. <div class="col s12 send_cloud" style="position: relative">
  2016. <div id="cloudRequestStatus" class="col s12">
  2017. </div>
  2018. <div class="translatable_selectEvent">Choose a CocoCloud event here, the analyzed result will
  2019. directly send to there</div>
  2020. <div style="width:100%;margin-top: 15px;">
  2021. <select class="browser-default" id="AI_webcam_events">
  2022. <option class="translatable_noEvent" value=null disabled>No event here. Login first
  2023. </option>
  2024. </select>
  2025. </div>
  2026. <span style="float:right;top: -45px;position: relative;margin-top: -38px;">
  2027. <i id="update_Coevent_web" class="material-icons">autorenew</i>
  2028. </span>
  2029. </div>
  2030. <div class="col s12 send_module" style="position: relative;display: none;height: 100px;">
  2031. <div class="translatable_send_module">Send Module</div>
  2032. <div class="col s6" style="margin-top:2px;padding: 0;">
  2033. <span class="translatable_send_result">Send Result:</span>
  2034. <select class="browser-default" id="select_send_capture"
  2035. style="width: 120px;display: inline-block;height: 35px;">
  2036. <option value="emotionResults_age" class="translatable_emotion_result_age_title">Age
  2037. </option>
  2038. <option value="emotionResults_emotion"
  2039. class="translatable_emotion_result_emotion_title">
  2040. Emotion</option>
  2041. <option value="emotionResults_gender" class="translatable_emotion_result_gender_title">
  2042. Sex
  2043. </option>
  2044. <option value="emotionResults_glasses"
  2045. class="translatable_emotion_result_glasses_title">
  2046. Glasses</option>
  2047. <option value="emotionResults_expression"
  2048. class="translatable_emotion_result_expression_title">Expression</option>
  2049. </select>
  2050. <span class="translatable_port">Port:</span>
  2051. <span class="port" style="padding-left:10px;"></span>
  2052. </div>
  2053. <div class="col s6" style="margin-top:2px;">
  2054. <a class="waves-effect waves-light blue lighten-2 btn translatable_connectBtn translatable_connectBtns disabled"
  2055. style="float:right;margin-right:5px">connect</a>
  2056. <a class="waves-effect waves-light blue lighten-2 btn translatable_disconnectBtn translatable_disconnectBtns "
  2057. style="float:right;margin-right:5px;display:none">disconnect</a>
  2058. </div>
  2059. </div>
  2060. </div>
  2061. </div>
  2062. </div>
  2063. <!-- 显示gesture recognition modal配置弹框 -->
  2064. <div id="setting_gesture_recog_modal" class="modal modal_closes">
  2065. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  2066. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  2067. <div class="modal-content" style="padding: 20px;">
  2068. <span class="modal_close" style="padding: 15px;">
  2069. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  2070. </span>
  2071. <h4 class="translatable_labs_center_modal_title">CocoBlockly Labs</h4>
  2072. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;" />
  2073. <div style="display:flex;justify-content:space-around;">
  2074. <div class="modal_setting_teacher_left setting_left_all">
  2075. <div class="card-image waves-effect waves-block waves-light">
  2076. <img class="" src="icons/AppCenter_ai_gesture_recognition.jpg"
  2077. style="border: solid 1.2px lightgray;width: 100%;">
  2078. </div>
  2079. <div>
  2080. <span id="ac-card-title emotion_recognition_enter_button"
  2081. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_gesture_recognition translatable_gesturesTitle"
  2082. style="font-size: 30px;">Gesture
  2083. Recognition</span>
  2084. <p class="translatable_gesture_recog_content">The trend of robot development is artificial
  2085. intelligence. Deep learning is the frontier technology of intelligent robot and a new
  2086. topic
  2087. in the field of machine learning.Deep learning technology is widely used in agriculture,
  2088. industry, military, aviation and other fields, and the organic combination with machines
  2089. can
  2090. design intelligent robots with high working efficiency, high real-time and high
  2091. accuracy.
  2092. </p>
  2093. </div>
  2094. </div>
  2095. <div class="modal_setting_teacher_right setting_right_all">
  2096. <div class="translatable_computer_configuration"
  2097. style="background: rgb(33, 150, 243);padding: 5px 10px;color: #fff;border-top-left-radius: 5px;border-top-right-radius: 5px;">
  2098. <span>Computer Configuration Requirements</span>
  2099. </div>
  2100. <div class="setting_border">
  2101. <p><span class="translatable_the_operating_system">Minimum Opearting System
  2102. version</span>:Windows (>Windows7), macOS (>10.11)</p>
  2103. <p><span class="translatable_resolution_of_the">Suggested Resolution
  2104. Supported</span>:1440*768
  2105. </p>
  2106. <p><span class="translatable_memory_capacity">Memory Capacity</span>:8GB-16GB</p>
  2107. <p><span class="translatable_the_hard_disk">The Hard Disk</span>:256GB-512Gb</p>
  2108. <p><span class="translatable_the_graphics_card">The Graphics Card</span>:650M</p>
  2109. <p><span class="translatable_is_need_camera">Do you need a camera</span>:<span
  2110. class="translatable_need">Ok</span></p>
  2111. <p><span class="translatable_is_need_microphone">Do you need a microphone</span>:<span
  2112. class="translatable_no_need">NO</span></p>
  2113. </div>
  2114. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  2115. href="#gesture_recog_modal" style="width: 94%;position: absolute;bottom: 5px;">Enter</a>
  2116. </div>
  2117. </div>
  2118. </div>
  2119. </div>
  2120. <!-- gesture recognition modal -->
  2121. <div id="gesture_recog_modal" class="modal">
  2122. <div id="gestureRecognitionTitle" class="modal-content">
  2123. <div style="margin-bottom:-10px;margin-top:10px;" class="row">
  2124. <div class="col s10">
  2125. <h4 class="translatable_gesturesTitle">Gesture Recognition</h4>
  2126. </div>
  2127. <div style="text-align:right;" class="col s2">
  2128. <a style="cursor: pointer;text-decoration:none; color:rgba(0,0,0.9);"
  2129. id="gesture_recognition_close" class="modal-action modal-close">
  2130. <h4><i class="small material-icons">close</i></h4>
  2131. </a>
  2132. </div>
  2133. </div>
  2134. <div class="row">
  2135. <div class="col s12">
  2136. <div class="switch" style="margin-bottom:20px;">
  2137. <label>
  2138. <span class="translatable_emotion_camera_off">Camera Off</span>
  2139. <input id="camera_switch_gesture" type="checkbox" onclick="cameraSwitchGesture();">
  2140. <span class="lever "></span><span class="translatable_emotion_camera_on">On</span>
  2141. </label>
  2142. </div>
  2143. </div>
  2144. </div>
  2145. <div style="margin-bottom:10px;" class="row">
  2146. <div style="float:center;" class="col s5">
  2147. <p class="translatable_gesture_webcam" style="margin-top:-20px;">Webcam:</p>
  2148. <div id="webCameraGestureFrame">
  2149. <div id="webCameraGesture"></div>
  2150. </div>
  2151. <div class="translatable_emotion_camera_turnon_text" id="gesture_webCamPlaceholder">Turn on the
  2152. Camera first
  2153. </div>
  2154. </div>
  2155. <div style="float:center;" class="col s7">
  2156. <a id="gestureAnalyzeButton"
  2157. class="disabled waves-effect waves-light btn blue translatable_gesture_recognition"
  2158. onclick="gestureRecognize();">Recognize</a>
  2159. <div id="gestureResultAreaFrame">
  2160. <h4 class="gestureResultAreaTitle translatable_gesture_recognition_result">Recognition
  2161. Result:
  2162. </h4>
  2163. <div id="gestureResultAreaContent" class="translatable_gesture_result">
  2164. No result yet.
  2165. </div>
  2166. </div>
  2167. <div class="col s12 select_send_way" style="position: relative; margin:12px 0;padding: 0;">
  2168. <span class="select_send_way_color translatable_send_cloud">Send Cloud</span>
  2169. <!-- <span class="translatable_send_module">Send Module</span> -->
  2170. </div>
  2171. <div class="s12" style="position: relative;margin-top: 45px;">
  2172. <div class="send_cloud">
  2173. <div id="cloudRequestStatuss" class="s12">
  2174. </div>
  2175. <div class="translatable_selectEvent" style="padding-right: 0.75rem;">Choose a CocoCloud
  2176. event
  2177. here, the analyzed result will
  2178. directly send to there</div>
  2179. <div style="width:100%;margin-top: 15px;">
  2180. <select class="browser-default" id="AI_gesture_events">
  2181. <option class="translatable_noEvent" value=null disabled>No event here. Login
  2182. first
  2183. </option>
  2184. </select>
  2185. </div>
  2186. <span style="float:right;top: -45px;position: relative;margin-top: -38px;">
  2187. <i id="update_Coevent_web" class="material-icons">autorenew</i>
  2188. </span>
  2189. </div>
  2190. <div class="col s12 send_module"
  2191. style="position: relative;display: none;height: 100px;padding: 0;">
  2192. <div class="translatable_send_module">Send Module</div>
  2193. <div class="input-field col s6" style="margin-top:2px;padding: 0;">
  2194. <span class="translatable_port">Port:</span>
  2195. <span class="port" style="padding-left:10px;"></span>
  2196. </div>
  2197. <div class="col s6" style="margin-top:2px;">
  2198. <a class="waves-effect waves-light blue lighten-2 btn translatable_connectBtns translatable_connectBtn disabled"
  2199. style="float:right;margin-right:5px">connect</a>
  2200. <a class="waves-effect waves-light blue lighten-2 btn translatable_disconnectBtns translatable_disconnectBtn"
  2201. style="float:right;margin-right:5px;display:none">disconnect</a>
  2202. </div>
  2203. </div>
  2204. </div>
  2205. </div>
  2206. </div>
  2207. <!-- <div class="row">
  2208. <div class="col s12">
  2209. <hr style="margin-top: 20px; border-top: 0.5px solid rgba(0,0,0,.1);" />
  2210. </div>
  2211. </div> -->
  2212. </div>
  2213. </div>
  2214. <!-- 显示voice speech modal配置弹框 -->
  2215. <div id="setting_voice_input_modal" class="modal modal_closes">
  2216. <span class="modal_close" style="padding: 15px;position: absolute;right: 0;cursor: pointer;"><i
  2217. class="small material-icons" style="font-size: 1.5rem;">close</i></span>
  2218. <div class="modal-content" style="padding: 20px;">
  2219. <h4 class="translatable_labs_center_modal_title">CocoBlockly Labs</h4>
  2220. <hr style="border-top: 1px solid #ddd;margin:20px 0 10px 0;" />
  2221. <div style="display:flex;justify-content:space-around;">
  2222. <div class="modal_setting_teacher_left setting_left_all">
  2223. <div class="card-image waves-effect waves-block waves-light">
  2224. <img class="" src="icons/AppCenter_ai_speech.jpg"
  2225. style="border: solid 1.2px lightgray;width: 100%;">
  2226. </div>
  2227. <div>
  2228. <span id="ac-card-title"
  2229. class="ac-card-title card-title activator grey-text text-darken-4 translatable_app_center_speech_recognition"
  2230. style="font-size: 30px;">Speech
  2231. Recognition</span>
  2232. <p class="translatable_voice_input_content">The trend of robot development is artificial
  2233. intelligence. Deep learning is the frontier technology of intelligent robot and a new
  2234. topic
  2235. in the field of machine learning.Deep learning technology is widely used in agriculture,
  2236. industry, military, aviation and other fields, and the organic combination with machines
  2237. can
  2238. design intelligent robots with high working efficiency, high real-time and high
  2239. accuracy.
  2240. </p>
  2241. </div>
  2242. </div>
  2243. <div class="modal_setting_teacher_right setting_right_all">
  2244. <div class="translatable_computer_configuration"
  2245. style="background: rgb(33, 150, 243);padding: 5px 10px;color: #fff;border-top-left-radius: 5px;border-top-right-radius: 5px;">
  2246. <span>Computer Configuration Requirements</span>
  2247. </div>
  2248. <div class="setting_border">
  2249. <p><span class="translatable_the_operating_system">Minimum Opearting System
  2250. version</span>:Windows (>Windows7), macOS (>10.11)</p>
  2251. <p><span class="translatable_resolution_of_the">Suggested Resolution
  2252. Supported</span>:1440*768
  2253. </p>
  2254. <p><span class="translatable_memory_capacity">Memory Capacity</span>:8GB-16GB</p>
  2255. <p><span class="translatable_the_hard_disk">The Hard Disk</span>:256GB-512Gb</p>
  2256. <p><span class="translatable_the_graphics_card">The Graphics Card</span>:650M</p>
  2257. <p><span class="translatable_is_need_camera">Do you need a camera</span>:<span
  2258. class="translatable_no_need">NO</span></p>
  2259. <p><span class="translatable_is_need_microphone">Do you need a microphone</span>:<span
  2260. class="translatable_need">OK</span></p>
  2261. </div>
  2262. <a class="waves-effect waves-light btn blue accent-3 translatable_app_center_enter_button modal-trigger"
  2263. href="#voice_input_modal" style="width: 94%;position: absolute;bottom: 5px;">Enter</a>
  2264. </div>
  2265. </div>
  2266. </div>
  2267. </div>
  2268. <!-- voice speech modal -->
  2269. <div id="voice_input_modal" class="modal voice-modal-trigger">
  2270. <div class="modal-content">
  2271. <div style="margin-top:10px;" class="row">
  2272. <div class="col s8">
  2273. <h4 class="translatable_speechDemoTitle">Speech Recognition</h4>
  2274. </div>
  2275. <div style="text-align:right;" class="col s4">
  2276. <a style="cursor: pointer;text-decoration:none; color:rgba(0,0,0.9);" id="voice_input_close"
  2277. class="modal-action modal-close">
  2278. <h4><i class="small material-icons">close</i></h4>
  2279. </a>
  2280. </div>
  2281. </div>
  2282. <div style="margin-bottom:10px;margin-top:-20px;" class="row">
  2283. <div class="col s12">
  2284. <p class="translatable_speechTip" style="font-size:15px;font-weight:200;">Voice recognition for
  2285. English, Cantonese & Mandarin.</p>
  2286. <hr
  2287. style="position:relative;top:-2px;margin-bottom:15px;border-color:rgba(0,0,0,.1); border-width: 1px;">
  2288. </div>
  2289. </div>
  2290. <div class="row" style="margin-top:-15px;margin-bottom:10px">
  2291. <div class="col s4">
  2292. <p class="translatable_speech_language_select">Select a language to recognize:</p>
  2293. </div>
  2294. <div style="margin-left:-20px;" class="col s2 speech_language" style="position:relative;top:3px">
  2295. <select id="speech_language_selection" class="browser-default" style="max-width:200px">
  2296. <option value="english" class="translatable_speech_language_English">English</option>
  2297. <option value="cantonese" class="translatable_speech_language_Cantonese">Cantonese</option>
  2298. <option value="mandarin" class="translatable_speech_language_Mandarin">Mandarin</option>
  2299. </select>
  2300. </div>
  2301. <div class="col" style="position:relative;top:5px">
  2302. <a id="speech_button" class="waves-effect waves-light btn blue translatable_speech_recognition"
  2303. style="padding:0 8px" onclick="processSpeech()/*startSpeech()*/">Start Recording</a>
  2304. </div>
  2305. <div class="col s3" style="position:relative;top:15px;">
  2306. <span style="font-weight:200;margin-left:-5px;" id="speech_process_title"
  2307. style="position:relative;top:-6px;"></span>
  2308. </div>
  2309. </div>
  2310. <div class="row">
  2311. <textarea id="speech_textarea" row="3" class="disabled translatable_speech_textarea_title"
  2312. style="width:772px;height:130px;resize:none;border-radius:5px;padding:10px;color:rgba(0,0,0,.4);"
  2313. readonly> Click on the mic button to start dictating...</textarea>
  2314. </div>
  2315. <div style="margin-top:5px;" class="row">
  2316. <div class="col s12 select_send_way" style="position: relative; margin-bottom:12px;">
  2317. <span class="select_send_way_color translatable_send_cloud">Send Cloud</span>
  2318. <!-- <span class="translatable_send_module">Send Module</span> -->
  2319. </div>
  2320. <div class="col s12 send_cloud" style="position: relative">
  2321. <div class="col s12">
  2322. <span id="speechDemoCloudRequest" style="font-weight:200;"></span>
  2323. </div>
  2324. <div class="translatable_selectEvent">Choose a CocoCloud event here, the analyzed result will
  2325. directly send to there</div>
  2326. <div style="width:95%">
  2327. <select style="margin-top:10px;" class="browser-default" id="AI_voice_events">
  2328. <option class="translatable_noEvent" value=null disabled>No event here. Login first
  2329. </option>
  2330. </select>
  2331. </div>
  2332. <span style="float:right;top: -45px;position: relative;">
  2333. <i id="update_Coevent_voice" class="material-icons">autorenew</i>
  2334. </span>
  2335. </div>
  2336. <div class="col s12 send_module" style="position: relative;display: none;height: 100px;">
  2337. <div class="translatable_send_module">Send Module</div>
  2338. <div class="input-field col s6" style="margin-top:2px;">
  2339. <span class="translatable_port">Port:</span>
  2340. <span class="port" style="padding-left:10px;"></span>
  2341. </div>
  2342. <div class="col s6" style="margin-top:2px;">
  2343. <a class="waves-effect waves-light blue lighten-2 btn translatable_connectBtns translatable_connectBtn disabled"
  2344. style="float:right;margin-right:5px">connect</a>
  2345. <a class="waves-effect waves-light blue lighten-2 btn translatable_disconnectBtn translatable_disconnectBtns "
  2346. style="float:right;margin-right:5px;display:none">disconnect</a>
  2347. </div>
  2348. </div>
  2349. </div>
  2350. </div>
  2351. </div>
  2352. </div>
  2353. </div>
  2354. </div>
  2355. <!-- iframe -->
  2356. <div id="iframe" class="modal modal_closes" style="width: 70%;">
  2357. <span class="modal_close" style="padding: 15px;right: 12px;">
  2358. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  2359. </span>
  2360. <!-- <iframe frameborder="0" style="width: 100%;height: 50vh;"></iframe> -->
  2361. </div>
  2362. <div id="updatePy" class="modal">
  2363. <!-- <i id="updatePy_icon" class="material-icons right" style="cursor:pointer;">close</i> -->
  2364. <div style="padding: 20px;">
  2365. <h2 style="font-size: 30px;margin-bottom: 0;" class="translatable_update_file">更新文件</h2>
  2366. <p>选择文件夹</p>
  2367. <div id="select_folder" class="select_folder" style="height: 300px;">
  2368. </div>
  2369. <!-- <div class="folder_name">
  2370. <span>文件名:</span>
  2371. <input class="folder_name_inpit" type="text">
  2372. </div> -->
  2373. <div class="update_bottom">
  2374. <button class="cancle">取消</button>
  2375. <button class="confim">确定</button>
  2376. </div>
  2377. </div>
  2378. </div>
  2379. <!-- Custom Alert: Content is loaded using JavaScript to display alerts -->
  2380. <div id="cus_alert" class="modale modal_small modal_custom">
  2381. <div class="modal-content">
  2382. <h5 id="cus_alert_title">Empty Alert</h5>
  2383. <p><span id="cus_alert_body">Empty alert text</span></p>
  2384. </div>
  2385. <div class="modal-footer">
  2386. <a id="cus_alert_button" class="waves-effect btn-flat modal-close blue"><span id="cus_alert_button_content"
  2387. style="color:#fff"></span></a>
  2388. <a id="cus_alert_ok_link" class="waves-effect btn-flat modal-close blue"><span class="translatable_okay"
  2389. style="color:#fff">Okay</span></a>
  2390. </div>
  2391. </div>
  2392. <!-- Env Detect Modal -->
  2393. <div id="env_detect" class="modal modal_closes">
  2394. <div class="modal-content">
  2395. <span class="modal_close" style="padding: 15px;">
  2396. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  2397. </span>
  2398. <h4 class="translatable_env_detect" style="margin-bottom:2.5rem;">Environment Detect</h4>
  2399. <div id="detect_before" style="position:relative;">
  2400. <div>
  2401. <img src="./icons/device-detect.svg" />
  2402. </div>
  2403. <div id="detect_preload" style="display:none;">
  2404. <div
  2405. style="position:relative;top:50%;transform:translateY(-50%);height:128px;width:128px;margin:0 auto;">
  2406. <div class="preloader-wrapper big active">
  2407. <div class="spinner-layer spinner-blue-only">
  2408. <div class="circle-clipper left">
  2409. <div class="circle"></div>
  2410. </div>
  2411. <div class="gap-patch">
  2412. <div class="circle"></div>
  2413. </div>
  2414. <div class="circle-clipper right">
  2415. <div class="circle"></div>
  2416. </div>
  2417. </div>
  2418. </div>
  2419. </div>
  2420. </div>
  2421. </div>
  2422. <div id="detect_result" style="display:none;">
  2423. <div style="border-bottom:2.5px #0057ff6e solid;padding:0.25rem 0;">
  2424. <h5 class="translatable_title_device">Device</h5>
  2425. <h5 class="translatable_title_result">Result</h5>
  2426. <h5 class="translatable_title_support">Support</h5>
  2427. <h5 class="translatable_title_suggest">Suggest</h5>
  2428. </div>
  2429. <div id="env_detect_os" style="margin-top:0.5rem;">
  2430. <div class="translatable_os">System</div>
  2431. <div></div>
  2432. <div class="detect-icons"></div>
  2433. <div></div>
  2434. </div>
  2435. <div id="env_detect_browser">
  2436. <div class="translatable_browser">Browser</div>
  2437. <div></div>
  2438. <div class="detect-icons"></div>
  2439. <div></div>
  2440. </div>
  2441. <div id="env_detect_plugin" style="margin-bottom:0.5rem;">
  2442. <div>Uploader</div>
  2443. <div></div>
  2444. <div class="detect-icons"></div>
  2445. <div></div>
  2446. </div>
  2447. </div>
  2448. </div>
  2449. <div class="modal-footer">
  2450. <a id="detect-btn" class="waves-effect waves-light btn-large blue">
  2451. <span class="translatable_detect">Detect</span>
  2452. </a>
  2453. </div>
  2454. </div>
  2455. <!-- Serial Monitor -->
  2456. <div id="Serial-monitor" class="card card-serialMonitor" style="display:none;height:0;opacity:0;">
  2457. <div class="code-header">
  2458. <span class="code-header-logo"><i class="material-icons" style="padding-top:10px">search</i></span>
  2459. <span class="card-title translatable_serialMonitor">Serial Monitor</span>
  2460. </div>
  2461. <div class="card-content" style="padding:8px 10px;">
  2462. <div class="row">
  2463. <div class="input-field col s6" style="margin-top:2px;">
  2464. <p id="ports-monitor" style="font-size:16px"><span class="translatable_port">Port:</span><span
  2465. style="padding-left:10px;"></span>
  2466. </p>
  2467. </div>
  2468. <div class="col s6" style="margin-top:2px;">
  2469. <a id="comms-cnt"
  2470. class="waves-effect waves-light blue lighten-2 btn translatable_connectBtn disabled"
  2471. style="float:right;margin-right:5px">connect</a>
  2472. <a id="comms-discnt" class="waves-effect waves-light blue lighten-2 btn translatable_disconnectBtn "
  2473. style="float:right;margin-right:5px;display:none">disconnect</a>
  2474. </div>
  2475. </div>
  2476. <div class="row">
  2477. <div class="input-field col s5">
  2478. <select id="serial_output_style" style="font-size:16px">
  2479. <option value="" selected class="translatable_no_line_ending">No line ending
  2480. </option>
  2481. <option value="nl" class="translatable_newline">Newline</option>
  2482. <option value="cr" class="translatable_CR">Carriage return</option>
  2483. <option value="blc" class="translatable_NL_CR">Both NL &amp; CR</option>
  2484. </select>
  2485. </div>
  2486. <div class="input-field col s5">
  2487. <select id="serial_baud" style="font-size:16px">
  2488. <option value="300">300 <span class="translatable_baud">baud</span></option>
  2489. <option value="1200">1200 <span class="translatable_baud">baud</span></option>
  2490. <option value="2400">2400 <span class="translatable_baud">baud</span></option>
  2491. <option value="4800">4800 <span class="translatable_baud">baud</span></option>
  2492. <option value="9600" selected>9600 <span class="translatable_baud">baud</span>
  2493. </option>
  2494. <option value="19200">19200 <span class="translatable_baud">baud</span></option>
  2495. <option value="38400">38400 <span class="translatable_baud">baud</span></option>
  2496. <option value="57600">57600 <span class="translatable_baud">baud</span></option>
  2497. <option value="115200">115200 <span class="translatable_baud">baud</span></option>
  2498. </select>
  2499. </div>
  2500. </div>
  2501. <div class="row">
  2502. <div class="input-field col s10">
  2503. <input id="comms-msg" type="text" style="margin:0">
  2504. <label for="Sending_Messages" class="translatable_sendMsg" style="font-size:16px">Sending
  2505. Messages</label>
  2506. </div>
  2507. <div class="input-field col s2">
  2508. <a id="comms-send" class="waves-effect waves-light blue lighten-2 btn translatable_sendBtn disabled"
  2509. style="float:right;padding-right:5px">SEND</a>
  2510. </div>
  2511. </div>
  2512. <div class="row">
  2513. <div class="col s12">
  2514. <textarea id="commsBox" label="readonly" readonly></textarea>
  2515. </div>
  2516. </div>
  2517. <div class="row" style="margin-bottom:8px">
  2518. <div class="col s4" style="margin-top:8px">
  2519. <input id="autoscroll" type="checkbox" class="filled-in" checked="checked">
  2520. <label for="autoscroll">
  2521. <span class="translatable_autoScroll">Autoscroll</span>
  2522. </label>
  2523. </div>
  2524. <div class="input-field col s8" style="margin:4px,0,8px,0">
  2525. <a id="comms-clear" class="waves-effect waves-light blue lighten-2 btn translatable_comms_clear"
  2526. style="float:right;margin-right:5px">CLEAR</a>
  2527. <a id="comms-export"
  2528. class="waves-effect waves-light blue lighten-2 btn translatable_comms_export modal-trigger"
  2529. href="#export-file" style="float:right;margin-right:5px">EXPORT</a>
  2530. </div>
  2531. </div>
  2532. </div>
  2533. </div>
  2534. <!-- login modal -->
  2535. <div id="login_modal" class="modal modal_closes" style="top:62px">
  2536. <div id="login_modal_preload" class="progress" style="display:none">
  2537. <div class="indeterminate"></div>
  2538. </div>
  2539. <div class="modal-content" style="padding:0;">
  2540. <span class="modal_close" style="padding: 15px;">
  2541. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  2542. </span>
  2543. <!-- add for login iframe -->
  2544. <div id="before_login"></div>
  2545. <div id="after_login">
  2546. <div id="userProfile_alias"></div>
  2547. <div style="width: 250px;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;"><span
  2548. class="translatable_user_email">Email:</span><span id="userProfile_username"> </span></div>
  2549. <div><span class="translatable_user_school">School:</span><span id="userProfile_school"></span></div>
  2550. <div id="userProfile_apikey">
  2551. <div>
  2552. <span class="translatable_Event">Event: </span>
  2553. <span style="margin-top: -13px;float:right;transform:translateY(35%);">
  2554. <i id="update_Coevent" class="material-icons" onclick="updateProject()">autorenew</i>
  2555. </span>
  2556. <p class="get_event" style="margin: 5px 0;color: #2196F3;"></p>
  2557. <select
  2558. style="outline:0; width: 100%; margin: 6px auto 8px auto; border: 1px solid rgba(0,0,0,.2);"
  2559. class="browser-default" id="cloud_events" onchange="changeProject()">
  2560. <option value=null disabled>No Event</option>
  2561. </select>
  2562. </div>
  2563. <div style="margin-top:5px">
  2564. <span>API Key: </span>
  2565. <a id="apikey-copy" data-clipboard-action="copy" data-clipboard-target="#api-key">
  2566. <i class="material-icons tiny">content_copy</i>
  2567. </a>
  2568. <textarea style="padding: 6px 6px; margin-top: 4px;" id="api-key" readonly></textarea>
  2569. </div>
  2570. </div>
  2571. </div>
  2572. </div>
  2573. <div class="modal-footer" style="display:none;">
  2574. <a id="modal_logout_btn" class="waves-effect btn-flat blue">
  2575. <span class="translatable_signout">Sign Out</span>
  2576. <img class="xuanhuan svgImg" src="/images/loading.svg" alt="">
  2577. </a>
  2578. <a id="modal_cococloud_btn" href="//cocorobo.cn/cloud" target="_black"
  2579. class="waves-effect btn-flat blue"><span class="translatable_cococloud">Go to CocoCloud</span></a>
  2580. </div>
  2581. </div>
  2582. <!-- local storage - import modal -->
  2583. <div id="Storage_import_modal" class="modal" style="width:500px">
  2584. <div class="modal-content">
  2585. <h4 class="translatable_localStorageImport">Import Project</h4>
  2586. <div> <span class="translatable_ImportTooltip" sytle="margin-left:10px">Select your project file(*.xml) and
  2587. import it to the current workspace.Warning:will replace current blocks</span></div>
  2588. <div id="import_area" class="row" style="margin: 10px;height: 170px;position: relative;">
  2589. <a id="modal_import_btn" class="waves-effect btn-flat blue" style="top:180px;position:fixed;"><span
  2590. class="translatable_import" style="font-size:15px;color:#fff">Import</span></a>
  2591. <span class="translatable_ImportContent"
  2592. style="top: 187px;width:300px;position:fixed;text-align:center;">Click to choose a file from
  2593. your computer</span>
  2594. </div>
  2595. </div>
  2596. </div>
  2597. <!-- General Alert: Content is loaded using JavaScript to display alerts -->
  2598. <div id="gen_alert" class="modale modal_closes modal_small" style="width:730px">
  2599. <div class="modal-content">
  2600. <span class="modal_close" style="padding: 15px;">
  2601. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  2602. </span>
  2603. <h5 id="gen_alert_title">Empty Alert</h5>
  2604. <p><span id="gen_alert_body">Empty alert text</span></p>
  2605. </div>
  2606. <div class="modal-footer">
  2607. <a id="gen_alert_ok_link" class="waves-effect btn-flat modal-close blue"><span class="translatable_okay"
  2608. style="color:#fff">Okay</span></a>
  2609. <a id="gen_alert_cancel_link" class="waves-effect btn-flat modal-close blue"><span
  2610. class="translatable_cancel" style="color:#fff">Cancel</span></a>
  2611. </div>
  2612. </div>
  2613. <!-- Example Alert: Content is loaded using JavaScript to display alerts -->
  2614. <div id="example_alert" class="modale modal_small" style="height:30%;width: 30%;">
  2615. <div class="modal-content">
  2616. <div id="loading" style="text-align:center;display: none;">
  2617. <img src="./gif/loading.gif" style="width: 300px;" />
  2618. </div>
  2619. <p
  2620. style="text-align:center;font-weight:bold;font-size:20px;z-index: 1087;position: absolute;left: 0;right: 0;top: 50%;">
  2621. <span id="example_alert_body">Empty alert text</span>
  2622. </p>
  2623. </div>
  2624. </div>
  2625. <!-- local storage - export modal -->
  2626. <div id="Storage_export_modal" class="modal" style="width:730px">
  2627. <div class="modal-content">
  2628. <h4 class="translatable_localStorageExport">Export Project</h4>
  2629. <div> <span class="translatable_ExportTooltip" sytle="margin-left:10px">Export current project blocks and
  2630. save it your computer,so you can open it next time when you need it</span></div>
  2631. <div class="row" style="margin: 10px;height: 200px;width: 640px;position: relative;">
  2632. <div style="display:block">
  2633. <div class="col l6">
  2634. <img src="./icons/blockly-file-export_xml.png"
  2635. style="width:20%;position:relative;left:50%;right:50%;transform:translateX(-50%);">
  2636. </div>
  2637. <div class="col l6">
  2638. <img src="./icons/blockly-file-export_png.png"
  2639. style="width:20%;position:relative;left:50%;right:50%;transform:translateX(-50%);">
  2640. </div>
  2641. </div>
  2642. <div>
  2643. <div class="col l6">
  2644. <a id="modal_exportFileBtn" class="waves-effect btn-flat blue"
  2645. style="left: 50%;right: 50%;transform: translateX(-50%)"><span
  2646. class="translatable_exportFile" style="font-size:15px;color:#fff">Project
  2647. File</span></a>
  2648. </div>
  2649. <div class="col l6">
  2650. <a id="modal_exportSnapBtn" class="waves-effect btn-flat blue"
  2651. style="left: 50%;right: 50%;transform: translateX(-50%)"><span
  2652. class="translatable_exportSnap" style="font-size:15px;color:#fff">Snapshot</span></a>
  2653. </div>
  2654. </div>
  2655. <div>
  2656. <div class="col l6">
  2657. <p class="translatable_ExportFileContent"
  2658. style="display:block;text-align:center;width:80%;position: relative;left: 50%;right: 50%;transform: translateX(-50%);font-size:0.875rem">
  2659. Will export as an *xml file.<br>for you to continuing code nextime</p>
  2660. </div>
  2661. <div class="col l6">
  2662. <p class="translatable_ExportSnapContent"
  2663. style="display:block;text-align:center;width:80%;position: relative;left: 50%;right: 50%;transform: translateX(-50%);font-size:0.875rem">
  2664. Will export to a *png picture.<br>for your reference</p>
  2665. </div>
  2666. </div>
  2667. </div>
  2668. </div>
  2669. </div>
  2670. <div style="display: none;" id="content_blocks"></div>
  2671. <!-- cloud storage modal -->
  2672. <div id="cloud_storage_modal" class="modal modal_closes">
  2673. <div class="modal-content">
  2674. <span class="modal_close" style="padding: 15px;">
  2675. <i class="small material-icons" style="font-size: 1.5rem;">close</i>
  2676. </span>
  2677. <h4 class="translatable_cloudStorageTitle">Cloud Storage</h4>
  2678. <div id="cloud_askLogin"></div>
  2679. <div id="cloud_fileListArea" class="cloud-file" style="display:none">
  2680. </div>
  2681. </div>
  2682. <div id="cloud_modal_preload" style="display:none">
  2683. <div style="position:relative;top:50%;transform:translateY(-50%);height:128px;width:128px;margin:0 auto;">
  2684. <div class="preloader-wrapper big active" style="top:0;left:0">
  2685. <div class="spinner-layer spinner-blue-only">
  2686. <div class="circle-clipper left">
  2687. <div class="circle"></div>
  2688. </div>
  2689. <div class="gap-patch">
  2690. <div class="circle"></div>
  2691. </div>
  2692. <div class="circle-clipper right">
  2693. <div class="circle"></div>
  2694. </div>
  2695. </div>
  2696. </div>
  2697. </div>
  2698. </div>
  2699. </div>
  2700. <!-- share modal -->
  2701. <div id="share" class="modal">
  2702. <div class="modal-content">
  2703. <h4 class="">程序分享</h4>
  2704. <div style="text-align: center;">
  2705. <div id="QrImg" style="display: inline-block;"></div>
  2706. </div>
  2707. <p class="qrImgUrl"></p>
  2708. </div>
  2709. </div>
  2710. <div class="downbox MouduleBox" style="display:none;position: fixed;width:175px;height:162px;right:50px;top:225px;">
  2711. <div>
  2712. <div class="translatable_iot_module">IoT Module</div>
  2713. </div>
  2714. <div>
  2715. <div class="translatable_ai_module">A.I. Module</div>
  2716. </div>
  2717. <div><a href="//python-blockly.cocorobo.cn" style="color: #424242 !important;"
  2718. class="translatable_cloud_mode">Cloud
  2719. Mode</a></div>
  2720. <div><a href="//ai-blockly.cocorobo.cn" style="color: #424242 !important;"
  2721. class="translatable_javascript_mode">JavaScript Mode</a></div>
  2722. </div>
  2723. <div id="ai_tt" class="downbox MouduleBox" style="display:none;position: fixed;width:230px;right:50px;top:225px;">
  2724. <div>1.Hello World</div>
  2725. <div>2.螢幕顯示 Hello World</div>
  2726. <div>3.畫布應用</div>
  2727. <div>4.迷你相機</div>
  2728. <div>5.簡易物體識別</div>
  2729. </div>
  2730. <!-- <iframe id="web" name="web" src="//x.cocorobo.cn/web.html" style="display: none"></iframe> -->
  2731. </body>
  2732. <script>
  2733. $("#modal_logout_btn").on("click", function () {
  2734. $("#modal_logout_btn").removeClass('blue');
  2735. $("#modal_logout_btn").css('background', 'gray')
  2736. $(".svgImg").css('display', 'block')
  2737. $(".translate-signout").css('opacity', '0.5')
  2738. $.ajax(`${CCB.base_url}api/logout`, {
  2739. type: "GET",
  2740. xhrFields: {
  2741. withCredentials: true
  2742. },
  2743. success: () => {
  2744. // $('#login_iframe').attr('src', '//staging.cocorobo.cn/login/');
  2745. appendIframe("TM_login");
  2746. $('#TM_login').children().css("height", "820px");
  2747. appendIframe("before_login");
  2748. appendIframe("cloud_askLogin");
  2749. Materialize.toast(CCB.str_group.success_userLogout, 4000);
  2750. CCB.userState = false;
  2751. $("#cloud_fileListArea").html("");
  2752. loginModalStatus();
  2753. $("#modal_logout_btn").addClass('blue')
  2754. $(".svgImg").css('display', 'none');
  2755. $(".translate-signout").css('opacity', '1')
  2756. }
  2757. });
  2758. });
  2759. </script>
  2760. <script type="text/javascript" src="./src/blockly/demo.js"></script>
  2761. <script type='text/javascript' src="./src/blockly/recorder.js"></script>
  2762. <script type='text/javascript' src="./src/blockly/jquery.s2t.js"></script>
  2763. </html>