working on AVI
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
#pragma once
|
||||
|
||||
#include "structs.h"
|
||||
#include <iostream>
|
||||
|
||||
// https://docs.microsoft.com/en-us/previous-versions//ms779636(v=vs.85)?redirectedfrom=MSDN
|
||||
namespace AVI {
|
||||
@@ -12,8 +13,7 @@ namespace AVI {
|
||||
bool valid = true;
|
||||
AVITypeHeader riff;
|
||||
AVITypeHeader hdrl;
|
||||
AVICommonHeader avih;
|
||||
AVIMainHeader main_hdr;
|
||||
AVIMainHeader avih;
|
||||
|
||||
struct State {
|
||||
|
||||
@@ -21,7 +21,7 @@ namespace AVI {
|
||||
|
||||
struct Video {
|
||||
uint32_t streamID;
|
||||
BitMapInfoHeader fmt;
|
||||
BitMapInfo fmt;
|
||||
} video;
|
||||
|
||||
struct Audio {
|
||||
@@ -49,14 +49,13 @@ namespace AVI {
|
||||
|
||||
read(avih);
|
||||
if (memcmp(avih.fourcc, "avih", 4) != 0) {valid = false; return;}
|
||||
if (avih.length != sizeof(main_hdr)) {valid = false; return;}
|
||||
if (avih.cb != 56) {valid = false; return;}
|
||||
|
||||
read(main_hdr);
|
||||
|
||||
uint32_t posOfStreamStart = pos;
|
||||
|
||||
for (uint32_t i = 0; i < main_hdr.streams; ++i) {
|
||||
for (uint32_t i = 0; i < avih.streams; ++i) {
|
||||
|
||||
uint32_t posOfStreamStart = pos;
|
||||
bool curStreamIsVideo = false;
|
||||
|
||||
AVITypeHeader strl;
|
||||
@@ -64,32 +63,30 @@ namespace AVI {
|
||||
if (memcmp(strl.fourcc, "LIST", 4) != 0) {valid = false; return;}
|
||||
if (memcmp(strl.type, "strl", 4) != 0) {valid = false; return;}
|
||||
|
||||
AVICommonHeader strh;
|
||||
AVIStreamHeader strh;
|
||||
read(strh);
|
||||
if (memcmp(strh.fourcc, "strh", 4) != 0) {valid = false; return;}
|
||||
|
||||
AVIStreamHeader stream_hdr;
|
||||
read(stream_hdr);
|
||||
if (memcmp(stream_hdr.type, "vids", 4) == 0) {
|
||||
if (memcmp(strh.type, "vids", 4) == 0) {
|
||||
state.video.streamID = i;
|
||||
state.streamHeaders[i] = stream_hdr;
|
||||
state.streamHeaders[i] = strh;
|
||||
curStreamIsVideo = true;
|
||||
} else if (memcmp(stream_hdr.type, "auds", 4) == 0) {
|
||||
} else if (memcmp(strh.type, "auds", 4) == 0) {
|
||||
state.audio.streamID = i;
|
||||
state.streamHeaders[i] = stream_hdr;
|
||||
state.streamHeaders[i] = strh;
|
||||
} else {
|
||||
valid = false; return;
|
||||
}
|
||||
|
||||
AVICommonHeader strf;
|
||||
read(strf);
|
||||
// ????
|
||||
uint8_t xx[8];
|
||||
read(xx);
|
||||
|
||||
// strf, depends on type (audio/video)
|
||||
if (curStreamIsVideo) {
|
||||
BitMapInfoHeader bmih;
|
||||
read(bmih);
|
||||
state.video.fmt = bmih;
|
||||
read(state.video.fmt); // BitmapInfoHeader
|
||||
} else {
|
||||
WaveFormat wf;
|
||||
read(state.audio.fmt);
|
||||
read(state.audio.fmt); // WaveFormatEx
|
||||
}
|
||||
|
||||
// seek to the next stream
|
||||
@@ -97,6 +94,13 @@ namespace AVI {
|
||||
|
||||
}
|
||||
|
||||
dumpState();
|
||||
|
||||
uint8_t tmp[128];
|
||||
read(tmp);
|
||||
|
||||
seek(pos-4);
|
||||
|
||||
AVITypeHeader movi;
|
||||
state.moviInfo.offset = pos;
|
||||
read(movi);
|
||||
@@ -124,10 +128,9 @@ namespace AVI {
|
||||
|
||||
|
||||
//seek(state.streamHeaders[state.video.streamID].start);
|
||||
AVICommonHeader chead;
|
||||
read(chead);
|
||||
//AVICommonHeader chead;
|
||||
//read(chead);
|
||||
|
||||
printf("nn");
|
||||
|
||||
}
|
||||
|
||||
@@ -153,6 +156,15 @@ namespace AVI {
|
||||
pos += size;
|
||||
}
|
||||
|
||||
|
||||
void dumpState() {
|
||||
|
||||
std::cout << "video @" << state.video.streamID << ": " << state.video.fmt.bmi_header.biWidth << "x" << state.video.fmt.bmi_header.biHeight << std::endl;
|
||||
std::cout << "audio @" << state.audio.streamID << ": " << state.audio.fmt.channels << " channels @ " << state.audio.fmt.samples_per_sec << " Hz" << std::endl;
|
||||
|
||||
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user