1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
/*===========================================================================*
* frame.h *
* *
* basic frames procedures *
* *
*===========================================================================*/
/*
* Copyright (c) 1995 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 FRAME_INCLUDED
#define FRAME_INCLUDED
/*==============*
* HEADER FILES *
*==============*/
#include "general.h"
#include "ansi.h"
#include "mtypes.h"
/*===========*
* CONSTANTS *
*===========*/
#define TYPE_IFRAME 2
#define TYPE_PFRAME 3
#define TYPE_BFRAME 4
/*=======================*
* STRUCTURE DEFINITIONS *
*=======================*/
typedef struct mpegFrame {
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 */
uint8 **ppm_data;
xel **rgb_data; /* pnm format -- see pbmplus docs */
xelval rgb_maxval; /* largest value of any pixel index */
int rgb_format; /* more info from pnm */
/*
* 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.
*/
Block **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 */
struct mpegFrame *next; /* points to the next B-frame to be encoded, if
* stdin is used as the input.
*/
} MpegFrame;
extern MpegFrame *Frame_New _ANSI_ARGS_((int id, int type));
extern void Frame_Init _ANSI_ARGS_((void));
extern void Frame_Free _ANSI_ARGS_((MpegFrame *frame));
extern void Frame_Exit _ANSI_ARGS_((void));
extern void Frame_AllocPPM _ANSI_ARGS_((MpegFrame * frame));
extern void Frame_AllocYCC _ANSI_ARGS_((MpegFrame * mf));
extern void Frame_AllocDecoded _ANSI_ARGS_((MpegFrame *frame,
boolean makeReference));
extern void Frame_AllocHalf _ANSI_ARGS_((MpegFrame *frame));
extern void Frame_AllocBlocks _ANSI_ARGS_((MpegFrame *mf));
extern void Frame_Resize _ANSI_ARGS_((MpegFrame *omf, MpegFrame *mf,
int insize_x, int insize_y,
int outsize_x, int outsize_y));
#endif /* FRAME_INCLUDED */
|