00001 /***************************************************************************** 00002 * float32tou8.c : converter from float32 to unsigned 8 bits integer 00003 ***************************************************************************** 00004 * Copyright (C) 2002 the VideoLAN team 00005 * $Id: float32tou8.c 11664 2005-07-09 06:17:09Z courmisch $ 00006 * 00007 * Authors: Xavier Maillard <[email protected]> 00008 * 00009 * This program is free software; you can redistribute it and/or modify 00010 * it under the terms of the GNU General Public License as published by 00011 * the Free Software Foundation; either version 2 of the License, or 00012 * (at your option) any later version. 00013 * 00014 * This program is distributed in the hope that it will be useful, 00015 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00016 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00017 * GNU General Public License for more details. 00018 * 00019 * You should have received a copy of the GNU General Public License 00020 * along with this program; if not, write to the Free Software 00021 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA. 00022 *****************************************************************************/ 00023 00024 /***************************************************************************** 00025 * Preamble 00026 *****************************************************************************/ 00027 #include <stdlib.h> /* malloc(), free() */ 00028 #include <string.h> 00029 00030 #include <vlc/vlc.h> 00031 #include "audio_output.h" 00032 #include "aout_internal.h" 00033 00034 /***************************************************************************** 00035 * Local prototypes 00036 *****************************************************************************/ 00037 static int Create ( vlc_object_t * ); 00038 00039 static void DoWork ( aout_instance_t *, aout_filter_t *, aout_buffer_t *, 00040 aout_buffer_t * ); 00041 00042 /***************************************************************************** 00043 * Module descriptor 00044 *****************************************************************************/ 00045 vlc_module_begin(); 00046 set_category( CAT_AUDIO ); 00047 set_subcategory( SUBCAT_AUDIO_MISC ); 00048 set_description( _("audio filter for float32->u8 conversion") ); 00049 set_capability( "audio filter", 1 ); 00050 set_callbacks( Create, NULL ); 00051 vlc_module_end(); 00052 00053 /***************************************************************************** 00054 * Create: allocate trivial mixer 00055 ***************************************************************************** 00056 * This function allocates and initializes a Crop vout method. 00057 *****************************************************************************/ 00058 static int Create( vlc_object_t *p_this ) 00059 { 00060 aout_filter_t * p_filter = (aout_filter_t *)p_this; 00061 00062 if ( p_filter->input.i_format != VLC_FOURCC('f','l','3','2') 00063 || p_filter->output.i_format != VLC_FOURCC('u','8',' ',' ') ) 00064 { 00065 return -1; 00066 } 00067 00068 if ( !AOUT_FMTS_SIMILAR( &p_filter->input, &p_filter->output ) ) 00069 { 00070 return -1; 00071 } 00072 00073 p_filter->pf_do_work = DoWork; 00074 p_filter->b_in_place = 1; 00075 00076 return 0; 00077 } 00078 00079 /***************************************************************************** 00080 * DoWork: convert a buffer 00081 *****************************************************************************/ 00082 static void DoWork( aout_instance_t * p_aout, aout_filter_t * p_filter, 00083 aout_buffer_t * p_in_buf, aout_buffer_t * p_out_buf ) 00084 { 00085 int i; 00086 float * p_in = (float *)p_in_buf->p_buffer; 00087 uint8_t * p_out = (uint8_t *)p_out_buf->p_buffer; 00088 00089 for ( i = p_in_buf->i_nb_samples 00090 * aout_FormatNbChannels( &p_filter->input ); i-- ; ) 00091 { 00092 if ( *p_in >= 1.0 ) *p_out = 255; 00093 else if ( *p_in < -1.0 ) *p_out = 0; 00094 else *p_out = (uint8_t)(128 + *p_in * 128); 00095 p_in++; p_out++; 00096 } 00097 00098 p_out_buf->i_nb_samples = p_in_buf->i_nb_samples; 00099 p_out_buf->i_nb_bytes = p_in_buf->i_nb_bytes / 4; 00100 } 00101