260 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			260 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | ||
| 	<view class="bottoms">
 | ||
| 		<view class="box" :class="{active: aindex == 1}" @click="getgogo(1)">
 | ||
| 			<view class="imgs">
 | ||
| 				<image mode="aspectFit" src="@/static/icons/tabbar/home.png" v-show="aindex != 1"></image>
 | ||
| 				<image mode="aspectFit" src="@/static/icons/tabbar/home-checked.png" v-show="aindex == 1"></image>
 | ||
| 			</view>
 | ||
| 			<view class="">首页</view>
 | ||
| 		</view>
 | ||
| 		<view class="box" :class="{active: aindex == 2}" @click="getgogo(2)">
 | ||
| 			<view class="imgs">
 | ||
| 				<image mode="aspectFit" src="@/static/icons/tabbar/order.png" v-show="aindex != 2"></image>
 | ||
| 				<image mode="aspectFit" src="@/static/icons/tabbar/order-checked.png" v-show="aindex == 2"></image>
 | ||
| 			</view>
 | ||
| 			<view class="">工单</view>
 | ||
| 		</view>
 | ||
| <!--		<view class="box" :class="{active: aindex == 3}" @click="getgogo(3)">-->
 | ||
| <!--			<view class="imgs">-->
 | ||
| <!--				<image mode="aspectFit" src="@/static/icons/tabbar/my.png" v-show="aindex != 3"></image>-->
 | ||
| <!--				<image mode="aspectFit" src="@/static/icons/tabbar/my-checked.png" v-show="aindex == 3"></image>-->
 | ||
| <!--			</view>-->
 | ||
| <!--			<view class="">我的</view>-->
 | ||
| <!--		</view>-->
 | ||
| 	</view>
 | ||
| </template>
 | ||
| 
 | ||
| <script>
 | ||
| 	import request from '../../utils/request';
 | ||
| 	import {
 | ||
| 		getToken
 | ||
| 	} from '@/utils/auth'
 | ||
|   let innerAudioContext ='';
 | ||
|   // #ifdef APP || H5
 | ||
|   const jyJPush = uni.requireNativePlugin('JY-JPush');
 | ||
|   // #endif
 | ||
| 	export default {
 | ||
| 		data() {
 | ||
| 			return {
 | ||
|         msgSocket: this.$msgSocket,
 | ||
|         // 是否正在播放
 | ||
|         ifPlay:false,
 | ||
| 				aindex: 1,
 | ||
| 				msgNum: null,
 | ||
|         identity: 'user',
 | ||
| 				nowPageInterval: null,
 | ||
| 				arr: [{
 | ||
| 						text: '首页'
 | ||
| 					},
 | ||
| 					{
 | ||
| 						text: '消息'
 | ||
| 					},
 | ||
| 					{
 | ||
| 						text: '运力'
 | ||
| 					}
 | ||
| 				]
 | ||
| 			}
 | ||
| 		},
 | ||
| 		props: {
 | ||
| 			msg: String|Number
 | ||
| 		},
 | ||
| 		onLoad() {
 | ||
| 			console.log('tabbag', uni.getStorageSync('identity'));
 | ||
| 
 | ||
| 		},
 | ||
| 		onUnload() {
 | ||
| 			if (this.nowPageInterval) {
 | ||
| 				clearTimeout(this.nowPageInterval);
 | ||
| 			}
 | ||
| 		},
 | ||
| 		mounted() {
 | ||
| 			// #ifdef APP || H5
 | ||
| 			this.identity = uni.getStorageSync('identity');
 | ||
| 			// #endif
 | ||
|       if (!this.nowPageInterval) {
 | ||
|         this.nowPageInterval = setInterval(() => {
 | ||
|           // console.log('this.$msgSocket: ',this.$msgSocket);
 | ||
|           this.msgSocket = this.$msgSocket
 | ||
|         }, 3000);
 | ||
|       }
 | ||
|       console.log(this.aindex);
 | ||
|       setTimeout(() => {
 | ||
|         this.msgInfo()
 | ||
|       }, 2000);
 | ||
| 			this.aindex = this.msg
 | ||
| 
 | ||
| 		},
 | ||
|     watch: {
 | ||
|       msgSocket(newVal, oldVal) {
 | ||
|         console.log('msgSocket值发生变化', newVal, oldVal)
 | ||
|         this.msgInfo()
 | ||
|       },
 | ||
|       deep: true,
 | ||
|     },
 | ||
| 		methods: {
 | ||
|       dianyidain() {
 | ||
|         if(!this.ifPlay){
 | ||
|           console.log('执行了,dianyidain');
 | ||
|           if(innerAudioContext!=""){
 | ||
|             try {
 | ||
|               console.log('调用前先销毁');
 | ||
|               innerAudioContext.stop();
 | ||
|               innerAudioContext.destroy();
 | ||
|               innerAudioContext="";
 | ||
|             }catch (e){
 | ||
|               console.log('销毁出错');
 | ||
|             }
 | ||
|           }
 | ||
|           innerAudioContext = uni.createInnerAudioContext();
 | ||
|           this.ifPlay=true
 | ||
|           // #ifdef APP-PLUS
 | ||
|           innerAudioContext.src = '../../static/msgV.mp3';
 | ||
|           // #endif
 | ||
|           // #ifndef APP-PLUS
 | ||
|           innerAudioContext.src = 'https://www.nuoyunr.com/lananRsc/rescue/msgV.mp3';
 | ||
|           // #endif
 | ||
|           // 设置播放次数和计数器
 | ||
|           const playCount = 3;
 | ||
|           let currentCount = 0;
 | ||
|           // 初次播放
 | ||
|           innerAudioContext.play();
 | ||
|           innerAudioContext.onError((err) => {
 | ||
|             console.error('播放错误', err);
 | ||
|             this.ifPlay=false
 | ||
|             innerAudioContext.stop();
 | ||
|             innerAudioContext.destroy(); // 播放错误后释放实例
 | ||
|           });
 | ||
|           // 监听音频播放结束事件
 | ||
|           innerAudioContext.onEnded(() => {
 | ||
|             // 播放计数加一
 | ||
|             currentCount++;
 | ||
|             // 判断是否达到播放次数上限
 | ||
|             if (currentCount < playCount) {
 | ||
|               // 继续播放
 | ||
|               innerAudioContext.play();
 | ||
|             } else {
 | ||
|               // 播放完成,可以在这里添加额外的逻辑
 | ||
|               console.log('播放完成');
 | ||
|               this.ifPlay=false
 | ||
|               //及时释放资源
 | ||
|               innerAudioContext.stop();
 | ||
|               innerAudioContext.destroy();
 | ||
|             }
 | ||
|           });
 | ||
|         }else{
 | ||
|           console.log('正在播放音频,拒绝播放请求');
 | ||
|         }
 | ||
|       },
 | ||
|       msgInfo() {
 | ||
|         console.log(this.msgSocket, 'msgSocket')
 | ||
|         if (this.msgSocket) {
 | ||
|           console.log('消息回调启动成功')
 | ||
|           this.msgSocket.onMessage(res => {
 | ||
|             console.log("发出提示音", res);
 | ||
|             // this.getbottom();
 | ||
|             this.dianyidain()
 | ||
|           })
 | ||
|         }
 | ||
| 
 | ||
|       },
 | ||
| 			async getbottom() {
 | ||
| 				if (!getToken()) {
 | ||
| 					return
 | ||
| 				}
 | ||
| 				let res = await request({
 | ||
| 					url: '/announcement/announcement/getOwnNoRead',
 | ||
| 					method: 'get',
 | ||
| 
 | ||
| 				})
 | ||
| 				console.log('jitiao', res);
 | ||
| 				if (res.code == 200) {
 | ||
| 					this.msgNum = res.data
 | ||
| 				}
 | ||
| 			},
 | ||
| 			getgogo(index) {
 | ||
| 				if (index == 1) {
 | ||
| 					this.aindex = index
 | ||
| 					uni.reLaunch({
 | ||
| 						url: '/pages-home/home/home'
 | ||
| 					})
 | ||
| 				}
 | ||
| 				if (index == 2) {
 | ||
| 					this.aindex = index
 | ||
| 					uni.reLaunch({
 | ||
| 						url: '/pages-order/orderList/orderList'
 | ||
| 					})
 | ||
| 				}
 | ||
| 				if (index == 3) {
 | ||
| 					this.aindex = index
 | ||
| 					uni.reLaunch({
 | ||
| 						url: '/pages/my/my'
 | ||
| 					})
 | ||
| 				}
 | ||
| 			}
 | ||
| 		}
 | ||
| 
 | ||
| 	}
 | ||
| </script>
 | ||
| 
 | ||
| <style scoped lang="scss">
 | ||
| 	.bottoms {
 | ||
| 		width: 100%;
 | ||
| 		// position: fixed;
 | ||
| 		// bottom: 0px;
 | ||
| 		background: #fff;
 | ||
| 		display: flex;
 | ||
| 		justify-content: space-between;
 | ||
| 		font-size: 14px;
 | ||
| 		font-weight: 400;
 | ||
| 		color: #FFFFFF;
 | ||
| 		padding: 12rpx 40rpx;
 | ||
| 		box-sizing: border-box;
 | ||
| 		box-shadow: 4rpx 2rpx 12rpx 0 #c3c3c3;
 | ||
| 		position: relative;
 | ||
| 		z-index: 99;
 | ||
| 	}
 | ||
| 
 | ||
| 	.box {
 | ||
| 		flex: 1;
 | ||
| 		width: 0;
 | ||
| 		display: flex;
 | ||
| 		flex-direction: column;
 | ||
| 		align-items: center;
 | ||
| 		justify-content: center;
 | ||
| 		font-size: 12px;
 | ||
| 		color: #929292;
 | ||
| 
 | ||
| 		&.active {
 | ||
| 			color: #327DFB;
 | ||
| 		}
 | ||
| 	}
 | ||
| 
 | ||
| 	.imgs {
 | ||
| 		margin: 0 auto;
 | ||
| 		width: 50rpx;
 | ||
| 		height: 50rpx;
 | ||
| 
 | ||
| 		image {
 | ||
| 			width: 100%;
 | ||
| 			height: 100%;
 | ||
| 		}
 | ||
| 	}
 | ||
| 
 | ||
| 	.hongdian {
 | ||
| 		width: 12px;
 | ||
| 		height: 12px;
 | ||
| 		background-color: crimson;
 | ||
| 		border-radius: 50%;
 | ||
| 		overflow: hidden;
 | ||
| 		position: absolute;
 | ||
| 		top: -5px;
 | ||
| 		right: -8px;
 | ||
| 		z-index: 9999;
 | ||
| 		display: flex;
 | ||
| 		align-items: center;
 | ||
| 		justify-content: center;
 | ||
| 		color: white;
 | ||
| 		font-size: 2px;
 | ||
| 	}
 | ||
| </style>
 | 
