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

📄 input.c

📁 uclinux 下的vlc播放器源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
/***************************************************************************** * input.c : internal management of input streams for the audio output ***************************************************************************** * Copyright (C) 2002-2004 the VideoLAN team * $Id: input.c 14953 2006-03-28 20:29:28Z zorglub $ * * Authors: Christophe Massiot <massiot@via.ecp.fr> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************//***************************************************************************** * Preamble *****************************************************************************/#include <stdlib.h>                            /* calloc(), malloc(), free() */#include <string.h>#include <vlc/vlc.h>#include <vlc/input.h>                 /* for input_thread_t and i_pts_delay */#ifdef HAVE_ALLOCA_H#   include <alloca.h>#endif#include "audio_output.h"#include "aout_internal.h"static void inputFailure( aout_instance_t *, aout_input_t *, char * );static int VisualizationCallback( vlc_object_t *, char const *,                                  vlc_value_t, vlc_value_t, void * );static int EqualizerCallback( vlc_object_t *, char const *,                              vlc_value_t, vlc_value_t, void * );/***************************************************************************** * aout_InputNew : allocate a new input and rework the filter pipeline *****************************************************************************/int aout_InputNew( aout_instance_t * p_aout, aout_input_t * p_input ){    audio_sample_format_t chain_input_format;    audio_sample_format_t chain_output_format;    vlc_value_t val, text;    char * psz_filters, *psz_visual;    int i_visual;    aout_FormatPrint( p_aout, "input", &p_input->input );    p_input->i_nb_filters = 0;    /* Prepare FIFO. */    aout_FifoInit( p_aout, &p_input->fifo, p_aout->mixer.mixer.i_rate );    p_input->p_first_byte_to_mix = NULL;    /* Prepare format structure */    memcpy( &chain_input_format, &p_input->input,            sizeof(audio_sample_format_t) );    memcpy( &chain_output_format, &p_aout->mixer.mixer,            sizeof(audio_sample_format_t) );    chain_output_format.i_rate = p_input->input.i_rate;    aout_FormatPrepare( &chain_output_format );    /* Now add user filters */    if( var_Type( p_aout, "visual" ) == 0 )    {        module_t *p_module;        var_Create( p_aout, "visual", VLC_VAR_STRING | VLC_VAR_HASCHOICE );        text.psz_string = _("Visualizations");        var_Change( p_aout, "visual", VLC_VAR_SETTEXT, &text, NULL );        val.psz_string = ""; text.psz_string = _("Disable");        var_Change( p_aout, "visual", VLC_VAR_ADDCHOICE, &val, &text );        val.psz_string = "spectrometer"; text.psz_string = _("Spectrometer");        var_Change( p_aout, "visual", VLC_VAR_ADDCHOICE, &val, &text );        val.psz_string = "scope"; text.psz_string = _("Scope");        var_Change( p_aout, "visual", VLC_VAR_ADDCHOICE, &val, &text );        val.psz_string = "spectrum"; text.psz_string = _("Spectrum");        var_Change( p_aout, "visual", VLC_VAR_ADDCHOICE, &val, &text );        /* Look for goom plugin */        p_module = config_FindModule( VLC_OBJECT(p_aout), "goom" );        if( p_module )        {            val.psz_string = "goom"; text.psz_string = "Goom";            var_Change( p_aout, "visual", VLC_VAR_ADDCHOICE, &val, &text );        }        /* Look for galaktos plugin */        p_module = config_FindModule( VLC_OBJECT(p_aout), "galaktos" );        if( p_module )        {            val.psz_string = "galaktos"; text.psz_string = "GaLaktos";            var_Change( p_aout, "visual", VLC_VAR_ADDCHOICE, &val, &text );        }        if( var_Get( p_aout, "effect-list", &val ) == VLC_SUCCESS )        {            var_Set( p_aout, "visual", val );            if( val.psz_string ) free( val.psz_string );        }        var_AddCallback( p_aout, "visual", VisualizationCallback, NULL );    }    if( var_Type( p_aout, "equalizer" ) == 0 )    {        module_config_t *p_config;        int i;        p_config = config_FindConfig( VLC_OBJECT(p_aout), "equalizer-preset" );        if( p_config && p_config->i_list )        {               var_Create( p_aout, "equalizer",                           VLC_VAR_STRING | VLC_VAR_HASCHOICE );            text.psz_string = _("Equalizer");            var_Change( p_aout, "equalizer", VLC_VAR_SETTEXT, &text, NULL );            val.psz_string = ""; text.psz_string = _("Disable");            var_Change( p_aout, "equalizer", VLC_VAR_ADDCHOICE, &val, &text );            for( i = 0; i < p_config->i_list; i++ )            {                val.psz_string = p_config->ppsz_list[i];                text.psz_string = p_config->ppsz_list_text[i];                var_Change( p_aout, "equalizer", VLC_VAR_ADDCHOICE,                            &val, &text );            }            var_AddCallback( p_aout, "equalizer", EqualizerCallback, NULL );        }    }    if( var_Type( p_aout, "audio-filter" ) == 0 )    {        var_Create( p_aout, "audio-filter",                    VLC_VAR_STRING | VLC_VAR_DOINHERIT );        text.psz_string = _("Audio filters");        var_Change( p_aout, "audio-filter", VLC_VAR_SETTEXT, &text, NULL );    }    if( var_Type( p_aout, "audio-visual" ) == 0 )    {        var_Create( p_aout, "audio-visual",                    VLC_VAR_STRING | VLC_VAR_DOINHERIT );        text.psz_string = _("Audio visualizations");        var_Change( p_aout, "audio-visual", VLC_VAR_SETTEXT, &text, NULL );    }    var_Get( p_aout, "audio-filter", &val );    psz_filters = val.psz_string;    var_Get( p_aout, "audio-visual", &val );    psz_visual = val.psz_string;    /* parse user filter lists */    for( i_visual = 0; i_visual < 2; i_visual++ )    {        char *psz_next = NULL;        char *psz_parser = i_visual ? psz_visual : psz_filters;        if( psz_parser == NULL || !*psz_parser )            continue;        while( psz_parser && *psz_parser )        {            aout_filter_t * p_filter = NULL;            if( p_input->i_nb_filters >= AOUT_MAX_FILTERS )            {                msg_Dbg( p_aout, "max filters reached (%d)", AOUT_MAX_FILTERS );                break;            }            while( *psz_parser == ' ' && *psz_parser == ':' )            {                psz_parser++;            }            if( ( psz_next = strchr( psz_parser , ':'  ) ) )            {                *psz_next++ = '\0';            }            if( *psz_parser =='\0' )            {                break;            }            /* Create a VLC object */            p_filter = vlc_object_create( p_aout, sizeof(aout_filter_t) );            if( p_filter == NULL )            {                msg_Err( p_aout, "cannot add user filter %s (skipped)",                         psz_parser );                psz_parser = psz_next;                continue;            }            vlc_object_attach( p_filter , p_aout );            /* try to find the requested filter */            if( i_visual == 1 ) /* this can only be a visualization module */            {                /* request format */                memcpy( &p_filter->input, &chain_output_format,                        sizeof(audio_sample_format_t) );                memcpy( &p_filter->output, &chain_output_format,                        sizeof(audio_sample_format_t) );                p_filter->p_module = module_Need( p_filter, "visualization",                                                  psz_parser, VLC_TRUE );            }            else /* this can be a audio filter module as well as a visualization module */            {                /* request format */                memcpy( &p_filter->input, &chain_input_format,                        sizeof(audio_sample_format_t) );                memcpy( &p_filter->output, &chain_output_format,                        sizeof(audio_sample_format_t) );                p_filter->p_module = module_Need( p_filter, "audio filter",                                              psz_parser, VLC_TRUE );                if ( p_filter->p_module == NULL )                {                    /* if the filter requested a special format, retry */                    if ( !( AOUT_FMTS_IDENTICAL( &p_filter->input,                                                 &chain_input_format )                            && AOUT_FMTS_IDENTICAL( &p_filter->output,                                                    &chain_output_format ) ) )                    {                        aout_FormatPrepare( &p_filter->input );                        aout_FormatPrepare( &p_filter->output );                        p_filter->p_module = module_Need( p_filter,                                                          "audio filter",                                                          psz_parser, VLC_TRUE );                    }                    /* try visual filters */                    else                    {                        memcpy( &p_filter->input, &chain_output_format,                                sizeof(audio_sample_format_t) );                        memcpy( &p_filter->output, &chain_output_format,                                sizeof(audio_sample_format_t) );                        p_filter->p_module = module_Need( p_filter,                                                          "visualization",                                                          psz_parser, VLC_TRUE );                    }                }            }            /* failure */            if ( p_filter->p_module == NULL )            {                msg_Err( p_aout, "cannot add user filter %s (skipped)",                         psz_parser );                vlc_object_detach( p_filter );                vlc_object_destroy( p_filter );                psz_parser = psz_next;                continue;            }            /* complete the filter chain if necessary */            if ( !AOUT_FMTS_IDENTICAL( &chain_input_format, &p_filter->input ) )            {                if ( aout_FiltersCreatePipeline( p_aout, p_input->pp_filters,                                                 &p_input->i_nb_filters,                                                 &chain_input_format,                                                 &p_filter->input ) < 0 )                {                    msg_Err( p_aout, "cannot add user filter %s (skipped)",                             psz_parser );                    module_Unneed( p_filter, p_filter->p_module );                    vlc_object_detach( p_filter );                    vlc_object_destroy( p_filter );                    psz_parser = psz_next;                    continue;                }            }            /* success */            p_filter->b_continuity = VLC_FALSE;            p_input->pp_filters[p_input->i_nb_filters++] = p_filter;            memcpy( &chain_input_format, &p_filter->output,                    sizeof( audio_sample_format_t ) );            /* next filter if any */            psz_parser = psz_next;        }    }    if( psz_filters ) free( psz_filters );    if( psz_visual ) free( psz_visual );    /* complete the filter chain if necessary */    if ( !AOUT_FMTS_IDENTICAL( &chain_input_format, &chain_output_format ) )    {        if ( aout_FiltersCreatePipeline( p_aout, p_input->pp_filters,                                         &p_input->i_nb_filters,                                         &chain_input_format,                                         &chain_output_format ) < 0 )        {            inputFailure( p_aout, p_input, "couldn't set an input pipeline" );            return -1;        }    }    /* Prepare hints for the buffer allocator. */    p_input->input_alloc.i_alloc_type = AOUT_ALLOC_HEAP;    p_input->input_alloc.i_bytes_per_sec = -1;    /* Create resamplers. */    if ( AOUT_FMT_NON_LINEAR( &p_aout->mixer.mixer ) )    {        p_input->i_nb_resamplers = 0;    }    else    {        chain_output_format.i_rate = (__MAX(p_input->input.i_rate,                                            p_aout->mixer.mixer.i_rate)                                 * (100 + AOUT_MAX_RESAMPLING)) / 100;        if ( chain_output_format.i_rate == p_aout->mixer.mixer.i_rate )        {            /* Just in case... */            chain_output_format.i_rate++;        }        p_input->i_nb_resamplers = 0;        if ( aout_FiltersCreatePipeline( p_aout, p_input->pp_resamplers,                                         &p_input->i_nb_resamplers,                                         &chain_output_format,                                         &p_aout->mixer.mixer ) < 0 )        {            inputFailure( p_aout, p_input, "couldn't set a resampler pipeline");            return -1;        }        aout_FiltersHintBuffers( p_aout, p_input->pp_resamplers,                                 p_input->i_nb_resamplers,                                 &p_input->input_alloc );        p_input->input_alloc.i_alloc_type = AOUT_ALLOC_HEAP;        /* Setup the initial rate of the resampler */        p_input->pp_resamplers[0]->input.i_rate = p_input->input.i_rate;    }    p_input->i_resampling_type = AOUT_RESAMPLING_NONE;    aout_FiltersHintBuffers( p_aout, p_input->pp_filters,                             p_input->i_nb_filters,                             &p_input->input_alloc );    p_input->input_alloc.i_alloc_type = AOUT_ALLOC_HEAP;    /* i_bytes_per_sec is still == -1 if no filters */    p_input->input_alloc.i_bytes_per_sec = __MAX(                                    p_input->input_alloc.i_bytes_per_sec,                                    (int)(p_input->input.i_bytes_per_frame                                     * p_input->input.i_rate                                     / p_input->input.i_frame_length) );    /* Success */    p_input->b_error = VLC_FALSE;    p_input->b_restart = VLC_FALSE;    return 0;}/***************************************************************************** * aout_InputDelete : delete an input ***************************************************************************** * This function must be entered with the mixer lock. *****************************************************************************/int aout_InputDelete( aout_instance_t * p_aout, aout_input_t * p_input ){    if ( p_input->b_error ) return 0;    aout_FiltersDestroyPipeline( p_aout, p_input->pp_filters,                                 p_input->i_nb_filters );    p_input->i_nb_filters = 0;    aout_FiltersDestroyPipeline( p_aout, p_input->pp_resamplers,                                 p_input->i_nb_resamplers );    p_input->i_nb_resamplers = 0;

⌨️ 快捷键说明

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