ffmpeg provider almost works now

Originally committed to SVN as r953.
This commit is contained in:
Rodrigo Braz Monteiro 2007-03-24 02:07:06 +00:00
parent 4f1f9ccdf0
commit d7a6ca1d76
4 changed files with 64 additions and 31 deletions

View file

@ -39,9 +39,9 @@
#include "video_frame.h" #include "video_frame.h"
/////////////// /////////
// Constructor // Reset
AegiVideoFrame::AegiVideoFrame() { void AegiVideoFrame::Reset() {
for (int i=0;i<4;i++) { for (int i=0;i<4;i++) {
data[i] = NULL; data[i] = NULL;
pitch[i] = 0; pitch[i] = 0;
@ -56,14 +56,21 @@ AegiVideoFrame::AegiVideoFrame() {
} }
///////////////
// Constructor
AegiVideoFrame::AegiVideoFrame() {
Reset();
}
////////////////// //////////////////
// Create default // Create default
AegiVideoFrame::AegiVideoFrame(int width,int height,VideoFrameFormat fmt) { AegiVideoFrame::AegiVideoFrame(int width,int height,VideoFrameFormat fmt) {
AegiVideoFrame(); Reset();
format = fmt; format = fmt;
w = width; w = width;
h = height; h = height;
pitch[0] = w; pitch[0] = w * GetBpp();
Allocate(); Allocate();
for (int i=0;i<4;i++) { for (int i=0;i<4;i++) {
@ -80,14 +87,16 @@ AegiVideoFrame::AegiVideoFrame(int width,int height,VideoFrameFormat fmt) {
void AegiVideoFrame::Allocate() { void AegiVideoFrame::Allocate() {
// Get size // Get size
int height = h; int height = h;
unsigned int size = pitch[0]*height; unsigned int size;
if (format == FORMAT_YV12) size = size * 3 / 2; if (format == FORMAT_YV12) size = pitch[0] * height * 3 / 2;
else size = size * GetBpp(); else size = pitch[0] * height;
// Reallocate, if necessary // Reallocate, if necessary
if (memSize != size) { if (memSize != size) {
if (cppAlloc) delete[] data[0]; if (data[0]) {
else free(data[0]); if (cppAlloc) delete[] data[0];
else free(data[0]);
}
data[0] = new unsigned char[size]; data[0] = new unsigned char[size];
for (int i=1;i<4;i++) data[i] = NULL; for (int i=1;i<4;i++) data[i] = NULL;
memSize = size; memSize = size;

View file

@ -52,6 +52,7 @@ enum VideoFrameFormat {
class AegiVideoFrame { class AegiVideoFrame {
private: private:
unsigned int memSize; unsigned int memSize;
void Reset();
public: public:
unsigned char *data[4]; // Pointers to the data planes. Interleaved formats only use data[0] unsigned char *data[4]; // Pointers to the data planes. Interleaved formats only use data[0]

View file

@ -300,19 +300,13 @@ const AegiVideoFrame LAVCVideoProvider::DoGetFrame(int n) {
// Return stored frame // Return stored frame
n = MID(0,n,GetFrameCount()-1); n = MID(0,n,GetFrameCount()-1);
if (n == frameNumber) { if (n == frameNumber) {
if (!validFrame) { if (!validFrame) validFrame = true;
//curFrame = AVFrameToWX(frame, n); return curFrame;
validFrame = true;
}
//return curFrame;
AegiVideoFrame dummy;
return dummy;
} }
// Following frame, just get it // Following frame, just get it
if (n == frameNumber+1) { if (n == frameNumber+1) {
GetNextFrame(); GetNextFrame();
//wxLogMessage(wxString::Format(_T("%i"),lastDecodeTime));
} }
// Needs to seek // Needs to seek
@ -380,21 +374,50 @@ const AegiVideoFrame LAVCVideoProvider::DoGetFrame(int n) {
#endif #endif
} }
// Bitmap // Get frame
//wxBitmap bmp; AegiVideoFrame final;
//if (frame) bmp = AVFrameToWX(frame, n); if (frame) {
//else bmp = wxBitmap(GetWidth(),GetHeight()); // Set AegiVideoFrame
PixelFormat format = codecContext->pix_fmt;
unsigned int size = avpicture_get_size(format,codecContext->width,codecContext->height);
final.w = codecContext->width;
final.h = codecContext->height;
final.flipped = false;
final.invertChannels = false;
//// Set current frame // Set format
//validFrame = true; switch (format) {
//curFrame = bmp; case PIX_FMT_BGR24: final.invertChannels = true;
//frameNumber = n; case PIX_FMT_RGB24: final.format = FORMAT_RGB24; break;
case PIX_FMT_BGR32: final.invertChannels = true;
case PIX_FMT_RGB32: final.format = FORMAT_RGB32; break;
case PIX_FMT_YUYV422: final.format = FORMAT_YUY2; break;
case PIX_FMT_YUV420P: final.format = FORMAT_YV12; break;
}
//// Return // Allocate
//return curFrame; final.pitch[0] = final.w * final.GetBpp();
final.Allocate();
AegiVideoFrame dummy; // Copy data
return dummy; if (final.format == FORMAT_YV12) {
memcpy(final.data[0],frame->data[0],final.w * final.h);
memcpy(final.data[1],frame->data[1],final.w * final.h / 4);
memcpy(final.data[2],frame->data[2],final.w * final.h / 4);
}
else memcpy(final.data[0],frame->data[0],size);
}
// No frame available
else final = AegiVideoFrame(GetWidth(),GetHeight());
// Set current frame
validFrame = true;
curFrame = final;
frameNumber = n;
// Return
return final;
} }

View file

@ -72,7 +72,7 @@ private:
__int64 lastDecodeTime; __int64 lastDecodeTime;
int frameNumber; int frameNumber;
int length; int length;
wxBitmap curFrame; AegiVideoFrame curFrame;
bool validFrame; bool validFrame;
uint8_t *buffer1; uint8_t *buffer1;