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

📄 headphone.c

📁 VLC Player Source Code
💻 C
📖 第 1 页 / 共 2 页
字号:
static int Create( vlc_object_t *p_this ){    aout_filter_t * p_filter = (aout_filter_t *)p_this;    bool b_fit = true;    /* Activate this filter only with stereo devices */    if( p_filter->output.i_physical_channels            != (AOUT_CHAN_LEFT|AOUT_CHAN_RIGHT) )    {        msg_Dbg( p_filter, "filter discarded (incompatible format)" );        return VLC_EGENERIC;    }    /* Request a specific format if not already compatible */    if( p_filter->input.i_original_channels            != p_filter->output.i_original_channels )    {        b_fit = false;        p_filter->input.i_original_channels =                                        p_filter->output.i_original_channels;    }    if( p_filter->input.i_format != VLC_FOURCC('f','l','3','2')          || p_filter->output.i_format != VLC_FOURCC('f','l','3','2') )    {        b_fit = false;        p_filter->input.i_format = VLC_FOURCC('f','l','3','2');        p_filter->output.i_format = VLC_FOURCC('f','l','3','2');    }    if( p_filter->input.i_rate != p_filter->output.i_rate )    {        b_fit = false;        p_filter->input.i_rate = p_filter->output.i_rate;    }    if( p_filter->input.i_physical_channels == (AOUT_CHAN_LEFT|AOUT_CHAN_RIGHT)          && ( p_filter->input.i_original_channels & AOUT_CHAN_DOLBYSTEREO )          && ! config_GetInt ( p_filter , "headphone-dolby" ) )    {        b_fit = false;        p_filter->input.i_physical_channels = AOUT_CHAN_LEFT | AOUT_CHAN_RIGHT |                                              AOUT_CHAN_CENTER |                                              AOUT_CHAN_REARLEFT |                                              AOUT_CHAN_REARRIGHT;    }    if( !b_fit )    {        msg_Dbg( p_filter, "requesting specific format" );        return VLC_EGENERIC;    }    /* Allocate the memory needed to store the module's structure */    p_filter->p_sys = malloc( sizeof(struct aout_filter_sys_t) );    if( p_filter->p_sys == NULL )        return VLC_ENOMEM;    p_filter->p_sys->i_overflow_buffer_size = 0;    p_filter->p_sys->p_overflow_buffer = NULL;    p_filter->p_sys->i_nb_atomic_operations = 0;    p_filter->p_sys->p_atomic_operations = NULL;    if( Init( VLC_OBJECT(p_filter), p_filter->p_sys                , aout_FormatNbChannels ( &p_filter->input )                , p_filter->input.i_physical_channels                , p_filter->input.i_rate ) < 0 )    {        free( p_filter->p_sys );        return VLC_EGENERIC;    }    p_filter->pf_do_work = DoWork;    p_filter->b_in_place = 0;    return VLC_SUCCESS;}/***************************************************************************** * Destroy: deallocate resources associated with headphone downmixer *****************************************************************************/static void Destroy( vlc_object_t *p_this ){    aout_filter_t * p_filter = (aout_filter_t *)p_this;    if( p_filter->p_sys != NULL )    {        free( p_filter->p_sys->p_overflow_buffer );        free( p_filter->p_sys->p_atomic_operations );        free( p_filter->p_sys );        p_filter->p_sys = NULL;    }}/***************************************************************************** * DoWork: convert a buffer *****************************************************************************/static void DoWork( aout_instance_t * p_aout, aout_filter_t * p_filter,                    aout_buffer_t * p_in_buf, aout_buffer_t * p_out_buf ){    VLC_UNUSED(p_aout);    int i_input_nb = aout_FormatNbChannels( &p_filter->input );    int i_output_nb = aout_FormatNbChannels( &p_filter->output );    float * p_in = (float*) p_in_buf->p_buffer;    uint8_t * p_out;    uint8_t * p_overflow;    uint8_t * p_slide;    size_t i_overflow_size;     /* in bytes */    size_t i_out_size;          /* in bytes */    unsigned int i, j;    int i_source_channel_offset;    int i_dest_channel_offset;    unsigned int i_delay;    double d_amplitude_factor;    /* out buffer characterisitcs */    p_out_buf->i_nb_samples = p_in_buf->i_nb_samples;    p_out_buf->i_nb_bytes = p_in_buf->i_nb_bytes * i_output_nb / i_input_nb;    p_out = p_out_buf->p_buffer;    i_out_size = p_out_buf->i_nb_bytes;    if( p_filter->p_sys != NULL )    {        /* Slide the overflow buffer */        p_overflow = p_filter->p_sys->p_overflow_buffer;        i_overflow_size = p_filter->p_sys->i_overflow_buffer_size;        memset( p_out, 0, i_out_size );        if ( i_out_size > i_overflow_size )            memcpy( p_out, p_overflow, i_overflow_size );        else            memcpy( p_out, p_overflow, i_out_size );        p_slide = p_filter->p_sys->p_overflow_buffer;        while( p_slide < p_overflow + i_overflow_size )        {            if( p_slide + i_out_size < p_overflow + i_overflow_size )            {                memset( p_slide, 0, i_out_size );                if( p_slide + 2 * i_out_size < p_overflow + i_overflow_size )                    memcpy( p_slide, p_slide + i_out_size, i_out_size );                else                    memcpy( p_slide, p_slide + i_out_size,                            p_overflow + i_overflow_size - ( p_slide + i_out_size ) );            }            else            {                memset( p_slide, 0, p_overflow + i_overflow_size - p_slide );            }            p_slide += i_out_size;        }        /* apply the atomic operations */        for( i = 0; i < p_filter->p_sys->i_nb_atomic_operations; i++ )        {            /* shorter variable names */            i_source_channel_offset                = p_filter->p_sys->p_atomic_operations[i].i_source_channel_offset;            i_dest_channel_offset                = p_filter->p_sys->p_atomic_operations[i].i_dest_channel_offset;            i_delay = p_filter->p_sys->p_atomic_operations[i].i_delay;            d_amplitude_factor                = p_filter->p_sys->p_atomic_operations[i].d_amplitude_factor;            if( p_out_buf->i_nb_samples > i_delay )            {                /* current buffer coefficients */                for( j = 0; j < p_out_buf->i_nb_samples - i_delay; j++ )                {                    ((float*)p_out)[ (i_delay+j)*i_output_nb + i_dest_channel_offset ]                        += p_in[ j * i_input_nb + i_source_channel_offset ]                           * d_amplitude_factor;                }                /* overflow buffer coefficients */                for( j = 0; j < i_delay; j++ )                {                    ((float*)p_overflow)[ j*i_output_nb + i_dest_channel_offset ]                        += p_in[ (p_out_buf->i_nb_samples - i_delay + j)                           * i_input_nb + i_source_channel_offset ]                           * d_amplitude_factor;                }            }            else            {                /* overflow buffer coefficients only */                for( j = 0; j < p_out_buf->i_nb_samples; j++ )                {                    ((float*)p_overflow)[ (i_delay - p_out_buf->i_nb_samples + j)                        * i_output_nb + i_dest_channel_offset ]                        += p_in[ j * i_input_nb + i_source_channel_offset ]                           * d_amplitude_factor;                }            }        }    }    else    {        memset( p_out, 0, i_out_size );    }}/* * Audio filter 2 *//***************************************************************************** * OpenFilter: *****************************************************************************/static int OpenFilter( vlc_object_t *p_this ){    filter_t *p_filter = (filter_t *)p_this;    bool b_fit = true;    /* Activate this filter only with stereo devices */    if( p_filter->fmt_out.audio.i_physical_channels            != (AOUT_CHAN_LEFT|AOUT_CHAN_RIGHT) )    {        msg_Dbg( p_filter, "filter discarded (incompatible format)" );        return VLC_EGENERIC;    }    /* Request a specific format if not already compatible */    if( p_filter->fmt_in.audio.i_original_channels            != p_filter->fmt_out.audio.i_original_channels )    {        b_fit = false;        p_filter->fmt_in.audio.i_original_channels =                                        p_filter->fmt_out.audio.i_original_channels;    }    if( p_filter->fmt_in.audio.i_format != VLC_FOURCC('f','l','3','2')          || p_filter->fmt_out.audio.i_format != VLC_FOURCC('f','l','3','2') )    {        b_fit = false;        p_filter->fmt_in.audio.i_format = VLC_FOURCC('f','l','3','2');        p_filter->fmt_out.audio.i_format = VLC_FOURCC('f','l','3','2');    }    if( p_filter->fmt_in.audio.i_rate != p_filter->fmt_out.audio.i_rate )    {        b_fit = false;        p_filter->fmt_in.audio.i_rate = p_filter->fmt_out.audio.i_rate;    }    if( p_filter->fmt_in.audio.i_physical_channels == (AOUT_CHAN_LEFT|AOUT_CHAN_RIGHT)          && ( p_filter->fmt_in.audio.i_original_channels & AOUT_CHAN_DOLBYSTEREO )          && !config_GetInt( p_filter, "headphone-dolby" ) )    {        b_fit = false;        p_filter->fmt_in.audio.i_physical_channels = AOUT_CHAN_LEFT | AOUT_CHAN_RIGHT |                                              AOUT_CHAN_CENTER |                                              AOUT_CHAN_REARLEFT |                                              AOUT_CHAN_REARRIGHT;    }    if( !b_fit )    {        msg_Dbg( p_filter, "requesting specific format" );        return VLC_EGENERIC;    }    /* Allocate the memory needed to store the module's structure */    p_filter->p_sys = malloc( sizeof(struct filter_sys_t) );    if( p_filter->p_sys == NULL )        return VLC_ENOMEM;    p_filter->p_sys->i_overflow_buffer_size = 0;    p_filter->p_sys->p_overflow_buffer = NULL;    p_filter->p_sys->i_nb_atomic_operations = 0;    p_filter->p_sys->p_atomic_operations = NULL;    if( Init( VLC_OBJECT(p_filter), (struct aout_filter_sys_t *)p_filter->p_sys                , aout_FormatNbChannels ( &(p_filter->fmt_in.audio) )                , p_filter->fmt_in.audio.i_physical_channels                , p_filter->fmt_in.audio.i_rate ) < 0 )    {        free( p_filter->p_sys );        return VLC_EGENERIC;    }    p_filter->pf_audio_filter = Convert;    p_filter->fmt_out.audio.i_rate = p_filter->fmt_in.audio.i_rate;    return VLC_SUCCESS;}/***************************************************************************** * CloseFilter : deallocate data structures *****************************************************************************/static void CloseFilter( vlc_object_t *p_this ){    filter_t *p_filter = (filter_t *)p_this;    if( p_filter->p_sys != NULL )    {        free( p_filter->p_sys->p_overflow_buffer );        free( p_filter->p_sys->p_atomic_operations );        free( p_filter->p_sys );        p_filter->p_sys = NULL;    }}static block_t *Convert( filter_t *p_filter, block_t *p_block ){    aout_filter_t aout_filter;    aout_buffer_t in_buf, out_buf;    block_t *p_out;    int i_out_size;    if( !p_block || !p_block->i_samples )    {        if( p_block )            block_Release( p_block );        return NULL;    }    i_out_size = p_block->i_samples *      p_filter->fmt_out.audio.i_bitspersample/8 *        aout_FormatNbChannels( &(p_filter->fmt_out.audio) );    p_out = p_filter->pf_audio_buffer_new( p_filter, i_out_size );    if( !p_out )    {        msg_Warn( p_filter, "can't get output buffer" );        block_Release( p_block );        return NULL;    }    p_out->i_samples = p_block->i_samples;    p_out->i_dts = p_block->i_dts;    p_out->i_pts = p_block->i_pts;    p_out->i_length = p_block->i_length;    aout_filter.p_sys = (struct aout_filter_sys_t *)p_filter->p_sys;    aout_filter.input = p_filter->fmt_in.audio;    aout_filter.input.i_format = p_filter->fmt_in.i_codec;    aout_filter.output = p_filter->fmt_out.audio;    aout_filter.output.i_format = p_filter->fmt_out.i_codec;    aout_filter.b_in_place = 0;    in_buf.p_buffer = p_block->p_buffer;    in_buf.i_nb_bytes = p_block->i_buffer;    in_buf.i_nb_samples = p_block->i_samples;    out_buf.p_buffer = p_out->p_buffer;    out_buf.i_nb_bytes = p_out->i_buffer;    out_buf.i_nb_samples = p_out->i_samples;    DoWork( (aout_instance_t *)p_filter, &aout_filter, &in_buf, &out_buf );    p_out->i_buffer = out_buf.i_nb_bytes;    p_out->i_samples = out_buf.i_nb_samples;    block_Release( p_block );    return p_out;}

⌨️ 快捷键说明

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