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.

339 lines
13 KiB

6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Crashes</title>
  6. <meta name="viewport" content="initial-scale=1.0">
  7. <meta charset="utf-8">
  8. <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
  9. <script src="socket.io/node_modules/socket.io-client/dist/socket.io.js"></script>
  10. <style>
  11. #map {
  12. height: 100%;
  13. }
  14. html, body {
  15. height: 100%;
  16. margin: 0;
  17. padding: 0;
  18. }
  19. </style>
  20. <style>
  21. #img-user{
  22. max-width: 150px;
  23. max-height: 150px;
  24. }
  25. .title{
  26. text-align: left;
  27. }
  28. td{
  29. padding: 20px 10px;
  30. }
  31. .popup{
  32. display: none; /* Hidden by default */
  33. position: fixed; /* Stay in place */
  34. left: 0;
  35. top: 0;
  36. width: 100%; /* Full width */
  37. height: 100%; /* Full height */
  38. overflow: auto; /* Enable scroll if needed */
  39. background-color: rgb(0,0,0); /* Fallback color */
  40. background-color: rgba(0,0,0,0.4); /* Black w/ opacity */
  41. padding-top: 60px;
  42. }
  43. #table,#table-user{
  44. background: white;
  45. padding: 40px 60px;
  46. }
  47. #content, #user-content{
  48. display: inline-block;
  49. background: white;
  50. }
  51. #submit{
  52. top: 50%;
  53. transform: translateY(-50%);
  54. }
  55. </style>
  56. </head>
  57. <body>
  58. <audio id="audio" src="http://www.soundjay.com/button/beep-07.wav" autoplay="false"></audio>
  59. <div id="map"></div>
  60. <!-- ANANA SOKIYIM JAVASCRIPT
  61. Sen nası gereksiz bir dilsin amk bütün bi gecemi yedin
  62. ben senenin ebeni sikiyim inşallah seni yazan programcının götüne av tüfeği girer
  63. AYNISI SOCKET.IO IÇIN DE GEÇERLİ ALLAHIM KAFAYI YİCEM ADAMLAR HERALDE "ACABA NE KADAR ÖZÜRLÜ BI FRAMERWORK YAZARIZ DUYE BAŞLAMIŞLAR IŞE"-->
  64. <div id = "popup" align = "center" class = "popup">
  65. <div id = "content">
  66. <canvas id="canvas" width="400" height="400" style="margin-top: 30px;">
  67. </canvas>
  68. <table border="0" cellpadding="10" cellspacing="0" id = "table" class = "modal">
  69. <tr>
  70. <td colspan="4" class="title"><strong>Priority: </strong></td>
  71. <td colspan="6" id = "priority">7</td>
  72. </tr>
  73. <tr>
  74. <td colspan="4" class="title"><strong>Type: </strong></td>
  75. <td colspan="6" id = "type"> Ambulance</td>
  76. </tr>
  77. <tr>
  78. <td colspan="4" class="title"><strong>Submitter: </strong></td>
  79. <td colspan="6">
  80. <a href="#" id = "user" class = "panel" onclick=
  81. "document.getElementById('popup').style.display='none';
  82. document.getElementById('user-popup').style.display='block';
  83. setUser(this.getAttribute('userid'))"
  84. >Efe Aydın </a>
  85. </td>
  86. </tr>
  87. <tr>
  88. <td colspan="4" class="title"><strong>Message: </strong></td>
  89. <td colspan="6" id = "message">Test ambulance</td>
  90. </tr>
  91. <tr>
  92. <td colspan="4" class="title"><strong>Tags: </strong></td>
  93. <td colspan="6" id = "tags">Test tags</td>
  94. </tr>
  95. </table>
  96. </div>
  97. </div>
  98. <div id = "user-popup" align = "center" class="popup">
  99. <div id = "user-content">
  100. <table border="0" cellpadding="10" cellspacing="0" id = "table-user" class = "modal">
  101. <tr>
  102. <td rowspan="3" colspan="7"><img src="cityscape.png" alt="img"id = "img-user"></td>
  103. <td colspan="2" class="title"><strong>Name: </strong></td>
  104. <td colspan="1" id = "name">Efe Aydın</td>
  105. </tr>
  106. <tr>
  107. <td colspan="2" class="title"><strong>TC: </strong></td>
  108. <td colspan="1" id = "tc">111111111111</td>
  109. </tr>
  110. <tr>
  111. <td colspan="2" class="title"><strong>Trust: </strong></td>
  112. <td colspan="1" id = "trust">7</td>
  113. </tr>
  114. <tr>
  115. <td colspan="4" class="title"><strong>Phone: </strong></td>
  116. <td colspan="6" id="phone">
  117. 0 555 555 55 55
  118. </td>
  119. </tr>
  120. <tr>
  121. <td colspan="4" class="title"><strong>E-mail: </strong></td>
  122. <td colspan="6" id = "email">efeaydin@citizenview.com</td>
  123. </tr>
  124. <tr>
  125. <td colspan="4" class="title"><strong>Health: </strong></td>
  126. <td colspan="6" id = "health">Test tags</td>
  127. </tr>
  128. </table>
  129. <button onclick=
  130. "document.getElementById('popup').style.display='block';
  131. document.getElementById('user-popup').style.display='none';"
  132. style="margin-bottom: 5px;">OK</button>
  133. </div>
  134. </div>
  135. <script>
  136. function setUser(id) {
  137. if(!(id in users)) {
  138. $.get("https://" + document.domain + ":5000/users/" + id, function (dataStr, status) {
  139. data_user = $.parseJSON(dataStr)
  140. users[id]=data_user
  141. document.getElementById("name").innerHTML = users[id]["realname"];
  142. document.getElementById("tc").innerHTML = users[id]["TC"];
  143. document.getElementById("trust").innerHTML = users[id]["trustability"];
  144. document.getElementById("phone").innerHTML = users[id]["tel"];
  145. document.getElementById("email").innerHTML = users[id]["email"];
  146. document.getElementById("img-user").setAttribute("src","https://" + document.domain + ":5000"+users[id]["avatar"])
  147. });
  148. }else {
  149. document.getElementById("name").innerHTML = users[id]["realname"];
  150. document.getElementById("tc").innerHTML = users[id]["TC"];
  151. document.getElementById("trust").innerHTML = users[id]["trustability"];
  152. document.getElementById("phone").innerHTML = users[id]["tel"];
  153. document.getElementById("email").innerHTML = users[id]["email"];
  154. document.getElementById("img-user").setAttribute("src","data:image/png;base64," + users[id]["image"])
  155. }
  156. }
  157. </script>
  158. <script>
  159. var modal = document.getElementById('popup');
  160. window.onclick = function(event) {
  161. if (event.target == modal) {
  162. modal.style.display = "none";
  163. }
  164. }
  165. </script>
  166. <script>
  167. var map;
  168. function initMap() {
  169. map = new google.maps.Map(document.getElementById('map'), {
  170. center: {lat: 39.92, lng: 32.85},
  171. zoom: 13
  172. });
  173. }
  174. </script>
  175. <script>
  176. var class_color_dict = {"person":"blue","car":"yellow"}
  177. var sound = document.getElementById("audio");
  178. var markers = [];
  179. var socket = io.connect('http://' + document.domain + ':' + location.port + "/crashes_socket");
  180. console.log('http://' + document.domain + ":4000/crashes_socket")
  181. console.log(socket);
  182. var markers = [];
  183. var denunciation_count = markers.length;
  184. var users = {};
  185. setInterval(function () {
  186. socket.emit("check",{})
  187. },1000);
  188. var LatLng = null;
  189. socket.on("new",function (dataStr) {
  190. for (var i = 0; i < markers.length; i++) {
  191. markers.pop().setMap(null);
  192. }
  193. console.log("Update received!")
  194. var data = $.parseJSON(dataStr);
  195. console.log(data);
  196. for(var key in data) {
  197. data[key].forEach(function (element,index) {
  198. if(element["location"]["longitude"] === undefined || element["location"]["latitude"] === undefined){
  199. return;
  200. }
  201. LatLng = {lat: parseFloat(element["location"]["latitude"]), lng: parseFloat(element["location"]["longitude"])};
  202. var marker = new google.maps.Marker({
  203. position: {lat: parseFloat(element["location"]["latitude"]), lng: parseFloat(element["location"]["longitude"])},
  204. map: map,
  205. label: element["priority"].toString(),
  206. title: element["message"]
  207. });
  208. marker.addListener('click', function () {
  209. document.getElementById('popup').style.display = 'block';
  210. document.getElementById("priority").innerHTML = element["priority"];
  211. document.getElementById("type").innerHTML = "Car Crash";
  212. document.getElementById("message").innerHTML = element["message"];
  213. if (!(key in users)) {
  214. $.get("https://" + document.domain + ":5000/users/" + key, function (dataStr, status) {
  215. data_user = $.parseJSON(dataStr);
  216. users[key] = data_user;
  217. document.getElementById("user").innerHTML = users[key]["realname"];
  218. });
  219. } else {
  220. document.getElementById("user").innerHTML = users[key]["realname"];
  221. }
  222. document.getElementById("user").setAttribute("userid", key);
  223. var canvas = document.getElementById("canvas");
  224. var ctx = canvas.getContext("2d");
  225. var image = new Image();
  226. var rects = []
  227. image.onload = function() {
  228. if(image.height > image.width){
  229. XY_RATIO = canvas.height/image.height
  230. canvas.width = image.width * XY_RATIO
  231. }else{
  232. XY_RATIO = canvas.width/image.width
  233. canvas.height = image.height * XY_RATIO
  234. }
  235. ctx.drawImage(image, 0, 0, image.width, image.height, // source rectangle
  236. 0, 0, canvas.width, canvas.height);
  237. for(i=0;i<element["output_dict"]["detection_classes"].length;i++){
  238. var box = element["output_dict"]["detection_boxes"][i];
  239. ctx.beginPath();
  240. ctx.lineWidth = "2";
  241. var box_class = element["output_dict"]["detection_classes"][i];
  242. ctx.strokeStyle = class_color_dict[box_class];
  243. ctx.rect(box[0]*XY_RATIO,box[2]*XY_RATIO,Math.abs(box[1]-box[0])*XY_RATIO,Math.abs(box[3]-box[2])*XY_RATIO);
  244. ctx.stroke()
  245. }
  246. for(i=0;i<element["people"].length;i++){
  247. ctx.beginPath();
  248. var person = element["people"][i]
  249. box = person[1]
  250. ctx.strokeStyle = "green";
  251. if(person[0]){
  252. ctx.strokeStyle = "red";
  253. }
  254. ctx.rect(box[3]*XY_RATIO,box[0]*XY_RATIO,(box[1]-box[3])*XY_RATIO,(box[0]-box[2])*XY_RATIO);
  255. ctx.stroke();
  256. rects.push({"x":box[3]*XY_RATIO,"y":box[0]*XY_RATIO,"w":(box[1]-box[3])*XY_RATIO,"h":(box[0]-box[2])*XY_RATIO,"id":person[2]})
  257. }
  258. };
  259. image.src = "data:image/png;base64," + element["img"]
  260. canvas.addEventListener('click', function(e) {
  261. console.log('click: ' + e.offsetX + '/' + e.offsetY);
  262. console.log(rects)
  263. var rect = collides(rects, e.offsetX, e.offsetY);
  264. if (rect) {
  265. document.getElementById('popup').style.display='none';
  266. document.getElementById('user-popup').style.display='block';
  267. setUser(rect.id);
  268. }
  269. }, false);
  270. });
  271. });
  272. }
  273. map.setCenter(LatLng);
  274. if (denunciation_count < markers.length) {
  275. sound.play();
  276. }
  277. denunciation_count = markers.length;
  278. });
  279. function collides(rects, x, y) {
  280. var isCollision = false;
  281. for (var i = 0, len = rects.length; i < len; i++) {
  282. var left = rects[i].x, right = rects[i].x+rects[i].w;
  283. var top = rects[i].y, bottom = rects[i].y+rects[i].h;
  284. if (right >= x
  285. && left <= x
  286. && bottom >= y
  287. && top <= y) {
  288. isCollision = rects[i];
  289. }
  290. }
  291. return isCollision;
  292. }
  293. </script>
  294. <script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyBuOC03IHPA_6TPnfk18b0SAgD1uge4-dk&callback=initMap" async defer></script>
  295. </body>
  296. </html>