@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.
Files changed (54) hide show
  1. package/README.md +7 -7
  2. package/dist/audio/audio-preview-iterator.d.ts +8 -2
  3. package/dist/audio-iterator-manager.d.ts +11 -6
  4. package/dist/debug-overlay/preview-overlay.d.ts +9 -4
  5. package/dist/esm/index.mjs +13759 -202
  6. package/dist/use-media-in-timeline.d.ts +3 -2
  7. package/package.json +6 -6
  8. package/dist/audio/allow-wait.js +0 -15
  9. package/dist/audio/audio-for-preview.js +0 -304
  10. package/dist/audio/audio-for-rendering.js +0 -194
  11. package/dist/audio/audio-preview-iterator.js +0 -176
  12. package/dist/audio/audio.js +0 -20
  13. package/dist/audio/props.js +0 -1
  14. package/dist/audio-extraction/audio-cache.js +0 -66
  15. package/dist/audio-extraction/audio-iterator.js +0 -132
  16. package/dist/audio-extraction/audio-manager.js +0 -113
  17. package/dist/audio-extraction/extract-audio.js +0 -132
  18. package/dist/audio-iterator-manager.js +0 -228
  19. package/dist/browser-can-use-webgl2.js +0 -13
  20. package/dist/caches.js +0 -61
  21. package/dist/calculate-playbacktime.js +0 -4
  22. package/dist/convert-audiodata/apply-volume.js +0 -17
  23. package/dist/convert-audiodata/combine-audiodata.js +0 -23
  24. package/dist/convert-audiodata/convert-audiodata.js +0 -73
  25. package/dist/convert-audiodata/resample-audiodata.js +0 -94
  26. package/dist/debug-overlay/preview-overlay.js +0 -42
  27. package/dist/extract-frame-and-audio.js +0 -101
  28. package/dist/get-sink.js +0 -15
  29. package/dist/get-time-in-seconds.js +0 -40
  30. package/dist/helpers/round-to-4-digits.js +0 -4
  31. package/dist/index.js +0 -12
  32. package/dist/is-type-of-error.js +0 -20
  33. package/dist/looped-frame.js +0 -10
  34. package/dist/media-player.js +0 -431
  35. package/dist/nonce-manager.js +0 -13
  36. package/dist/prewarm-iterator-for-looping.js +0 -56
  37. package/dist/render-timestamp-range.js +0 -9
  38. package/dist/show-in-timeline.js +0 -31
  39. package/dist/use-media-in-timeline.js +0 -103
  40. package/dist/video/props.js +0 -1
  41. package/dist/video/video-for-preview.js +0 -331
  42. package/dist/video/video-for-rendering.js +0 -263
  43. package/dist/video/video-preview-iterator.js +0 -122
  44. package/dist/video/video.js +0 -35
  45. package/dist/video-extraction/add-broadcast-channel-listener.js +0 -125
  46. package/dist/video-extraction/extract-frame-via-broadcast-channel.js +0 -113
  47. package/dist/video-extraction/extract-frame.js +0 -85
  48. package/dist/video-extraction/get-allocation-size.js +0 -6
  49. package/dist/video-extraction/get-frames-since-keyframe.js +0 -108
  50. package/dist/video-extraction/keyframe-bank.js +0 -159
  51. package/dist/video-extraction/keyframe-manager.js +0 -206
  52. package/dist/video-extraction/remember-actual-matroska-timestamps.js +0 -19
  53. package/dist/video-extraction/rotate-frame.js +0 -34
  54. 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
  [![NPM Downloads](https://img.shields.io/npm/dm/@remotion/media.svg?style=flat&color=black&label=Downloads)](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, allowWait: AllowWait | null, onBufferScheduled: (buffer: WrappedAudioBuffer) => void) => Promise<{
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, allowWait: import("./audio/allow-wait").AllowWait | null, onBufferScheduled: (buffer: WrappedAudioBuffer) => void) => Promise<{
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, fps, playbackRate, getIsPlaying, scheduleAudioNode, bufferState, }: {
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, allowWait: import("../audio/allow-wait").AllowWait | null, onBufferScheduled: (buffer: import("mediabunny").WrappedAudioBuffer) => void) => Promise<{
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, fps, playbackRate, getIsPlaying, scheduleAudioNode, bufferState, }: {
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;