example2.html 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Speedtest</title>
  5. <style type="text/css">
  6. html,body{
  7. margin:0;
  8. padding:0;
  9. border:none;
  10. text-align:center;
  11. }
  12. div.test{
  13. display:inline-block;
  14. margin:1em;
  15. text-align:center;
  16. }
  17. div.testName,div.meterUnit{
  18. font-size:3vw;
  19. }
  20. div.meter{
  21. font-size:6vw;
  22. line-height:1.5em;
  23. height:1.5em !important;
  24. }
  25. .flash{
  26. animation:flash 0.6s linear infinite;
  27. }
  28. @keyframes flash{
  29. 0%{opacity:0.6;}
  30. 50%{opacity:1;}
  31. }
  32. </style>
  33. </head>
  34. <body>
  35. <h1>Speedtest</h1>
  36. <div class="test">
  37. <div class="testName">Download</div>
  38. <div class="meter">&nbsp;<span id="download"></span>&nbsp;</div>
  39. <div class="meterUnit">Mbit/s</div>
  40. </div>
  41. <div class="test">
  42. <div class="testName">Upload</div>
  43. <div class="meter">&nbsp;<span id="upload"></span>&nbsp;</div>
  44. <div class="meterUnit">Mbit/s</div>
  45. </div>
  46. <div class="test">
  47. <div class="testName">Latency</div>
  48. <div class="meter">&nbsp;<span id="ping"></span>&nbsp;</div>
  49. <div class="meterUnit">ms</div>
  50. </div>
  51. <div class="test">
  52. <div class="testName">Jitter</div>
  53. <div class="meter">&nbsp;<span id="jitter"></span>&nbsp;</div>
  54. <div class="meterUnit">ms</div>
  55. </div>
  56. <div id="ip"></div>
  57. <script type="text/javascript">
  58. var w=new Worker("speedtest_worker.min.js");
  59. var interval=setInterval(function(){w.postMessage("status");}.bind(this),100);
  60. w.onmessage=function(event){
  61. var data=event.data.split(";");
  62. var status=Number(data[0]);
  63. var dl=document.getElementById("download"),ul=document.getElementById("upload"),ping=document.getElementById("ping"),ip=document.getElementById("ip"),jitter=document.getElementById("jitter");
  64. dl.className=status==1?"flash":"";ping.className=status==2?"flash":"";jitter.className=ul.className=status==3?"flash":"";
  65. if(status>=4){
  66. clearInterval(interval);
  67. }
  68. dl.innerHTML=data[1];
  69. ul.innerHTML=data[2];
  70. ping.innerHTML=data[3];
  71. jitter.innerHTML=data[5];
  72. ip.innerHTML="Your IP: "+data[4];
  73. }.bind(this);
  74. w.postMessage('start {"url_dl":"garbage.php","url_ul":"empty.dat","url_ping":"empty.dat","time_dl":"10","time_ul":"15","count_ping":"30"}'); //start with custom parameters. paths are relative to js file. you can omit parameters that you don't want to change
  75. </script>
  76. </body>
  77. </html>