mirror of
https://github.com/mpv-player/mpv
synced 2024-12-13 18:36:09 +00:00
d05326c4bc
- rewrite video equalizer handling (i teszted with mga g400 [x]mga,xv,xvidix and radeon xv,xvidix ) - fix some small gtk bug - i dunno, i don't remember ... :) git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@6756 b3059339-0415-0410-9bf9-f77b7e298cf2
404 lines
10 KiB
C
404 lines
10 KiB
C
|
|
#include <inttypes.h>
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
#include "ws.h"
|
|
#include "mplayer/play.h"
|
|
#include "interface.h"
|
|
#include "skin/skin.h"
|
|
#include "mplayer/gtk/eq.h"
|
|
|
|
#include "../mplayer.h"
|
|
#include "mplayer/widgets.h"
|
|
#include "mplayer/mplayer.h"
|
|
#include "app.h"
|
|
#include "../libvo/x11_common.h"
|
|
#include "../libvo/video_out.h"
|
|
#include "../input/input.h"
|
|
#include "../libao2/audio_out.h"
|
|
#include "../mixer.h"
|
|
#include "../libao2/audio_plugin.h"
|
|
#include "../libao2/eq.h"
|
|
|
|
#include <inttypes.h>
|
|
#include <sys/types.h>
|
|
|
|
#include "../libmpdemux/stream.h"
|
|
#include "../libmpdemux/demuxer.h"
|
|
|
|
guiInterface_t guiIntfStruct;
|
|
|
|
char * gstrcat( char ** dest,char * src )
|
|
{
|
|
char * tmp = NULL;
|
|
|
|
if ( !src ) return NULL;
|
|
|
|
if ( *dest )
|
|
{
|
|
tmp=malloc( strlen( *dest ) + strlen( src ) + 1 );
|
|
strcpy( tmp,*dest ); strcat( tmp,src ); free( *dest );
|
|
}
|
|
else
|
|
{ tmp=malloc( strlen( src ) + 1 ); strcpy( tmp,src ); }
|
|
*dest=tmp;
|
|
return tmp;
|
|
}
|
|
|
|
void guiInit( void )
|
|
{
|
|
memset( &guiIntfStruct,0,sizeof( guiIntfStruct ) );
|
|
memset( >kEquChannels,0,sizeof( gtkEquChannels ) );
|
|
appInit( (void*)mDisplay );
|
|
}
|
|
|
|
void guiDone( void )
|
|
{
|
|
mp_msg( MSGT_GPLAYER,MSGL_V,"[mplayer] exit.\n" );
|
|
mplStop();
|
|
gtkDone();
|
|
wsXDone();
|
|
}
|
|
|
|
int guiCMDArray[] =
|
|
{
|
|
evLoad,
|
|
evLoadSubtitle,
|
|
evAbout,
|
|
evPlay,
|
|
evStop,
|
|
evPlayList,
|
|
evPreferences,
|
|
evFullScreen,
|
|
evSkinBrowser
|
|
};
|
|
|
|
typedef struct
|
|
{
|
|
demux_stream_t *ds;
|
|
unsigned int format;
|
|
struct codecs_st *codec;
|
|
int inited;
|
|
// output format:
|
|
float timer;
|
|
float fps;
|
|
float frametime;
|
|
int i_bps;
|
|
int disp_w,disp_h;
|
|
} tmp_sh_video_t;
|
|
|
|
extern ao_functions_t * audio_out;
|
|
extern vo_functions_t * video_out;
|
|
|
|
void guiGetEvent( int type,char * arg )
|
|
{
|
|
stream_t * stream = (stream_t *) arg;
|
|
#ifdef USE_DVDREAD
|
|
dvd_priv_t * dvdp = (dvd_priv_t *) arg;
|
|
#endif
|
|
|
|
switch ( type )
|
|
{
|
|
case guiXEvent:
|
|
wsEvents( wsDisplay,(XEvent *)arg,NULL );
|
|
gtkEventHandling();
|
|
break;
|
|
case guiCEvent:
|
|
switch ( (int)arg )
|
|
{
|
|
case guiSetPlay: guiIntfStruct.Playing=1; mplState(); break;
|
|
case guiSetStop: guiIntfStruct.Playing=0; mplState(); break;
|
|
case guiSetPause: guiIntfStruct.Playing=2; mplState(); break;
|
|
}
|
|
break;
|
|
case guiSetState:
|
|
mplState();
|
|
break;
|
|
case guiSetFileName:
|
|
if ( arg ) guiSetFilename( guiIntfStruct.Filename,arg );
|
|
break;
|
|
case guiSetAudioOnly:
|
|
guiIntfStruct.AudioOnly=(int)arg;
|
|
if ( (int)arg ) wsVisibleWindow( &appMPlayer.subWindow,wsHideWindow );
|
|
else wsVisibleWindow( &appMPlayer.subWindow,wsShowWindow );
|
|
break;
|
|
case guiReDrawSubWindow:
|
|
wsPostRedisplay( &appMPlayer.subWindow );
|
|
if ( guiIntfStruct.Playing == 1 ) wsSetBackgroundRGB( &appMPlayer.subWindow,0,0,0 );
|
|
break;
|
|
case guiSetShVideo:
|
|
{
|
|
if ( !appMPlayer.subWindow.isFullScreen )
|
|
{
|
|
wsResizeWindow( &appMPlayer.subWindow,vo_dwidth,vo_dheight );
|
|
wsMoveWindow( &appMPlayer.subWindow,True,appMPlayer.sub.x,appMPlayer.sub.y );
|
|
}
|
|
guiIntfStruct.MovieWidth=vo_dwidth;
|
|
guiIntfStruct.MovieHeight=vo_dheight;
|
|
}
|
|
break;
|
|
#ifdef USE_DVDREAD
|
|
case guiSetDVD:
|
|
guiIntfStruct.DVD.titles=dvdp->vmg_file->tt_srpt->nr_of_srpts;
|
|
guiIntfStruct.DVD.chapters=dvdp->vmg_file->tt_srpt->title[dvd_title].nr_of_ptts;
|
|
guiIntfStruct.DVD.angles=dvdp->vmg_file->tt_srpt->title[dvd_title].nr_of_angles;
|
|
guiIntfStruct.DVD.nr_of_audio_channels=dvdp->nr_of_channels;
|
|
memcpy( guiIntfStruct.DVD.audio_streams,dvdp->audio_streams,sizeof( dvdp->audio_streams ) );
|
|
guiIntfStruct.DVD.nr_of_subtitles=dvdp->nr_of_subtitles;
|
|
memcpy( guiIntfStruct.DVD.subtitles,dvdp->subtitles,sizeof( dvdp->subtitles ) );
|
|
guiIntfStruct.DVD.current_title=dvd_title + 1;
|
|
guiIntfStruct.DVD.current_chapter=dvd_chapter + 1;
|
|
guiIntfStruct.DVD.current_angle=dvd_angle + 1;
|
|
guiIntfStruct.Track=dvd_title + 1;
|
|
break;
|
|
#endif
|
|
case guiSetStream:
|
|
guiIntfStruct.StreamType=stream->type;
|
|
switch( stream->type )
|
|
{
|
|
case STREAMTYPE_DVD:
|
|
guiGetEvent( guiSetDVD,(char *)stream->priv );
|
|
break;
|
|
#ifdef HAVE_VCD
|
|
case STREAMTYPE_VCD:
|
|
{
|
|
int i;
|
|
for ( i=1;i < 100;i++ )
|
|
if ( vcd_seek_to_track( stream->fd,i ) < 0 ) break;
|
|
vcd_seek_to_track( stream->fd,vcd_track );
|
|
guiIntfStruct.VCDTracks=--i;
|
|
mp_msg( MSGT_GPLAYER,MSGL_INFO,"[interface] vcd tracks: %d\n",guiIntfStruct.VCDTracks );
|
|
guiIntfStruct.Track=vcd_track;
|
|
break;
|
|
}
|
|
#endif
|
|
}
|
|
break;
|
|
#ifdef HAVE_NEW_INPUT
|
|
case guiIEvent:
|
|
printf( "cmd: %d\n",(int)arg );
|
|
switch( (int)arg )
|
|
{
|
|
case MP_CMD_QUIT:
|
|
mplEventHandling( evExit,0 );
|
|
break;
|
|
case MP_CMD_VO_FULLSCREEN:
|
|
mplEventHandling( evFullScreen,0 );
|
|
break;
|
|
default:
|
|
mplEventHandling( guiCMDArray[ (int)arg - MP_CMD_GUI_EVENTS - 1 ],0 );
|
|
}
|
|
break;
|
|
#endif
|
|
case guiClearStruct:
|
|
#ifdef USE_DVDREAD
|
|
if ( (unsigned int)arg & guiDVD ) memset( &guiIntfStruct.DVD,0,sizeof( guiDVDStruct ) );
|
|
#endif
|
|
#ifdef HAVE_VCD
|
|
if ( (unsigned int)arg & guiVCD ) guiIntfStruct.VCDTracks=0;
|
|
#endif
|
|
break;
|
|
case guiReDraw:
|
|
mplEventHandling( evRedraw,0 );
|
|
break;
|
|
case guiSetVolume:
|
|
if ( audio_out )
|
|
{
|
|
float l,r;
|
|
mixer_getvolume( &l,&r );
|
|
guiIntfStruct.Volume=(r>l?r:l);
|
|
if ( r != l ) guiIntfStruct.Balance=( ( r - l ) + 100 ) * 0.5f;
|
|
else guiIntfStruct.Balance=50.0f;
|
|
btnModify( evSetVolume,guiIntfStruct.Volume );
|
|
btnModify( evSetBalance,guiIntfStruct.Balance );
|
|
}
|
|
|
|
if ( gtkEnableAudioEqualizer )
|
|
{
|
|
equalizer_t eq;
|
|
int i,j;
|
|
for ( i=0;i<6;i++ )
|
|
for ( j=0;j<10;j++ )
|
|
{
|
|
eq.channel=i; eq.band=j; eq.gain=gtkEquChannels[i][j];
|
|
gtkSet( gtkSetEqualizer,0,&eq );
|
|
}
|
|
}
|
|
break;
|
|
case guiSetDefaults:
|
|
#if defined( HAVE_VCD ) || defined( USE_DVDREAD )
|
|
if ( guiIntfStruct.DiskChanged )
|
|
{
|
|
/*
|
|
#ifdef USE_DVDREAD
|
|
switch ( guiIntfStruct.StreamType )
|
|
{
|
|
case STREAMTYPE_DVD: filename=DEFAULT_DVD_DEVICE; break;
|
|
}
|
|
#endif
|
|
*/
|
|
guiIntfStruct.DiskChanged=0;
|
|
guiGetEvent( guiCEvent,(char *)guiSetPlay );
|
|
}
|
|
#endif
|
|
|
|
#ifdef USE_SUB
|
|
if ( guiIntfStruct.SubtitleChanged || !guiIntfStruct.FilenameChanged )
|
|
{
|
|
if ( ( guiIntfStruct.Subtitlename )&&( guiIntfStruct.Subtitlename[0] != 0 ) ) sub_name=guiIntfStruct.Subtitlename;
|
|
guiIntfStruct.SubtitleChanged=0;
|
|
}
|
|
#endif
|
|
|
|
if ( guiIntfStruct.AudioFile ) audio_stream=guiIntfStruct.AudioFile;
|
|
else if ( guiIntfStruct.FilenameChanged ) audio_stream=NULL;
|
|
|
|
if ( gtkEnableAudioEqualizer )
|
|
{
|
|
if ( ao_plugin_cfg.plugin_list ) { if ( !strstr( ao_plugin_cfg.plugin_list,"eq" ) ) gstrcat( &ao_plugin_cfg.plugin_list,",eq" ); }
|
|
else gstrcat( &ao_plugin_cfg.plugin_list,"eq" );
|
|
}
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
extern unsigned int GetTimerMS( void );
|
|
extern int mplTimer;
|
|
|
|
void guiEventHandling( void )
|
|
{
|
|
if ( !guiIntfStruct.Playing || guiIntfStruct.AudioOnly ) wsHandleEvents();
|
|
gtkEventHandling();
|
|
mplTimer=GetTimerMS() / 20;
|
|
}
|
|
|
|
// ---
|
|
|
|
float gtkEquChannels[6][10];
|
|
|
|
plItem * plCurrent = NULL;
|
|
plItem * plList = NULL;
|
|
plItem * plLastPlayed = NULL;
|
|
|
|
#if defined( MP_DEBUG ) && 0
|
|
void list( void )
|
|
{
|
|
plItem * next = plList;
|
|
printf( "--- list ---\n" );
|
|
while( next || next->next )
|
|
{
|
|
printf( "item: %s/%s\n",next->path,next->name );
|
|
if ( next->next ) next=next->next; else break;
|
|
}
|
|
printf( "--- end of list ---\n" );
|
|
}
|
|
#else
|
|
#define list();
|
|
#endif
|
|
|
|
void * gtkSet( int cmd,float fparam, void * vparam )
|
|
{
|
|
mp_cmd_t * mp_cmd = (mp_cmd_t *)calloc( 1,sizeof( *mp_cmd ) );
|
|
equalizer_t * eq = (equalizer_t *)vparam;
|
|
plItem * item = (plItem *)vparam;
|
|
|
|
switch ( cmd )
|
|
{
|
|
// --- handle playlist
|
|
case gtkAddPlItem: // add item to playlist
|
|
if ( plList )
|
|
{
|
|
plItem * next = plList;
|
|
while ( next->next ) { /*printf( "%s\n",next->name );*/ next=next->next; }
|
|
next->next=item; item->prev=next;
|
|
}
|
|
else { item->prev=item->next=NULL; plCurrent=plList=item; }
|
|
list();
|
|
return NULL;
|
|
case gtkGetNextPlItem: // get current item from playlist
|
|
if ( plCurrent )
|
|
{
|
|
plCurrent=plCurrent->next;
|
|
if ( !plCurrent && plList )
|
|
{
|
|
plItem * next = plList;
|
|
while ( next->next ) { if ( !next->next ) break; next=next->next; }
|
|
plCurrent=next;
|
|
}
|
|
return plCurrent;
|
|
}
|
|
return NULL;
|
|
case gtkGetPrevPlItem:
|
|
if ( plCurrent )
|
|
{
|
|
plCurrent=plCurrent->prev;
|
|
if ( !plCurrent && plList ) plCurrent=plList;
|
|
return plCurrent;
|
|
}
|
|
break;
|
|
case gtkGetCurrPlItem: // get current item
|
|
return plCurrent;
|
|
case gtkDelPl: // delete list
|
|
{
|
|
plItem * curr = plList;
|
|
plItem * next;
|
|
if ( !plList ) return NULL;
|
|
if ( !curr->next )
|
|
{
|
|
if ( curr->path ) free( curr->path );
|
|
if ( curr->name ) free( curr->name );
|
|
free( curr );
|
|
}
|
|
else
|
|
{
|
|
while ( curr->next )
|
|
{
|
|
next=curr->next;
|
|
if ( curr->path ) free( curr->path );
|
|
if ( curr->name ) free( curr->name );
|
|
free( curr );
|
|
curr=next;
|
|
}
|
|
}
|
|
plList=NULL; plCurrent=NULL;
|
|
}
|
|
return NULL;
|
|
// --- set equalizers
|
|
case gtkSetContrast:
|
|
mp_cmd->id=MP_CMD_CONTRAST; mp_cmd->name=strdup( "contrast" );
|
|
break;
|
|
case gtkSetBrightness:
|
|
mp_cmd->id=MP_CMD_BRIGHTNESS; mp_cmd->name=strdup( "brightness" );
|
|
break;
|
|
case gtkSetHue:
|
|
mp_cmd->id=MP_CMD_HUE; mp_cmd->name=strdup( "hue" );
|
|
break;
|
|
case gtkSetSaturation:
|
|
mp_cmd->id=MP_CMD_SATURATION; mp_cmd->name=strdup( "saturation" );
|
|
break;
|
|
case gtkSetEqualizer:
|
|
if ( eq )
|
|
{
|
|
gtkEquChannels[eq->channel][eq->band]=eq->gain;
|
|
audio_plugin_eq.control( AOCONTROL_PLUGIN_EQ_SET_GAIN,(int)eq );
|
|
}
|
|
else
|
|
{
|
|
int i,j; equalizer_t tmp; tmp.gain=0.0f;
|
|
memset( gtkEquChannels,0,sizeof( gtkEquChannels ) );
|
|
for ( i=0;i<6;i++ )
|
|
for ( j=0;j<10;j++ )
|
|
{ tmp.channel=i; tmp.band=j; audio_plugin_eq.control( AOCONTROL_PLUGIN_EQ_SET_GAIN,(int)&tmp ); }
|
|
}
|
|
return NULL;
|
|
default: free( mp_cmd ); return NULL;
|
|
}
|
|
mp_cmd->args[0].v.i=(int)fparam;
|
|
mp_cmd->args[1].v.i=1;
|
|
mp_input_queue_cmd( mp_cmd );
|
|
return NULL;
|
|
}
|