276 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			276 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | ||
| 	<view class="bottoms">
 | ||
| 
 | ||
| 		<view class="box" :class="{active: aindex == 1}" @click="getgogo(1)" v-if="role == 'user' ">
 | ||
| 			<view class="imgs">
 | ||
| 				<image src="@/static/icons/tabbar/home.png" v-show="aindex != 1"></image>
 | ||
| 				<image src="@/static/icons/tabbar/home-checked.png" v-show="aindex == 1"></image>
 | ||
| 			</view>
 | ||
| 			<view class="">首页</view>
 | ||
| 		</view>
 | ||
| 		<view class="box" :class="{active: aindex == 8}" @click="getgogo(8)" v-if="role == 'police' ">
 | ||
| 			<view class="imgs">
 | ||
| 				<image src="@/static/icons/tabbar/home.png" v-show="aindex != 8"></image>
 | ||
| 				<image src="@/static/icons/tabbar/home-checked.png" v-show="aindex == 8"></image>
 | ||
| 			</view>
 | ||
| 			<view class="">首页</view>
 | ||
| 		</view>
 | ||
| 
 | ||
| <!-- 		<view class="box" @click="getgogo(2)">
 | ||
| 			<view class="imgs" style="position: relative;">
 | ||
| 				<view class="hongdian" v-if=" msgNum && msgNum != 0  ">
 | ||
| 					{{msgNum || ""}}
 | ||
| 				</view>
 | ||
| 				<view class="imgs">
 | ||
| 					<image src="../../static/message.png" v-show="aindex == 2"></image>
 | ||
| 					<image src="../../static/messagex.png" v-show="aindex != 2"></image>
 | ||
| 				</view>
 | ||
| 			</view>
 | ||
| 			<view class="">消息</view>
 | ||
| 		</view> -->
 | ||
| 		<!-- #ifdef APP-PLUS || H5 -->
 | ||
| 		<view class="box" :class="{active: aindex == 3}" @click="getgogo(3)">
 | ||
| 			<view class="imgs">
 | ||
| 				<image src="@/static/icons/tabbar/car.png" v-show="aindex != 3"></image>
 | ||
| 				<image src="@/static/icons/tabbar/car-checked.png" v-show="aindex == 3"></image>
 | ||
| 			</view>
 | ||
| 			<view class="">运力</view>
 | ||
| 		</view>
 | ||
| 		<!-- #endif -->
 | ||
| 
 | ||
| 		<view class="box" :class="{active: aindex == 4}" @click="getgogo(4)">
 | ||
| 			<view class="imgs">
 | ||
| 				<image src="@/static/icons/tabbar/my.png" v-show="aindex != 4"></image>
 | ||
| 				<image src="@/static/icons/tabbar/my-checked.png" v-show="aindex == 4"></image>
 | ||
| 			</view>
 | ||
| 			<view class="">个人中心</view>
 | ||
| 		</view>
 | ||
| 	</view>
 | ||
| </template>
 | ||
| 
 | ||
| <script>
 | ||
| 	import request from '../../utils/request';
 | ||
| 	import {
 | ||
| 		getToken
 | ||
| 	} from '@/utils/auth'
 | ||
| 	const innerAudioContext = uni.createInnerAudioContext();
 | ||
| 	const jyJPush = uni.requireNativePlugin('JY-JPush');
 | ||
| 	export default {
 | ||
| 		data() {
 | ||
| 			return {
 | ||
| 				msgSocket: this.$msgSocket,
 | ||
| 				aindex: 1,
 | ||
| 				msgNum: null,
 | ||
| 				role: 'user',
 | ||
| 				nowPageInterval: null,
 | ||
| 				arr: [{
 | ||
| 						text: '首页'
 | ||
| 					},
 | ||
| 					{
 | ||
| 						text: '消息'
 | ||
| 					},
 | ||
| 					{
 | ||
| 						text: '运力'
 | ||
| 					},
 | ||
| 					{
 | ||
| 						text: '个人中心'
 | ||
| 					},
 | ||
| 				]
 | ||
| 			}
 | ||
| 		},
 | ||
| 		props: {
 | ||
| 			msg: String
 | ||
| 		},
 | ||
| 		onLoad() {
 | ||
| 			console.log('tabbag', uni.getStorageSync('identity'));
 | ||
| 
 | ||
| 		},
 | ||
| 		onUnload() {
 | ||
| 			if (this.nowPageInterval) {
 | ||
| 				clearTimeout(this.nowPageInterval);
 | ||
| 			}
 | ||
| 		},
 | ||
| 		mounted() {
 | ||
| 			// #ifdef APP || H5
 | ||
| 
 | ||
| 			console.log('tabbag', uni.getStorageSync('identity'));
 | ||
| 			this.role = uni.getStorageSync('identity');
 | ||
| 			// #endif
 | ||
| 			if (!this.nowPageInterval) {
 | ||
| 				this.nowPageInterval = setInterval(() => {
 | ||
| 
 | ||
| 					this.msgSocket = this.$msgSocket
 | ||
| 				}, 3000);
 | ||
| 			}
 | ||
| 			console.log(this.aindex);
 | ||
| 			setTimeout(() => {
 | ||
| 				this.msgInfo()
 | ||
| 			}, 2000);
 | ||
| 
 | ||
| 			this.aindex = this.msg
 | ||
| 			this.getbottom()
 | ||
| 		},
 | ||
| 		watch: {
 | ||
| 			msgSocket(newVal, oldVal) {
 | ||
| 				console.log('msgSocket值发生变化', newVal, oldVal)
 | ||
| 				this.msgInfo()
 | ||
| 			},
 | ||
| 			deep: true,
 | ||
| 		},
 | ||
| 		methods: {
 | ||
| 
 | ||
| 			dianyidain() {
 | ||
| 				console.log('执行了,dianyidain');
 | ||
| 				innerAudioContext.src = 'https://www.nuoyunr.com/lananRsc/rescue/msgV.mp3';
 | ||
| 				// 设置播放次数和计数器
 | ||
| 				const playCount = 5;
 | ||
| 				let currentCount = 0;
 | ||
| 
 | ||
| 				// 监听音频播放结束事件
 | ||
| 				innerAudioContext.onEnded(() => {
 | ||
| 					// 播放计数加一
 | ||
| 					currentCount++;
 | ||
| 
 | ||
| 					// 判断是否达到播放次数上限
 | ||
| 					if (currentCount < playCount) {
 | ||
| 						// 继续播放
 | ||
| 						innerAudioContext.play();
 | ||
| 					} else {
 | ||
| 						// 播放完成,可以在这里添加额外的逻辑
 | ||
| 						console.log('播放完成');
 | ||
| 					}
 | ||
| 				});
 | ||
| 
 | ||
| 				// 初次播放
 | ||
| 				innerAudioContext.play();
 | ||
| 
 | ||
| 
 | ||
| 			},
 | ||
| 			msgInfo() {
 | ||
| 				console.log(this.msgSocket, 'msgSocket')
 | ||
| 				if (this.msgSocket) {
 | ||
| 					console.log('消息回调启动成功')
 | ||
| 					this.msgSocket.onMessage(res => {
 | ||
| 						console.log("发出提示音");
 | ||
| 						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/rescue/rescue'
 | ||
| 					})
 | ||
| 				}
 | ||
| 				if (index == 2) {
 | ||
| 					this.aindex = index
 | ||
| 					uni.reLaunch({
 | ||
| 						url: '/pages/message/message'
 | ||
| 					})
 | ||
| 				}
 | ||
| 				if (index == 3) {
 | ||
| 					this.aindex = index
 | ||
| 					uni.reLaunch({
 | ||
| 						url: '/pages/move/move'
 | ||
| 					})
 | ||
| 				}
 | ||
| 				if (index == 4) {
 | ||
| 					this.aindex = index
 | ||
| 					uni.reLaunch({
 | ||
| 						url: '/pages/my/my'
 | ||
| 					})
 | ||
| 				}
 | ||
| 				if (index == 8) {
 | ||
| 					this.aindex = index
 | ||
| 					uni.reLaunch({
 | ||
| 						url: '/pages/rescue/trafficPolice'
 | ||
| 					})
 | ||
| 				}
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 			}
 | ||
| 		}
 | ||
| 
 | ||
| 	}
 | ||
| </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;
 | ||
| 	}
 | ||
| 
 | ||
| 	.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> |