Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

"VP8X format error: missing VP8/VP8L chunk" even when VP8 is there #45

Closed
KamilZajac opened this issue May 11, 2023 · 18 comments
Closed

Comments

@KamilZajac
Copy link

KamilZajac commented May 11, 2023

Hi,

So I'm having a rather weird issue with the extractBitStreamFromVp8x method.
From time to time, when my app is building the video I got " VP8X format error: missing VP8/VP8L chunk " error.

I did some investigation and it turns out, that when I encode my not working base64 image with atob, there is like an extra 'n' next to the 'RIFF'
so I have RIFFn\x17\x00\x00WEBPVP8X ... while on other images I would get f.e RIFF\x88\x02\x00\x00WEBPVP8X ...;

This leads to a problem, that a chunkTag in extractBitStreamFromVp8x will be VP8 instead of VP8 ( space is on the left instead on the right )

function extractBitStreamFromVp8x(buffer) {
  /*
   32bit VP8X Chunk size
   8bit Flags: Rsv I L E X A R
   24bit Reserved
   24bit Canvas Width Minus One
   24bit Canvas Height Minus One
  */
  let offset = 4 + 1 + 3 + 3 + 3
  while (offset < buffer.length) {
    const chunkTag = buffer.substr(offset, 4);
    console.log(chunkTag); // <<---- ' VP8' instead of 'VP8 '
    offset += 4
    const chunkSize = readUint32LittleEndian(buffer, offset)
    offset += 4
    switch (chunkTag) {
      case 'VP8 ':
      case 'VP8L':
        // eslint-disable-next-line no-case-declarations
        const size = buffer.substr(offset - 4, 4)
        // eslint-disable-next-line no-case-declarations
        const body = buffer.substr(offset, chunkSize)
        return size + body
      default:
        offset += chunkSize
        break
    }
  }
    
  throw new Error('VP8X format error: missing VP8/VP8L chunk.')
}

If I manually remove this 'n' like parseRIFF(autoAtob(image.slice(23)).replace('RIFFn', 'RIFF') Then it seems to be fine, but this is a rather dirty workaround and I wonder if this can be fixed somehow?

Base64 for reference:



@Akimyou
Copy link
Owner

Akimyou commented May 14, 2023 via email

@KamilZajac
Copy link
Author

Thank you.
Not sure if this is relevant, but I've tested like a 100 of screenshots from this recording and it's not only 'n' added after RIFF but each screenshot has a random character there.
I've also tested this on original Whammy js, and it works there

@KamilZajac
Copy link
Author

@Akimyou Hey, any progress in this issue? : )

@Akimyou
Copy link
Owner

Akimyou commented May 22, 2023

can you try on this branch ? https://github.com/Akimyou/ts-whammy/tree/bugfix/issue45

@KamilZajac
Copy link
Author

Ok, so with this change, there are no errors, but the produced video is corrupted and I can't open it.
Also, recordings that previously worked, now are not working, so now I can't create any working video ; |

If that makes anything easier, I can send you an array of 200 base64 images for the problematic recording

@Akimyou
Copy link
Owner

Akimyou commented May 22, 2023

Ok, can you zip it email to me ?

@KamilZajac
Copy link
Author

Ok, done, thanks

@Akimyou
Copy link
Owner

Akimyou commented May 22, 2023

can you try on parseRIFF function ?

@KamilZajac
Copy link
Author

I have run parseRIFF for every snapshot and in every case it returned

{
    "data": [
        ":image/webp;base64,"
    ]
}

If I put those snapshots to fromImageArrayWithOptions it creates blob, wich seems reasonable:
{ size : 46698 type: "video/webm" }

but it's corrupted. I can't open it

@Akimyou
Copy link
Owner

Akimyou commented Jun 15, 2023

@KamilZajac , do you send the zip images to my email ? please tell me your email title.
I need you send me the issue images for try to fix this bug

@RafaelSencare
Copy link

Any progress on this? Just stumbled in the same problem. I have a \0 character in front of VP8 ( "\0VP8") who was making it throw 'VP8X format error: missing VP8/VP8L chunk.' but with the "fixes" I just received a black video

@Akimyou
Copy link
Owner

Akimyou commented Aug 4, 2023 via email

@KamilZajac
Copy link
Author

@Akimyou Hey, I've sent you email (@iCloud address ) once again with text document containing a list of base64 encoded images.

I was trying to fix this library, but I've end up using originial whammy-js and just rewrote it to TS. Works well

@Akimyou
Copy link
Owner

Akimyou commented Aug 11, 2023

Hello, i have find a way to resolve this issue. I will update it ASAP. thanks.

@Akimyou
Copy link
Owner

Akimyou commented Aug 11, 2023

@Akimyou Akimyou closed this as completed Aug 11, 2023
@KamilZajac
Copy link
Author

@Akimyou It seems to work great
May I ask you to close this demo2 page now, or use other images for this case? thanks

@Akimyou
Copy link
Owner

Akimyou commented Aug 11, 2023

@KamilZajac , yeah, i change the demo2 use other data. please check.

@Akimyou
Copy link
Owner

Akimyou commented Sep 28, 2023 via email

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants