Index: ao_sdl.c =================================================================== RCS file: /cvsroot/mplayer/main/libao2/ao_sdl.c,v retrieving revision 1.15 diff -u -r1.15 ao_sdl.c --- ao_sdl.c 26 Nov 2001 11:30:35 -0000 1.15 +++ ao_sdl.c 24 May 2002 23:55:41 -0000 @@ -16,6 +16,7 @@ #include "audio_out.h" #include "audio_out_internal.h" #include "afmt.h" +#include #include "../libvo/fastmemcpy.h" @@ -46,7 +47,7 @@ static unsigned int buf_write=0; static unsigned int buf_read_pos=0; static unsigned int buf_write_pos=0; - +static unsigned int volume=127; static int full_buffers=0; static int buffered_bytes=0; @@ -79,6 +80,7 @@ x=BUFFSIZE-buf_read_pos; if(x>len) x=len; memcpy(data+len2,buffer[buf_read]+buf_read_pos,x); + SDL_MixAudio(data+len2, data+len2, x, volume); len2+=x; len-=x; buffered_bytes-=x; buf_read_pos+=x; if(buf_read_pos>=BUFFSIZE){ @@ -93,8 +95,6 @@ // end ring buffer stuff -#include - #if defined(sun) && defined(__svr4__) /* setenv is missing on solaris */ static void setenv(const char *name, const char *val, int _xx) @@ -114,7 +114,23 @@ // to set/get/query special features/parameters static int control(int cmd,int arg){ - return -1; + switch (cmd) { + case AOCONTROL_GET_VOLUME: + { + ao_control_vol_t* vol = (ao_control_vol_t*)arg; + vol->left = vol->right = (float)((volume + 127)/2.55); + return CONTROL_OK; + } + case AOCONTROL_SET_VOLUME: + { + float diff; + ao_control_vol_t* vol = (ao_control_vol_t*)arg; + diff = (vol->left+vol->right) / 2; + volume = (int)(diff * 2.55) - 127; + return CONTROL_OK; + } + } + return -1; } // SDL Callback function