| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368 | 
							- <template name="dever-audio">
 
- 	<view class="control">
 
- 		<view v-if="lrc">
 
- 			<bing-lyric :lyrics="lyrics" :centerStyle="centerStyle" :curTime="currentTimeSecond" :areaStyle="cuAreaStyle" :selectControlStyle="selectControlStyle" :lyricStyle="lyricStyle"
 
- 					 @centerBtnClick="centerBtnClick" @copyLyrics="copy"></bing-lyric>
 
- 		</view>
 
- 		<view @click="open" v-if="!lrc">
 
- 			<cover-image v-if="pic" class="poster" :src="pic" mode="aspectFill" style="height:auto">
 
- 			</cover-image>
 
- 			
 
- 			<cover-image
 
- 			class="ico-music-playing" v-if="playButton"></cover-image>
 
- 			
 
- 			<cover-image
 
- 			class="ico-music-play" v-if="!playButton"></cover-image>
 
- 		</view>
 
- 		
 
- 		<view :class="audioClass">
 
- 			<view class="audio-wrapper">
 
- 				<view class="audio-number">{{currentTime}}</view>
 
- 				<slider class="audio-slider" :activeColor="color" block-size="16" :value="current" :max="duration" @changing="seek=true,current=$event.detail.value"
 
- 				 @change="change"></slider>
 
- 				<view class="audio-number">{{durationTime}}</view>
 
- 			</view>
 
- 			<view class="audio-controll" v-if="lrc">
 
- 				<cover-image class="image" v-if="!recycleStatus" @click="setRecycle" src="@/static/music/recycle.png" mode="aspectFit"></cover-image>
 
- 				
 
- 				<cover-image class="image" v-if="recycleStatus" @click="setRecycle" src="@/static/music/recycled.png" mode="aspectFit"></cover-image>
 
- 				
 
- 				<cover-image class="image" @click="last" src="@/static/music/last.png" mode="aspectFit"></cover-image>
 
- 				
 
- 				<cover-image class="image" v-if="!play" @click="open" src="@/static/music/play.png" mode="aspectFit"></cover-image>
 
- 				<cover-image class="image" v-if="play" @click="open" src="@/static/music/pause.png" mode="aspectFit"></cover-image>
 
- 				
 
- 				<cover-image class="image" @click="next" src="@/static/music/next.png" mode="aspectFit"></cover-image>
 
- 			</view>
 
- 		</view>
 
- 	</view>
 
- </template>
 
- <script>
 
- import bingLyric from '@/lib/bing-lyric/bing-lyric.vue'
 
- import copyText from "@/lib/clipboard.thorui.js"; 
 
- export default {
 
- 	name: "dever-audio",
 
- 	props: {
 
- 		src : {
 
- 			type    : String,
 
- 			value	: null
 
- 		},
 
- 		loop : {
 
- 			type    : Boolean,
 
- 			value	: false
 
- 		},
 
- 		pic : {
 
- 			type    : String,
 
- 			value	: null
 
- 		},
 
- 		auto : {
 
- 			type    : Boolean,
 
- 			value	: false
 
- 		},
 
- 		control : {
 
- 			type    : Boolean,
 
- 			value	: false
 
- 		},
 
- 		color: {
 
- 			type:String,
 
- 			default:'#169af3'
 
- 		},
 
- 		title : '',
 
- 		singer : '',
 
- 		lrc : '',
 
- 		lrc_color : '',
 
- 		lrc_atcolor : '',
 
- 		recycle : '',
 
- 	},
 
- 	components:{
 
- 		bingLyric
 
- 	},
 
- 	data() {
 
- 		return {
 
- 			time : {},
 
- 			objectFit : 'fill',
 
- 			play : false,
 
- 			playButton : false,
 
- 			audio : false,
 
- 			recycleStatus : false,
 
- 			audioClass : 'audio-lrc',
 
- 			currentTime: '', //当前播放时间
 
- 			duration:'',
 
- 			durationTime: '', //总时长
 
- 			current: 0, //slider当前进度
 
- 			loading: false, //是否处于读取状态
 
- 			paused: true, //是否处于暂停状态
 
- 			seek: false ,//是否处于拖动状态
 
- 			currentTimeSecond: 0,//当前播放秒数
 
- 			centerStyle: {
 
- 				btnImg: '../../static/music/btn.png',
 
- 			},
 
- 			lyricStyle: {
 
- 				color: this.lrc_color ,//歌词颜色,
 
- 				activeColor: this.lrc_atcolor ,//当前播放的歌词的颜色,
 
- 				fontSize: '16px' ,//歌词字体尺寸
 
- 				activeFontSize: '16px' ,//当前播放的歌词的字体尺寸
 
- 				lineHeight: '40px' ,//每句歌词的显示区域的高度 以此来调整歌词间距
 
- 				activeLineHeight: '32px' ,//当前播放歌词的显示区域的高度
 
- 				selectedBGColor: 'inherit' ,//进入歌词选择模式时,被选择的歌词背景颜色
 
- 			},
 
- 			cuAreaStyle: {
 
- 				width: '100vw',
 
- 				height: '100vh',
 
- 				background : 'url('+this.pic+')',
 
- 			},
 
- 			selectControlStyle : {
 
- 				color : 'white',
 
- 				itemBackgroundColor : '#333333',
 
- 				backgroundColor : 'rgba(0,0,0,0)',
 
- 			},
 
- 			lyrics: [],
 
- 			
 
- 		};
 
- 	},
 
- 	watch: {
 
- 		//监听总时长改变
 
- 		duration(e) {
 
- 			//this.durationTime = this.format(e)
 
- 		},
 
- 		//监听当前进度改变
 
- 		current(e) {
 
- 			this.currentTime = this.format(e)
 
- 			this.currentTimeSecond = e;
 
- 			this.timeUpdate(this.currentTimeSecond);
 
- 		}
 
- 	},
 
- 	mounted() {
 
- 		
 
- 		//考虑换成getBackgroundAudioManager()
 
- 		if (this.Dever.source == 'h5') {
 
- 			this.audio = uni.createInnerAudioContext()
 
- 			this.audio.src = this.src;
 
- 			this.audio.obeyMuteSwitch = false;
 
- 			this.audio.autoplay = this.auto;
 
- 			//this.audio.loop = this.loop;
 
- 		} else {
 
- 			this.audio = uni.getBackgroundAudioManager()
 
- 			this.audio.title = this.title;
 
- 			this.audio.singer = this.singer;
 
- 			this.audio.coverImgUrl = this.pic;
 
- 			this.audio.src = this.src;
 
- 		}
 
- 		
 
- 		this.recycleStatus = this.recycle;
 
- 		if (!this.lrc) {
 
- 			this.lyrics = [];
 
- 			this.audioClass = 'audio';
 
- 		} else {
 
- 			if (this.lrc.length > 0) {
 
- 				this.lyrics = this.lrc;
 
- 			} else {
 
- 				this.lyrics = [];
 
- 			}
 
- 			
 
- 			this.audioClass = 'audio-lrc';
 
- 		}
 
- 		
 
- 		this.current = 0;
 
- 		
 
- 		//音频进度更新事件
 
- 		this.audio.onTimeUpdate(() => {
 
- 			if (!this.seek) {
 
- 				this.current = this.audio.currentTime;
 
- 			}
 
- 			if (!this.durationTime) {
 
- 				this.duration = this.audio.duration;
 
- 				this.durationTime = this.format(this.audio.duration);
 
- 			}
 
- 		})
 
- 		//音频完成更改进度事件
 
- 		this.audio.onSeeked(() => {
 
- 			this.seek = false;
 
- 		})
 
- 		//音频播放完成事件
 
- 		this.audio.onEnded(() => {
 
- 			if (this.recycleStatus) {
 
- 				// 播放下一曲
 
- 				this.next();
 
- 			} else {
 
- 				this.play = false;
 
- 				this.playButton = false;
 
- 				this.audio.seek(0);
 
- 				this.start();
 
- 			}
 
- 		});
 
- 	},
 
- 	methods:{
 
- 		start : function()  {
 
- 			this.$emit('update:load', true);
 
- 			if (!this.play) {
 
- 				this.Dever.bgm().stop();
 
- 				this.audio.play();
 
- 				this.play = true;
 
- 				this.playButton = true;
 
- 				this.$emit('play', 'start');
 
- 			}
 
- 		},
 
- 		stop : function() {
 
- 			if (this.play) {
 
- 				this.audio.pause();
 
- 				this.play = false;
 
- 				this.playButton = false;
 
- 				this.$emit('play', 'stop');
 
- 			}
 
- 		},
 
- 		open : function()  {
 
- 			if (!this.play) {
 
- 				this.start();
 
- 			} else {
 
- 				this.stop(true);
 
- 			}
 
- 		},
 
- 		//上一曲
 
- 		last : function() {
 
- 			this.$emit('last');
 
- 		},
 
- 		//下一曲
 
- 		next : function() {
 
- 			this.$emit('next');
 
- 		},
 
- 		//多曲循环播放
 
- 		setRecycle : function() {
 
- 			this.recycleStatus = !this.recycleStatus;
 
- 			this.$emit('setRecycle');
 
- 		},
 
- 		//格式化时长
 
- 		format : function(num) {
 
- 			return '0'.repeat(2 - String(Math.floor(num / 60)).length) + Math.floor(num / 60) + ':' + '0'.repeat(2 - String(
 
- 				Math.floor(num % 60)).length) + Math.floor(num % 60)
 
- 		},
 
- 		//完成拖动事件
 
- 		change : function(e) {
 
- 			this.audio.seek(e.detail.value)
 
- 		},
 
- 		copy : function(e) {
 
- 			var self = this;
 
- 			var value = '';
 
- 			for (var i in e.lyrics) {
 
- 				value += e.lyrics[i] + "\r\n";
 
- 			}
 
- 			copyText.getClipboardData(value, function(res) {
 
- 				if (res) {
 
- 					self.Dever.alert('复制成功');
 
- 				} else {
 
- 					self.Dever.alert('复制失败');
 
- 				}
 
- 			});
 
- 		},
 
- 		centerBtnClick : function(e) {
 
- 			this.currentTimeSecond = e.centerTime
 
- 			this.audio.seek(this.currentTimeSecond);
 
- 		},
 
- 		timeUpdate : function(time) {
 
- 			if (this.play == true) {
 
- 				var currentTime = time;
 
- 				currentTime = parseInt(currentTime);
 
- 				if (!this.time[currentTime]) {
 
- 					this.time[currentTime] = currentTime;
 
- 					this.$emit('play', 'time', [this, currentTime]);
 
- 				}
 
- 			}
 
- 		}
 
- 	},
 
- }
 
- </script>
 
- <style scoped>
 
- .control {
 
- 	width: 100%;
 
- 	height: 100%;
 
- 	z-index: 2;
 
- 	background: transparent;
 
- 	position: absolute;
 
- 	left: 0;
 
- 	top: 0;
 
- 	overflow: hidden;
 
- }
 
- .poster{
 
- 	background-size: cover;
 
- 	position: absolute;
 
- 	left: 0;
 
- 	top: 0;
 
- 	width: 100%;
 
- 	height: 100%;
 
- }
 
- .audio-lrc {
 
- 	padding: 24rpx;
 
- 	background: #fff;
 
- 	border-radius: 20rpx;
 
- 	position: absolute;
 
- 	z-index: 100;
 
- 	background: #666666;
 
- 	background: hsla(0,0%,100%,.6);
 
- 	
 
- 	bottom: 10rpx;
 
- 	left: 20rpx;
 
- 	width: 78%;
 
- }
 
- .audio {
 
- 	padding: 24rpx;
 
- 	background: #fff;
 
- 	border-radius: 20rpx;
 
- 	position: absolute;
 
- 	z-index: 100;
 
- 	background: transparent;
 
- 	
 
- 	bottom: 0rpx;
 
- 	left: 0rpx;
 
- 	width: 100%;
 
- }
 
- .audio-wrapper {
 
- 	display: flex;
 
- 	align-items: center;
 
- }
 
- .audio-number {
 
- 	font-size: 24rpx;
 
- 	line-height: 1;
 
- 	color: #333;
 
- 	color: #fff;
 
- }
 
- .audio-slider {
 
- 	flex: 1;
 
- 	margin: 0 30rpx;
 
- }
 
- .audio-controll {
 
- 	display: flex;
 
- 	justify-content: space-around;
 
- 	margin-top: 26rpx;
 
- }
 
- .audio-controll .image {
 
- 	display: inline-block;
 
- 	height: 30rpx;
 
- 	width: 30rpx;
 
- }
 
- .ico-music-play{
 
-   background: url(@/static/music/speaker.png) no-repeat;
 
-   background-size: cover;
 
-   width: 100rpx;
 
-   height: 100rpx;
 
-   position: absolute;
 
-   left: 50%;
 
-   top: 50%;
 
-   transform: translate3d(-50%,-50%,0);
 
- }
 
- .ico-music-playing{
 
-   background: url() no-repeat;
 
-   background-size: cover;
 
-   width: 100rpx;
 
-   height: 100rpx;
 
-   position: absolute;
 
-   left: 50%;
 
-   top: 50%;
 
-   transform: translate3d(-50%,-50%,0);
 
- }
 
- </style>
 
 
  |