WXdraw.js 11 KB

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