update
This commit is contained in:
parent
881037a195
commit
8472b29247
15
README.md
15
README.md
@ -21,15 +21,18 @@
|
|||||||
|
|
||||||
## 参数
|
## 参数
|
||||||
```javascript
|
```javascript
|
||||||
//自动快进
|
//快进抓取
|
||||||
evanEnv.enableAutoForward = true
|
jsMedia.setSpeed(10);
|
||||||
//完成后自动下载
|
//完成后自动下载
|
||||||
evanEnv.enableAutoDownload = true
|
jsMedia.enableAutoDownload = true;
|
||||||
|
//手工触发下载
|
||||||
|
jsMedia.download();
|
||||||
```
|
```
|
||||||
|
|
||||||
## FFmpeg合并示例
|
## FFmpeg合并示例
|
||||||
```shell
|
```shell
|
||||||
ffmpeg -i mediasource_0_0_0.mp4 -i mediasource_0_1_0.mp4 -c copy -bsf:a aac_adtstoasc out.mp4
|
ffmpeg -i audio.mp4 -acodec copy audio.aac
|
||||||
|
ffmpeg -i audio.aac -i video.mp4 -c copy -bsf:a aac_adtstoasc out.mp4
|
||||||
```
|
```
|
||||||
|
|
||||||
## 大文件分段需要先文件合并
|
## 大文件分段需要先文件合并
|
||||||
@ -37,9 +40,5 @@ ffmpeg -i mediasource_0_0_0.mp4 -i mediasource_0_1_0.mp4 -c copy -bsf:a aac_adts
|
|||||||
copy /b mediasource_0_0_*.mp4 out.mp4
|
copy /b mediasource_0_0_*.mp4 out.mp4
|
||||||
```
|
```
|
||||||
|
|
||||||
## 常见问题
|
|
||||||
- 合并后声音播放不正常:由于部分网站使用了HE-AAC v2(AAC+SBR+PS)作为音频编码,大部分播放器还不支持此音频流格式,故声音不正常,使用Windows自带的视频播放器播放正常
|
|
||||||
|
|
||||||
|
|
||||||
## 特别说明
|
## 特别说明
|
||||||
- 仅限内部交流使用,请勿用于非法用途
|
- 仅限内部交流使用,请勿用于非法用途
|
@ -12,14 +12,13 @@
|
|||||||
// @grant none
|
// @grant none
|
||||||
// ==/UserScript==
|
// ==/UserScript==
|
||||||
|
|
||||||
evanEnv = new Object();
|
jsMedia = new Object();
|
||||||
evanEnv.mediaSources = [];
|
jsMedia.mediaSources = [];
|
||||||
evanEnv.enableAutoForward = true;
|
jsMedia.enableAutoDownload = true;
|
||||||
evanEnv.enableAutoDownload = true;
|
|
||||||
|
|
||||||
(function () {
|
(function () {
|
||||||
evanEnv.videos = document.getElementsByTagName('video');
|
jsMedia.videos = document.getElementsByTagName('video');
|
||||||
evanEnv.downloadRawData = function (bufferList, fileName = 'out', ext = '.mp4') {
|
jsMedia.downloadRawData = function (bufferList, fileName = 'out', ext = '.mp4') {
|
||||||
var buffList = new Array();
|
var buffList = new Array();
|
||||||
var totalLength = 0;
|
var totalLength = 0;
|
||||||
|
|
||||||
@ -59,36 +58,42 @@ evanEnv.enableAutoDownload = true;
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
evanEnv.download = function () {
|
jsMedia.download = function () {
|
||||||
for (var i = 0; i < evanEnv.mediaSources.length; i++) {
|
for (var i = 0; i < jsMedia.mediaSources.length; i++) {
|
||||||
var currentItem = evanEnv.mediaSources[i];
|
var currentItem = jsMedia.mediaSources[i];
|
||||||
if (currentItem.downloaded == undefined || currentItem.downloaded == false) {
|
if (currentItem.downloaded == undefined || currentItem.downloaded == false) {
|
||||||
for (var x = 0; x < currentItem.rawSources.length; x++) {
|
for (var x = 0; x < currentItem.rawSources.length; x++) {
|
||||||
evanEnv.downloadRawData(currentItem.rawSources[x], 'mediasource_' + i + '_' + x);
|
jsMedia.downloadRawData(currentItem.rawSources[x], 'mediasource_' + i + '_' + x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
currentItem.downloaded = true;
|
currentItem.downloaded = true;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
evanEnv.downloadMediaSource = function (mediaSource) {
|
jsMedia.downloadMediaSource = function (mediaSource) {
|
||||||
for (var x = 0; x < mediaSource.rawSources.length; x++) {
|
for (var x = 0; x < mediaSource.rawSources.length; x++) {
|
||||||
evanEnv.downloadRawData(mediaSource.rawSources[x], 'mediasource_' + x);
|
jsMedia.downloadRawData(mediaSource.rawSources[x], 'mediasource_' + x);
|
||||||
mediaSource.downloaded = true;
|
mediaSource.downloaded = true;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
jsMedia.setSpeed = function (speed) {
|
||||||
|
for (let i = 0, length = jsMedia.videos.length; i < length; i++) {
|
||||||
|
jsMedia.videos[i].playbackRate = 10;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
var proxy_addSourceBuffer = MediaSource.prototype.addSourceBuffer;
|
var proxy_addSourceBuffer = MediaSource.prototype.addSourceBuffer;
|
||||||
MediaSource.prototype.addSourceBuffer = function (mimeType) {
|
MediaSource.prototype.addSourceBuffer = function (mimeType) {
|
||||||
var mediaSourceThis = this;
|
var mediaSourceThis = this;
|
||||||
|
|
||||||
evanEnv.mediaSources.push(this);
|
jsMedia.mediaSources.push(this);
|
||||||
this.lastPos = 0;
|
this.lastPos = 0;
|
||||||
if (evanEnv.enableAutoDownload) {
|
if (jsMedia.enableAutoDownload) {
|
||||||
this.onsourceended = function () {
|
this.onsourceended = function () {
|
||||||
evanEnv.download();
|
jsMedia.download();
|
||||||
};
|
};
|
||||||
this.onsourceclose = function () {
|
this.onsourceclose = function () {
|
||||||
evanEnv.downloadMediaSource(this);
|
jsMedia.downloadMediaSource(this);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -100,17 +105,6 @@ evanEnv.enableAutoDownload = true;
|
|||||||
var buffList = [];
|
var buffList = [];
|
||||||
this.rawSources.push(buffList);
|
this.rawSources.push(buffList);
|
||||||
retSourceBuffer.rawData = buffList;
|
retSourceBuffer.rawData = buffList;
|
||||||
if (evanEnv.enableAutoForward) {
|
|
||||||
retSourceBuffer.onupdate = function () {
|
|
||||||
if (this.buffered != this.buffered.length > 0) {
|
|
||||||
var endPos = this.buffered.end(0);
|
|
||||||
if (endPos > 5 && endPos - mediaSourceThis.lastPos > 25) {
|
|
||||||
evanEnv.videos[0].currentTime = endPos - 3;
|
|
||||||
mediaSourceThis.lastPos = evanEnv.videos[0].currentTime;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
return retSourceBuffer;
|
return retSourceBuffer;
|
||||||
};
|
};
|
||||||
var proxy_appendBuffer = SourceBuffer.prototype.appendBuffer;
|
var proxy_appendBuffer = SourceBuffer.prototype.appendBuffer;
|
||||||
|
Loading…
Reference in New Issue
Block a user