WXdraw.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416
  1. //画布
  2. var canvas;
  3. var context;
  4. //蒙版
  5. var canvas_bak = document.getElementById("box");;
  6. var context_bak;
  7. var canvasWidth = 720;
  8. var canvasHeight = 1280;
  9. var canvasTop;
  10. var canvasLeft;
  11. var winHeight = window.screen.height - window.innerHeight
  12. var vowidth = window.screen.width
  13. var topwinHeightDraw = window.screen.height - window.innerHeight + 30; //计算title top 头部
  14. var numse = window.screen.height //-winHeight
  15. //计算title top 头部
  16. if (numse <= 70) {
  17. var voheight = window.screen.height - winHeight - 34 - 20
  18. } else {
  19. console.log("numse>>>", numse)
  20. var voheight = window.screen.height - topwinHeightDraw - 20
  21. }
  22. //console.log("画笔大小>>>",window.innerHeight)
  23. //画笔大小
  24. var size = 1;
  25. var color = '#000000';
  26. var resolving
  27. //alert(winHeight)
  28. var url = window.location.href;
  29. url = url.split('/')
  30. var query = window.location.search.substring(1);
  31. // debugger
  32. // query = "clientType=3&username=WqXTc1593762177&userCardId=377"
  33. // debugger
  34. var vars = query.split("&");
  35. var data = {}
  36. var clientType = vars.find(e => {
  37. return e.startsWith('clientType')
  38. }) || ''
  39. var cardIp = vars.find(e => {
  40. return e.startsWith('cardIp')
  41. }) || ''
  42. var port = vars.find(e => {
  43. return e.startsWith('port')
  44. }) || ''
  45. var sn = vars.find(e => {
  46. return e.startsWith('sn')
  47. }) || ''
  48. var username = vars.find(e => {
  49. return e.startsWith('username')
  50. }) || ''
  51. var userCardId = vars.find(e => {
  52. return e.startsWith('userCardId')
  53. }) || ''
  54. var ip = vars.find(e => {
  55. return e.startsWith('ip')
  56. }) || ''
  57. var data = {}
  58. data.clientType = clientType.substring(11, clientType.length)
  59. data.cardIp = cardIp.substring(7, cardIp.length)
  60. data.port = port.substring(5, port.length)
  61. data.sn = sn.substring(3, sn.length)
  62. data.username = username.substring(9, username.length)
  63. data.userCardId = userCardId.substring(11, userCardId.length)
  64. data.ip = ip.substring(3, ip.length)
  65. // var urlss=url[2]
  66. // urlss = "14.215.128.96"
  67. urlss = '192.168.31.20'
  68. // urlss = 'test.androidscloud.com'
  69. // debugger
  70. // var cUrl = ''
  71. // cUrl = "ws://192.168.11.66:9101";
  72. // var cUrl="wss://www.ted2018.com:9101"
  73. // var cUrl = "ws://192.168.198.21:9101"
  74. var cUrl = "ws://14.215.128.97:15508"
  75. // if (data.clientType == 3) {
  76. // cUrl = "wss://" + urlss + "/authControlWebSocket?" + "clientType=" + data.clientType + "&username=" + data.username +
  77. // "&userCardId=" + data.userCardId
  78. // } else if (data.clientType == 2) {
  79. // // cUrl = "wss://" + urlss + "/shareWebSocket?" + "clientType=" + data.clientType + "&username=" + data.username +
  80. // // "&userCardId=" + data.userCardId + "&ip=" + data.ip
  81. // cUrl = "wss://test.androidscloud.com/videoWebSocket?clientType=1&cardIp=14.215.128.96&port=2005&sn=RK3930C2301900005";
  82. // } else {
  83. // cUrl = "wss://" + urlss + "/controlWebSocket?" + "clientType=" + data.clientType + "&cardIp=" + data.cardIp + "&port=" +
  84. // data.port + "&sn=" + data.sn
  85. // }
  86. console.log(cUrl, 'curl')
  87. // var cUrl = Number(data.clientType) === 3? "ws://"+urlss+"/authControlWebSocket?"+"clientType="+data.clientType+"&username="+data.username+"&userCardId="+data.userCardId : "ws://"+urlss+"/controlWebSocket?"+"clientType="+data.clientType+"&cardIp="+data.cardIp+"&port="+data.port+"&sn="+data.sn
  88. var wsss = new WebSocket(cUrl);
  89. console.log('wsssss==============', wsss)
  90. wsss.binaryType = 'arraybuffer';
  91. ////
  92. // wsss = new WebSocket(
  93. // "ws://14.215.128.96/authControlWebSocket?clientType=3&username=WqXTc1593762177&userCardId=377");
  94. wsss.onopen = function() {
  95. console.log("onopen==============");
  96. var pings = {
  97. "event": "getScreenStatus"
  98. }
  99. wsss.send(JSON.stringify(pings));
  100. var bitRate = {
  101. "data": {
  102. "bitRate": 2243000
  103. },
  104. "event": "bitRate"
  105. }
  106. // wsss.send(JSON.stringify(bitRate));
  107. wsss.send(ExexuteMove(JSON.stringify(bitRate),data.sn))
  108. };
  109. // wsss.onmessage = function(event) {
  110. // // console.log("onMessage==============", event);
  111. // // var resets = JSON.parse(event.data)
  112. // // var resets = event.data;
  113. // // resets.errorMsg && alert(resets.errorMsg)
  114. // // resolving = resets.data.orientation
  115. // // if (resolving == 1) {} else {}
  116. // // console.log('>>>resolvingresolvingresolving', resolving)
  117. // };
  118. wsss.onclose = function(event) {
  119. console.log("onclose==============");
  120. };
  121. wsss.onerror = function(event) {
  122. console.log("onerror==============");
  123. };
  124. $('#box').on("click", function() {
  125. draw_graph('pencil', this)
  126. })
  127. //剪切板
  128. $(".upload").on("click", function() {
  129. let texts = $(this).attr("data-text")
  130. if (texts == "uploads") {
  131. $(".mainbox").css({
  132. "display": "block"
  133. })
  134. $(".sbox").css({
  135. "display": "none"
  136. })
  137. } else if (texts == "Signout") {
  138. // alert()
  139. }
  140. })
  141. //home 控制home
  142. $(".botmat1img").on("click", function() {
  143. let codes = $(this).attr("data-text")
  144. console.log(codes)
  145. if (codes == "home") {
  146. // var bitRate = {
  147. // "data": {
  148. // "keyCode": 3
  149. // },
  150. // "event": "keyCode"
  151. // }
  152. // console.log("打印主页json", JSON.stringify(bitRate))
  153. wsss.send(ExexuteKeyBoard(3),data.sn);
  154. // console.log("打印主页json", wsss)
  155. } else if (codes == "return") {
  156. // var bitRate = {
  157. // "data": {
  158. // "keyCode": "4"
  159. // },
  160. // "event": "keyCode"
  161. // }
  162. // wsss.send(JSON.stringify(bitRate));
  163. wsss.send(ExexuteKeyBoard(4),data.sn);
  164. } else if (codes == "gengduo") {
  165. // var bitRate = {
  166. // "data": {
  167. // "keyCode": "187"
  168. // },
  169. // "event": "keyCode"
  170. // }
  171. // wsss.send(JSON.stringify(bitRate));
  172. wsss.send(ExexuteKeyBoard(187),data.sn);
  173. }
  174. })
  175. //高清控制
  176. $(".PictureQuality").on("click", function() {
  177. $(this).addClass("avit").siblings().removeClass('avit')
  178. let id = $(this).attr("data-id")
  179. var bitRate = {
  180. "data": {
  181. "bitRate": id
  182. },
  183. "event": "bitRate"
  184. }
  185. wsss.send(ExexuteMove(JSON.stringify(bitRate),data.sn))
  186. console.log(id)
  187. })
  188. //画图形
  189. var draw_graph = function(graphType, obj) {
  190. console.log('111》》》', graphType)
  191. //把蒙版放于画板上面
  192. //$("#canvas_bak").css("z-index",1);
  193. $("#container").css("z-index", 30);
  194. $("#dedit").css("z-index", 20);
  195. //先画在蒙版上 再复制到画布上
  196. chooseImg(obj);
  197. var canDraw = false;
  198. var startX;
  199. var startY;
  200. //鼠标按下获取 开始xy开始画图
  201. var touchstart = function(e) {
  202. $('.control-right-img').attr({
  203. "data-id": "2"
  204. })
  205. $(".leftmains").css({
  206. "right": "-4rem"
  207. })
  208. // .toFixed(2)
  209. var touchfor = e.originalEvent.targetTouches; //for 的手指数组
  210. var touch = e.originalEvent.targetTouches[0];
  211. var thochlethng = e.originalEvent.targetTouches.length
  212. //是否横屏
  213. if (resolving == 0) {
  214. let ping
  215. for (let i = 0; i < touchfor.length; i++) {
  216. let cawidthXs = touchfor[i].pageY * (1280 / voheight)
  217. let caheightYs = 720 - touchfor[i].pageX * (720 / vowidth)
  218. ping = {
  219. "data": {
  220. "action": 0,
  221. "count": touchfor.length,
  222. "pointerId": i,
  223. "x": cawidthXs.toFixed(2),
  224. "y": caheightYs.toFixed(2)
  225. },
  226. "event": "0"
  227. }
  228. }
  229. // wsss.send(JSON.stringify(ping));
  230. wsss.send(ExexuteMove(JSON.stringify(ping),data.sn))
  231. console.log("鼠标按下>>>", ping)
  232. } else {
  233. let ping
  234. for (let i = 0; i < touchfor.length; i++) {
  235. let cawidthXs = touchfor[i].pageX * (720 / vowidth)
  236. let caheightYs = touchfor[i].pageY * (1280 / voheight)
  237. ping = {
  238. "data": {
  239. "action": 0,
  240. "count": touchfor.length,
  241. "pointerId": i,
  242. "x": cawidthXs.toFixed(2),
  243. "y": caheightYs.toFixed(2)
  244. },
  245. "event": "0"
  246. }
  247. }
  248. // wsss.send(JSON.stringify(ping));
  249. wsss.send(ExexuteMove(JSON.stringify(ping),data.sn))
  250. console.log("鼠标按下>>>", ping)
  251. }
  252. canDraw = true;
  253. };
  254. //鼠标离开 把蒙版canvas的图片生成到canvas中
  255. var touchend = function(e) {
  256. var touchfor = e.originalEvent.changedTouches; //for 的手指数组
  257. var touch = e.originalEvent.changedTouches[0];
  258. var thochlethng = e.originalEvent.changedTouches.length
  259. // alert(thochlethng)
  260. //是否横屏 morePortionUp
  261. if (resolving == 0) {
  262. let ping
  263. for (let i = 0; i < touchfor.length; i++) {
  264. let cawidthXs = touchfor[i].pageY * (1280 / voheight)
  265. let caheightYs = 720 - touchfor[i].pageX * (720 / vowidth)
  266. ping = {
  267. "data": {
  268. "action": 1,
  269. "count": touchfor.length,
  270. "pointerId": i,
  271. "x": cawidthXs.toFixed(2),
  272. "y": caheightYs.toFixed(2)
  273. },
  274. "event": "1"
  275. }
  276. }
  277. // wsss.send(JSON.stringify(ping));
  278. wsss.send(ExexuteMove(JSON.stringify(ping),data.sn))
  279. } else {
  280. let ping
  281. for (let i = 0; i < touchfor.length; i++) {
  282. let cawidthXs = touchfor[i].pageX * (720 / vowidth)
  283. let caheightYs = touchfor[i].pageY * (1280 / voheight)
  284. ping = {
  285. "data": {
  286. "action": 1,
  287. "count": touchfor.length,
  288. "pointerId": i,
  289. "x": cawidthXs.toFixed(2),
  290. "y": caheightYs.toFixed(2)
  291. },
  292. "event": "1"
  293. }
  294. }
  295. // wsss.send(JSON.stringify(ping));
  296. wsss.send(ExexuteMove(JSON.stringify(ping),data.sn))
  297. }
  298. canDraw = false;
  299. };
  300. //清空层 云手机超出屏幕的开关
  301. var clearContext = function(type) {
  302. canDraw = false;
  303. }
  304. // 鼠标移动
  305. var touchmove = function(e) {
  306. e = e || window.event;
  307. var touchfor = e.originalEvent.targetTouches; //for 的手指数组
  308. var touch = e.originalEvent.targetTouches[0];
  309. var thochlethng = e.originalEvent.targetTouches.length
  310. let ping
  311. //是否横屏 morePortionMove
  312. if (resolving == 0) {
  313. let obj = []
  314. for (let i = 0; i < touchfor.length; i++) {
  315. let cawidthXs = touchfor[i].pageY * (1280 / voheight)
  316. let caheightYs = 720 - touchfor[i].pageX * (720 / vowidth)
  317. ping = {
  318. "data": {
  319. "action": 2,
  320. "count": touchfor.length,
  321. "pointerId": i,
  322. "x": cawidthXs.toFixed(2),
  323. "y": caheightYs.toFixed(2)
  324. },
  325. "event": "2"
  326. }
  327. }
  328. // wsss.send(JSON.stringify(ping));
  329. wsss.send(ExexuteMove(JSON.stringify(ping),data.sn))
  330. } else {
  331. let ping
  332. for (let i = 0; i < touchfor.length; i++) {
  333. let cawidthXs = touchfor[i].pageX * (720 / vowidth)
  334. let caheightYs = touchfor[i].pageY * (1280 / voheight)
  335. ping = {
  336. "data": {
  337. "action": 2,
  338. "count": touchfor.length,
  339. "pointerId": i,
  340. "x": cawidthXs.toFixed(2),
  341. "y": caheightYs.toFixed(2)
  342. },
  343. "event": "2"
  344. }
  345. }
  346. // wsss.send(JSON.stringify(ping));
  347. wsss.send(ExexuteMove(JSON.stringify(ping),data.sn))
  348. }
  349. // var ping = {"data":{"action":2,"count":1,"pointerId":0,"x":cawidthX.toFixed(2),"y":caheightY.toFixed(2)},"event":"2"}
  350. };
  351. //鼠标离开区域以外 除了涂鸦 都清空
  352. var mouseout = function() {
  353. if (graphType != 'handwriting') {
  354. clearContext();
  355. }
  356. }
  357. $(canvas_bak).unbind();
  358. $(canvas_bak).bind('touchstart', touchstart);
  359. $(canvas_bak).bind('touchmove', touchmove);
  360. $(canvas_bak).bind('touchend', touchend);
  361. $(canvas_bak).bind('mouseout', mouseout);
  362. }
  363. //选择功能按钮 修改样式
  364. function chooseImg(obj) {
  365. }