Changeset 3577


Ignore:
Timestamp:
May 30, 2011 8:35:42 AM (13 years ago)
Author:
ming
Message:

Fixed #1285: Add support for SDL 1.3

Location:
pjproject/branches/projects/2.0-dev
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • pjproject/branches/projects/2.0-dev/pjmedia/build/os-auto.mak.in

    r3484 r3577  
    164164# Determine whether we should compile the obj-c version of a particular source code 
    165165# 
    166 ifeq ($(AC_PJMEDIA_VIDEO),mac_os) 
    167 # Mac OS specific, use obj-c 
     166ifeq ($(AC_PJMEDIA_VIDEO),$(filter $(AC_PJMEDIA_VIDEO),mac_os iphone_os)) 
     167# Mac and iPhone OS specific, use obj-c 
    168168export PJMEDIA_VIDEODEV_OBJS += sdl_dev_m.o 
    169169else 
  • pjproject/branches/projects/2.0-dev/pjmedia/src/pjmedia-videodev/sdl_dev.c

    r3537 r3577  
    3333#   include "SDL_opengl.h" 
    3434#   define OPENGL_DEV_IDX 1 
     35#else 
     36#   define OPENGL_DEV_IDX -999 
    3537#endif 
    3638 
     
    5557{ 
    5658#if PJ_IS_BIG_ENDIAN 
    57     {PJMEDIA_FORMAT_RGBA,  0, 0xFF000000, 0xFF0000, 0xFF00, 0xFF} , 
    58     {PJMEDIA_FORMAT_RGB24, 0, 0xFF0000, 0xFF00, 0xFF, 0} , 
    59     {PJMEDIA_FORMAT_BGRA,  0, 0xFF00, 0xFF0000, 0xFF000000, 0xFF} , 
     59    {PJMEDIA_FORMAT_RGBA,  SDL_PIXELFORMAT_RGBA8888, 
     60     0xFF000000, 0xFF0000, 0xFF00, 0xFF} , 
     61    {PJMEDIA_FORMAT_RGB24, SDL_PIXELFORMAT_RGB24, 
     62     0xFF0000, 0xFF00, 0xFF, 0} , 
     63    {PJMEDIA_FORMAT_BGRA,  SDL_PIXELFORMAT_BGRA8888, 
     64     0xFF00, 0xFF0000, 0xFF000000, 0xFF} , 
    6065#else 
    61     {PJMEDIA_FORMAT_RGBA,  0, 0xFF, 0xFF00, 0xFF0000, 0xFF000000} , 
    62     {PJMEDIA_FORMAT_RGB24, 0, 0xFF, 0xFF00, 0xFF0000, 0} , 
    63     {PJMEDIA_FORMAT_BGRA,  0, 0xFF0000, 0xFF00, 0xFF, 0xFF000000} , 
    64 #endif 
    65  
    66     {PJMEDIA_FORMAT_DIB  , 0, 0xFF0000, 0xFF00, 0xFF, 0} , 
     66    {PJMEDIA_FORMAT_RGBA,  SDL_PIXELFORMAT_ABGR8888, 
     67     0xFF, 0xFF00, 0xFF0000, 0xFF000000} , 
     68    {PJMEDIA_FORMAT_RGB24, SDL_PIXELFORMAT_BGR24, 
     69     0xFF, 0xFF00, 0xFF0000, 0} , 
     70    {PJMEDIA_FORMAT_BGRA,  SDL_PIXELFORMAT_ARGB8888, 
     71     0xFF0000, 0xFF00, 0xFF, 0xFF000000} , 
     72#endif 
     73 
     74    {PJMEDIA_FORMAT_DIB  , SDL_PIXELFORMAT_RGB24, 
     75     0xFF0000, 0xFF00, 0xFF, 0} , 
    6776 
    6877    {PJMEDIA_FORMAT_YUY2, SDL_YUY2_OVERLAY, 0, 0, 0, 0} , 
     
    7584}; 
    7685 
     86#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
     87@interface SDLDelegate: NSObject 
     88{ 
     89    @public 
     90    struct sdl_stream       *strm; 
     91} 
     92 
     93- (void)sdl_init; 
     94- (void)sdl_quit; 
     95- (void)detect_new_fmt; 
     96- (int)sdl_create; 
     97- (void)sdl_destroy; 
     98- (int)handle_event; 
     99- (pj_status_t)put_frame; 
     100@end 
     101#endif 
     102 
    77103/* sdl_ device info */ 
    78104struct sdl_dev_info 
     
    90116    unsigned                     dev_count; 
    91117    struct sdl_dev_info         *dev_info; 
     118#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
     119    NSAutoreleasePool           *apool; 
     120    SDLDelegate                 *delegate; 
     121#endif 
    92122}; 
    93  
    94 #if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
    95 @interface SDLDelegate: NSObject 
    96 { 
    97     @public 
    98     struct sdl_stream       *strm; 
    99 } 
    100  
    101 - (int)sdl_thread; 
    102 - (int)handle_event; 
    103 - (pj_status_t)put_frame; 
    104 @end 
    105 #endif 
    106123 
    107124/* Video stream. */ 
     
    120137    pj_bool_t                    render_exited; 
    121138    pj_status_t                  status; 
    122  
     139    pjmedia_format              *new_fmt; 
     140 
     141#if SDL_VERSION_ATLEAST(1,3,0) 
     142    SDL_Window                  *window;            /**< Display window.    */ 
     143    SDL_Renderer                *renderer;          /**< Display renderer.  */ 
     144    SDL_Texture                 *scr_tex;           /**< Screen texture.    */ 
     145    int                          pitch;             /**< Pitch value.       */ 
     146#endif 
    123147    SDL_Rect                     rect;              /**< Display rectangle. */ 
    124148    SDL_Surface                 *screen;            /**< Display screen.    */ 
     
    126150    SDL_Overlay                 *overlay;           /**< YUV overlay.       */ 
    127151#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
     152#if SDL_VERSION_ATLEAST(1,3,0) 
     153    SDL_GLContext               *gl_context; 
     154#endif 
    128155    GLuint                       texture; 
    129156    void                        *tex_buf; 
     
    231258    struct sdl_factory *sf = (struct sdl_factory*)f; 
    232259    struct sdl_dev_info *ddi; 
    233     unsigned i; 
     260    unsigned i, j; 
     261 
     262#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
     263    sf->apool = [[NSAutoreleasePool alloc] init]; 
     264    sf->delegate = [[SDLDelegate alloc] init]; 
     265    [sf->delegate performSelectorOnMainThread:@selector(sdl_init)  
     266                  withObject:nil waitUntilDone:YES]; 
     267#else 
     268    /* Initialize the SDL library */ 
     269    if (SDL_Init(SDL_INIT_VIDEO)) { 
     270        PJ_LOG(4, (THIS_FILE, "Cannot initialize SDL")); 
     271        return PJMEDIA_EVID_INIT; 
     272    } 
     273#endif 
    234274 
    235275    sf->dev_count = 1; 
     
    245285    strncpy(ddi->info.name, "SDL renderer", sizeof(ddi->info.name)); 
    246286    ddi->info.name[sizeof(ddi->info.name)-1] = '\0'; 
    247     strncpy(ddi->info.driver, "SDL", sizeof(ddi->info.driver)); 
    248     ddi->info.driver[sizeof(ddi->info.driver)-1] = '\0'; 
    249     ddi->info.dir = PJMEDIA_DIR_RENDER; 
    250     ddi->info.has_callback = PJ_FALSE; 
    251     ddi->info.caps = PJMEDIA_VID_DEV_CAP_FORMAT | 
    252                      PJMEDIA_VID_DEV_CAP_OUTPUT_RESIZE; 
    253  
    254287    ddi->info.fmt_cnt = PJ_ARRAY_SIZE(sdl_fmts); 
    255     ddi->info.fmt = (pjmedia_format*) 
    256                     pj_pool_calloc(sf->pool, ddi->info.fmt_cnt, 
    257                                    sizeof(pjmedia_format)); 
    258     for (i = 0; i < ddi->info.fmt_cnt; i++) { 
    259         pjmedia_format *fmt = &ddi->info.fmt[i]; 
    260         pjmedia_format_init_video(fmt, sdl_fmts[i].fmt_id, 
    261                                   DEFAULT_WIDTH, DEFAULT_HEIGHT, 
    262                                   DEFAULT_FPS, 1); 
    263     } 
    264288 
    265289#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
     
    268292    strncpy(ddi->info.name, "SDL openGL renderer", sizeof(ddi->info.name)); 
    269293    ddi->info.name[sizeof(ddi->info.name)-1] = '\0'; 
    270     strncpy(ddi->info.driver, "SDL", sizeof(ddi->info.driver)); 
    271     ddi->info.driver[sizeof(ddi->info.driver)-1] = '\0'; 
    272     ddi->info.dir = PJMEDIA_DIR_RENDER; 
    273     ddi->info.has_callback = PJ_FALSE; 
    274     ddi->info.caps = PJMEDIA_VID_DEV_CAP_FORMAT; 
    275      
    276     ddi->info.fmt_cnt = PJ_ARRAY_SIZE(sdl_fmts); 
    277294    ddi->info.fmt_cnt = 1; 
    278     ddi->info.fmt = (pjmedia_format*) 
    279     pj_pool_calloc(sf->pool, ddi->info.fmt_cnt, 
    280                    sizeof(pjmedia_format)); 
    281     for (i = 0; i < ddi->info.fmt_cnt; i++) { 
    282         pjmedia_format *fmt = &ddi->info.fmt[i]; 
    283         pjmedia_format_init_video(fmt, sdl_fmts[i].fmt_id, 
    284                                   DEFAULT_WIDTH, DEFAULT_HEIGHT, 
    285                                   DEFAULT_FPS, 1); 
    286     }     
    287 #endif 
     295#endif 
     296 
     297    for (i = 0; i < sf->dev_count; i++) { 
     298        ddi = &sf->dev_info[i]; 
     299        strncpy(ddi->info.driver, "SDL", sizeof(ddi->info.driver)); 
     300        ddi->info.driver[sizeof(ddi->info.driver)-1] = '\0'; 
     301        ddi->info.dir = PJMEDIA_DIR_RENDER; 
     302        ddi->info.has_callback = PJ_FALSE; 
     303        ddi->info.caps = PJMEDIA_VID_DEV_CAP_FORMAT | 
     304                         PJMEDIA_VID_DEV_CAP_OUTPUT_RESIZE; 
     305#if SDL_VERSION_ATLEAST(1,3,0) 
     306        ddi->info.caps |= PJMEDIA_VID_DEV_CAP_OUTPUT_WINDOW; 
     307#endif 
     308 
     309        ddi->info.fmt = (pjmedia_format*) 
     310                        pj_pool_calloc(sf->pool, ddi->info.fmt_cnt, 
     311                                       sizeof(pjmedia_format)); 
     312        for (j = 0; j < ddi->info.fmt_cnt; j++) { 
     313            pjmedia_format *fmt = &ddi->info.fmt[j]; 
     314            pjmedia_format_init_video(fmt, sdl_fmts[j].fmt_id, 
     315                                      DEFAULT_WIDTH, DEFAULT_HEIGHT, 
     316                                      DEFAULT_FPS, 1); 
     317        } 
     318    } 
    288319 
    289320    PJ_LOG(4, (THIS_FILE, "SDL initialized")); 
     
    300331    sf->pool = NULL; 
    301332    pj_pool_release(pool); 
     333 
     334#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
     335    [sf->delegate performSelectorOnMainThread:@selector(sdl_quit)  
     336                  withObject:nil waitUntilDone:YES]; 
     337    [sf->delegate release]; 
     338    [sf->apool release]; 
     339#else 
     340    SDL_Quit(); 
     341#endif 
    302342 
    303343    return PJ_SUCCESS; 
     
    378418} 
    379419 
    380 static void destroy_sdl(struct sdl_stream *strm) 
     420static void destroy_sdl(struct sdl_stream *strm, pj_bool_t destroy_win) 
    381421{ 
    382422    if (strm->surf) { 
     
    393433        strm->texture = 0; 
    394434    } 
     435#endif 
     436#if SDL_VERSION_ATLEAST(1,3,0) 
     437#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
     438    if (strm->gl_context) { 
     439        SDL_GL_DeleteContext(strm->gl_context); 
     440        strm->gl_context = NULL; 
     441    } 
     442#endif 
     443    if (strm->scr_tex) { 
     444        SDL_DestroyTexture(strm->scr_tex); 
     445        strm->scr_tex = NULL; 
     446    } 
     447    if (strm->renderer) { 
     448        SDL_DestroyRenderer(strm->renderer); 
     449        strm->renderer = NULL; 
     450    } 
     451#ifndef __IPHONEOS__ 
     452    if (destroy_win) { 
     453        if (strm->window && 
     454            !(strm->param.flags & PJMEDIA_VID_DEV_CAP_OUTPUT_WINDOW)) 
     455        { 
     456            SDL_DestroyWindow(strm->window); 
     457        } 
     458        strm->window = NULL; 
     459    } 
     460#endif 
    395461#endif 
    396462} 
     
    417483    strm->rect.h = (Uint16)vfd->size.h; 
    418484 
     485    destroy_sdl(strm, PJ_FALSE); 
     486 
     487#if SDL_VERSION_ATLEAST(1,3,0) 
     488    if (!strm->window) { 
     489        Uint32 flags = SDL_WINDOW_SHOWN | SDL_WINDOW_RESIZABLE; 
     490 
     491        if (strm->param.rend_id == OPENGL_DEV_IDX) 
     492            flags |= SDL_WINDOW_OPENGL; 
     493 
     494        if (strm->param.flags & PJMEDIA_VID_DEV_CAP_OUTPUT_WINDOW) { 
     495            /* Use the window supplied by the application. */ 
     496            strm->window = SDL_CreateWindowFrom(strm->param.window); 
     497        } else { 
     498            /* Create the window where we will draw. */ 
     499            strm->window = SDL_CreateWindow("pjmedia-SDL video", 
     500                                            SDL_WINDOWPOS_CENTERED, 
     501                                            SDL_WINDOWPOS_CENTERED, 
     502                                            strm->rect.w, strm->rect.h, 
     503                                            flags); 
     504        } 
     505        if (!strm->window) 
     506            return PJMEDIA_EVID_SYSERR; 
     507    } 
     508 
     509    SDL_SetWindowSize(strm->window, strm->rect.w, strm->rect.h); 
     510 
     511    /** 
     512      * We must call SDL_CreateRenderer in order for draw calls to 
     513      * affect this window. 
     514      */ 
     515    strm->renderer = SDL_CreateRenderer(strm->window, -1, 0); 
     516    if (!strm->renderer) 
     517        return PJMEDIA_EVID_SYSERR; 
     518 
     519#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
     520    if (strm->param.rend_id == OPENGL_DEV_IDX) { 
     521        strm->gl_context = SDL_GL_CreateContext(strm->window); 
     522        if (!strm->gl_context) 
     523            return PJMEDIA_EVID_SYSERR; 
     524        SDL_GL_MakeCurrent(strm->window, strm->gl_context); 
     525    } 
     526#endif 
     527 
     528    strm->screen = SDL_GetWindowSurface(strm->window); 
     529 
     530#else 
     531 
    419532    /* Initialize the display */ 
    420533    strm->screen = SDL_SetVideoMode(strm->rect.w, strm->rect.h, 0, ( 
    421534#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
    422535                                    strm->param.rend_id == OPENGL_DEV_IDX? 
    423                                     SDL_OPENGL: 
     536                                    SDL_OPENGL | SDL_RESIZABLE: 
    424537#endif 
    425538                                    SDL_RESIZABLE | SDL_SWSURFACE)); 
     
    429542    SDL_WM_SetCaption("pjmedia-SDL video", NULL); 
    430543 
    431     destroy_sdl(strm); 
     544#endif 
    432545 
    433546#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
     
    453566        glGenTextures(1, &strm->texture); 
    454567 
     568        if (!strm->texture) 
     569            return PJMEDIA_EVID_SYSERR; 
     570 
    455571#if defined(PJ_WIN32) && PJ_WIN32 != 0 
    456572        /** 
     
    466582    } else 
    467583#endif 
     584#if SDL_VERSION_ATLEAST(1,3,0) 
     585    {     
     586        strm->scr_tex = SDL_CreateTexture(strm->renderer, sdl_info->sdl_format, 
     587                                          SDL_TEXTUREACCESS_STREAMING, 
     588                                          strm->rect.w, strm->rect.h); 
     589        if (strm->scr_tex == NULL) 
     590            return PJMEDIA_EVID_SYSERR; 
     591     
     592        strm->pitch = strm->rect.w * SDL_BYTESPERPIXEL(sdl_info->sdl_format); 
     593    } 
     594#else 
    468595    if (vfi->color_model == PJMEDIA_COLOR_MODEL_RGB) { 
    469596        strm->surf = SDL_CreateRGBSurface(SDL_SWSURFACE, 
     
    483610            return PJMEDIA_EVID_SYSERR; 
    484611    } 
     612#endif 
    485613 
    486614    return PJ_SUCCESS; 
    487615} 
    488616 
     617static void detect_fmt_change(struct sdl_stream *strm) 
     618{ 
     619    if (strm->new_fmt) { 
     620        /* Stop the stream */ 
     621        sdl_stream_stop((pjmedia_vid_dev_stream *)strm); 
     622         
     623        /* Re-initialize SDL */ 
     624        strm->status = init_sdl(strm, strm->new_fmt); 
     625         
     626        if (strm->status == PJ_SUCCESS) { 
     627            pjmedia_format_copy(&strm->param.fmt, strm->new_fmt); 
     628            /* Restart the stream */ 
     629            sdl_stream_start((pjmedia_vid_dev_stream *)strm); 
     630        } 
     631        strm->new_fmt = NULL; 
     632    } 
     633} 
     634 
    489635#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
    490636@implementation SDLDelegate 
    491 - (int)sdl_thread 
     637- (void)sdl_init 
     638{ 
     639    if (SDL_Init(SDL_INIT_VIDEO)) { 
     640        PJ_LOG(4, (THIS_FILE, "Cannot initialize SDL")); 
     641    } 
     642} 
     643 
     644- (void)sdl_quit 
     645{ 
     646    SDL_Quit(); 
     647} 
     648 
     649- (void)detect_new_fmt 
     650{ 
     651    detect_fmt_change(strm); 
     652} 
     653 
     654- (int)sdl_create 
    492655{ 
    493656#else 
     
    496659    struct sdl_stream *strm = (struct sdl_stream*)data; 
    497660#endif 
    498  
    499     /* Initialize the SDL library */ 
    500     if (SDL_Init(SDL_INIT_VIDEO)) { 
    501         PJ_LOG(4, (THIS_FILE, "Cannot initialize SDL")); 
    502         strm->status = PJMEDIA_EVID_INIT; 
    503         goto on_return; 
    504     } 
    505661 
    506662#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
     
    517673on_return: 
    518674    if (strm->status != PJ_SUCCESS) { 
    519         destroy_sdl(strm);       
    520         SDL_Quit(); 
     675        destroy_sdl(strm, PJ_TRUE); 
    521676        strm->screen = NULL; 
    522677    } 
     
    524679    return strm->status; 
    525680} 
     681 
     682- (void)sdl_destroy 
     683{ 
     684    destroy_sdl(strm, PJ_TRUE); 
     685}     
    526686 
    527687- (int)handle_event 
     
    547707#endif 
    548708#endif 
     709 
     710        detect_fmt_change(strm); 
     711         
    549712        /** 
    550713         * The event polling must be placed in the same thread that 
     
    556719 
    557720            switch(sevent.type) { 
    558                 case SDL_USEREVENT: 
    559                 { 
    560                     pjmedia_format *fmt; 
    561  
    562                     if (sevent.user.code == PJMEDIA_EVENT_NONE) { 
    563                         strm->is_quitting = PJ_TRUE; 
    564                         goto on_return; 
    565                     } 
    566  
    567                     pj_assert(sevent.user.code == PJMEDIA_VID_DEV_CAP_FORMAT); 
    568  
    569                     fmt = (pjmedia_format *)sevent.user.data1; 
    570  
    571                     /* Stop the stream */ 
    572                     sdl_stream_stop((pjmedia_vid_dev_stream *)strm); 
    573  
    574                     /* Re-initialize SDL */ 
    575                     strm->status = init_sdl(strm, fmt); 
    576  
    577                     if (strm->status == PJ_SUCCESS) { 
    578                         pjmedia_format_copy(&strm->param.fmt, fmt);  
    579                         /* Restart the stream */ 
    580                         sdl_stream_start((pjmedia_vid_dev_stream *)strm); 
    581                     } 
    582  
    583                     break; 
    584                 } 
    585  
    586721                case SDL_MOUSEBUTTONDOWN: 
    587722                    pevent.event_type = PJMEDIA_EVENT_MOUSEBUTTONDOWN; 
     
    670805#endif 
    671806on_return: 
    672     destroy_sdl(strm); 
    673     SDL_Quit(); 
     807    destroy_sdl(strm, PJ_TRUE); 
    674808    strm->screen = NULL; 
    675809 
     
    693827        glTexCoord2f(1, 1); glVertex2i(stream->rect.w, stream->rect.h); 
    694828        glEnd(); 
     829#if SDL_VERSION_ATLEAST(1,3,0) 
     830        SDL_GL_SwapWindow(stream->window); 
     831#else 
    695832        SDL_GL_SwapBuffers(); 
     833#endif 
    696834    } 
    697835} 
     
    736874        } 
    737875        SDL_BlitSurface(stream->surf, NULL, stream->screen, NULL); 
    738         SDL_UpdateRect(stream->screen, 0, 0, 0, 0); 
     876#if SDL_VERSION_ATLEAST(1,3,0) 
     877        SDL_UpdateWindowSurface(stream->window); 
     878#else 
     879        SDL_UpdateRect(stream->screen, 0, 0, 0, 0); 
     880#endif 
    739881    } else if (stream->overlay) { 
    740882        int i, sz, offset; 
     
    756898        SDL_DisplayYUVOverlay(stream->overlay, &stream->rect); 
    757899    } 
     900#if SDL_VERSION_ATLEAST(1,3,0) 
     901    else if (stream->scr_tex) { 
     902        SDL_UpdateTexture(stream->scr_tex, NULL, frame->buf, stream->pitch); 
     903        SDL_RenderClear(stream->renderer); 
     904        SDL_RenderCopy(stream->renderer, stream->scr_tex, NULL, NULL); 
     905        SDL_RenderPresent(stream->renderer); 
     906    } 
     907#endif 
    758908#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
    759909    else if (stream->param.rend_id == OPENGL_DEV_IDX) { 
     
    778928    stream->frame = frame;     
    779929    [stream->delegate performSelectorOnMainThread:@selector(put_frame)  
    780                           withObject:nil waitUntilDone:YES]; 
     930                      withObject:nil waitUntilDone:YES]; 
    781931 
    782932    return PJ_SUCCESS; 
     
    828978        strm->status = PJ_SUCCESS; 
    829979#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
    830         pj_assert(![NSThread isMainThread]); 
    831980        strm->apool = [[NSAutoreleasePool alloc] init]; 
    832981        strm->delegate = [[SDLDelegate alloc]init]; 
    833982        strm->delegate->strm = strm; 
    834         /* On Mac OS X, we need to call SDL functions in the main thread */ 
    835         [strm->delegate performSelectorOnMainThread:@selector(sdl_thread) 
     983        /* On Darwin OS, we need to call SDL functions in the main thread */ 
     984        [strm->delegate performSelectorOnMainThread:@selector(sdl_create) 
    836985                        withObject:nil waitUntilDone:YES]; 
    837986        if ((status = strm->status) != PJ_SUCCESS) { 
     
    847996 
    848997        while(strm->status == PJ_SUCCESS && !strm->surf && !strm->overlay 
     998#if SDL_VERSION_ATLEAST(1,3,0) 
     999              && !strm->scr_tex 
     1000#endif 
    8491001#if PJMEDIA_VIDEO_DEV_SDL_HAS_OPENGL 
    8501002              && !strm->texture 
     
    9391091        return PJ_SUCCESS; 
    9401092    } else if (cap == PJMEDIA_VID_DEV_CAP_FORMAT) { 
    941         SDL_Event sevent; 
    942          
    943         strm->status = PJ_TRUE; 
    944         sevent.type = SDL_USEREVENT; 
    945         sevent.user.code = PJMEDIA_VID_DEV_CAP_FORMAT; 
    946         sevent.user.data1 = (void *)pval; 
    947         SDL_PushEvent(&sevent); 
    948          
    949         while (strm->status == PJ_TRUE) 
     1093        strm->new_fmt = (pjmedia_format *)pval; 
     1094#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
     1095        [strm->delegate performSelectorOnMainThread:@selector(detect_new_fmt) 
     1096                        withObject:nil waitUntilDone:YES]; 
     1097#endif 
     1098        while (strm->new_fmt) 
    9501099            pj_thread_sleep(10); 
    9511100         
     
    9571106             * to its original format. 
    9581107             */ 
    959             strm->status = PJ_TRUE; 
    960             sevent.user.data1 = &strm->param.fmt; 
    961             SDL_PushEvent(&sevent); 
    962              
    963             while (strm->status == PJ_TRUE) 
     1108            strm->new_fmt = &strm->param.fmt; 
     1109#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
     1110            [strm->delegate performSelectorOnMainThread:@selector(detect_new_fmt) 
     1111                            withObject:nil waitUntilDone:YES]; 
     1112#endif 
     1113            while (strm->new_fmt) 
    9641114                pj_thread_sleep(10); 
    9651115             
     
    10041154    /* Wait for renderer put_frame() to finish */ 
    10051155    stream->is_running = PJ_FALSE; 
    1006     for (i=0; !stream->render_exited && i<100; ++i) 
     1156#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
     1157    if (![NSThread isMainThread]) 
     1158#endif 
     1159    for (i=0; !stream->render_exited && i<50; ++i) 
    10071160        pj_thread_sleep(10); 
    10081161 
     
    10151168{ 
    10161169    struct sdl_stream *stream = (struct sdl_stream*)strm; 
    1017     SDL_Event sevent; 
    10181170 
    10191171    PJ_ASSERT_RETURN(stream != NULL, PJ_EINVAL); 
     
    10221174 
    10231175    if (!stream->is_quitting) { 
    1024         sevent.type = SDL_USEREVENT; 
    1025         sevent.user.code = PJMEDIA_EVENT_NONE; 
    1026         SDL_PushEvent(&sevent); 
     1176        stream->is_quitting = PJ_TRUE; 
    10271177        if (stream->sdl_thread) 
    10281178            pj_thread_join(stream->sdl_thread); 
     
    10301180 
    10311181#if defined(PJ_DARWINOS) && PJ_DARWINOS!=0 
    1032     if (stream->delegate) 
     1182    if (stream->delegate) { 
     1183        [stream->delegate performSelectorOnMainThread:@selector(sdl_destroy) 
     1184                          withObject:nil waitUntilDone:YES]; 
    10331185        [stream->delegate release]; 
    1034     if (stream->apool) 
     1186        stream->delegate = NULL; 
     1187    } 
     1188    if (stream->apool) { 
    10351189        [stream->apool release]; 
     1190        stream->apool = NULL; 
     1191    } 
    10361192#endif 
    10371193    pj_pool_release(stream->pool); 
  • pjproject/branches/projects/2.0-dev/pjsip-apps/src/ipjsua/config.cfg

    r3175 r3577  
     1--auto-answer=200 
     2--video 
    13--clock-rate=8000 
  • pjproject/branches/projects/2.0-dev/pjsip-apps/src/ipjsua/ipjsua.xcodeproj/project.pbxproj

    r3312 r3577  
    1919                3A0D7ECD123DD46C009D5030 /* MainWindow-iPad.xib in Resources */ = {isa = PBXBuildFile; fileRef = 3A0D7ECC123DD46C009D5030 /* MainWindow-iPad.xib */; }; 
    2020                3A0D7F20123F2254009D5030 /* SecondView-iPad.xib in Resources */ = {isa = PBXBuildFile; fileRef = 3A0D7F1F123F2254009D5030 /* SecondView-iPad.xib */; }; 
     21                3AE06674138E6C25008EE71A /* libpjmedia-videodev-arm-apple-darwin9.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE06673138E6C25008EE71A /* libpjmedia-videodev-arm-apple-darwin9.a */; }; 
     22                3AE06681138E6F88008EE71A /* AVFoundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE06680138E6F88008EE71A /* AVFoundation.framework */; }; 
     23                3AE06683138E6FBB008EE71A /* libSDL.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE06682138E6FBB008EE71A /* libSDL.a */; }; 
     24                3AE06693138E7056008EE71A /* OpenGLES.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE06692138E7056008EE71A /* OpenGLES.framework */; }; 
     25                3AE06695138E70B9008EE71A /* libz.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE06694138E70B9008EE71A /* libz.dylib */; }; 
     26                3AE06699138E70F0008EE71A /* CoreGraphics.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE06696138E70F0008EE71A /* CoreGraphics.framework */; }; 
     27                3AE0669A138E70F0008EE71A /* CoreMedia.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE06697138E70F0008EE71A /* CoreMedia.framework */; }; 
     28                3AE0669B138E70F0008EE71A /* CoreVideo.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE06698138E70F0008EE71A /* CoreVideo.framework */; }; 
     29                3AE0669D138E710C008EE71A /* QuartzCore.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE0669C138E710C008EE71A /* QuartzCore.framework */; }; 
     30                3AE066A5138E72A4008EE71A /* libavcodec.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE0669E138E72A4008EE71A /* libavcodec.a */; }; 
     31                3AE066A6138E72A4008EE71A /* libavcore.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE0669F138E72A4008EE71A /* libavcore.a */; }; 
     32                3AE066A7138E72A4008EE71A /* libavdevice.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE066A0138E72A4008EE71A /* libavdevice.a */; }; 
     33                3AE066A8138E72A4008EE71A /* libavfilter.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE066A1138E72A4008EE71A /* libavfilter.a */; }; 
     34                3AE066A9138E72A4008EE71A /* libavformat.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE066A2138E72A4008EE71A /* libavformat.a */; }; 
     35                3AE066AA138E72A4008EE71A /* libavutil.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE066A3138E72A4008EE71A /* libavutil.a */; }; 
     36                3AE066AB138E72A4008EE71A /* libswscale.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE066A4138E72A4008EE71A /* libswscale.a */; }; 
    2137                3AE9099D11587BB900FAEAA5 /* AudioToolbox.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3AE9099C11587BB900FAEAA5 /* AudioToolbox.framework */; }; 
    2238                3AE90A2D1158B52500FAEAA5 /* pjsua_app.c in Sources */ = {isa = PBXBuildFile; fileRef = 3AE90A2C1158B52500FAEAA5 /* pjsua_app.c */; }; 
     
    6076                3A0D7ECC123DD46C009D5030 /* MainWindow-iPad.xib */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = "MainWindow-iPad.xib"; path = "Resources-iPad/MainWindow-iPad.xib"; sourceTree = "<group>"; }; 
    6177                3A0D7F1F123F2254009D5030 /* SecondView-iPad.xib */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = "SecondView-iPad.xib"; path = "Resources-iPad/SecondView-iPad.xib"; sourceTree = "<group>"; }; 
     78                3AE06673138E6C25008EE71A /* libpjmedia-videodev-arm-apple-darwin9.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = "libpjmedia-videodev-arm-apple-darwin9.a"; path = "../../../pjmedia/lib/libpjmedia-videodev-arm-apple-darwin9.a"; sourceTree = "<group>"; }; 
     79                3AE06680138E6F88008EE71A /* AVFoundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AVFoundation.framework; path = System/Library/Frameworks/AVFoundation.framework; sourceTree = SDKROOT; }; 
     80                3AE06682138E6FBB008EE71A /* libSDL.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libSDL.a; path = "../../../../../Library/Developer/Xcode/DerivedData/SDLiPhoneOS-fyjdxvchuwlpnghehmebkvasdrke/Build/Products/Debug-iphoneos/libSDL.a"; sourceTree = "<group>"; }; 
     81                3AE06692138E7056008EE71A /* OpenGLES.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = OpenGLES.framework; path = System/Library/Frameworks/OpenGLES.framework; sourceTree = SDKROOT; }; 
     82                3AE06694138E70B9008EE71A /* libz.dylib */ = {isa = PBXFileReference; lastKnownFileType = "compiled.mach-o.dylib"; name = libz.dylib; path = usr/lib/libz.dylib; sourceTree = SDKROOT; }; 
     83                3AE06696138E70F0008EE71A /* CoreGraphics.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreGraphics.framework; path = System/Library/Frameworks/CoreGraphics.framework; sourceTree = SDKROOT; }; 
     84                3AE06697138E70F0008EE71A /* CoreMedia.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreMedia.framework; path = System/Library/Frameworks/CoreMedia.framework; sourceTree = SDKROOT; }; 
     85                3AE06698138E70F0008EE71A /* CoreVideo.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreVideo.framework; path = System/Library/Frameworks/CoreVideo.framework; sourceTree = SDKROOT; }; 
     86                3AE0669C138E710C008EE71A /* QuartzCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = QuartzCore.framework; path = System/Library/Frameworks/QuartzCore.framework; sourceTree = SDKROOT; }; 
     87                3AE0669E138E72A4008EE71A /* libavcodec.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libavcodec.a; path = "../../../../video/ffmpeg-iphone/lib/libavcodec.a"; sourceTree = "<group>"; }; 
     88                3AE0669F138E72A4008EE71A /* libavcore.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libavcore.a; path = "../../../../video/ffmpeg-iphone/lib/libavcore.a"; sourceTree = "<group>"; }; 
     89                3AE066A0138E72A4008EE71A /* libavdevice.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libavdevice.a; path = "../../../../video/ffmpeg-iphone/lib/libavdevice.a"; sourceTree = "<group>"; }; 
     90                3AE066A1138E72A4008EE71A /* libavfilter.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libavfilter.a; path = "../../../../video/ffmpeg-iphone/lib/libavfilter.a"; sourceTree = "<group>"; }; 
     91                3AE066A2138E72A4008EE71A /* libavformat.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libavformat.a; path = "../../../../video/ffmpeg-iphone/lib/libavformat.a"; sourceTree = "<group>"; }; 
     92                3AE066A3138E72A4008EE71A /* libavutil.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libavutil.a; path = "../../../../video/ffmpeg-iphone/lib/libavutil.a"; sourceTree = "<group>"; }; 
     93                3AE066A4138E72A4008EE71A /* libswscale.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libswscale.a; path = "../../../../video/ffmpeg-iphone/lib/libswscale.a"; sourceTree = "<group>"; }; 
    6294                3AE9099C11587BB900FAEAA5 /* AudioToolbox.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AudioToolbox.framework; path = System/Library/Frameworks/AudioToolbox.framework; sourceTree = SDKROOT; }; 
    6395                3AE90A2C1158B52500FAEAA5 /* pjsua_app.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = pjsua_app.c; path = ../pjsua/pjsua_app.c; sourceTree = SOURCE_ROOT; }; 
     
    117149                                3AE90EBC115F7BCE00FAEAA5 /* libsrtp-arm-apple-darwin9.a in Frameworks */, 
    118150                                3A0D789F121E324E009D5030 /* CFNetwork.framework in Frameworks */, 
     151                                3AE06674138E6C25008EE71A /* libpjmedia-videodev-arm-apple-darwin9.a in Frameworks */, 
     152                                3AE06681138E6F88008EE71A /* AVFoundation.framework in Frameworks */, 
     153                                3AE06683138E6FBB008EE71A /* libSDL.a in Frameworks */, 
     154                                3AE06693138E7056008EE71A /* OpenGLES.framework in Frameworks */, 
     155                                3AE06695138E70B9008EE71A /* libz.dylib in Frameworks */, 
     156                                3AE06699138E70F0008EE71A /* CoreGraphics.framework in Frameworks */, 
     157                                3AE0669A138E70F0008EE71A /* CoreMedia.framework in Frameworks */, 
     158                                3AE0669B138E70F0008EE71A /* CoreVideo.framework in Frameworks */, 
     159                                3AE0669D138E710C008EE71A /* QuartzCore.framework in Frameworks */, 
     160                                3AE066A5138E72A4008EE71A /* libavcodec.a in Frameworks */, 
     161                                3AE066A6138E72A4008EE71A /* libavcore.a in Frameworks */, 
     162                                3AE066A7138E72A4008EE71A /* libavdevice.a in Frameworks */, 
     163                                3AE066A8138E72A4008EE71A /* libavfilter.a in Frameworks */, 
     164                                3AE066A9138E72A4008EE71A /* libavformat.a in Frameworks */, 
     165                                3AE066AA138E72A4008EE71A /* libavutil.a in Frameworks */, 
     166                                3AE066AB138E72A4008EE71A /* libswscale.a in Frameworks */, 
    119167                        ); 
    120168                        runOnlyForDeploymentPostprocessing = 0; 
     
    185233                        isa = PBXGroup; 
    186234                        children = ( 
     235                                3AE06694138E70B9008EE71A /* libz.dylib */, 
     236                                3AE0669C138E710C008EE71A /* QuartzCore.framework */, 
     237                                3AE06696138E70F0008EE71A /* CoreGraphics.framework */, 
     238                                3AE06697138E70F0008EE71A /* CoreMedia.framework */, 
     239                                3AE06698138E70F0008EE71A /* CoreVideo.framework */, 
     240                                3AE06692138E7056008EE71A /* OpenGLES.framework */, 
     241                                3AE06680138E6F88008EE71A /* AVFoundation.framework */, 
    187242                                1DF5F4DF0D08C38300B7A737 /* UIKit.framework */, 
    188243                                1D30AB110D05D00D00671497 /* Foundation.framework */, 
     
    206261                        isa = PBXGroup; 
    207262                        children = ( 
     263                                3AE0669E138E72A4008EE71A /* libavcodec.a */, 
     264                                3AE0669F138E72A4008EE71A /* libavcore.a */, 
     265                                3AE066A0138E72A4008EE71A /* libavdevice.a */, 
     266                                3AE066A1138E72A4008EE71A /* libavfilter.a */, 
     267                                3AE066A2138E72A4008EE71A /* libavformat.a */, 
     268                                3AE066A3138E72A4008EE71A /* libavutil.a */, 
     269                                3AE066A4138E72A4008EE71A /* libswscale.a */, 
     270                                3AE06682138E6FBB008EE71A /* libSDL.a */, 
    208271                                3AE90EB1115F7BCE00FAEAA5 /* libg7221codec-arm-apple-darwin9.a */, 
    209272                                3AE90EB2115F7BCE00FAEAA5 /* libilbccodec-arm-apple-darwin9.a */, 
     
    218281                                3AE90A711158C6B400FAEAA5 /* libpjmedia-audiodev-arm-apple-darwin9.a */, 
    219282                                3AE90A731158C6B400FAEAA5 /* libpjmedia-codec-arm-apple-darwin9.a */, 
     283                                3AE06673138E6C25008EE71A /* libpjmedia-videodev-arm-apple-darwin9.a */, 
    220284                                3AE90A751158C6B400FAEAA5 /* libpjnath-arm-apple-darwin9.a */, 
    221285                                3AE90A771158C6B400FAEAA5 /* libpjsip-arm-apple-darwin9.a */, 
     
    258322                        buildConfigurationList = C01FCF4E08A954540054247B /* Build configuration list for PBXProject "ipjsua" */; 
    259323                        compatibilityVersion = "Xcode 3.1"; 
     324                        developmentRegion = English; 
    260325                        hasScannedForEncodings = 1; 
     326                        knownRegions = ( 
     327                                en, 
     328                        ); 
    261329                        mainGroup = 29B97314FDCFA39411CA2CEA /* ipjsua */; 
    262330                        projectDirPath = ""; 
     
    320388                                        "\"$(SRCROOT)/../../../pjnath/lib\"", 
    321389                                        "\"$(SRCROOT)/../../../pjsip/lib\"", 
     390                                        "\"$(SDKROOT)$(SYSTEM_LIBRARY_DIR)/Frameworks/AVFoundation.framework\"", 
     391                                        "\"$(SRCROOT)/../../../../../Library/Developer/Xcode/DerivedData/SDLiPhoneOS-fyjdxvchuwlpnghehmebkvasdrke/Build/Products/Debug-iphoneos\"", 
     392                                        "\"$(SRCROOT)/../../../../video/ffmpeg-iphone/lib\"", 
    322393                                ); 
     394                                ONLY_ACTIVE_ARCH = YES; 
    323395                                PRODUCT_NAME = ipjsua; 
    324                                 SDKROOT = iphoneos3.2; 
     396                                SDKROOT = iphoneos; 
    325397                                TARGETED_DEVICE_FAMILY = "1,2"; 
    326398                        }; 
     
    345417                                        "\"$(SRCROOT)/../../../pjnath/lib\"", 
    346418                                        "\"$(SRCROOT)/../../../pjsip/lib\"", 
     419                                        "\"$(SDKROOT)$(SYSTEM_LIBRARY_DIR)/Frameworks/AVFoundation.framework\"", 
     420                                        "\"$(SRCROOT)/../../../../../Library/Developer/Xcode/DerivedData/SDLiPhoneOS-fyjdxvchuwlpnghehmebkvasdrke/Build/Products/Debug-iphoneos\"", 
     421                                        "\"$(SRCROOT)/../../../../video/ffmpeg-iphone/lib\"", 
    347422                                ); 
     423                                ONLY_ACTIVE_ARCH = YES; 
    348424                                PRODUCT_NAME = ipjsua; 
    349                                 SDKROOT = iphoneos3.2; 
     425                                SDKROOT = iphoneos; 
    350426                                TARGETED_DEVICE_FAMILY = "1,2"; 
    351427                        }; 
     
    376452                                        ../../../third_party/lib, 
    377453                                ); 
     454                                ONLY_ACTIVE_ARCH = NO; 
    378455                                OTHER_CFLAGS = ""; 
    379456                                PREBINDING = NO; 
    380                                 SDKROOT = iphoneos3.2; 
     457                                SDKROOT = iphoneos; 
    381458                        }; 
    382459                        name = Debug; 
     
    406483                                        ../../../third_party/lib, 
    407484                                ); 
     485                                ONLY_ACTIVE_ARCH = NO; 
    408486                                OTHER_CFLAGS = ""; 
    409487                                PREBINDING = NO; 
    410                                 SDKROOT = iphoneos3.2; 
     488                                SDKROOT = iphoneos; 
    411489                        }; 
    412490                        name = Release; 
Note: See TracChangeset for help on using the changeset viewer.