Ignore:
Timestamp:
Mar 19, 2011 5:33:21 AM (14 years ago)
Author:
ming
Message:

Re #1213 (video devices):
Modified ios_dev and qt_dev to use pjmedia_vid_dev_stream

File:
1 edited

Legend:

Unmodified
Added
Removed
  • pjproject/branches/projects/2.0-dev/pjmedia/src/pjmedia-videodev/qt_dev.m

    r3459 r3467  
    7373struct qt_stream 
    7474{ 
    75     pjmedia_vid_stream   base;              /**< Base stream           */ 
    76     pjmedia_vid_param    param;             /**< Settings              */ 
    77     pj_pool_t           *pool;              /**< Memory pool.          */ 
    78  
    79     pj_timestamp         cap_frame_ts;      /**< Captured frame tstamp */ 
    80     unsigned             cap_ts_inc;        /**< Increment             */ 
    81      
    82     pjmedia_vid_cb       vid_cb;            /**< Stream callback.      */ 
    83     void                *user_data;         /**< Application data.     */ 
     75    pjmedia_vid_dev_stream  base;           /**< Base stream           */ 
     76    pjmedia_vid_param       param;          /**< Settings              */ 
     77    pj_pool_t              *pool;           /**< Memory pool.          */ 
     78 
     79    pj_timestamp            cap_frame_ts;   /**< Captured frame tstamp */ 
     80    unsigned                cap_ts_inc;     /**< Increment             */ 
     81     
     82    pjmedia_vid_cb          vid_cb;         /**< Stream callback.      */ 
     83    void                   *user_data;      /**< Application data.     */ 
    8484 
    8585    QTCaptureSession                    *cap_session; 
     
    101101                                            unsigned index, 
    102102                                            pjmedia_vid_param *param); 
    103 static pj_status_t qt_factory_create_stream(pjmedia_vid_dev_factory *f, 
    104                                             const pjmedia_vid_param *param, 
    105                                             const pjmedia_vid_cb *cb, 
    106                                             void *user_data, 
    107                                             pjmedia_vid_stream **p_vid_strm); 
    108  
    109 static pj_status_t qt_stream_get_param(pjmedia_vid_stream *strm, 
     103static pj_status_t qt_factory_create_stream( 
     104                                        pjmedia_vid_dev_factory *f, 
     105                                        const pjmedia_vid_param *param, 
     106                                        const pjmedia_vid_cb *cb, 
     107                                        void *user_data, 
     108                                        pjmedia_vid_dev_stream **p_vid_strm); 
     109 
     110static pj_status_t qt_stream_get_param(pjmedia_vid_dev_stream *strm, 
    110111                                       pjmedia_vid_param *param); 
    111 static pj_status_t qt_stream_get_cap(pjmedia_vid_stream *strm, 
     112static pj_status_t qt_stream_get_cap(pjmedia_vid_dev_stream *strm, 
    112113                                     pjmedia_vid_dev_cap cap, 
    113114                                     void *value); 
    114 static pj_status_t qt_stream_set_cap(pjmedia_vid_stream *strm, 
     115static pj_status_t qt_stream_set_cap(pjmedia_vid_dev_stream *strm, 
    115116                                     pjmedia_vid_dev_cap cap, 
    116117                                     const void *value); 
    117 static pj_status_t qt_stream_start(pjmedia_vid_stream *strm); 
    118 static pj_status_t qt_stream_stop(pjmedia_vid_stream *strm); 
    119 static pj_status_t qt_stream_destroy(pjmedia_vid_stream *strm); 
     118static pj_status_t qt_stream_start(pjmedia_vid_dev_stream *strm); 
     119static pj_status_t qt_stream_stop(pjmedia_vid_dev_stream *strm); 
     120static pj_status_t qt_stream_destroy(pjmedia_vid_dev_stream *strm); 
    120121 
    121122/* Operations */ 
     
    130131}; 
    131132 
    132 static pjmedia_vid_stream_op stream_op = 
     133static pjmedia_vid_dev_stream_op stream_op = 
    133134{ 
    134135    &qt_stream_get_param, 
     
    302303    param->flags = PJMEDIA_VID_DEV_CAP_FORMAT; 
    303304    param->clock_rate = DEFAULT_CLOCK_RATE; 
    304     param->frame_rate.num = DEFAULT_FPS; 
    305     param->frame_rate.denum = 1; 
    306305    pj_memcpy(&param->fmt, &di->info.fmt[0], sizeof(param->fmt)); 
    307306 
     
    348347 
    349348/* API: create stream */ 
    350 static pj_status_t qt_factory_create_stream(pjmedia_vid_dev_factory *f, 
    351                                             const pjmedia_vid_param *param, 
    352                                             const pjmedia_vid_cb *cb, 
    353                                             void *user_data, 
    354                                             pjmedia_vid_stream **p_vid_strm) 
     349static pj_status_t qt_factory_create_stream( 
     350                                        pjmedia_vid_dev_factory *f, 
     351                                        const pjmedia_vid_param *param, 
     352                                        const pjmedia_vid_cb *cb, 
     353                                        void *user_data, 
     354                                        pjmedia_vid_dev_stream **p_vid_strm) 
    355355{ 
    356356    struct qt_factory *qf = (struct qt_factory*)f; 
     
    445445 
    446446        pj_assert(vfd->fps.num); 
    447         strm->cap_ts_inc = PJMEDIA_SPF2(&strm->param.clock_rate, &vfd->fps, 1); 
     447        strm->cap_ts_inc = PJMEDIA_SPF2(strm->param.clock_rate, &vfd->fps, 1); 
    448448         
    449449        [strm->video_output setMinimumVideoFrameInterval: 
     
    470470     
    471471on_error: 
    472     qt_stream_destroy((pjmedia_vid_stream *)strm); 
     472    qt_stream_destroy((pjmedia_vid_dev_stream *)strm); 
    473473     
    474474    return status; 
     
    476476 
    477477/* API: Get stream info. */ 
    478 static pj_status_t qt_stream_get_param(pjmedia_vid_stream *s, 
     478static pj_status_t qt_stream_get_param(pjmedia_vid_dev_stream *s, 
    479479                                       pjmedia_vid_param *pi) 
    480480{ 
     
    495495 
    496496/* API: get capability */ 
    497 static pj_status_t qt_stream_get_cap(pjmedia_vid_stream *s, 
     497static pj_status_t qt_stream_get_cap(pjmedia_vid_dev_stream *s, 
    498498                                     pjmedia_vid_dev_cap cap, 
    499499                                     void *pval) 
     
    515515 
    516516/* API: set capability */ 
    517 static pj_status_t qt_stream_set_cap(pjmedia_vid_stream *s, 
     517static pj_status_t qt_stream_set_cap(pjmedia_vid_dev_stream *s, 
    518518                                     pjmedia_vid_dev_cap cap, 
    519519                                     const void *pval) 
     
    534534 
    535535/* API: Start stream. */ 
    536 static pj_status_t qt_stream_start(pjmedia_vid_stream *strm) 
     536static pj_status_t qt_stream_start(pjmedia_vid_dev_stream *strm) 
    537537{ 
    538538    struct qt_stream *stream = (struct qt_stream*)strm; 
     
    553553 
    554554/* API: Stop stream. */ 
    555 static pj_status_t qt_stream_stop(pjmedia_vid_stream *strm) 
     555static pj_status_t qt_stream_stop(pjmedia_vid_dev_stream *strm) 
    556556{ 
    557557    struct qt_stream *stream = (struct qt_stream*)strm; 
     
    569569 
    570570/* API: Destroy stream. */ 
    571 static pj_status_t qt_stream_destroy(pjmedia_vid_stream *strm) 
     571static pj_status_t qt_stream_destroy(pjmedia_vid_dev_stream *strm) 
    572572{ 
    573573    struct qt_stream *stream = (struct qt_stream*)strm; 
Note: See TracChangeset for help on using the changeset viewer.