home.html 51 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="initial-scale=1,maximum-scale=1, minimum-scale=1,user-scalable=no">
  7. <meta name="x5-orientation" content="portrait" />
  8. <meta name="screen-orientation" content="portrait" />
  9. <meta name="viewport" content="width=device-width, minimum-scale=1.0,maximum-scale=1.0,user-scalable=no">
  10. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
  11. <meta name="apple-mobile-web-app-capable" content="yes">
  12. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  13. <meta name="format-detection" content="telephone=no, email=no">
  14. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
  15. <meta name="apple-mobile-web-app-capable" content="yes">
  16. <!-- 删除苹果默认的工具栏和菜单栏 -->
  17. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  18. <!-- 设置苹果工具栏颜��? -->
  19. <meta name="format-detection" content="telphone=no, email=no">
  20. <!-- 忽略页面中的数字识别为电话,忽略email识别 -->
  21. <!-- 启用360浏览器的极速模��?(webkit) -->
  22. <meta name="renderer" content="webkit">
  23. <!-- 避免IE使用兼容模式 -->
  24. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  25. <!-- 针对手持设备优化,主要是针对一些老的不识别viewport的浏览器,比如黑��? -->
  26. <meta name="HandheldFriendly" content="true">
  27. <!-- 微软的老式浏览��? -->
  28. <meta name="MobileOptimized" content="320">
  29. <!-- uc强制竖屏 -->
  30. <!-- <meta name="screen-orientation" content="portrait"> -->
  31. <!-- QQ强制竖屏 -->
  32. <!-- <meta name="x5-orientation" content="portrait"> -->
  33. <!-- 不能旋转,问题出在这 -->
  34. <!-- UC强制全屏 -->
  35. <meta name="full-screen" content="yes">
  36. <!-- QQ强制全屏 -->
  37. <meta name="x5-fullscreen" content="true">
  38. <!-- UC应用模式 -->
  39. <meta name="browsermode" content="application">
  40. <!-- QQ应用模式 -->
  41. <meta name="x5-page-mode" content="app">
  42. <!-- windows phone 点击无高��? -->
  43. <meta name="msapplication-tap-highlight" content="no">
  44. <title></title>
  45. <link rel="stylesheet" href="../static/css/homeNew.css?id=103">
  46. <link rel="stylesheet" type="text/css" href="../static/css/swiper-bundle.min.css" />
  47. <script src="../static/css/swiper-bundle.min.js"></script>
  48. <script async defer src="https://buttons.github.io/buttons.js"></script>
  49. <style>
  50. .swiper-button-next {
  51. width: 15px;
  52. height: 15px;
  53. background: url(../static/img/xia_icon.png);
  54. right: 15px;
  55. }
  56. .swiper-button-prev {
  57. width: 15px;
  58. height: 15px;
  59. background: url(../static/img/shang_icon.png);
  60. left: 15px;
  61. }
  62. .swiper-button-next:after,
  63. .swiper-container-rtl .swiper-button-prev:after {
  64. content: "" !important;
  65. }
  66. .swiper-button-prev:after,
  67. .swiper-container-rtl .swiper-button-next:after {
  68. content: "" !important;
  69. }
  70. .wxTips {
  71. text-align: center;
  72. position: absolute;
  73. top: 50%;
  74. left: 50%;
  75. transform: translate(-50%, -50%);
  76. z-index: 99999;
  77. height: 2.5rem;
  78. line-height: 2.5rem;
  79. border-radius: .2rem;
  80. padding: 0 .8rem;
  81. background-color: rgba(0, 0, 0, 0.5);
  82. margin-top: -5rem;
  83. color: #fff;
  84. font-size: .7rem;
  85. display: none;
  86. }
  87. .homebg {
  88. width: 100%;
  89. height: 100%;
  90. border-radius: 20px;
  91. }
  92. </style>
  93. </head>
  94. <body style="background: #F8F9FA;overflow:scroll;overflow-y: hidden;overflow-x: hidden;">
  95. <div style="width: 100%;height: 100%;" id="homeapp">
  96. <!-- Swiper -->
  97. <div class="newhelp" style="z-index: 50;">
  98. <div class="helpImg">
  99. <img src="../static/img/bangzu_icon.png" />
  100. </div>
  101. <div class="font helpfont">使用帮助?</div>
  102. </div>
  103. <div class="buyIcon" style="z-index: 50;">
  104. <img src="../static/img/goumai_icon.png" />
  105. </div>
  106. <div class="swiper-container">
  107. <div class="swiper-wrapper">
  108. <div class="swiper-slide" v-for="(item,index) in homeList" :key="item.id"
  109. :class="[index==0 ? 'swiper-slide-active' : '' , index==1 ? 'swiper-slide-next' : '']">
  110. <div class="canvas" style="z-index: 1;">
  111. <!-- <div style="height: 100%;" class="wine" :id="'wine'+index"></div> -->
  112. <!-- <canvas :id="'playCanvas'+index" width="450" height="800"></canvas> -->
  113. <!-- <video width="100%" height="100%" style="border-radius: 1.25rem;object-fit: fill;"
  114. disablePictureInPicture="true" autoplay poster="images/loader-thumb.jpg"
  115. :id="'player'+index"></video>
  116. <audio width="100 %" preload="auto" autoplay controls poster="images/loader-thumb.jpg"
  117. :id="'audioPlayer'+index"></audio> -->
  118. <img src="img/homebg.png" class="homebg" @click="homeinfo(item)" />
  119. <div class="camvas-head" style="z-index: 5555;">
  120. <div class="tophead">
  121. <div class="th_left">
  122. <!-- {{item.buyVipType}} -->
  123. <img src="../static/img/xingyao_icon.png" v-if="item.buyVipType==='SVIP'" />
  124. <img src="../static/img/xingdong_icon.png" v-else />
  125. </div>
  126. <div class="th_right">
  127. <div class="thl-font">{{item.diskName}}</div>
  128. <div class="thl-time">{{remainTime(item.ctime,item.exceptTime)}}</div>
  129. </div>
  130. </div>
  131. <div class="th_renew homeRenew" style="z-index: 5000;" @click="renew(item)">
  132. 续费
  133. </div>
  134. </div>
  135. </div>
  136. </div>
  137. <div class="swiper-slide">
  138. <div class="canvas" style="display: none;">
  139. <div style="height: 100%;" class="kongWine">
  140. <div class="kphone">
  141. <div class="kp_img">
  142. <img src="../static/img/goumai_pic.png" />
  143. </div>
  144. <div class="kp_btn" style="z-index: 5000;">
  145. 购买云手机
  146. </div>
  147. </div>
  148. </div>
  149. </div>
  150. </div>
  151. </div>
  152. <!-- Add Arrows -->
  153. <div class="swiper-button-next" @click="swiperNext()"></div>
  154. <div class="swiper-button-prev" @click="swiperPrev()"></div>
  155. </div>
  156. <!-- 没登录状态 -->
  157. <div class="canvasfalse" style="display: none;">
  158. <div class="notLoggedin">
  159. <image src="../static/img/tianjiashouji_pic.png"></image>
  160. </div>
  161. <!-- 审核-->
  162. <div id="showsuss">
  163. <div class="notLoggedin-text">
  164. <div>下载云手机</div>
  165. <div>体验更多功能</div>
  166. </div>
  167. <div class="notLoggedin-bt">
  168. 立即下载
  169. </div>
  170. </div>
  171. </div>
  172. <div class="maxs" style="display: none;">
  173. <div class="mainbox" style="display: none;">
  174. <div class="boxTitle">提示</div>
  175. <div class="boxText">
  176. <div>由于小程序的功能限制,此功能暂时</div>
  177. <div>无法使用,请下载APP使用更多功能</div>
  178. </div>
  179. <!--<div class="boxbt" onclick="cp(document.getElementById('user_ref_id'));">立即前往下载</div>-->
  180. <div class="boxbt" onclick="cp(document.getElementById('user_ref_id'));">立即前往下载</div>
  181. <div class="boximg"><img src="../static/img/wx/guanbi_icon.png"></div>
  182. </div>
  183. </div>
  184. <div class="wxTips">
  185. 云手机数量不足,请稍后再试
  186. </div>
  187. </div>
  188. <div id="copy-txt" style="position: absolute;opacity: 0;">
  189. <span id="user_ref_id">www.androidsCloud.com</span>
  190. </div>
  191. <script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.0.js"></script>
  192. <!-- 视频-->
  193. <script src="../static/js/jquery-1.11.0.min.js"></script>
  194. <!-- <script type="text/javascript" src="../static/js/Decoder.js"></script>
  195. <script type="text/javascript" src="../static/js/YUVCanvas.js"></script>
  196. <script type="text/javascript" src="../static/js/Player.js"></script> -->
  197. <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  198. <!-- <script type="text/javascript" src="helper.js"></script>
  199. <script type="text/javascript" src="pcm-player.js"></script>
  200. <script type="text/javascript" src="webgl.js"></script> -->
  201. <!-- <script src="helper.js"></script> -->
  202. <!-- <script type="text/javascript" src="jmuxer.js"></script> -->
  203. <script src="https://cdn.bootcss.com/vConsole/3.2.0/vconsole.min.js"></script>
  204. <script type="text/javascript">
  205. var u = navigator.userAgent;
  206. var html = document.querySelector("html");
  207. var clientWidth = html.getBoundingClientRect().width;
  208. var clientheight = window.innerHeight;
  209. html.style.fontSize = clientWidth / 23.4375 + "px";
  210. //Android终端
  211. var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1;
  212. //iOS终端
  213. var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);
  214. if (isAndroid) {
  215. //如果为Android
  216. const ch = (20 * clientWidth) / clientheight
  217. console.log("长和宽", clientWidth, clientheight)
  218. $('.swiper-slide').css("padding", `20% ${ch}%`)
  219. }
  220. if (isiOS) {
  221. //如果为iOS
  222. const ch = (20 * clientWidth) / clientheight
  223. console.log("长和宽", clientWidth, clientheight)
  224. $('.swiper-slide').css("padding", `20% ${ch}%`)
  225. }
  226. // const ch = (20 * clientWidth) / clientheight
  227. // console.log("长和宽", clientWidth, clientheight)
  228. var app = new Vue({
  229. el: '#homeapp',
  230. data: {
  231. message: 'Hello Vue!',
  232. homeList: [],
  233. urlData: {},
  234. rbdData: {},
  235. activeIndexData: "",
  236. swipeDirection: "",
  237. },
  238. mounted() {
  239. // var jmuxer = new JMuxer({
  240. // node: 'player',
  241. // flushingTime: 15,
  242. // fps: 30,
  243. // mode: 'video',
  244. // debug: false
  245. // });
  246. // var audioMuxer = new JMuxer({
  247. // node: 'audioPlayer',
  248. // flushingTime: 15,
  249. // clearBuffer: true,
  250. // fps: 60, //可以不选,原先43
  251. // mode: 'audio',
  252. // debug: false
  253. // });
  254. // //初始化一下就可以了,
  255. let vConsole = new VConsole();
  256. // //你打印的数据 比如
  257. console.log('test');
  258. //就可像小程序一样的看了和调试了。
  259. this.$nextTick(function() {
  260. this.gethomeList();
  261. });
  262. var that = this;
  263. var swiper = new Swiper('.swiper-container', {
  264. observer: true, //修改swiper自己或子元素时,自动初始化swiper
  265. observeParents: true, //修改swiper的父元素时,自动初始化swiper
  266. navigation: {
  267. nextEl: '.swiper-button-next',
  268. prevEl: '.swiper-button-prev',
  269. },
  270. on: {
  271. touchEnd: function(event) {
  272. console.log('触摸停止');
  273. console.log(swiper.swipeDirection);
  274. this.swipeDirection = swiper.swipeDirection;
  275. },
  276. transitionStart: function() {
  277. console.log("transitionStart", this.activeIndex)
  278. this.activeIndexData = this.activeIndex;
  279. },
  280. slideChangeTransitionStart: function() {
  281. console.log("slideChangeTransitionStart", this.activeIndex)
  282. this.activeIndexData = this.activeIndex;
  283. },
  284. slideChangeTransitionEnd: function() {
  285. console.log("slideChangeTransitionEnd", this.activeIndex)
  286. this.activeIndexData = this.activeIndex;
  287. if (this.swipeDirection == "next") {
  288. that.getSwiperInfo("nextSlide");
  289. } else if (this.swipeDirection == "prev") {
  290. that.getSwiperInfo("prevSlide");
  291. }
  292. },
  293. // slideChangeStart: function() {
  294. // alert(this.activeIndext);
  295. // },
  296. // slideChangeEnd: function() {
  297. // console.log("下标啊", this)
  298. // },
  299. // ransitionStart: function(activeIndex) {
  300. // console.log("下标啊", this, activeIndex)
  301. // },
  302. // slideChangeEnd: function(swiperHere) {
  303. // var txt = $('.swiper-slide-active').html();
  304. // console.log("打印索引值", txt)
  305. // }
  306. }
  307. });
  308. },
  309. methods: {
  310. homeinfo(data) {
  311. console.log("打印数据", data, this.urlData)
  312. if (this.urlData.status === 0) {
  313. console.log("打印数据", data, this.urlData.data.sn)
  314. wx.miniProgram.navigateTo({
  315. url: '/pages/trialInterface/trialInterface?record=' + data.id + '&sn=' + this
  316. .urlData.data.sn,
  317. })
  318. } else {
  319. $(".wxTips").show()
  320. $('.wxTips').delay(2000).hide(0);
  321. // wx.miniProgram.showToast({
  322. // title: this.urlData.msg,
  323. // icon: "none",
  324. // duration: 500,
  325. // });
  326. }
  327. },
  328. renew(data) {
  329. console.log("续费啊", data);
  330. wx.miniProgram.navigateTo({
  331. url: '/pages/order/renew/index?record=' + data.id,
  332. })
  333. },
  334. remainTime(ctime, exceptTime) {
  335. var date1 = ctime;
  336. var date2 = exceptTime; //结束时间
  337. var date3 = new Date(date2.replace(/-/g, '/')).getTime() - new Date(date1.replace(/-/g, '/'))
  338. .getTime(); //时间差的毫秒数
  339. console.log("时间戳===========》", date3)
  340. //------------------------------
  341. var tmiss = ''
  342. //计算出相差天数
  343. var days = Math.floor(date3 / (24 * 3600 * 1000))
  344. // console.log(days + "天");
  345. //计算出小时数
  346. var leave1 = date3 % (24 * 3600 * 1000) //计算天数后剩余的毫秒数
  347. var hours = Math.floor(leave1 / (3600 * 1000))
  348. //计算相差分钟数
  349. var leave2 = leave1 % (3600 * 1000) //计算小时数后剩余的毫秒数
  350. var minutes = Math.floor(leave2 / (60 * 1000))
  351. //计算相差秒数
  352. var leave3 = leave2 % (60 * 1000) //计算分钟数后剩余的毫秒数
  353. var seconds = Math.round(leave3 / 1000)
  354. var times = ""
  355. if (Number(days) == 0) {
  356. // console.log(hours + "小时" + minutes + "分")
  357. tmiss = Number(hours) + "小时" + Number(minutes) + "分"
  358. } else {
  359. if (Number(hours) == 0 && Number(minutes) == 0) {
  360. // console.log(days + "天")
  361. tmiss = Number(days) + "天"
  362. } else {
  363. // console.log(days + "天" + hours + "小时 ")
  364. tmiss = Number(days) + "天" + Number(hours) + "小时 "
  365. }
  366. }
  367. // console.log("tmiss>>>>>>", tmiss);
  368. return tmiss
  369. },
  370. swiperNext(data) {
  371. this.getSwiperInfo("next");
  372. },
  373. swiperPrev() {
  374. this.getSwiperInfo("prev");
  375. },
  376. getSwiperInfo(data) {
  377. console.log("方向=======", data, $('.swiper-slide-active').index());
  378. // return
  379. if (data == "next") {
  380. var activeIndex = $('.swiper-slide-active').index() + 1;
  381. } else if (data == "prev") {
  382. var activeIndex = $('.swiper-slide-active').index() - 1;
  383. } else if (data == "prevSlide") {
  384. var activeIndex = $('.swiper-slide-active').index();
  385. } else if (data == "nextSlide") {
  386. var activeIndex = $('.swiper-slide-active').index();
  387. }
  388. var ids = "#wine" + $('.swiper-slide-active').index();
  389. var domprev = $(ids);
  390. console.log("下标id======", activeIndex);
  391. domprev.empty();
  392. // var baseUrl = "http://192.168.31.20";
  393. var baseUrl = "http://192.168.199.243";
  394. var urlss = 'test.androidscloud.com'
  395. let that = this;
  396. let rbdData = {
  397. "userCardId": that.homeList[activeIndex].id,
  398. "deviceStatus": 1,
  399. };
  400. // setTimeout(() => {
  401. $.ajax({
  402. url: baseUrl + "/api/storage/v1/cardStatus/getRbd/restart",
  403. data: JSON.stringify(rbdData),
  404. type: 'post',
  405. dataType: 'json',
  406. // async: false,
  407. contentType: "application/json;charset=UTF-8",
  408. headers: {
  409. 'token': tokens.substring(6, tokens.length),
  410. "Authorization": tokens.substring(6, tokens.length)
  411. },
  412. success: function(data) {
  413. that.urlData = data;
  414. console.log("挂载安卓卡成功", that.urlData);
  415. //
  416. }
  417. })
  418. // var fpsCount = 0;
  419. // var requestCount = 0;
  420. // var timeCount = 0;
  421. // var isVisuable = true;
  422. // var isFeed = true;
  423. // var isDrag = false;
  424. // var shoudDrop = false;
  425. // var isEnough = true;
  426. // var ifCanPlay = false;
  427. // var isFinish = false;
  428. // var delayTime = new Date().getTime();
  429. // var feedTime = new Date().getTime();
  430. // var readyTime = new Date().getTime();
  431. // var requestTime = new Date().getTime();
  432. // var curTime = new Date().getTime();
  433. // var requestTime = new Date().getTime(); //记录离开时间
  434. // var playerid = 'player' + activeIndex;
  435. // var audioPlayerid = 'audioPlayer' + activeIndex;
  436. // var myVideo = document.getElementById(playerid);
  437. // var myAudio = document.getElementById(audioPlayerid);
  438. // var audioBuffer = [];
  439. // var audioBack = [];
  440. // Module = {};
  441. // Module.onRuntimeInitialized = function() {
  442. // console.log("Wasm 加载成功!")
  443. // isFinish = true;
  444. // }
  445. // document.addEventListener("visibilitychange", () => {
  446. // if (document.visibilityState == "visible") {
  447. // console.log("页面可见,继续喂视频");
  448. // //requestTime = new Date().getTime();
  449. // isVisuable = true;
  450. // } else {
  451. // isVisuable = false;
  452. // isFeed = false;
  453. // myVideo.pause();
  454. // }
  455. // });
  456. // myVideo.play();
  457. // myVideo.addEventListener('pause', function() {
  458. // //console.log("视频播放暂停");
  459. // isFeed = false;
  460. // });
  461. // myAudio.addEventListener('canplay', function() {
  462. // console.log("缓冲区大小 %f", myAudio.buffered.end(0) - myAudio.buffered.start(0));
  463. // });
  464. // // var socketURL = "ws://192.168.11.66:9101";
  465. // var socketURL = "ws://192.168.198.11:9101"
  466. // // socketURL = "ws://14.215.128.98:14077";
  467. // //socketURL = "wss://192.168.11.242:9104";
  468. // var jmuxer = new JMuxer({
  469. // node: playerid,
  470. // flushingTime: 15,
  471. // fps: 30,
  472. // mode: 'video',
  473. // debug: false
  474. // });
  475. // var audioMuxer = new JMuxer({
  476. // node: audioPlayerid,
  477. // flushingTime: 15,
  478. // clearBuffer: true,
  479. // fps: 60, //可以不选,原先43
  480. // mode: 'audio',
  481. // debug: false
  482. // });
  483. // curTime = new Date().getTime();
  484. // var ws = new WebSocket(socketURL);
  485. // ws.binaryType = 'arraybuffer';
  486. // //断开检测
  487. // ws.onclose = function(e) {
  488. // alert("websocket连接断开");
  489. // console.log('websocket 断开: ' + e.code + ' ' + e.reason + ' ' + e.wasClean);
  490. // console.log(e);
  491. // }
  492. // ws.addEventListener('open', function(event) {
  493. // console.log("发送配置帧");
  494. // // ws.send(ConfigChannel("RK3923C1201900139"));
  495. // });
  496. // ws.addEventListener('error', function(event) {
  497. // console.log("连接失败");
  498. // });
  499. // ws.addEventListener('message', function(event) {
  500. // var data = that.ParseProto(event.data); //JAVA服务器转发
  501. // //console.log("收到数据");
  502. // var audioData = {
  503. // audio: data.audio,
  504. // video: null,
  505. // duration: data.duration
  506. // };
  507. // var videoData = {
  508. // audio: null,
  509. // video: data.video,
  510. // duration: data.duration
  511. // };
  512. // if (myAudio.readyState == 2) {
  513. // requestTime = new Date().getTime();
  514. // isEnough = false;
  515. // console.log("数据存储不够,出现声音停止,时间差 %f", myAudio.buffered.end(0));
  516. // myAudio.pause();
  517. // //myAudio.playbackRate = 2;
  518. // } else if (myAudio.readyState == 4 && isEnough == false) {
  519. // myAudio.play();
  520. // var time = new Date().getTime();
  521. // isEnough = true;
  522. // console.log("填满耗时 %d ms, 填充帧数 %d, 填充延迟 %d ms", time - requestTime, requestCount,
  523. // requestCount * 23);
  524. // console.log("----接收到启动 %d ms, 缓冲区 %f---", time - delayTime, myAudio.buffered.end(
  525. // 0) - myAudio.played
  526. // .end(0));
  527. // }
  528. // if (data.audio != null) //喂音频
  529. // {
  530. // if (myAudio.buffered.length > 0 && myAudio.played.length > 0) {
  531. // var bufferTime = myAudio.buffered.end(0) - myAudio.played.end(0);
  532. // //console.log(" bufferTime %d", bufferTime);
  533. // if (bufferTime > 1) {
  534. // //console.log("丢掉一些包");
  535. // //return;
  536. // }
  537. // }
  538. // audioMuxer.feed(audioData);
  539. // }
  540. // if (data.video != null) //喂视频
  541. // {
  542. // if (isFeed) {
  543. // jmuxer.feed(data);
  544. // }
  545. // //jmuxer.feed(videoData);
  546. // }
  547. // });
  548. // myVideo.onmousedown = function(event) {
  549. // //放在此处只是为了方便演示,实际使用中查找横竖屏只要刚连接上时调用一次就好。
  550. // //var checkBuffer = GetScreenState();
  551. // //ws.send(checkBuffer);
  552. // if (!isFeed) {
  553. // console.log("重新申请I帧");
  554. // requestTime = new Date().getTime();
  555. // var buffer = RequestIFrame();
  556. // //var buffer = new Uint8Array([0x01]);
  557. // ws.send(buffer);
  558. // }
  559. // //console.log("报文 %s", PrintArry(buffer));
  560. // if (event.button == 0) {
  561. // var posX = event.offsetX * 1080 * 1.0 / myVideo.clientWidth;
  562. // var posY = event.offsetY * 1920 * 1.0 / myVideo.clientHeight;
  563. // var buffer = ExexuteMouseDown(posX.toString(), posY.toString());
  564. // ws.send(buffer);
  565. // isDrag = true;
  566. // }
  567. // }
  568. // myVideo.onmousemove = function(event) {
  569. // if (isDrag && event.button == 0) {
  570. // var posX = event.offsetX * 1080 * 1.0 / myVideo.clientWidth;
  571. // var posY = event.offsetY * 1920 * 1.0 / myVideo.clientHeight;
  572. // var buffer = ExexuteMouseMove(posX.toString(), posY.toString());
  573. // ws.send(buffer);
  574. // //console.log("移动位置 %d, %d", posX, posY);
  575. // }
  576. // }
  577. // myVideo.onmouseup = function(event) {
  578. // isDrag = false;
  579. // var posX = event.offsetX * 1080 * 1.0 / myVideo.clientWidth;
  580. // var posY = event.offsetY * 1920 * 1.0 / myVideo.clientHeight;
  581. // var buffer = ExexuteMouseUp(posX.toString(), posY.toString());
  582. // ws.send(buffer);
  583. // }
  584. // myVideo.onkeydown = function(event) {
  585. // ExexuteKeyDown(e.keyCode);
  586. // }
  587. },
  588. //解协议
  589. ParseProto(data) {
  590. //隐藏控件 controls
  591. var fpsCount = 0;
  592. var requestCount = 0;
  593. var timeCount = 0;
  594. var isVisuable = true;
  595. var isFeed = true;
  596. var isDrag = false;
  597. var shoudDrop = false;
  598. var isEnough = true;
  599. var ifCanPlay = false;
  600. var isFinish = false;
  601. var delayTime = new Date().getTime();
  602. var feedTime = new Date().getTime();
  603. var readyTime = new Date().getTime();
  604. var requestTime = new Date().getTime();
  605. var curTime = new Date().getTime();
  606. var requestTime = new Date().getTime(); //记录离开时间
  607. var temp = "";
  608. var input = new Uint8Array(data),
  609. duration,
  610. video,
  611. audio;
  612. if (input[0] == 0 && input[1] == 0 && input[2] == 0 && input[3] == 1) {
  613. // debugger
  614. video = input;
  615. duration = 24;
  616. var nalType = input[4] & 0x1f; //nalType == 0x07|| nalType == 0x08 || nalType == 0x05
  617. if (!isFeed) {
  618. if (nalType == 0x05) {
  619. console.log("发现I帧");
  620. }
  621. if (nalType == 0x05 && isVisuable) {
  622. console.log("检测到I帧 %d,重新渲染, 耗时 %d ms", nalType, new Date().getTime() - requestTime);
  623. isFeed = true;
  624. }
  625. }
  626. } else if (input[0] == 0xff) {
  627. if (!isEnough) {
  628. requestCount++;
  629. //audioBuffer.push(input);
  630. }
  631. audio = input;
  632. if (new Date().getTime() - curTime > 100) {
  633. delayTime = new Date().getTime();
  634. console.log("接收时间 %d ms", new Date().getTime() - curTime);
  635. }
  636. curTime = new Date().getTime();
  637. duration = 24;
  638. //console.log("duration %d", duration);
  639. } else if (input[0] == 0x68) {
  640. if (input[23] == 0x05) //横竖屏标识
  641. {
  642. var state = CheckScreenDirection(input.slice(24, 24 + 8));
  643. if (state == 1) {
  644. console.log("安卓卡此时竖屏");
  645. //竖屏处理
  646. } else {
  647. console.log("安卓卡此时横屏");
  648. //横屏处理
  649. }
  650. }
  651. if (input[23] == 0x0b) {
  652. console.log("多端登陆");
  653. }
  654. //console.log("屏幕旋转 %s", PrintArry(input));
  655. }
  656. return {
  657. audio: audio,
  658. video: video,
  659. duration: duration
  660. };
  661. },
  662. gethomeList() {
  663. var baseUrl = 'http://192.168.199.243';
  664. // var baseUrl = "http://192.168.31.20";
  665. var query = window.location.search.substring(1);
  666. var vars = query.split("&");
  667. var tokens = vars.find(e => {
  668. return e.startsWith('token')
  669. }) || ''
  670. var data = {}
  671. var clientType = vars.find(e => {
  672. return e.startsWith('clientType')
  673. }) || ''
  674. var cardIp = vars.find(e => {
  675. return e.startsWith('cardIp')
  676. }) || ''
  677. var port = vars.find(e => {
  678. return e.startsWith('port')
  679. }) || ''
  680. var sn = vars.find(e => {
  681. return e.startsWith('sn')
  682. }) || ''
  683. var demoTime = vars.find(e => {
  684. return e.startsWith('demoTime')
  685. }) || ''
  686. var id = vars.find(e => {
  687. return e.startsWith('id')
  688. }) || ''
  689. var vip = vars.find(e => {
  690. return e.startsWith('vip')
  691. }) || ''
  692. var diskName = vars.find(e => {
  693. return e.startsWith('diskName')
  694. }) || ''
  695. var times = vars.find(e => {
  696. return e.startsWith('times')
  697. }) || ''
  698. var username = vars.find(e => {
  699. return e.startsWith('username')
  700. }) || ''
  701. var userCardId = vars.find(e => {
  702. return e.startsWith('userCardId')
  703. }) || ''
  704. var ip = vars.find(e => {
  705. return e.startsWith('ip')
  706. }) || ''
  707. var windowHeight = vars.find(e => {
  708. return e.startsWith('windowHeight')
  709. }) || ''
  710. var tokens = vars.find(e => {
  711. return e.startsWith('token')
  712. }) || ''
  713. data.clientType = clientType.substring(11, clientType.length)
  714. data.cardIp = cardIp.substring(7, cardIp.length)
  715. data.port = port.substring(5, port.length)
  716. data.sn = sn.substring(3, sn.length)
  717. data.demoTime = demoTime.substring(9, demoTime.length)
  718. data.id = id.substring(3, id.length)
  719. data.vip = vip.substring(4, vip.length)
  720. data.diskName = diskName.substring(9, diskName.length)
  721. data.times = times.substring(6, times.length)
  722. data.username = username.substring(9, username.length)
  723. data.userCardId = userCardId.substring(11, userCardId.length)
  724. data.ip = ip.substring(3, ip.length)
  725. console.log("data====", data);
  726. this.urlData = data;
  727. let that = this;
  728. $.ajax({
  729. url: baseUrl + "/api/user/v1/client/disk/info",
  730. data: {},
  731. type: 'get',
  732. dataType: 'json',
  733. headers: {
  734. 'token': tokens.substring(6, tokens.length),
  735. "Authorization": tokens.substring(6, tokens.length)
  736. },
  737. success: function(data) {
  738. console.log("云手机信息=======", data);
  739. if (data.data) {
  740. that.homeList = data.data.diskInfo;
  741. console.log("云手机this.homeListthis.homeListthis.homeList=======", that
  742. .homeList);
  743. var urlss = 'test.androidscloud.com'
  744. let rbdData = {
  745. "userCardId": that.homeList[0].id,
  746. "deviceStatus": 1,
  747. };
  748. let activeIndex = $('.swiper-slide-active').index();
  749. // let that = this;
  750. setTimeout(() => {
  751. $.ajax({
  752. url: baseUrl +
  753. "/api/storage/v1/cardStatus/getRbd/restart",
  754. data: JSON.stringify(rbdData),
  755. // data:rbdData,
  756. type: 'post',
  757. dataType: 'json',
  758. contentType: "application/json;charset=UTF-8",
  759. async: false,
  760. headers: {
  761. 'token': tokens.substring(6, tokens.length),
  762. "Authorization": tokens.substring(6, tokens
  763. .length)
  764. },
  765. success: function(data) {
  766. that.urlData = data;
  767. console.log("挂载安卓卡成功", that.urlData);
  768. //
  769. }
  770. })
  771. console.log(
  772. "that.urlDatathat.urlDatathat.urlDatathat.urlData",
  773. that.urlData);
  774. //隐藏控件 controls
  775. // var fpsCount = 0;
  776. // var requestCount = 0;
  777. // var timeCount = 0;
  778. // var isVisuable = true;
  779. // var isFeed = true;
  780. // var isDrag = false;
  781. // var shoudDrop = false;
  782. // var isEnough = true;
  783. // var ifCanPlay = false;
  784. // var isFinish = false;
  785. // var delayTime = new Date().getTime();
  786. // var feedTime = new Date().getTime();
  787. // var readyTime = new Date().getTime();
  788. // var requestTime = new Date().getTime();
  789. // var curTime = new Date().getTime();
  790. // var requestTime = new Date().getTime(); //记录离开时间
  791. // var playerid = 'player' + activeIndex;
  792. // var audioPlayerid = 'audioPlayer' + activeIndex;
  793. // var myVideo = document.getElementById(playerid);
  794. // var myAudio = document.getElementById(audioPlayerid);
  795. // var audioBuffer = [];
  796. // var audioBack = [];
  797. // Module = {};
  798. // Module.onRuntimeInitialized = function() {
  799. // console.log("Wasm 加载成功!")
  800. // isFinish = true;
  801. // }
  802. // document.addEventListener("visibilitychange", () => {
  803. // if (document.visibilityState == "visible") {
  804. // console.log("页面可见,继续喂视频");
  805. // //requestTime = new Date().getTime();
  806. // isVisuable = true;
  807. // } else {
  808. // isVisuable = false;
  809. // isFeed = false;
  810. // myVideo.pause();
  811. // }
  812. // });
  813. // myVideo.play();
  814. // myVideo.addEventListener('pause', function() {
  815. // //console.log("视频播放暂停");
  816. // isFeed = false;
  817. // });
  818. // myAudio.addEventListener('canplay', function() {
  819. // console.log("缓冲区大小 %f", myAudio.buffered.end(0) -
  820. // myAudio.buffered.start(0));
  821. // });
  822. // // var socketURL = "ws://192.168.11.66:9101";
  823. // var socketURL = "ws://192.168.198.11:9101"
  824. // // socketURL = "ws://14.215.128.98:14077";
  825. // //socketURL = "wss://192.168.11.242:9104";
  826. // var jmuxer = new JMuxer({
  827. // node: playerid,
  828. // flushingTime: 15,
  829. // fps: 30,
  830. // mode: 'video',
  831. // debug: false
  832. // });
  833. // var audioMuxer = new JMuxer({
  834. // node: audioPlayerid,
  835. // flushingTime: 15,
  836. // clearBuffer: true,
  837. // fps: 60, //可以不选,原先43
  838. // mode: 'audio',
  839. // debug: false
  840. // });
  841. // curTime = new Date().getTime();
  842. // var ws = new WebSocket(socketURL);
  843. // ws.binaryType = 'arraybuffer';
  844. // //断开检测
  845. // ws.onclose = function(e) {
  846. // alert("websocket连接断开");
  847. // console.log('websocket 断开: ' + e.code + ' ' + e
  848. // .reason + ' ' + e.wasClean);
  849. // console.log(e);
  850. // }
  851. // ws.addEventListener('open', function(event) {
  852. // console.log("发送配置帧");
  853. // // ws.send(ConfigChannel("RK3923C1201900139"));
  854. // });
  855. // ws.addEventListener('error', function(event) {
  856. // console.log("连接失败");
  857. // });
  858. // ws.addEventListener('message', function(event) {
  859. // var data = that.ParseProto(event
  860. // .data); //JAVA服务器转发
  861. // //console.log("收到数据");
  862. // var audioData = {
  863. // audio: data.audio,
  864. // video: null,
  865. // duration: data.duration
  866. // };
  867. // var videoData = {
  868. // audio: null,
  869. // video: data.video,
  870. // duration: data.duration
  871. // };
  872. // if (myAudio.readyState == 2) {
  873. // requestTime = new Date().getTime();
  874. // isEnough = false;
  875. // console.log("数据存储不够,出现声音停止,时间差 %f", myAudio
  876. // .buffered.end(0));
  877. // myAudio.pause();
  878. // //myAudio.playbackRate = 2;
  879. // } else if (myAudio.readyState == 4 && isEnough ==
  880. // false) {
  881. // myAudio.play();
  882. // var time = new Date().getTime();
  883. // isEnough = true;
  884. // console.log(
  885. // "填满耗时 %d ms, 填充帧数 %d, 填充延迟 %d ms",
  886. // time - requestTime, requestCount,
  887. // requestCount * 23);
  888. // console.log("----接收到启动 %d ms, 缓冲区 %f---",
  889. // time - delayTime, myAudio.buffered
  890. // .end(0) - myAudio.played
  891. // .end(0));
  892. // }
  893. // if (data.audio != null) //喂音频
  894. // {
  895. // if (myAudio.buffered.length > 0 && myAudio
  896. // .played.length > 0) {
  897. // var bufferTime = myAudio.buffered.end(
  898. // 0) - myAudio.played.end(0);
  899. // //console.log(" bufferTime %d", bufferTime);
  900. // if (bufferTime > 1) {
  901. // //console.log("丢掉一些包");
  902. // //return;
  903. // }
  904. // }
  905. // audioMuxer.feed(audioData);
  906. // }
  907. // if (data.video != null) //喂视频
  908. // {
  909. // if (isFeed) {
  910. // jmuxer.feed(data);
  911. // }
  912. // //jmuxer.feed(videoData);
  913. // }
  914. // });
  915. // myVideo.onmousedown = function(event) {
  916. // //放在此处只是为了方便演示,实际使用中查找横竖屏只要刚连接上时调用一次就好。
  917. // //var checkBuffer = GetScreenState();
  918. // //ws.send(checkBuffer);
  919. // if (!isFeed) {
  920. // console.log("重新申请I帧");
  921. // requestTime = new Date().getTime();
  922. // var buffer = RequestIFrame();
  923. // //var buffer = new Uint8Array([0x01]);
  924. // ws.send(buffer);
  925. // }
  926. // //console.log("报文 %s", PrintArry(buffer));
  927. // if (event.button == 0) {
  928. // var posX = event.offsetX * 1080 * 1.0 / myVideo
  929. // .clientWidth;
  930. // var posY = event.offsetY * 1920 * 1.0 / myVideo
  931. // .clientHeight;
  932. // var buffer = ExexuteMouseDown(posX.toString(),
  933. // posY.toString());
  934. // ws.send(buffer);
  935. // isDrag = true;
  936. // }
  937. // }
  938. // myVideo.onmousemove = function(event) {
  939. // if (isDrag && event.button == 0) {
  940. // var posX = event.offsetX * 1080 * 1.0 / myVideo
  941. // .clientWidth;
  942. // var posY = event.offsetY * 1920 * 1.0 / myVideo
  943. // .clientHeight;
  944. // var buffer = ExexuteMouseMove(posX.toString(),
  945. // posY.toString());
  946. // ws.send(buffer);
  947. // //console.log("移动位置 %d, %d", posX, posY);
  948. // }
  949. // }
  950. // myVideo.onmouseup = function(event) {
  951. // isDrag = false;
  952. // var posX = event.offsetX * 1080 * 1.0 / myVideo
  953. // .clientWidth;
  954. // var posY = event.offsetY * 1920 * 1.0 / myVideo
  955. // .clientHeight;
  956. // var buffer = ExexuteMouseUp(posX.toString(), posY
  957. // .toString());
  958. // ws.send(buffer);
  959. // }
  960. // myVideo.onkeydown = function(event) {
  961. // ExexuteKeyDown(e.keyCode);
  962. // }
  963. }, 1)
  964. } else {
  965. }
  966. //
  967. }
  968. })
  969. }
  970. }
  971. })
  972. var homeList = []; //云手机列表信息
  973. var url = window.location.href;
  974. url = url.split('/')
  975. console.log(url)
  976. // var baseUrl = 'https://' + url[2] //'http://192.168.31.159'//'http://' + url[2]
  977. // var baseUrl = 'http://192.168.31.20'
  978. var baseUrl = 'http://192.168.199.243';
  979. var query = window.location.search.substring(1);
  980. var vars = query.split("&");
  981. // var urls = "https://xcx.androidscloud.com"
  982. // 审核
  983. $.ajax({
  984. url: baseUrl + "/api/user/v1/config/download/isShow",
  985. data: {},
  986. type: 'get',
  987. dataType: 'json',
  988. contentType: "application/json;charset=UTF-8",
  989. success: function(data) {
  990. if (data.data) {
  991. $("#showsuss").show()
  992. } else {
  993. $("#showsuss").hide()
  994. }
  995. //
  996. }
  997. })
  998. // var baseUrl = window.location.href; //"http://192.168.31.20"
  999. document.body.addEventListener('touchmove', function(e) {
  1000. e.preventDefault()
  1001. }, {
  1002. passive: false
  1003. })
  1004. var data = {}
  1005. var clientType = vars.find(e => {
  1006. return e.startsWith('clientType')
  1007. }) || ''
  1008. var cardIp = vars.find(e => {
  1009. return e.startsWith('cardIp')
  1010. }) || ''
  1011. var port = vars.find(e => {
  1012. return e.startsWith('port')
  1013. }) || ''
  1014. var sn = vars.find(e => {
  1015. return e.startsWith('sn')
  1016. }) || ''
  1017. var demoTime = vars.find(e => {
  1018. return e.startsWith('demoTime')
  1019. }) || ''
  1020. var id = vars.find(e => {
  1021. return e.startsWith('id')
  1022. }) || ''
  1023. var vip = vars.find(e => {
  1024. return e.startsWith('vip')
  1025. }) || ''
  1026. var diskName = vars.find(e => {
  1027. return e.startsWith('diskName')
  1028. }) || ''
  1029. var times = vars.find(e => {
  1030. return e.startsWith('times')
  1031. }) || ''
  1032. var username = vars.find(e => {
  1033. return e.startsWith('username')
  1034. }) || ''
  1035. var userCardId = vars.find(e => {
  1036. return e.startsWith('userCardId')
  1037. }) || ''
  1038. var ip = vars.find(e => {
  1039. return e.startsWith('ip')
  1040. }) || ''
  1041. var windowHeight = vars.find(e => {
  1042. return e.startsWith('windowHeight')
  1043. }) || ''
  1044. var tokens = vars.find(e => {
  1045. return e.startsWith('token')
  1046. }) || ''
  1047. $(".swiper-container").css("height", windowHeight.substring(13, windowHeight.length));
  1048. console.log("获取网页高度", windowHeight.substring(13, windowHeight.length));
  1049. // $(".aaa").text(clientType.substring(11, clientType.length))
  1050. // let cardIp = getUrlParam('cardIp');
  1051. // console.log(cardIp)
  1052. $.ajax({
  1053. url: baseUrl + "/api/user/v1/client/disk/info",
  1054. data: {},
  1055. type: 'get',
  1056. dataType: 'json',
  1057. headers: {
  1058. 'token': tokens.substring(6, tokens.length),
  1059. "Authorization": tokens.substring(6, tokens.length)
  1060. },
  1061. success: function(data) {
  1062. console.log("云手机信息=======", data);
  1063. if (data.data) {
  1064. homeList = data.data.diskInfo;
  1065. } else {
  1066. }
  1067. //
  1068. }
  1069. })
  1070. getQueryString: (name) => {
  1071. let reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
  1072. let r = window.location.search.substr(1).match(reg);
  1073. console.log(name)
  1074. if (r != null) {
  1075. return unescape(decodeURI(r[2]));
  1076. return null;
  1077. }
  1078. }
  1079. data.clientType = clientType.substring(11, clientType.length)
  1080. data.cardIp = cardIp.substring(7, cardIp.length)
  1081. data.port = port.substring(5, port.length)
  1082. data.sn = sn.substring(3, sn.length)
  1083. data.demoTime = demoTime.substring(9, demoTime.length)
  1084. data.id = id.substring(3, id.length)
  1085. data.vip = vip.substring(4, vip.length)
  1086. data.diskName = diskName.substring(9, diskName.length)
  1087. data.times = times.substring(6, times.length)
  1088. data.username = username.substring(9, username.length)
  1089. data.userCardId = userCardId.substring(11, userCardId.length)
  1090. data.ip = ip.substring(3, ip.length)
  1091. let timestext = "剩" + decodeURI(data.times) || data.demoTime / 3600 + "小时"
  1092. $(".diskName").text(decodeURI(data.diskName) || data.username)
  1093. console.log("timestext>>>>>>", timestext);
  1094. $(".canvastime").text(timestext)
  1095. if (data.vip == "0") {
  1096. $(".canvasfalse").css({
  1097. "display": "block"
  1098. })
  1099. $(".canvas").css({
  1100. "display": "none"
  1101. })
  1102. } else {
  1103. $(".canvas").css({
  1104. "display": "block"
  1105. })
  1106. $(".canvasfalse").css({
  1107. "display": "none"
  1108. })
  1109. }
  1110. function onMessage(evt) {
  1111. console.log("onMessage==============", evt);
  1112. var messageData = new Uint8Array(evt.data);
  1113. player.decode(messageData);
  1114. }
  1115. $("canvas").on("click", function() {
  1116. client.close()
  1117. // ?clientType=0&cardIp=30.30.30.42&port=9100&sn=RK3930C2301900042&demoTime=3600&id=3
  1118. setTimeout(() => {
  1119. wx.miniProgram.navigateTo({
  1120. url: '/pages/trialInterface/trialInterface?clientType=' + data.clientType +
  1121. "&cardIp=" + data.cardIp +
  1122. "&port=" + data.port + "&sn=" + data.sn + "&username=" + data.username +
  1123. "&userCardId=" + data.userCardId +
  1124. "&demoTime=3600&id=" + data.id + "&diskName=" + decodeURI(data.diskName)
  1125. })
  1126. }, 100);
  1127. })
  1128. $(".helps").click(function() {
  1129. // wx.miniProgram.navigateTo({
  1130. // url: '/pages/viewurl/viewurl'
  1131. // })
  1132. //按点击处理
  1133. var set = $('.helps').attr("data-id")
  1134. if (set == '1') {
  1135. $('.helps').attr({
  1136. "data-id": "2"
  1137. })
  1138. $(".helps").hide();
  1139. $(".help").css({
  1140. "right": "0"
  1141. })
  1142. } else {
  1143. $('.helps').attr({
  1144. "data-id": "1"
  1145. })
  1146. $(".help").css({
  1147. "right": "-4rem"
  1148. })
  1149. }
  1150. });
  1151. function stopPropagation(e) {
  1152. if (e.stopPropagation)
  1153. e.stopPropagation();
  1154. else
  1155. e.cancelBubble = true;
  1156. }
  1157. $(document).bind('click', function() {
  1158. $(".help").css({
  1159. "right": "-4rem"
  1160. })
  1161. $('.helps').attr({
  1162. "data-id": "1"
  1163. })
  1164. $(".helps").show();
  1165. });
  1166. $('.helpfont').bind('click', function(e) {
  1167. console.log("帮助啊啊");
  1168. // stopPropagation(e);
  1169. wx.miniProgram.navigateTo({
  1170. url: '/pages/viewurl/viewurl'
  1171. })
  1172. });
  1173. $('.buyIcon,.kp_btn').bind('click', function(e) {
  1174. console.log("购买");
  1175. // stopPropagation(e);
  1176. wx.miniProgram.navigateTo({
  1177. url: '/pages/order/buy/index'
  1178. })
  1179. });
  1180. // $('.homeRenew').bind('click', function(e) {
  1181. // console.log("续费啊");
  1182. // // stopPropagation(e);
  1183. // wx.miniProgram.navigateTo({
  1184. // url: '/pages/order/buy/index'
  1185. // })
  1186. // });
  1187. $(".homeRenew").on("click", function() {
  1188. console.log("续费啊");
  1189. wx.miniProgram.navigateTo({
  1190. url: '/pages/order/renew/index'
  1191. })
  1192. });
  1193. $('.helps').bind('click', function(e) {
  1194. stopPropagation(e);
  1195. });
  1196. $(".boximg").on("click", function() {
  1197. $(".mainbox").css({
  1198. "display": "none"
  1199. })
  1200. $(".maxs").css({
  1201. "display": "none"
  1202. })
  1203. })
  1204. $(".maxs").on("click", function() {
  1205. $(".mainbox").css({
  1206. "display": "none"
  1207. })
  1208. $(".maxs").css({
  1209. "display": "none"
  1210. })
  1211. })
  1212. $(".addto").on("click", function() {
  1213. $(".mainbox").css({
  1214. "display": "block"
  1215. })
  1216. $(".maxs").css({
  1217. "display": "block"
  1218. })
  1219. })
  1220. $(".notLoggedin-bt").on("click", function() {
  1221. // $(".mainbox").css({
  1222. // "display": "block"
  1223. // })
  1224. // $(".maxs").css({
  1225. // "display": "block"
  1226. // })
  1227. })
  1228. function selectText(x) {
  1229. if (document.selection) {
  1230. var range = document.body.createTextRange();
  1231. range.moveToElementText(x);
  1232. range.select();
  1233. } else if (window.getSelection) {
  1234. var selection = window.getSelection();
  1235. var range = document.createRange();
  1236. selection.removeAllRanges();
  1237. range.selectNodeContents(x);
  1238. selection.addRange(range);
  1239. }
  1240. }
  1241. function cp(x) {
  1242. $(".mainbox").css({
  1243. "display": "none"
  1244. })
  1245. $(".sbox").css({
  1246. "display": "block"
  1247. })
  1248. selectText(x);
  1249. document.execCommand("copy");
  1250. alert("复制成功")
  1251. }
  1252. </script>
  1253. <script>
  1254. //隐藏控件 controls
  1255. // var fpsCount = 0;
  1256. // var requestCount = 0;
  1257. // var timeCount = 0;
  1258. // var isVisuable = true;
  1259. // var isFeed = true;
  1260. // var isDrag = false;
  1261. // var shoudDrop = false;
  1262. // var isEnough = true;
  1263. // var ifCanPlay = false;
  1264. // var isFinish = false;
  1265. // var delayTime = new Date().getTime();
  1266. // var feedTime = new Date().getTime();
  1267. // var readyTime = new Date().getTime();
  1268. // var requestTime = new Date().getTime();
  1269. // var curTime = new Date().getTime();
  1270. // var requestTime = new Date().getTime(); //记录离开时间
  1271. // var myVideo = document.getElementById("player");
  1272. // var myAudio = document.getElementById("audioPlayer");
  1273. // var audioBuffer = [];
  1274. // var audioBack = [];
  1275. // Module = {};
  1276. // Module.onRuntimeInitialized = function() {
  1277. // console.log("Wasm 加载成功!")
  1278. // isFinish = true;
  1279. // }
  1280. // document.addEventListener("visibilitychange", () => {
  1281. // if (document.visibilityState == "visible") {
  1282. // console.log("页面可见,继续喂视频");
  1283. // //requestTime = new Date().getTime();
  1284. // isVisuable = true;
  1285. // } else {
  1286. // isVisuable = false;
  1287. // isFeed = false;
  1288. // myVideo.pause();
  1289. // }
  1290. // });
  1291. // myVideo.play();
  1292. // myVideo.addEventListener('pause', function() {
  1293. // //console.log("视频播放暂停");
  1294. // isFeed = false;
  1295. // });
  1296. // myAudio.addEventListener('canplay', function() {
  1297. // console.log("缓冲区大小 %f", myAudio.buffered.end(0) - myAudio.buffered.start(0));
  1298. // });
  1299. // //解协议
  1300. // function ParseProto(data) {
  1301. // var temp = "";
  1302. // var input = new Uint8Array(data),
  1303. // duration,
  1304. // video,
  1305. // audio;
  1306. // if (input[0] == 0 && input[1] == 0 && input[2] == 0 && input[3] == 1) {
  1307. // // debugger
  1308. // video = input;
  1309. // duration = 24;
  1310. // var nalType = input[4] & 0x1f; //nalType == 0x07|| nalType == 0x08 || nalType == 0x05
  1311. // if (!isFeed) {
  1312. // if (nalType == 0x05) {
  1313. // console.log("发现I帧");
  1314. // }
  1315. // if (nalType == 0x05 && isVisuable) {
  1316. // console.log("检测到I帧 %d,重新渲染, 耗时 %d ms", nalType, new Date().getTime() - requestTime);
  1317. // isFeed = true;
  1318. // }
  1319. // }
  1320. // } else if (input[0] == 0xff) {
  1321. // if (!isEnough) {
  1322. // requestCount++;
  1323. // //audioBuffer.push(input);
  1324. // }
  1325. // audio = input;
  1326. // if (new Date().getTime() - curTime > 100) {
  1327. // delayTime = new Date().getTime();
  1328. // console.log("接收时间 %d ms", new Date().getTime() - curTime);
  1329. // }
  1330. // curTime = new Date().getTime();
  1331. // duration = 24;
  1332. // //console.log("duration %d", duration);
  1333. // } else if (input[0] == 0x68) {
  1334. // if (input[23] == 0x05) //横竖屏标识
  1335. // {
  1336. // var state = CheckScreenDirection(input.slice(24, 24 + 8));
  1337. // if (state == 1) {
  1338. // console.log("安卓卡此时竖屏");
  1339. // //竖屏处理
  1340. // } else {
  1341. // console.log("安卓卡此时横屏");
  1342. // //横屏处理
  1343. // }
  1344. // }
  1345. // if (input[23] == 0x0b) {
  1346. // console.log("多端登陆");
  1347. // }
  1348. // //console.log("屏幕旋转 %s", PrintArry(input));
  1349. // }
  1350. // return {
  1351. // audio: audio,
  1352. // video: video,
  1353. // duration: duration
  1354. // };
  1355. // }
  1356. // window.onload = function() {
  1357. // // var socketURL = 'wss://jmuxer-demo-server.herokuapp.com';
  1358. // //socketURL = "ws://127.0.0.1:8080"
  1359. // // socketURL = "ws://192.168.11.233:8080"
  1360. // //socketURL = "ws://14.215.128.98:14112";
  1361. // var socketURL = "ws://192.168.11.66:9101";
  1362. // // socketURL = "ws://14.215.128.98:14077";
  1363. // //socketURL = "wss://192.168.11.242:9104";
  1364. // var jmuxer = new JMuxer({
  1365. // node: 'player',
  1366. // flushingTime: 15,
  1367. // fps: 30,
  1368. // mode: 'video',
  1369. // debug: false
  1370. // });
  1371. // var audioMuxer = new JMuxer({
  1372. // node: 'audioPlayer',
  1373. // flushingTime: 15,
  1374. // clearBuffer: true,
  1375. // fps: 60, //可以不选,原先43
  1376. // mode: 'audio',
  1377. // debug: false
  1378. // });
  1379. // curTime = new Date().getTime();
  1380. // var ws = new WebSocket(socketURL);
  1381. // ws.binaryType = 'arraybuffer';
  1382. // //断开检测
  1383. // ws.onclose = function(e) {
  1384. // alert("websocket连接断开");
  1385. // console.log('websocket 断开: ' + e.code + ' ' + e.reason + ' ' + e.wasClean);
  1386. // console.log(e);
  1387. // }
  1388. // ws.addEventListener('open', function(event) {
  1389. // console.log("发送配置帧");
  1390. // ws.send(ConfigChannel("RK3923C1201900139"));
  1391. // });
  1392. // ws.addEventListener('error', function(event) {
  1393. // console.log("连接失败");
  1394. // });
  1395. // ws.addEventListener('message', function(event) {
  1396. // var data = ParseProto(event.data); //JAVA服务器转发
  1397. // //console.log("收到数据");
  1398. // var audioData = {
  1399. // audio: data.audio,
  1400. // video: null,
  1401. // duration: data.duration
  1402. // };
  1403. // var videoData = {
  1404. // audio: null,
  1405. // video: data.video,
  1406. // duration: data.duration
  1407. // };
  1408. // if (myAudio.readyState == 2) {
  1409. // requestTime = new Date().getTime();
  1410. // isEnough = false;
  1411. // console.log("数据存储不够,出现声音停止,时间差 %f", myAudio.buffered.end(0));
  1412. // myAudio.pause();
  1413. // //myAudio.playbackRate = 2;
  1414. // } else if (myAudio.readyState == 4 && isEnough == false) {
  1415. // myAudio.play();
  1416. // var time = new Date().getTime();
  1417. // isEnough = true;
  1418. // console.log("填满耗时 %d ms, 填充帧数 %d, 填充延迟 %d ms", time - requestTime, requestCount, requestCount * 23);
  1419. // console.log("----接收到启动 %d ms, 缓冲区 %f---", time - delayTime, myAudio.buffered.end(0) - myAudio.played.end(0));
  1420. // }
  1421. // if (data.audio != null) //喂音频
  1422. // {
  1423. // if (myAudio.buffered.length > 0 && myAudio.played.length > 0) {
  1424. // var bufferTime = myAudio.buffered.end(0) - myAudio.played.end(0);
  1425. // //console.log(" bufferTime %d", bufferTime);
  1426. // if (bufferTime > 1) {
  1427. // //console.log("丢掉一些包");
  1428. // //return;
  1429. // }
  1430. // }
  1431. // audioMuxer.feed(audioData);
  1432. // }
  1433. // if (data.video != null) //喂视频
  1434. // {
  1435. // if (isFeed) {
  1436. // jmuxer.feed(data);
  1437. // }
  1438. // //jmuxer.feed(videoData);
  1439. // }
  1440. // });
  1441. // myVideo.onmousedown = function(event) {
  1442. // //放在此处只是为了方便演示,实际使用中查找横竖屏只要刚连接上时调用一次就好。
  1443. // //var checkBuffer = GetScreenState();
  1444. // //ws.send(checkBuffer);
  1445. // if (!isFeed) {
  1446. // console.log("重新申请I帧");
  1447. // requestTime = new Date().getTime();
  1448. // var buffer = RequestIFrame();
  1449. // //var buffer = new Uint8Array([0x01]);
  1450. // ws.send(buffer);
  1451. // }
  1452. // //console.log("报文 %s", PrintArry(buffer));
  1453. // if (event.button == 0) {
  1454. // var posX = event.offsetX * 1080 * 1.0 / myVideo.clientWidth;
  1455. // var posY = event.offsetY * 1920 * 1.0 / myVideo.clientHeight;
  1456. // var buffer = ExexuteMouseDown(posX.toString(), posY.toString());
  1457. // ws.send(buffer);
  1458. // isDrag = true;
  1459. // }
  1460. // }
  1461. // myVideo.onmousemove = function(event) {
  1462. // if (isDrag && event.button == 0) {
  1463. // var posX = event.offsetX * 1080 * 1.0 / myVideo.clientWidth;
  1464. // var posY = event.offsetY * 1920 * 1.0 / myVideo.clientHeight;
  1465. // var buffer = ExexuteMouseMove(posX.toString(), posY.toString());
  1466. // ws.send(buffer);
  1467. // //console.log("移动位置 %d, %d", posX, posY);
  1468. // }
  1469. // }
  1470. // myVideo.onmouseup = function(event) {
  1471. // isDrag = false;
  1472. // var posX = event.offsetX * 1080 * 1.0 / myVideo.clientWidth;
  1473. // var posY = event.offsetY * 1920 * 1.0 / myVideo.clientHeight;
  1474. // var buffer = ExexuteMouseUp(posX.toString(), posY.toString());
  1475. // ws.send(buffer);
  1476. // }
  1477. // myVideo.onkeydown = function(event) {
  1478. // ExexuteKeyDown(e.keyCode);
  1479. // }
  1480. // }
  1481. // function Back() {
  1482. // if (event.button == 2) {
  1483. // //ExexuteKeyDown(4);
  1484. // }
  1485. // ExexuteKeyDown(4);
  1486. // window.event.returnValue = false;
  1487. // return false;
  1488. // }
  1489. </script>
  1490. </body>
  1491. </html>