medicineVideo.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. <template>
  2. <div>
  3. <div class="video-container">
  4. <img src="../assets/pc/img/bg@3x.png" alt="" class="back-img" />
  5. <el-row>
  6. <el-col :span="14" :push="2">
  7. <el-card class="video-player">
  8. <div id="J_prismPlayer" :style="{ height: height + 'px' }">
  9. <!-- <img src="../assets/pc/img/video-img.jpg" alt /> -->
  10. </div>
  11. <div class="title">
  12. <div class="video-title">
  13. <img src="../assets/pc/img/title-img.jpg" class="title-img" />
  14. <div class="broadcaster-name">恒瑞测试</div>
  15. <div class="info">
  16. <div class="viewer-num">
  17. <i class="el-icon-view icon"></i>观众:588
  18. </div>
  19. <div class="share">
  20. <i class="el-icon-share icon"></i>分享
  21. </div>
  22. </div>
  23. </div>
  24. <div class="present">
  25. <el-popover
  26. placement="right"
  27. title=""
  28. width="450"
  29. trigger="click"
  30. >
  31. <div class="present-content">
  32. <div class="present-title">打赏</div>
  33. <div class="content">
  34. <!-- 礼物赠送 -->
  35. <div
  36. class="item"
  37. v-for="(item, i) in presentList"
  38. :key="item.img"
  39. >
  40. <el-popover
  41. placement="top-end"
  42. title=""
  43. width="300"
  44. trigger="click"
  45. >
  46. <div class="present-send">
  47. <div class="present-info">
  48. <div>
  49. <img
  50. :src="item.img"
  51. alt=""
  52. class="present-img"
  53. />
  54. </div>
  55. <div class="present-desc">
  56. <p>{{ item.desc }}</p>
  57. <div class="present-num">
  58. <div>数量:</div>
  59. <el-input-number
  60. v-model="presentNum"
  61. @change="handleChange"
  62. :min="1"
  63. :max="99"
  64. label=""
  65. ></el-input-number>
  66. </div>
  67. </div>
  68. </div>
  69. <div class="present-totalprice">
  70. <div>
  71. <span>合计:</span
  72. ><span style="color: #f04040">{{
  73. item.price
  74. }}</span>
  75. </div>
  76. <div class="send">
  77. <el-button type="danger">赠送</el-button>
  78. </div>
  79. </div>
  80. </div>
  81. <div slot="reference">
  82. <img :src="item.img" alt="" />
  83. <p>{{ item.desc }}</p>
  84. <p class="price">{{ item.price }}</p>
  85. </div>
  86. </el-popover>
  87. </div>
  88. </div>
  89. </div>
  90. <div class="present-btn" slot="reference">
  91. <img src="../assets/pc/img/present.png" alt="" />
  92. </div>
  93. </el-popover>
  94. <span style="line-height: 30px" class="c-666"> 打赏 </span>
  95. </div>
  96. </div>
  97. <div class="barrage">
  98. <div class="video-mobile c-666">
  99. <i class="el-icon-mobile icon"></i>手机观看
  100. </div>
  101. <div class="barrage-btn c-666">
  102. 弹幕<el-switch
  103. v-model="barrageFlag"
  104. active-color="#409EFF"
  105. inactive-color="#cccccc"
  106. >
  107. </el-switch>
  108. </div>
  109. </div>
  110. </el-card>
  111. </el-col>
  112. <el-col :span="6" :push="2">
  113. <el-card class="comments" :style="{ height: commentsHeight + 'px' }">
  114. <div class="cose-title">聊天互动</div>
  115. <div
  116. class="messages-content"
  117. id="commentsList"
  118. :style="{ height: minHeight + 'px' }"
  119. @scroll="changeScrollFlag"
  120. >
  121. <div class="item" v-for="(item, i) in commentList" :key="i">
  122. <div v-show="item.action == 103">
  123. <div class="time" v-show="item.timeFlag">
  124. {{ item.sendTime }}
  125. </div>
  126. <div class="message">
  127. <div class="head-img">
  128. <img :src="item.head_img" alt="" />
  129. </div>
  130. <div class="word">
  131. <div class="user">
  132. {{ item.user_name || "上海市网友" }}
  133. </div>
  134. <div class="tidings">{{ item.content }}</div>
  135. </div>
  136. </div>
  137. </div>
  138. <div v-show="item.action == 101" class="item101">
  139. {{ item.content }}
  140. </div>
  141. </div>
  142. </div>
  143. <div class="send">
  144. <div class="textbox">
  145. <el-input
  146. v-model="commentsText"
  147. placeholder="我也来说几句"
  148. ></el-input>
  149. </div>
  150. <div class="send-btn">
  151. <el-button type="primary" @click="sendComment">发送</el-button>
  152. </div>
  153. </div>
  154. </el-card>
  155. </el-col>
  156. </el-row>
  157. </div>
  158. <div
  159. style="height: 1000px; background-color: #232323; margin-top: 100px"
  160. ></div>
  161. </div>
  162. </template>
  163. <script>
  164. import remoteLoad from "../util/remoteLoad";
  165. import moment from "moment";
  166. import "../assets/pc/css/video.scss";
  167. export default {
  168. data() {
  169. return {
  170. windowWidth: document.documentElement.clientWidth, //实时屏幕宽度
  171. width: 876,
  172. height: 492,
  173. commentsHeight: 629,
  174. minHeight: 528,
  175. presentNum: 1,
  176. barrageFlag: true,
  177. presentList: [
  178. {
  179. img: "https://static.mudu.tv/assets/img/console/reward/call.png",
  180. desc: "为你打call",
  181. price: "免费",
  182. },
  183. {
  184. img: "https://static.mudu.tv/assets/img/console/reward/heart.png",
  185. desc: "怦然心动",
  186. price: "免费",
  187. },
  188. {
  189. img: "https://static.mudu.tv/assets/img/console/reward/flower.png",
  190. desc: "鲜花礼盒",
  191. price: "免费",
  192. },
  193. {
  194. img: "https://static.mudu.tv/assets/img/console/reward/rock.gif",
  195. desc: "冲天云彩大火箭",
  196. price: "免费",
  197. },
  198. {
  199. img: "https://static.mudu.tv/assets/img/console/reward/yacht.png",
  200. desc: "梦幻环游飞艇",
  201. price: "免费",
  202. },
  203. ],
  204. commentsText: "",
  205. // commentApi: {},
  206. // scrollTop: 0,
  207. //是否滚动屏幕
  208. isScrollFlag: false,
  209. commentList: [],
  210. wsObj: {},
  211. roomId: 0,
  212. myVideoPlayer: null,
  213. };
  214. },
  215. async created() {
  216. console.log("--------------------------");
  217. let scale = this.windowWidth / 1536;
  218. this.height = parseInt(scale * 492);
  219. this.width = parseInt(scale * 876);
  220. this.commentsHeight = this.height + 139;
  221. this.minHeight = this.commentsHeight - 41 - 33 - 27;
  222. },
  223. async mounted() {
  224. this.linkWebSocket();
  225. this.scrollToBottom();
  226. if (window.Aliplayer) {
  227. this.myVideoPlayer = window.Aliplayer;
  228. } else {
  229. await remoteLoad(
  230. "https://g.alicdn.com/de/prismplayer/2.9.3/aliplayer-min.js"
  231. );
  232. this.myVideoPlayer = window.Aliplayer;
  233. console.log(window.Aliplayer);
  234. }
  235. this.initVideoPlayer();
  236. },
  237. methods: {
  238. handleChange(value) {
  239. this.$data.presentNum = value;
  240. console.log(this.$data.presentNum);
  241. },
  242. //评论显示从下到上
  243. scrollToBottom() {
  244. this.$nextTick(() => {
  245. var container = this.$el.querySelector("#commentsList");
  246. container.scrollTop = container.scrollHeight;
  247. });
  248. },
  249. changeScrollFlag(e) {
  250. const self = this;
  251. let top = e.target.scrollTop;
  252. let scrollHeight = e.target.scrollHeight;
  253. let clientHeight = e.target.clientHeight;
  254. let gap = scrollHeight - clientHeight;
  255. if (gap > top) {
  256. //滚动屏幕,设置对应flag
  257. self.isScrollFlag = true;
  258. } else {
  259. self.isScrollFlag = false;
  260. }
  261. },
  262. linkWebSocket() {
  263. const self = this;
  264. let roomId = self.roomId;
  265. let wsObj = new WebSocket(
  266. "ws://47.75.134.87:9501?roomId=18&userId=7&group=1"
  267. ); //建立连接
  268. self.wsObj = wsObj;
  269. wsObj.onopen = function () {
  270. //发送请求
  271. wsObj.send("Hello WebSocket");
  272. };
  273. wsObj.onmessage = function (ev) {
  274. let scrollFlag = self.isScrollFlag;
  275. let commentsList = self.commentList;
  276. //获取后端响应
  277. let data = ev.data;
  278. let commentInfo = JSON.parse(data);
  279. // console.log(commentInfo);
  280. if (roomId == 0 && commentInfo.roomId) {
  281. self.roomId = commentInfo.roomId;
  282. }
  283. if (commentsList.length >= 2) {
  284. let lastComment = commentsList[commentsList.length - 1];
  285. // console.log(lastComment);
  286. let flag = self.compareTime(
  287. lastComment.sendTime,
  288. commentInfo.sendTime
  289. );
  290. commentInfo.timeFlag = flag;
  291. } else {
  292. commentInfo.timeFlag = true;
  293. }
  294. self.commentList.push(commentInfo);
  295. if (!scrollFlag) {
  296. self.scrollToBottom();
  297. }
  298. };
  299. /* wsObj.onclose = function (ev) {
  300. alert("close");
  301. };
  302. wsObj.onerror = function (ev) {
  303. alert("error");
  304. }; */
  305. },
  306. sendComment() {
  307. const self = this;
  308. let wsObj = self.wsObj;
  309. let roomId = self.roomId;
  310. let commentContent = self.commentsText;
  311. let comment = {
  312. action: "roomBroadcast",
  313. controller: "broadcast",
  314. params: {
  315. content: commentContent,
  316. type: "txt",
  317. roomId: roomId,
  318. group: 1,
  319. },
  320. };
  321. let json = JSON.stringify(comment);
  322. wsObj.send(json);
  323. self.commentsText = "";
  324. },
  325. initVideoPlayer() {
  326. const myVideoPlayer = this.myVideoPlayer;
  327. const self = this;
  328. let videoHeight = self.height + "px";
  329. var player = new myVideoPlayer(
  330. {
  331. id: "J_prismPlayer",
  332. source: "http://ivi.bupt.edu.cn/hls/btv1hd.m3u8",
  333. width: "100%",
  334. height: "500px",
  335. autoplay: true,
  336. isLive: true,
  337. rePlay: true,
  338. playsinline: true,
  339. preload: true,
  340. controlBarVisibility: "hover",
  341. useH5Prism: true,
  342. },
  343. function (player) {
  344. // alert("The player is created");
  345. }
  346. );
  347. },
  348. compareTime(oldTime, newTime) {
  349. let garMinutes = 2;
  350. let oldDate = new Date(oldTime);
  351. let newDate = new Date(newTime);
  352. let o_time = oldDate.getTime();
  353. let n_time = newDate.getTime();
  354. let gapTime = n_time - o_time;
  355. let flag;
  356. if (gapTime > garMinutes * 60 * 1000) {
  357. flag = true;
  358. } else {
  359. flag = false;
  360. }
  361. return flag;
  362. },
  363. },
  364. };
  365. </script>