From fc34760fe9f4b4d20d70bf6664be28b04ec48b1f Mon Sep 17 00:00:00 2001 From: hongqiongxing Date: Mon, 5 Aug 2024 23:14:27 +0800 Subject: [PATCH] =?UTF-8?q?fix(xgplayer):=20=E5=88=86=E6=AE=B5=20=E6=92=AD?= =?UTF-8?q?=E6=94=BE=E5=A2=9E=E5=8A=A0loop=E5=A4=84=E7=90=86,=E5=B9=B6?= =?UTF-8?q?=E4=BF=AE=E5=A4=8DoffsetCurrentTime=E8=8E=B7=E5=8F=96=E5=BC=82?= =?UTF-8?q?=E5=B8=B8=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../xgplayer/src/plugins/time/timesegments.js | 70 ++++++++++++++++--- packages/xgplayer/src/utils/util.js | 42 ----------- 2 files changed, 61 insertions(+), 51 deletions(-) diff --git a/packages/xgplayer/src/plugins/time/timesegments.js b/packages/xgplayer/src/plugins/time/timesegments.js index dca3f97b6..c7b42615d 100644 --- a/packages/xgplayer/src/plugins/time/timesegments.js +++ b/packages/xgplayer/src/plugins/time/timesegments.js @@ -1,4 +1,47 @@ import { BasePlugin, Events, Util } from '../../plugin' +export function getIndexByTime (time, segments) { + const _len = segments.length + let _index = -1 + if (_len < 1) { + return _index + } + if (time <= segments[0].end || _len < 2) { + _index = 0 + } else if (time > segments[_len - 1].end) { + _index = _len - 1 + } else { + for (let i = 1; i < _len; i++) { + if (time > segments[i - 1].end && time <= segments[i].end){ + _index = i + break + } + } + } + return _index +} + +export function getOffsetCurrentTime (currentTime, segments, index = -1) { + let _index = -1 + if (index >= 0 && index < segments.length) { + _index = index + } else { + _index = getIndexByTime(currentTime, segments) + } + if (_index < 0) { + return -1 + } + const _len = segments.length + const { start, end, cTime, offset } = segments[_index] + if (currentTime < start) { + return cTime + } else if (currentTime >= start && currentTime <= end) { + return currentTime - offset + } else if (currentTime > end && _index >= _len - 1) { + return end - offset + } + return -1 +} + /** * 进行事件分段控制 */ @@ -97,8 +140,8 @@ export default class TimeSegmentsControls extends BasePlugin { if (!this._checkIfEnabled(timeSegments)) { return } - const index = Util.getIndexByTime(currentTime,timeSegments) - const time = Util.getOffsetCurrentTime(currentTime, timeSegments, index) + const index = getIndexByTime(currentTime,timeSegments) + const time = getOffsetCurrentTime(currentTime, timeSegments, index) this.player.offsetCurrentTime = time this.changeIndex(index, timeSegments) } @@ -108,7 +151,7 @@ export default class TimeSegmentsControls extends BasePlugin { if (!this._checkIfEnabled(timeSegments)) { return } - const time = Util.getOffsetCurrentTime(0, timeSegments) + const time = getOffsetCurrentTime(0, timeSegments) this.player.offsetCurrentTime = time this.changeIndex(0, timeSegments) if (this.curPos.start > 0){ @@ -123,12 +166,11 @@ export default class TimeSegmentsControls extends BasePlugin { } const _len = timeSegments.length this.lastCurrentTime = currentTime - const index = Util.getIndexByTime(currentTime, timeSegments) + const index = getIndexByTime(currentTime, timeSegments) if (index !== this.curIndex) { this.changeIndex(index, timeSegments) } - const curTime = Util.getOffsetCurrentTime(currentTime, timeSegments, index) - + const curTime = getOffsetCurrentTime(currentTime, timeSegments, index) this.player.offsetCurrentTime = curTime // 根据分段信息进行放时间点跳转 @@ -139,6 +181,16 @@ export default class TimeSegmentsControls extends BasePlugin { if (currentTime < start) { this.player.currentTime = start } else if (currentTime > end && index >= _len - 1) { + this.triggerCustomEnded() + } + } + + triggerCustomEnded () { + const { loop } = this.playerConfig + if (loop) { + const time = this.convertVideoTime(0) + this.player.seek(time) + } else { this.player.pause() this.player.emit('ended') } @@ -154,7 +206,7 @@ export default class TimeSegmentsControls extends BasePlugin { } else if (currentTime > timeSegments[timeSegments.length - 1].end) { this.player.currentTime = timeSegments[timeSegments.length - 1].end } else { - const _index = Util.getIndexByTime(currentTime, timeSegments) + const _index = getIndexByTime(currentTime, timeSegments) if (_index >= 0) { const _seekTime = this.getSeekTime(currentTime, this.lastCurrentTime, _index, timeSegments) if (_seekTime >= 0 ) { @@ -172,7 +224,8 @@ export default class TimeSegmentsControls extends BasePlugin { } const _len = timeSegments.length if (offsetTime < timeSegments[0].duration) { - return offsetTime + const { start } = timeSegments[0] + return offsetTime + start } else if (offsetTime >= timeSegments[_len - 1].duration) { return timeSegments[_len - 1].end } else { @@ -201,7 +254,6 @@ export default class TimeSegmentsControls extends BasePlugin { } getSeekTime (currentTime, lastCurrentTime, index, timeSegments) { - console.log('>>>getSeekTime', currentTime, lastCurrentTime, index) let _time = -1 const { start, end } = timeSegments[index] if (currentTime < timeSegments[0].start) { diff --git a/packages/xgplayer/src/utils/util.js b/packages/xgplayer/src/utils/util.js index ce79fe96b..29c13b4e0 100755 --- a/packages/xgplayer/src/utils/util.js +++ b/packages/xgplayer/src/utils/util.js @@ -882,48 +882,6 @@ util.convertDeg = function (val) { return val % 360 } -util.getIndexByTime = function (time, segments) { - const _len = segments.length - let _index = -1 - if (_len < 1) { - return _index - } - if (time <= segments[0].end || _len < 2) { - _index = 0 - } else if (time > segments[_len - 1].end) { - _index = _len - 1 - } else { - for (let i = 1; i < _len; i++) { - if (time > segments[i - 1].end && time <= segments[i].end){ - _index = i - break - } - } - } - return _index -} -util.getOffsetCurrentTime = function (currentTime, segments, index = -1) { - let _index = -1 - if (index >= 0 && index < segments.length) { - _index = index - } else { - _index = util.getIndexByTime(currentTime, segments) - } - if (_index < 0) { - return -1 - } - const _len = segments.length - const { start, end, cTime, offset } = segments[_index] - if (currentTime < start) { - return cTime - } else if (currentTime >= start && currentTime <= end) { - return currentTime - offset - } else if (currentTime > end && _index >= _len - 1) { - return end - } - return -1 -} - /** * * @param {*} offsetTime