@remotion/media 4.0.427 → 4.0.429
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -7
- package/dist/audio/audio-preview-iterator.d.ts +8 -2
- package/dist/audio-iterator-manager.d.ts +11 -6
- package/dist/debug-overlay/preview-overlay.d.ts +9 -4
- package/dist/esm/index.mjs +13759 -202
- package/dist/use-media-in-timeline.d.ts +3 -2
- package/package.json +6 -6
- package/dist/audio/allow-wait.js +0 -15
- package/dist/audio/audio-for-preview.js +0 -304
- package/dist/audio/audio-for-rendering.js +0 -194
- package/dist/audio/audio-preview-iterator.js +0 -176
- package/dist/audio/audio.js +0 -20
- package/dist/audio/props.js +0 -1
- package/dist/audio-extraction/audio-cache.js +0 -66
- package/dist/audio-extraction/audio-iterator.js +0 -132
- package/dist/audio-extraction/audio-manager.js +0 -113
- package/dist/audio-extraction/extract-audio.js +0 -132
- package/dist/audio-iterator-manager.js +0 -228
- package/dist/browser-can-use-webgl2.js +0 -13
- package/dist/caches.js +0 -61
- package/dist/calculate-playbacktime.js +0 -4
- package/dist/convert-audiodata/apply-volume.js +0 -17
- package/dist/convert-audiodata/combine-audiodata.js +0 -23
- package/dist/convert-audiodata/convert-audiodata.js +0 -73
- package/dist/convert-audiodata/resample-audiodata.js +0 -94
- package/dist/debug-overlay/preview-overlay.js +0 -42
- package/dist/extract-frame-and-audio.js +0 -101
- package/dist/get-sink.js +0 -15
- package/dist/get-time-in-seconds.js +0 -40
- package/dist/helpers/round-to-4-digits.js +0 -4
- package/dist/index.js +0 -12
- package/dist/is-type-of-error.js +0 -20
- package/dist/looped-frame.js +0 -10
- package/dist/media-player.js +0 -431
- package/dist/nonce-manager.js +0 -13
- package/dist/prewarm-iterator-for-looping.js +0 -56
- package/dist/render-timestamp-range.js +0 -9
- package/dist/show-in-timeline.js +0 -31
- package/dist/use-media-in-timeline.js +0 -103
- package/dist/video/props.js +0 -1
- package/dist/video/video-for-preview.js +0 -331
- package/dist/video/video-for-rendering.js +0 -263
- package/dist/video/video-preview-iterator.js +0 -122
- package/dist/video/video.js +0 -35
- package/dist/video-extraction/add-broadcast-channel-listener.js +0 -125
- package/dist/video-extraction/extract-frame-via-broadcast-channel.js +0 -113
- package/dist/video-extraction/extract-frame.js +0 -85
- package/dist/video-extraction/get-allocation-size.js +0 -6
- package/dist/video-extraction/get-frames-since-keyframe.js +0 -108
- package/dist/video-extraction/keyframe-bank.js +0 -159
- package/dist/video-extraction/keyframe-manager.js +0 -206
- package/dist/video-extraction/remember-actual-matroska-timestamps.js +0 -19
- package/dist/video-extraction/rotate-frame.js +0 -34
- package/dist/video-iterator-manager.js +0 -109
package/README.md
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
# @remotion/media
|
|
2
|
-
|
|
2
|
+
|
|
3
3
|
Experimental WebCodecs-based media tags
|
|
4
|
-
|
|
4
|
+
|
|
5
5
|
[](https://npmcharts.com/compare/@remotion/media?minimal=true)
|
|
6
|
-
|
|
6
|
+
|
|
7
7
|
## Installation
|
|
8
|
-
|
|
8
|
+
|
|
9
9
|
```bash
|
|
10
10
|
npm install @remotion/media --save-exact
|
|
11
11
|
```
|
|
12
|
-
|
|
12
|
+
|
|
13
13
|
When installing a Remotion package, make sure to align the version of all `remotion` and `@remotion/*` packages to the same version.
|
|
14
14
|
Remove the `^` character from the version number to use the exact version.
|
|
15
|
-
|
|
15
|
+
|
|
16
16
|
## Usage
|
|
17
|
-
|
|
17
|
+
|
|
18
18
|
See the [documentation](https://remotion.dev/docs/media) for more information.
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import type { WrappedAudioBuffer } from 'mediabunny';
|
|
2
|
-
import { type AllowWait } from './allow-wait';
|
|
3
2
|
export declare const HEALTHY_BUFFER_THRESHOLD_SECONDS = 1;
|
|
4
3
|
export type QueuedNode = {
|
|
5
4
|
node: AudioBufferSourceNode;
|
|
@@ -26,7 +25,7 @@ export declare const makeAudioIterator: (startFromSecond: number, cache: {
|
|
|
26
25
|
from: number;
|
|
27
26
|
until: number;
|
|
28
27
|
} | null;
|
|
29
|
-
tryToSatisfySeek: (time: number,
|
|
28
|
+
tryToSatisfySeek: (time: number, onBufferScheduled: (buffer: WrappedAudioBuffer) => void) => Promise<{
|
|
30
29
|
type: "not-satisfied";
|
|
31
30
|
reason: string;
|
|
32
31
|
} | {
|
|
@@ -34,6 +33,13 @@ export declare const makeAudioIterator: (startFromSecond: number, cache: {
|
|
|
34
33
|
} | {
|
|
35
34
|
type: "satisfied";
|
|
36
35
|
}>;
|
|
36
|
+
bufferAsFarAsPossible: (onBufferScheduled: (buffer: WrappedAudioBuffer) => void, maxTimestamp: number) => Promise<{
|
|
37
|
+
type: "ended";
|
|
38
|
+
} | {
|
|
39
|
+
type: "waiting";
|
|
40
|
+
} | {
|
|
41
|
+
type: "max-reached";
|
|
42
|
+
}>;
|
|
37
43
|
addChunkForAfterResuming: (buffer: AudioBuffer, timestamp: number) => void;
|
|
38
44
|
moveQueuedChunksToPauseQueue: () => void;
|
|
39
45
|
getNumberOfChunksAfterResuming: () => number;
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import type { InputAudioTrack, WrappedAudioBuffer } from 'mediabunny';
|
|
2
|
-
import type { UseBufferState } from 'remotion';
|
|
3
2
|
import type { DelayPlaybackIfNotPremounting } from './delay-playback-if-not-premounting';
|
|
4
3
|
import type { Nonce } from './nonce-manager';
|
|
5
|
-
export declare const audioIteratorManager: ({ audioTrack, delayPlaybackHandleIfNotPremounting, sharedAudioContext, getIsLooping, getEndTime, getStartTime, updatePlaybackTime, initialMuted, }: {
|
|
4
|
+
export declare const audioIteratorManager: ({ audioTrack, delayPlaybackHandleIfNotPremounting, sharedAudioContext, getIsLooping, getEndTime, getStartTime, updatePlaybackTime, initialMuted, drawDebugOverlay, }: {
|
|
6
5
|
audioTrack: InputAudioTrack;
|
|
7
6
|
delayPlaybackHandleIfNotPremounting: () => DelayPlaybackIfNotPremounting;
|
|
8
7
|
sharedAudioContext: AudioContext;
|
|
@@ -11,6 +10,7 @@ export declare const audioIteratorManager: ({ audioTrack, delayPlaybackHandleIfN
|
|
|
11
10
|
getStartTime: () => number;
|
|
12
11
|
initialMuted: boolean;
|
|
13
12
|
updatePlaybackTime: (time: number) => void;
|
|
13
|
+
drawDebugOverlay: () => void;
|
|
14
14
|
}) => {
|
|
15
15
|
startAudioIterator: ({ nonce, playbackRate, startFromSecond, getIsPlaying, scheduleAudioNode, }: {
|
|
16
16
|
startFromSecond: number;
|
|
@@ -38,7 +38,7 @@ export declare const audioIteratorManager: ({ audioTrack, delayPlaybackHandleIfN
|
|
|
38
38
|
from: number;
|
|
39
39
|
until: number;
|
|
40
40
|
} | null;
|
|
41
|
-
tryToSatisfySeek: (time: number,
|
|
41
|
+
tryToSatisfySeek: (time: number, onBufferScheduled: (buffer: WrappedAudioBuffer) => void) => Promise<{
|
|
42
42
|
type: "not-satisfied";
|
|
43
43
|
reason: string;
|
|
44
44
|
} | {
|
|
@@ -46,18 +46,23 @@ export declare const audioIteratorManager: ({ audioTrack, delayPlaybackHandleIfN
|
|
|
46
46
|
} | {
|
|
47
47
|
type: "satisfied";
|
|
48
48
|
}>;
|
|
49
|
+
bufferAsFarAsPossible: (onBufferScheduled: (buffer: WrappedAudioBuffer) => void, maxTimestamp: number) => Promise<{
|
|
50
|
+
type: "ended";
|
|
51
|
+
} | {
|
|
52
|
+
type: "waiting";
|
|
53
|
+
} | {
|
|
54
|
+
type: "max-reached";
|
|
55
|
+
}>;
|
|
49
56
|
addChunkForAfterResuming: (buffer: AudioBuffer, timestamp: number) => void;
|
|
50
57
|
moveQueuedChunksToPauseQueue: () => void;
|
|
51
58
|
getNumberOfChunksAfterResuming: () => number;
|
|
52
59
|
} | null;
|
|
53
60
|
destroyIterator: () => void;
|
|
54
|
-
seek: ({ newTime, nonce,
|
|
61
|
+
seek: ({ newTime, nonce, playbackRate, getIsPlaying, scheduleAudioNode, }: {
|
|
55
62
|
newTime: number;
|
|
56
63
|
nonce: Nonce;
|
|
57
|
-
fps: number;
|
|
58
64
|
playbackRate: number;
|
|
59
65
|
getIsPlaying: () => boolean;
|
|
60
|
-
bufferState: UseBufferState;
|
|
61
66
|
scheduleAudioNode: (node: AudioBufferSourceNode, mediaTimestamp: number) => void;
|
|
62
67
|
}) => Promise<void>;
|
|
63
68
|
getAudioIteratorsCreated: () => number;
|
|
@@ -31,7 +31,7 @@ export declare const drawPreviewOverlay: ({ context, audioTime, audioContextStat
|
|
|
31
31
|
from: number;
|
|
32
32
|
until: number;
|
|
33
33
|
} | null;
|
|
34
|
-
tryToSatisfySeek: (time: number,
|
|
34
|
+
tryToSatisfySeek: (time: number, onBufferScheduled: (buffer: import("mediabunny").WrappedAudioBuffer) => void) => Promise<{
|
|
35
35
|
type: "not-satisfied";
|
|
36
36
|
reason: string;
|
|
37
37
|
} | {
|
|
@@ -39,18 +39,23 @@ export declare const drawPreviewOverlay: ({ context, audioTime, audioContextStat
|
|
|
39
39
|
} | {
|
|
40
40
|
type: "satisfied";
|
|
41
41
|
}>;
|
|
42
|
+
bufferAsFarAsPossible: (onBufferScheduled: (buffer: import("mediabunny").WrappedAudioBuffer) => void, maxTimestamp: number) => Promise<{
|
|
43
|
+
type: "ended";
|
|
44
|
+
} | {
|
|
45
|
+
type: "waiting";
|
|
46
|
+
} | {
|
|
47
|
+
type: "max-reached";
|
|
48
|
+
}>;
|
|
42
49
|
addChunkForAfterResuming: (buffer: AudioBuffer, timestamp: number) => void;
|
|
43
50
|
moveQueuedChunksToPauseQueue: () => void;
|
|
44
51
|
getNumberOfChunksAfterResuming: () => number;
|
|
45
52
|
} | null;
|
|
46
53
|
destroyIterator: () => void;
|
|
47
|
-
seek: ({ newTime, nonce,
|
|
54
|
+
seek: ({ newTime, nonce, playbackRate, getIsPlaying, scheduleAudioNode, }: {
|
|
48
55
|
newTime: number;
|
|
49
56
|
nonce: import("../nonce-manager").Nonce;
|
|
50
|
-
fps: number;
|
|
51
57
|
playbackRate: number;
|
|
52
58
|
getIsPlaying: () => boolean;
|
|
53
|
-
bufferState: import("remotion").UseBufferState;
|
|
54
59
|
scheduleAudioNode: (node: AudioBufferSourceNode, mediaTimestamp: number) => void;
|
|
55
60
|
}) => Promise<void>;
|
|
56
61
|
getAudioIteratorsCreated: () => number;
|