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

📄 ffplay.c

📁 symbian下ffmpeg编程。。废了好大劲下下来的!。
💻 C
📖 第 1 页 / 共 5 页
字号:
        }        if (is->paused && ic->iformat == &rtsp_demuxer) {            /* wait 10 ms to avoid trying to get another packet */            /* XXX: horrible */            SDL_Delay(10);            continue;        }#endif        if (is->seek_req) {            ret = av_seek_frame(is->ic, -1, is->seek_pos, is->seek_flags);            if (ret < 0) {                fprintf(stderr, "%s: error while seeking\n", is->ic->filename);            }else{                if (is->audio_stream >= 0) {                    packet_queue_flush(&is->audioq);                    packet_queue_put(&is->audioq, &flush_pkt);                }                if (is->subtitle_stream >= 0) {                    packet_queue_flush(&is->subtitleq);                    packet_queue_put(&is->subtitleq, &flush_pkt);                }                if (is->video_stream >= 0) {                    packet_queue_flush(&is->videoq);                    packet_queue_put(&is->videoq, &flush_pkt);                }            }            is->seek_req = 0;        }        /* if the queue are full, no need to read more */        if (is->audioq.size > MAX_AUDIOQ_SIZE ||            is->videoq.size > MAX_VIDEOQ_SIZE ||            is->subtitleq.size > MAX_SUBTITLEQ_SIZE ||            url_feof(&ic->pb)) {            /* wait 10 ms */            SDL_Delay(10);            continue;        }        ret = av_read_frame(ic, pkt);        if (ret < 0) {            if (url_ferror(&ic->pb) == 0) {                SDL_Delay(100); /* wait for user event */                continue;            } else                break;        }        if (pkt->stream_index == is->audio_stream) {            packet_queue_put(&is->audioq, pkt);        } else if (pkt->stream_index == is->video_stream) {            packet_queue_put(&is->videoq, pkt);        } else if (pkt->stream_index == is->subtitle_stream) {            packet_queue_put(&is->subtitleq, pkt);        } else {            av_free_packet(pkt);        }    }    /* wait until the end */    while (!is->abort_request) {        SDL_Delay(100);    }    ret = 0; fail:    /* disable interrupting */    global_video_state = NULL;    /* close each stream */    if (is->audio_stream >= 0)        stream_component_close(is, is->audio_stream);    if (is->video_stream >= 0)        stream_component_close(is, is->video_stream);    if (is->subtitle_stream >= 0)        stream_component_close(is, is->subtitle_stream);    if (is->ic) {        av_close_input_file(is->ic);        is->ic = NULL; /* safety */    }    url_set_interrupt_cb(NULL);    if (ret != 0) {        SDL_Event event;        event.type = FF_QUIT_EVENT;        event.user.data1 = is;        SDL_PushEvent(&event);    }    return 0;}VideoState *stream_open(const char *filename, AVInputFormat *iformat){    VideoState *is;    is = av_mallocz(sizeof(VideoState));    if (!is)        return NULL;    pstrcpy(is->filename, sizeof(is->filename), filename);    is->iformat = iformat;    if (screen) {        is->width = screen->w;        is->height = screen->h;    }    is->ytop = 0;    is->xleft = 0;    /* start video display */    is->pictq_mutex = SDL_CreateMutex();    is->pictq_cond = SDL_CreateCond();    is->subpq_mutex = SDL_CreateMutex();    is->subpq_cond = SDL_CreateCond();    /* add the refresh timer to draw the picture */    schedule_refresh(is, 40);    is->av_sync_type = av_sync_type;    is->parse_tid = SDL_CreateThread(decode_thread, is);    if (!is->parse_tid) {        av_free(is);        return NULL;    }    return is;}void stream_close(VideoState *is){    VideoPicture *vp;    int i;    /* XXX: use a special url_shutdown call to abort parse cleanly */    is->abort_request = 1;    SDL_WaitThread(is->parse_tid, NULL);    /* free all pictures */    for(i=0;i<VIDEO_PICTURE_QUEUE_SIZE; i++) {        vp = &is->pictq[i];        if (vp->bmp) {            SDL_FreeYUVOverlay(vp->bmp);            vp->bmp = NULL;        }    }    SDL_DestroyMutex(is->pictq_mutex);    SDL_DestroyCond(is->pictq_cond);    SDL_DestroyMutex(is->subpq_mutex);    SDL_DestroyCond(is->subpq_cond);}static void stream_cycle_channel(VideoState *is, int codec_type){    AVFormatContext *ic = is->ic;    int start_index, stream_index;    AVStream *st;    if (codec_type == CODEC_TYPE_VIDEO)        start_index = is->video_stream;    else if (codec_type == CODEC_TYPE_AUDIO)        start_index = is->audio_stream;    else        start_index = is->subtitle_stream;    if (start_index < (codec_type == CODEC_TYPE_SUBTITLE ? -1 : 0))        return;    stream_index = start_index;    for(;;) {        if (++stream_index >= is->ic->nb_streams)        {            if (codec_type == CODEC_TYPE_SUBTITLE)            {                stream_index = -1;                goto the_end;            } else                stream_index = 0;        }        if (stream_index == start_index)            return;        st = ic->streams[stream_index];        if (st->codec->codec_type == codec_type) {            /* check that parameters are OK */            switch(codec_type) {            case CODEC_TYPE_AUDIO:                if (st->codec->sample_rate != 0 &&                    st->codec->channels != 0)                    goto the_end;                break;            case CODEC_TYPE_VIDEO:            case CODEC_TYPE_SUBTITLE:                goto the_end;            default:                break;            }        }    } the_end:    stream_component_close(is, start_index);    stream_component_open(is, stream_index);}/*static void toggle_full_screen(void){    int w, h, flags;    is_full_screen = !is_full_screen;    if (!fs_screen_width) {        / * use default SDL method * /        SDL_WM_ToggleFullScreen(screen);    } else {        / * use the recorded resolution * /        flags = SDL_HWSURFACE|SDL_ASYNCBLIT|SDL_HWACCEL;        if (is_full_screen) {            w = fs_screen_width;            h = fs_screen_height;            flags |= SDL_FULLSCREEN;        } else {            w = screen_width;            h = screen_height;            flags |= SDL_RESIZABLE;        }        screen = SDL_SetVideoMode(w, h, 0, flags);        cur_stream->width = w;        cur_stream->height = h;    }}*/static void toggle_pause(void){    if (cur_stream)        stream_pause(cur_stream);    step = 0;}static void step_to_next_frame(void){    if (cur_stream) {        if (cur_stream->paused)            cur_stream->paused=0;        cur_stream->video_current_pts = get_video_clock(cur_stream);    }    step = 1;}static void do_exit(void){    if (cur_stream) {        stream_close(cur_stream);        cur_stream = NULL;    }    if (show_status)        printf("\n");    SDL_Quit();    exit(0);}static void toggle_audio_display(void){    if (cur_stream) {        cur_stream->show_audio = !cur_stream->show_audio;    }}/*/ * handle an event sent by the GUI * /static void event_loop(void){    SDL_Event event;    double incr, pos, frac;    for(;;) {        SDL_WaitEvent(&event);        switch(event.type) {        case SDL_KEYDOWN:            switch(event.key.keysym.sym) {            case SDLK_ESCAPE:            case SDLK_q:                do_exit();                break;            case SDLK_f:                toggle_full_screen();                break;            case SDLK_p:            case SDLK_SPACE:                toggle_pause();                break;            case SDLK_s: //S: Step to next frame                step_to_next_frame();                break;            case SDLK_a:                if (cur_stream)                    stream_cycle_channel(cur_stream, CODEC_TYPE_AUDIO);                break;            case SDLK_v:                if (cur_stream)                    stream_cycle_channel(cur_stream, CODEC_TYPE_VIDEO);                break;            case SDLK_t:                if (cur_stream)                    stream_cycle_channel(cur_stream, CODEC_TYPE_SUBTITLE);                break;            case SDLK_w:                toggle_audio_display();                break;            case SDLK_LEFT:                incr = -10.0;                goto do_seek;            case SDLK_RIGHT:                incr = 10.0;                goto do_seek;            case SDLK_UP:                incr = 60.0;                goto do_seek;            case SDLK_DOWN:                incr = -60.0;            do_seek:                if (cur_stream) {                    if (seek_by_bytes) {                        pos = url_ftell(&cur_stream->ic->pb);                        if (cur_stream->ic->bit_rate)                            incr *= cur_stream->ic->bit_rate / 60.0;                        else                            incr *= 180000.0;                        pos += incr;                        stream_seek(cur_stream, pos, incr);                    } else {                        pos = get_master_clock(cur_stream);                        pos += incr;                        stream_seek(cur_stream, (int64_t)(pos * AV_TIME_BASE), incr);                    }                }                break;            default:                break;            }            break;        case SDL_MOUSEBUTTONDOWN:            if (cur_stream) {                int ns, hh, mm, ss;                int tns, thh, tmm, tss;                tns = cur_stream->ic->duration/1000000LL;                thh = tns/3600;                tmm = (tns%3600)/60;                tss = (tns%60);                frac = (double)event.button.x/(double)cur_stream->width;                ns = frac*tns;                hh = ns/3600;                mm = (ns%3600)/60;                ss = (ns%60);                fprintf(stderr, "Seek to %2.0f%% (%2d:%02d:%02d) of total duration (%2d:%02d:%02d)       \n", frac*100,                        hh, mm, ss, thh, tmm, tss);                stream_seek(cur_stream, (int64_t)(cur_stream->ic->start_time+frac*cur_stream->ic->duration), 0);            }            break;        case SDL_VIDEORESIZE:            if (cur_stream) {                screen = SDL_SetVideoMode(event.resize.w, event.resize.h, 0,                                          SDL_HWSURFACE|SDL_RESIZABLE|SDL_ASYNCBLIT|SDL_HWACCEL);                cur_stream->width = event.resize.w;                cur_stream->height = event.resize.h;            }            break;        case SDL_QUIT:        case FF_QUIT_EVENT:            do_exit();            break;        case FF_ALLOC_EVENT:            alloc_picture(event.user.data1);            break;        case FF_REFRESH_EVENT:            video_refresh_timer(event.user.data1);            break;        default:            break;        }    }}*//*void opt_width(const char *arg){    screen_width = atoi(arg);}void opt_height(const char *arg){    screen_height = atoi(arg);}static void opt_format(const char *arg){    file_iformat = av_find_input_format(arg);    if (!file_iformat) {        fprintf(stderr, "Unknown input format: %s\n", arg);        exit(1);    }}#ifdef CONFIG_NETWORKvoid opt_rtp_tcp(void){    / * only tcp protocol * /    rtsp_default_protocols = (1 << RTSP_PROTOCOL_RTP_TCP);}#endifvoid opt_sync(const char *arg){    if (!strcmp(arg, "audio"))        av_sync_type = AV_SYNC_AUDIO_MASTER;    else if (!strcmp(arg, "video"))        av_sync_type = AV_SYNC_VIDEO_MASTER;    else if (!strcmp(arg, "ext"))        av_sync_type = AV_SYNC_EXTERNAL_CLOCK;    else        show_help();}void opt_seek(const char *arg){    start_time = parse_date(arg, 1);}static void opt_debug(const char *arg){    av_log_set_level(99);    debug = atoi(arg);}static void opt_vismv(const char *arg){    debug_mv = atoi(arg);}static void opt_thread_count(const char *arg){    thread_count= atoi(arg);#if !defined(HAVE_THREADS)    fprintf(stderr, "Warning: not compiled with thread support, using thread emulation\n");#endif}const OptionDef options[] = {    { "h", 0, {(void*)show_help}, "show help" 

⌨️ 快捷键说明

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