-
Notifications
You must be signed in to change notification settings - Fork 7
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
Comments
Will check it Asap发自我的 iPad在 2023年5月11日,21:07,Kamil ***@***.***> 写道:
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?
—Reply to this email directly, view it on GitHub, or unsubscribe.You are receiving this because you are subscribed to this thread.Message ID: ***@***.***>
|
Thank you. |
@Akimyou Hey, any progress in this issue? : ) |
can you try on this branch ? https://github.com/Akimyou/ts-whammy/tree/bugfix/issue45 |
Ok, so with this change, there are no errors, but the produced video is corrupted and I can't open it. If that makes anything easier, I can send you an array of 200 base64 images for the problematic recording |
Ok, can you zip it email to me ? |
Ok, done, thanks |
can you try on parseRIFF function ? |
I have run parseRIFF for every snapshot and in every case it returned
If I put those snapshots to fromImageArrayWithOptions it creates blob, wich seems reasonable: but it's corrupted. I can't open it |
@KamilZajac , do you send the zip images to my email ? please tell me your email title. |
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 |
Can you zip the bad data to me?在 2023年7月24日,18:33,Rafael Saraceni ***@***.***> 写道:
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
—Reply to this email directly, view it on GitHub, or unsubscribe.You are receiving this because you were mentioned.Message ID: ***@***.***>
|
Hello, i have find a way to resolve this issue. I will update it ASAP. thanks. |
Fixed on: https://github.com/Akimyou/ts-whammy/releases/tag/v1.1.4 |
@Akimyou It seems to work great |
@KamilZajac , yeah, i change the demo2 use other data. please check. |
sorry for late response,can you give me an demo ?
… 2023年9月25日 04:15,Sudhir Pradhan ***@***.***> 写道:
hey I am getting "File wasn't available on site" as output from tsWhammy.fromImageArray(tempImages, 30), what is the possible cause of this error?
<https://user-images.githubusercontent.com/10247213/270189327-6f588fcf-b15a-4e5f-9aa6-2174b6216c97.png>
—
Reply to this email directly, view it on GitHub <#45 (comment)>, or unsubscribe <https://github.com/notifications/unsubscribe-auth/ADSH6RRS7MIYLXAS7QC3HT3X4CIGZANCNFSM6AAAAAAX6D22OQ>.
You are receiving this because you were mentioned.
|
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.eRIFF\x88\x02\x00\x00WEBPVP8X ...
;This leads to a problem, that a
chunkTag
inextractBitStreamFromVp8x
will beVP8
instead ofVP8
( space is on the left instead on the right )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:

The text was updated successfully, but these errors were encountered: