/*===========================================================================* * encoders_frames.h * * * * stuff dealing with frames * * * *===========================================================================*/ /* * Copyright (c) 1993 The Regents of the University of California. * All rights reserved. * * Permission to use, copy, modify, and distribute this software and its * documentation for any purpose, without fee, and without written agreement is * hereby granted, provided that the above copyright notice and the following * two paragraphs appear in all copies of this software. * * IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT * OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF * CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES, * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY * AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS * ON AN "AS IS" BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATION TO * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. */ #ifndef __ENCODERS_FRAME__ #define __ENCODERS_FRAME__ /*==============* * HEADER FILES * *==============*/ #include "general.h" #include "mtypes.h" /*=======================* * STRUCTURE DEFINITIONS * *=======================*/ typedef struct EncodermpegFrame { int type; char inputFileName[256]; int id; /* the frame number -- starts at 0 */ boolean inUse; /* TRUE iff this frame is currently being used */ /* FALSE means any data here can be thrashed */ /* * now, the YCrCb data. All pixel information is stored in unsigned * 8-bit pieces. We separate y, cr, and cb because cr and cb are * subsampled by a factor of 2. */ uint8 **orig_y, **orig_cr, **orig_cb; /* now, the decoded data -- relevant only if * referenceFrame == DECODED_FRAME * */ uint8 **decoded_y, **decoded_cr, **decoded_cb; /* reference data */ uint8 **ref_y, **ref_cr, **ref_cb; /* * these are the Blocks which will ultimately compose MacroBlocks. * A Block is in a format that mp_fwddct() can crunch. */ MBlock **y_blocks, **cr_blocks, **cb_blocks; /* * this is the half-pixel luminance data (for reference frames) */ uint8 **halfX, **halfY, **halfBoth; boolean halfComputed; /* TRUE iff half-pixels already computed */ } EncoderMpegFrame; typedef struct FrameTableStruct { EncoderMpegFrame *frame; /* this changes during execution */ /* the following are all initted once and never changed */ /* (they depend only on the pattern */ struct FrameTableStruct *next; struct FrameTableStruct *prev; /* nextOutput is a pointer to next frame table entry to output */ struct FrameTableStruct *nextOutput; boolean freeNow; /* TRUE iff no frames point back to this */ int number; int bFrameNumber; /* actual frame number, if a b-frame */ } FrameTable; #endif