WIP
This commit is contained in:
@@ -3,35 +3,54 @@ import * as HME from "h264-mp4-encoder";
|
||||
class MP4 {
|
||||
private hme: Promise<HME.H264MP4Encoder>;
|
||||
private encoder: HME.H264MP4Encoder | null = null;
|
||||
private frameTime: number;
|
||||
|
||||
constructor(width: number, height: number) {
|
||||
constructor(
|
||||
private width: number,
|
||||
private height: number,
|
||||
frameTime: number = 1000
|
||||
) {
|
||||
this.hme = HME.createH264MP4Encoder();
|
||||
this.setup(width, height);
|
||||
this.frameTime = frameTime;
|
||||
}
|
||||
|
||||
async setup(width: number, height: number) {
|
||||
this.encoder = await this.hme;
|
||||
this.encoder.width = width;
|
||||
this.encoder.height = height;
|
||||
this.encoder.frameRate = 1000 / this.frameTime;
|
||||
this.encoder.quantizationParameter = 10;
|
||||
this.encoder.initialize();
|
||||
}
|
||||
|
||||
// add(frame: CanvasImageSource | string, delay: number) {
|
||||
// // this.encoder?.addFrameRgba()
|
||||
// }
|
||||
async add(data: Uint8ClampedArray, frames: number) {
|
||||
if (this.encoder === null) {
|
||||
await this.setup(this.width, this.height);
|
||||
}
|
||||
|
||||
// async render(): Promise<File> {
|
||||
// const blob = await this.video.complete();
|
||||
while (frames--) {
|
||||
this.encoder?.addFrameRgba(data);
|
||||
}
|
||||
}
|
||||
|
||||
// const timestamp = Date.now();
|
||||
async render(): Promise<File> {
|
||||
this.encoder?.finalize();
|
||||
|
||||
// const file = new File([blob], `board_${timestamp}.webm`, {
|
||||
// type: "video/webm",
|
||||
// lastModified: timestamp,
|
||||
// });
|
||||
const uint8Array = this.encoder?.FS.readFile(
|
||||
this.encoder.outputFilename
|
||||
) as Uint8Array;
|
||||
|
||||
// return file;
|
||||
// }
|
||||
const timestamp = Date.now();
|
||||
|
||||
const file = new File([uint8Array], `board_${timestamp}.mp4`, {
|
||||
type: "video/mp4",
|
||||
lastModified: timestamp,
|
||||
});
|
||||
|
||||
this.encoder?.delete();
|
||||
|
||||
return file;
|
||||
}
|
||||
}
|
||||
|
||||
export default MP4;
|
||||
|
||||
Reference in New Issue
Block a user