You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

meshviewer.index.html 10 KiB

пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. <DOCTYPE html>
  2. <html>
  3. <meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
  4. <!--
  5. Copyright (c) 2012 The Native Client Authors. All rights reserved.
  6. Use of this source code is governed by a BSD-style license that can be
  7. found in the LICENSE file.
  8. -->
  9. <head>
  10. <style type="text/css">
  11. body
  12. {
  13. font:12px Consolas;
  14. }
  15. button
  16. {
  17. font:14px Consolas;
  18. }
  19. textarea
  20. {
  21. font:14px Consolas;
  22. }
  23. #id_div_progress_status
  24. {
  25. font:12px Consolas;
  26. }
  27. #id_div_progress
  28. {
  29. position: absolute;
  30. top: 20%;
  31. left: 30%;
  32. right: 30%;
  33. z-index: 3;
  34. background-color:white;
  35. border:1px solid #000000;
  36. visibility: hidden;
  37. }
  38. progress
  39. {
  40. background-color: #f3f3f3;
  41. border: 0;
  42. height: 18px;
  43. width: 200px;
  44. border-radius: 9px;
  45. }
  46. progress::-webkit-progress-bar
  47. {
  48. background-color: #f3f3f3;
  49. border: 1px solid #000000;
  50. padding: 2px 2px;
  51. height: 20px;
  52. border-radius: 0px;
  53. }
  54. progress::-webkit-progress-value
  55. {
  56. background-color: #22BB22;
  57. border: 0px;
  58. height: 14px;
  59. border-radius: 0px;
  60. }
  61. #id_div_listener
  62. {
  63. position: relative;
  64. }
  65. #id_div_frame_embed
  66. {
  67. position: absolute;
  68. top: 2px;
  69. left: 2px;
  70. z-index: -1;
  71. }
  72. #BGCanvas
  73. {
  74. border:1px solid #000000;
  75. }
  76. #id_div_helper_cmd_0
  77. {
  78. margin-left: 5px;
  79. }
  80. </style>
  81. <title>Mesh Viewer Web Edition</title>
  82. </head>
  83. <script type="text/javascript">
  84. //Base data Setup : GLOBAL STYLE
  85. g_div_frame_embed_save = '';
  86. g_div_frame_embed = null;
  87. g_txtarea_code_src = null;
  88. g_div_helper_cmd = [null, null];
  89. g_div_helper_args = null;
  90. g_div_helper_cmnt = null;
  91. g_div_helper_vars = null;
  92. g_div_alphabet = null;
  93. g_div_progress = null;
  94. g_div_progress_status = null;
  95. g_progress_bar = null;
  96. g_var_progress_bar = -1;
  97. g_frame_embed = null;
  98. //This is the module pointer : can be either the NaCl or Em one depending on the context.
  99. g_embed_module = null;
  100. var g_mesh_code_base = [];
  101. var CodeDictionnary = [];
  102. g_code_id = 0;
  103. g_mesh_code_base[0] = "//This is a comment\nsc#f8f afcb 1 1 1 0";
  104. g_mesh_code_base[1] = "//This is a comment\naddlight 0.0 position (4 -1 -4) color (.0 .2 .5 1)\naddlight 0.0 position (8 2 6) color #ffff";
  105. function machinchose() { return 'test machin '; }
  106. function GetTextAreaCodeSrc() { return g_txtarea_code_src; }
  107. function GetDivProgress() { return g_div_progress; }
  108. function GetProgressBar() { return g_progress_bar; }
  109. function GetDivProgressStatus() { return g_div_progress_status; }
  110. function GetDivEmbedData() { return g_div_frame_embed; }
  111. function GetDivEmbedDataSave() { return g_div_frame_embed_save; }
  112. function GetFrameData() { return g_frame_embed; }
  113. //Communication with iframe content.
  114. function InitModuleVar() { g_embed_module = GetiFrameModuleVar(); }
  115. function GetiFrameDivEmbed() { return (!g_frame_embed) ? (null) : (g_frame_embed.contentWindow.GetDivEmbed()); }
  116. function GetiFrameModuleVar() { return (!g_frame_embed) ? (null) : (g_frame_embed.contentWindow.GetEmbedModule()); }
  117. function IsUsingNaCl() { return window.chrome; }
  118. </script>
  119. <script src="./utils.js"></script>
  120. <script src="./progressstatus.js"></script>
  121. <script type="text/javascript">
  122. //Used by typedictionnary.js
  123. function GetCmdDictionnary() { return CodeDictionnary[g_code_id]; }
  124. g_code_id = 1;
  125. </script>
  126. <script src="./typedictionnary.js"></script>
  127. <!-- Init Scene setup dictionnary -->
  128. <script type="text/javascript">
  129. CodeDictionnary[g_code_id--] = new TypeDictionnary("SceneSetup");
  130. </script>
  131. <script src="./scenesetup.js"></script>
  132. <!-- Init Easy mesh dictionnary -->
  133. <script type="text/javascript">
  134. CodeDictionnary[g_code_id] = new TypeDictionnary("EasyMesh");
  135. </script>
  136. <script src="./easymeshdictionnary.js"></script>
  137. <!-- Revert datas to normal -->
  138. <script type="text/javascript">
  139. g_code_id = 0;
  140. </script>
  141. <script type="text/javascript">
  142. //Base init for all datas
  143. function VarInit()
  144. {
  145. //Init frame variable first.
  146. g_frame_embed = document.getElementById('id_frame_embed');
  147. //This is in an iframe.
  148. g_div_frame_embed = g_frame_embed.contentDocument.getElementById('id_div_frame_embed');
  149. //The rest of these are in this page.
  150. g_txtarea_code_src = document.getElementById('id_txtarea_code_src');
  151. g_div_helper_cmd[0] = document.getElementById('id_div_helper_cmd_0');
  152. g_div_helper_cmd[1] = document.getElementById('id_div_helper_cmd_1');
  153. g_div_helper_args = document.getElementById('id_div_helper_args');
  154. g_div_helper_cmnt = document.getElementById('id_div_helper_cmnt');
  155. g_div_helper_vars = document.getElementById('id_div_helper_vars');
  156. g_div_alphabet = document.getElementById('id_div_alphabet');
  157. g_div_progress = document.getElementById('id_div_progress');
  158. g_div_progress_status = document.getElementById('id_div_progress_status');
  159. g_progress_bar = document.getElementById('id_progress_bar');
  160. }
  161. //Base init
  162. function Init()
  163. {
  164. VarInit();
  165. //Put here any cookie update
  166. if (!g_txtarea_code_src.value)
  167. g_txtarea_code_src.value = g_mesh_code_base[g_code_id];
  168. //Fill the TOC
  169. if (!g_div_alphabet.innerHTML)
  170. {
  171. for (var i = 0; i < CodeDictionnary.length; i++)
  172. {
  173. g_code_id = i;
  174. var new_toc = BuildTOC(true);
  175. var pattern = new RegExp("^[a-zA-Z\.]");
  176. while (pattern.test(new_toc))
  177. new_toc = new_toc.replace(pattern, "<b>$&");
  178. pattern = new RegExp("[a-zA-Z\.]$");
  179. while (pattern.test(new_toc))
  180. new_toc = new_toc.replace(pattern, "$&</b>");
  181. pattern = new RegExp("([a-zA-Z])([\.])");
  182. while (pattern.test(new_toc))
  183. new_toc = new_toc.replace(pattern, "$1</b>$2");
  184. pattern = new RegExp("([\.])([a-zA-Z])");
  185. while (pattern.test(new_toc))
  186. new_toc = new_toc.replace(pattern, "$1<b>$2");
  187. CodeDictionnary[i].m_alphabet = new_toc;
  188. }
  189. g_code_id = 0;
  190. InitEditValues();
  191. }
  192. //NaCl Specific
  193. if (IsUsingNaCl())
  194. {
  195. DynLoadFile("naclloading.js");
  196. g_frame_embed.src = 'meshviewer.nacl.html';
  197. }
  198. else
  199. g_frame_embed.src = 'meshviewer.em.html';
  200. g_frame_embed.onload = function() { VarInit(); }
  201. //Tick has been done, start Tick
  202. window.setTimeout("Tick()", 200);
  203. }
  204. function Tick()
  205. {
  206. window.setTimeout("Tick()", 100);
  207. var text_src = g_txtarea_code_src;
  208. var div_cmds = g_div_helper_cmd;
  209. var div_args = g_div_helper_args;
  210. var div_cmnt = g_div_helper_cmnt;
  211. var div_vars = g_div_helper_vars;
  212. CmdLookup(div_cmds, div_args, div_cmnt, div_vars, text_src);
  213. }
  214. function StoreTextAreaValue()
  215. {
  216. g_mesh_code_base[g_code_id] = GetTextAreaCodeSrc().value;
  217. }
  218. function ExchangeSetup()
  219. {
  220. StoreTextAreaValue();
  221. g_code_id = (g_code_id + 1) % 2;
  222. InitEditValues();
  223. }
  224. function InitEditValues()
  225. {
  226. GetTextAreaCodeSrc().value = g_mesh_code_base[g_code_id];
  227. g_div_alphabet.innerHTML = '&nbsp;Table of content<br>&nbsp;[' + CodeDictionnary[g_code_id].m_alphabet + ']&nbsp;<br>&nbsp;';
  228. }
  229. //Handle message from the NaCl module
  230. function ModuleSentMessage(message)
  231. {
  232. alert('Module sent message: ' + message.data);
  233. }
  234. //Called by the "Send Mesh Command !" button
  235. function SendMessageToModule()
  236. {
  237. StoreTextAreaValue();
  238. var message = g_mesh_code_base[1] + ' \n';
  239. message += ' custom setmesh "' + g_mesh_code_base[0] + '"';
  240. if (g_embed_module)
  241. g_embed_module.SendMessage(message);
  242. else
  243. alert("Module not loaded !");
  244. }
  245. </script>
  246. <body>
  247. <h1>Mesh Viewer : Web version.</h1>
  248. <p>
  249. <div id="final_div">
  250. <div id="id_div_listener" align="center" style="width:770px;height:200px">
  251. <canvas id="BGCanvas" width="772" height="202"></canvas>
  252. <div id="id_div_progress">
  253. <br>&nbsp;
  254. <progress id="id_progress_bar" align="left"></progress>
  255. <div id="id_div_progress_status">....</div>&nbsp;
  256. </div>
  257. <div id="id_div_frame_embed">
  258. <iframe onload="Init();" id="id_frame_embed" src="empty.html" width=770 height=200 frameborder=0 scrolling=no></iframe>
  259. </div>
  260. </div>
  261. </div>
  262. </p>
  263. <table border="0" cellpadding="0" cellspacing="0" width="772">
  264. <tr>
  265. <td align="left">
  266. <div><button onclick="SendMessageToModule()">Send Mesh Command !</button></div>
  267. </td>
  268. <td align="right">
  269. <div><button onclick="ExchangeSetup()">Edit Scene Setup.</button></div>
  270. </td>
  271. </tr>
  272. </table>
  273. <table border="0" cellpadding="0" cellspacing="0">
  274. <tr>
  275. <td height="1%">
  276. <div id="bouton">
  277. <textarea autofocus id="id_txtarea_code_src" rows="6" cols="94" style="font: 14px Consolas; resize: none;"></textarea>
  278. </div>
  279. </td>
  280. <td valign="top" rowspan="3">&nbsp;</td>
  281. <td valign="top" rowspan="3">
  282. <div><b><u>Variable Types usage :</u></b></div>
  283. <div id="id_div_helper_vars"></div>
  284. </td>
  285. </tr>
  286. <tr>
  287. <td height="1%">
  288. <div id="id_div_alphabet"></div>
  289. </td>
  290. </tr>
  291. <tr>
  292. <td valign="top">
  293. <table border="0" cellpadding="0" cellspacing="0">
  294. <tr>
  295. <td valign="top"><div id="id_div_helper_cmd_0"></div></td>
  296. <td valign="top"><div id="id_div_helper_cmd_1"></div></td>
  297. <td valign="top"><div id="id_div_helper_args" ></div></td>
  298. <td valign="top"><div id="id_div_helper_cmnt" ></div></td>
  299. </tr>
  300. </table>
  301. </td>
  302. </tr>
  303. </table>
  304. </body>
  305. </html>