opt.c

来自「64-bits H.264 from ffmpeg 2008 version B」· C语言 代码 · 共 447 行 · 第 1/2 页

C
447
字号
//
///**
// *
// * @param buf a buffer which is used for returning non string values as strings, can be NULL
// * @param buf_len allocated length in bytes of buf
// */
//const char *av_get_string(void *obj, const char *name, const AVOption **o_out, char *buf, int buf_len){
//    const AVOption *o= av_find_opt(obj, name, NULL, 0, 0);
//    void *dst;
//    uint8_t *bin;
//    int len, i;
//    if(!o || o->offset<=0)
//        return NULL;
//    if(o->type != FF_OPT_TYPE_STRING && (!buf || !buf_len))
//        return NULL;
//
//    dst= ((uint8_t*)obj) + o->offset;
//    if(o_out) *o_out= o;
//
//    switch(o->type){
//    case FF_OPT_TYPE_FLAGS:     snprintf(buf, buf_len, "0x%08X",*(int    *)dst);break;
//    case FF_OPT_TYPE_INT:       snprintf(buf, buf_len, "%d" , *(int    *)dst);break;
//    case FF_OPT_TYPE_INT64:     snprintf(buf, buf_len, "%"PRId64, *(int64_t*)dst);break;
//    case FF_OPT_TYPE_FLOAT:     snprintf(buf, buf_len, "%f" , *(float  *)dst);break;
//    case FF_OPT_TYPE_DOUBLE:    snprintf(buf, buf_len, "%f" , *(double *)dst);break;
//    case FF_OPT_TYPE_RATIONAL:  snprintf(buf, buf_len, "%d/%d", ((AVRational*)dst)->num, ((AVRational*)dst)->den);break;
//    case FF_OPT_TYPE_STRING:    return *(void**)dst;
//    case FF_OPT_TYPE_BINARY:
//        len = *(int*)(((uint8_t *)dst) + sizeof(uint8_t *));
//        if(len >= (buf_len + 1)/2) return NULL;
//        bin = *(uint8_t**)dst;
//        for(i = 0; i < len; i++) snprintf(buf + i*2, 3, "%02X", bin[i]);
//        break;
//    default: return NULL;
//    }
//    return buf;
//}
//
//static int av_get_number(void *obj, const char *name, const AVOption **o_out, double *num, int *den, int64_t *intnum){
//    const AVOption *o= av_find_opt(obj, name, NULL, 0, 0);
//    void *dst;
//    if(!o || o->offset<=0)
//        goto error;
//
//    dst= ((uint8_t*)obj) + o->offset;
//
//    if(o_out) *o_out= o;
//
//    switch(o->type){
//    case FF_OPT_TYPE_FLAGS:     *intnum= *(unsigned int*)dst;return 0;
//    case FF_OPT_TYPE_INT:       *intnum= *(int    *)dst;return 0;
//    case FF_OPT_TYPE_INT64:     *intnum= *(int64_t*)dst;return 0;
//    case FF_OPT_TYPE_FLOAT:     *num=    *(float  *)dst;return 0;
//    case FF_OPT_TYPE_DOUBLE:    *num=    *(double *)dst;return 0;
//    case FF_OPT_TYPE_RATIONAL:  *intnum= ((AVRational*)dst)->num;
//                                *den   = ((AVRational*)dst)->den;
//                                                        return 0;
//    }
//error:
//    *den=*intnum=0;
//    return -1;
//}
//
//double av_get_double(void *obj, const char *name, const AVOption **o_out){
//    int64_t intnum=1;
//    double num=1;
//    int den=1;
//
//    av_get_number(obj, name, o_out, &num, &den, &intnum);
//    return num*intnum/den;
//}
//
//AVRational av_get_q(void *obj, const char *name, const AVOption **o_out){
//    int64_t intnum=1;
//    double num=1;
//    int den=1;
//
//    av_get_number(obj, name, o_out, &num, &den, &intnum);
//    if(num == 1.0 && (int)intnum == intnum)
//        return (AVRational){intnum, den};
//    else
//        return av_d2q(num*intnum/den, 1<<24);
//}
//
//int64_t av_get_int(void *obj, const char *name, const AVOption **o_out){
//    int64_t intnum=1;
//    double num=1;
//    int den=1;
//
//    av_get_number(obj, name, o_out, &num, &den, &intnum);
//    return num*intnum/den;
//}
//
//static void opt_list(void *obj, void *av_log_obj, const char *unit)
//{
//    const AVOption *opt=NULL;
//
//    while((opt= av_next_option(obj, opt))){
//        if(!(opt->flags & (AV_OPT_FLAG_ENCODING_PARAM|AV_OPT_FLAG_DECODING_PARAM)))
//            continue;
//
//        /* Don't print CONST's on level one.
//         * Don't print anything but CONST's on level two.
//         * Only print items from the requested unit.
//         */
//        if (!unit && opt->type==FF_OPT_TYPE_CONST)
//            continue;
//        else if (unit && opt->type!=FF_OPT_TYPE_CONST)
//            continue;
//        else if (unit && opt->type==FF_OPT_TYPE_CONST && strcmp(unit, opt->unit))
//            continue;
//        else if (unit && opt->type == FF_OPT_TYPE_CONST)
//            av_log(av_log_obj, AV_LOG_INFO, "   %-15s ", opt->name);
//        else
//            av_log(av_log_obj, AV_LOG_INFO, "-%-17s ", opt->name);
//
//        switch( opt->type )
//        {
//            case FF_OPT_TYPE_FLAGS:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<flags>" );
//                break;
//            case FF_OPT_TYPE_INT:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<int>" );
//                break;
//            case FF_OPT_TYPE_INT64:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<int64>" );
//                break;
//            case FF_OPT_TYPE_DOUBLE:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<double>" );
//                break;
//            case FF_OPT_TYPE_FLOAT:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<float>" );
//                break;
//            case FF_OPT_TYPE_STRING:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<string>" );
//                break;
//            case FF_OPT_TYPE_RATIONAL:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<rational>" );
//                break;
//            case FF_OPT_TYPE_BINARY:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<binary>" );
//                break;
//            case FF_OPT_TYPE_CONST:
//            default:
//                av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "" );
//                break;
//        }
//        av_log(av_log_obj, AV_LOG_INFO, "%c", (opt->flags & AV_OPT_FLAG_ENCODING_PARAM) ? 'E' : '.');
//        av_log(av_log_obj, AV_LOG_INFO, "%c", (opt->flags & AV_OPT_FLAG_DECODING_PARAM) ? 'D' : '.');
//        av_log(av_log_obj, AV_LOG_INFO, "%c", (opt->flags & AV_OPT_FLAG_VIDEO_PARAM   ) ? 'V' : '.');
//        av_log(av_log_obj, AV_LOG_INFO, "%c", (opt->flags & AV_OPT_FLAG_AUDIO_PARAM   ) ? 'A' : '.');
//        av_log(av_log_obj, AV_LOG_INFO, "%c", (opt->flags & AV_OPT_FLAG_SUBTITLE_PARAM) ? 'S' : '.');
//
//        if(opt->help)
//            av_log(av_log_obj, AV_LOG_INFO, " %s", opt->help);
//        av_log(av_log_obj, AV_LOG_INFO, "\n");
//        if (opt->unit && opt->type != FF_OPT_TYPE_CONST) {
//            opt_list(obj, av_log_obj, opt->unit);
//        }
//    }
//}
//
//int av_opt_show(void *obj, void *av_log_obj){
//    if(!obj)
//        return -1;
//
//    av_log(av_log_obj, AV_LOG_INFO, "%s AVOptions:\n", (*(AVClass**)obj)->class_name);
//
//    opt_list(obj, av_log_obj, NULL);
//
//    return 0;
//}
//
///** Set the values of the AVCodecContext or AVFormatContext structure.
// * They are set to the defaults specified in the according AVOption options
// * array default_val field.
// *
// * @param s AVCodecContext or AVFormatContext for which the defaults will be set
// */
void av_opt_set_defaults2(void *s, int mask, int flags)
{
    const AVOption *opt = NULL;
    while ((opt = av_next_option(s, opt)) != NULL) {
        if((opt->flags & mask) != flags)
            continue;
        switch(opt->type) {
            case FF_OPT_TYPE_CONST:
                /* Nothing to be done here */
            break;
            case FF_OPT_TYPE_FLAGS:
            case FF_OPT_TYPE_INT: {
                int val;
                val = (int)opt->default_val;
                av_set_int(s, opt->name, val);
            }
            break;
            case FF_OPT_TYPE_FLOAT: {
                double val;
                val = opt->default_val;
                av_set_double(s, opt->name, val);
            }
            break;
            case FF_OPT_TYPE_RATIONAL: {
                AVRational val;
                val = av_d2q(opt->default_val, INT_MAX);
                av_set_q(s, opt->name, val);
            }
            break;
            case FF_OPT_TYPE_STRING:
            case FF_OPT_TYPE_BINARY:
                /* Cannot set default for string as default_val is of type * double */
            break;
            default:
                av_log(s, AV_LOG_DEBUG, "AVOption type %d of option %s not implemented yet\n", opt->type, opt->name);
        }
    }
}
//
//void av_opt_set_defaults(void *s){
//    av_opt_set_defaults2(s, 0, 0);
//}
//

⌨️ 快捷键说明

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