⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 x264.h

📁 从FFMPEG转换而来的H264解码程序,VC下编译..
💻 H
📖 第 1 页 / 共 2 页
字号:
        int          i_me_range; /* integer pixel motion estimation search range (from predicted mv) */        int          i_mv_range; /* maximum length of a mv (in pixels). -1 = auto, based on level */        int          i_mv_range_thread; /* minimum space between threads. -1 = auto, based on number of threads. */        int          i_subpel_refine; /* subpixel motion estimation quality */        int          b_bidir_me; /* jointly optimize both MVs in B-frames */        int          b_chroma_me; /* chroma ME for subpel and mode decision in P-frames */        int          b_bframe_rdo; /* RD based mode decision for B-frames */        int          b_mixed_references; /* allow each mb partition in P-frames to have it's own reference number */        int          i_trellis;  /* trellis RD quantization */        int          b_fast_pskip; /* early SKIP detection on P-frames */        int          b_dct_decimate; /* transform coefficient thresholding on P-frames */        int          i_noise_reduction; /* adaptive pseudo-deadzone */        /* the deadzone size that will be used in luma quantization */        int          i_luma_deadzone[2]; /* {inter, intra} */        int          b_psnr;    /* compute and print PSNR stats */        int          b_ssim;    /* compute and print SSIM stats */    } analyse;    /* Rate control parameters */    struct    {        int         i_rc_method;    /* X264_RC_* */        int         i_qp_constant;  /* 0-51 */        int         i_qp_min;       /* min allowed QP value */        int         i_qp_max;       /* max allowed QP value */        int         i_qp_step;      /* max QP step between frames */        int         i_bitrate;        float       f_rf_constant;  /* 1pass VBR, nominal QP */        float       f_rate_tolerance;        int         i_vbv_max_bitrate;        int         i_vbv_buffer_size;        float       f_vbv_buffer_init;        float       f_ip_factor;        float       f_pb_factor;        /* 2pass */        int         b_stat_write;   /* Enable stat writing in psz_stat_out */        char        *psz_stat_out;        int         b_stat_read;    /* Read stat from psz_stat_in and use it */        char        *psz_stat_in;        /* 2pass params (same as ffmpeg ones) */        char        *psz_rc_eq;     /* 2 pass rate control equation */        float       f_qcompress;    /* 0.0 => cbr, 1.0 => constant qp */        float       f_qblur;        /* temporally blur quants */        float       f_complexity_blur; /* temporally blur complexity */        x264_zone_t *zones;         /* ratecontrol overrides */        int         i_zones;        /* number of zone_t's */        char        *psz_zones;     /* alternate method of specifying zones */    } rc;    /* Muxing parameters */    int b_aud;                  /* generate access unit delimiters */    int b_repeat_headers;       /* put SPS/PPS before each keyframe */    int i_sps_id;               /* SPS and PPS id number */} x264_param_t;typedef struct {    int level_idc;    int mbps;        /* max macroblock processing rate (macroblocks/sec) */    int frame_size;  /* max frame size (macroblocks) */    int dpb;         /* max decoded picture buffer (bytes) */    int bitrate;     /* max bitrate (kbit/sec) */    int cpb;         /* max vbv buffer (kbit) */    int mv_range;    /* max vertical mv component range (pixels) */    int mvs_per_2mb; /* max mvs per 2 consecutive mbs. */    int slice_rate;  /* ?? */    int bipred8x8;   /* limit bipred to >=8x8 */    int direct8x8;   /* limit b_direct to >=8x8 */    int frame_only;  /* forbid interlacing */} x264_level_t;/* all of the levels defined in the standard, terminated by .level_idc=0 */extern const x264_level_t x264_levels[];/* x264_param_default: *      fill x264_param_t with default values and do CPU detection */void    x264_param_default( x264_param_t * );/* x264_param_parse: *  set one parameter by name. *  returns 0 on success, or returns one of the following errors. *  note: BAD_VALUE occurs only if it can't even parse the value, *  numerical range is not checked until x264_encoder_open() or *  x264_encoder_reconfig(). *  value=NULL means "true" for boolean options, but is a BAD_VALUE for non-booleans. */#define X264_PARAM_BAD_NAME  (-1)#define X264_PARAM_BAD_VALUE (-2)int x264_param_parse( x264_param_t *, const char *name, const char *value );/**************************************************************************** * Picture structures and functions. ****************************************************************************/typedef struct x264_image_t{    int     i_csp;    int     i_plane;    int     i_stride[4];    uint8_t *plane[4];} x264_image_t;typedef struct x264_picture_t{    /* In: force picture type (if not auto) XXX: ignored for now     * Out: type of the picture encoded */    int     i_type;    /* In: force quantizer for > 0 */    int     i_qpplus1;    /* In: user pts, Out: pts of encoded picture (user)*/    int64_t i_pts;    /* In: raw data */    x264_image_t img;    /* */    int64_t i_sqe_y,i_sqe_u,i_sqe_v;} x264_picture_t;struct x264_frame_t;typedef void (*x264_fill_picture_t)(struct x264_frame_t *pic,void *data);/* x264_picture_alloc: *  alloc data for a picture. You must call x264_picture_clean on it. */void x264_picture_alloc( x264_picture_t *pic, int i_csp, int i_width, int i_height );/* x264_picture_clean: *  free associated resource for a x264_picture_t allocated with *  x264_picture_alloc ONLY */void x264_picture_clean( x264_picture_t *pic );/**************************************************************************** * NAL structure and functions: ****************************************************************************//* nal */enum nal_unit_type_e{    NAL_UNKNOWN = 0,    NAL_SLICE   = 1,    NAL_SLICE_DPA   = 2,    NAL_SLICE_DPB   = 3,    NAL_SLICE_DPC   = 4,    NAL_SLICE_IDR   = 5,    /* ref_idc != 0 */    NAL_SEI         = 6,    /* ref_idc == 0 */    NAL_SPS         = 7,    NAL_PPS         = 8,    NAL_AUD         = 9,    /* ref_idc == 0 for 6,9,10,11,12 */};enum nal_priority_e{    NAL_PRIORITY_DISPOSABLE = 0,    NAL_PRIORITY_LOW        = 1,    NAL_PRIORITY_HIGH       = 2,    NAL_PRIORITY_HIGHEST    = 3,};typedef struct x264_nal_t{    int i_ref_idc;  /* nal_priority_e */    int i_type;     /* nal_unit_type_e */    /* This data are raw payload */    int     i_payload;    uint8_t *p_payload;} x264_nal_t;/* x264_nal_encode: *      encode a nal into a buffer, setting the size. *      if b_annexeb then a long synch work is added *      XXX: it currently doesn't check for overflow */int x264_nal_encode( void *, int *, int b_annexeb, x264_nal_t *nal );/* x264_nal_decode: *      decode a buffer nal into a x264_nal_t */int x264_nal_decode( x264_nal_t *nal, void *, int );/**************************************************************************** * Encoder functions: ****************************************************************************//* x264_encoder_open: *      create a new encoder handler, all parameters from x264_param_t are copied */x264_t *x264_encoder_open   ( x264_param_t * );/* x264_encoder_reconfig: *      change encoder options while encoding, *      analysis-related parameters from x264_param_t are copied */int     x264_encoder_reconfig( x264_t *, x264_param_t * );/* x264_encoder_headers: *      return the SPS and PPS that will be used for the whole stream */int     x264_encoder_headers( x264_t *, x264_nal_t **, int * );/* x264_encoder_encode: *      encode one picture */int     x264_encoder_encode ( x264_t *, x264_nal_t **, int *, x264_fill_picture_t pic_in_fill, void *pic_in_fill_data,x264_picture_t * );/* x264_encoder_close: *      close an encoder handler */void    x264_encoder_close  ( x264_t * );#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -