Mercurial > mplayer.hg
annotate Gui/interface.c @ 7912:e15e76559bd5
Reverse Arpi's commit and put the right fix in place.
author | albeu |
---|---|
date | Fri, 25 Oct 2002 16:06:25 +0000 |
parents | 0e5544951425 |
children | e5dda05f9aab |
rev | line source |
---|---|
6280 | 1 |
4845 | 2 #include <inttypes.h> |
3 #include <stdlib.h> | |
4 #include <stdio.h> | |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
5 #include <string.h> |
4798 | 6 |
7 #include "ws.h" | |
8 #include "mplayer/play.h" | |
9 #include "interface.h" | |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
10 #include "skin/skin.h" |
6627 | 11 #include "mplayer/gtk/eq.h" |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
12 |
4798 | 13 #include "../mplayer.h" |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
14 #include "mplayer/widgets.h" |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
15 #include "mplayer/mplayer.h" |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
16 #include "app.h" |
6794 | 17 #include "cfg.h" |
18 #include "../help_mp.h" | |
19 #include "../subreader.h" | |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
20 #include "../libvo/x11_common.h" |
5789 | 21 #include "../libvo/video_out.h" |
6794 | 22 #include "../libvo/font_load.h" |
7169 | 23 #include "../libvo/sub.h" |
4858 | 24 #include "../input/input.h" |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
25 #include "../libao2/audio_out.h" |
6627 | 26 #include "../mixer.h" |
27 #include "../libao2/audio_plugin.h" | |
28 #include "../libao2/eq.h" | |
5789 | 29 |
6280 | 30 #include <inttypes.h> |
31 #include <sys/types.h> | |
32 | |
6996 | 33 #ifdef USE_ICONV |
7128 | 34 #include <iconv.h> |
6996 | 35 #endif |
36 | |
5665 | 37 #include "../libmpdemux/stream.h" |
5789 | 38 #include "../libmpdemux/demuxer.h" |
7217 | 39 #include "../libmpdemux/stheader.h" |
40 #include "../libmpcodecs/dec_video.h" | |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
41 |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
42 guiInterface_t guiIntfStruct; |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
43 |
6627 | 44 char * gstrcat( char ** dest,char * src ) |
45 { | |
46 char * tmp = NULL; | |
47 | |
48 if ( !src ) return NULL; | |
49 | |
50 if ( *dest ) | |
51 { | |
52 tmp=malloc( strlen( *dest ) + strlen( src ) + 1 ); | |
53 strcpy( tmp,*dest ); strcat( tmp,src ); free( *dest ); | |
54 } | |
55 else | |
56 { tmp=malloc( strlen( src ) + 1 ); strcpy( tmp,src ); } | |
57 *dest=tmp; | |
58 return tmp; | |
59 } | |
60 | |
6794 | 61 int gstrcmp( char * a,char * b ) |
62 { | |
63 if ( !a && !b ) return 0; | |
64 if ( !a || !b ) return -1; | |
65 return strcmp( a,b ); | |
66 } | |
67 | |
7019 | 68 int gstrncmp( char * a,char * b,int size ) |
69 { | |
70 if ( !a && !b ) return 0; | |
71 if ( !a || !b ) return -1; | |
72 return strncmp( a,b,size ); | |
73 } | |
74 | |
6794 | 75 char * gstrdup( char * str ) |
76 { | |
77 if ( !str ) return NULL; | |
78 return strdup( str ); | |
79 } | |
80 | |
81 void gfree( void ** p ) | |
82 { | |
83 if ( *p == NULL ) return; | |
84 free( *p ); *p=NULL; | |
85 } | |
86 | |
87 void gset( char ** str,char * what ) | |
88 { | |
7887
0e5544951425
A small patch to Gui/interface.c; the first fix is a plain bug, the second is
arpi
parents:
7707
diff
changeset
|
89 if ( *str ) { if ( !strstr( *str,what ) ) { gstrcat( str,"," ); gstrcat( str,what ); }} |
6794 | 90 else gstrcat( str,what ); |
91 } | |
92 | |
7582 | 93 void gaddlist( char *** list,char * entry ) |
94 { | |
95 int i; | |
96 | |
97 if ( (*list) ) | |
98 { | |
99 for ( i=0;(*list)[i];i++ ) free( (*list)[i] ); | |
100 free( (*list) ); | |
101 } | |
102 | |
103 (*list)=malloc( 8 ); | |
104 (*list)[0]=gstrdup( entry ); | |
105 (*list)[1]=NULL; | |
106 } | |
107 | |
6996 | 108 #ifdef USE_ICONV |
109 char * gconvert_uri_to_filename( char * str ) | |
110 { | |
111 iconv_t d; | |
112 char * out = strdup( str ); | |
113 char * tmp = NULL; | |
114 char * ize; | |
115 size_t inb,outb; | |
116 char * charset = "ISO8859-1"; | |
117 char * cs; | |
118 | |
119 if ( !strchr( str,'%' ) ) return str; | |
120 | |
121 { | |
122 char * t = calloc( 1,strlen( out ) ); | |
123 int i,c = 0; | |
124 for ( i=0;i < (int)strlen( out );i++ ) | |
125 if ( out[i] != '%' ) t[c++]=out[i]; | |
126 else | |
127 { | |
128 char tmp[4] = "0xXX"; | |
129 // if ( out[++i] == '%' ) { t[c++]='%'; continue; }; | |
130 tmp[2]=out[++i]; tmp[3]=out[++i]; | |
131 t[c++]=(char)strtol( tmp,(char **)NULL,0 ); | |
132 } | |
133 free( out ); | |
134 out=t; | |
135 } | |
136 | |
137 if ( (cs=getenv( "CHARSET" )) && *cs ) charset=cs; | |
138 | |
139 inb=outb=strlen( out ); | |
140 tmp=calloc( 1,outb + 1 ); | |
141 ize=tmp; | |
142 d=iconv_open( charset,"UTF-8" ); | |
143 if ( (iconv_t)(-1) == d ) return str; | |
144 iconv( d,&out,&inb,&tmp,&outb ); | |
145 iconv_close( d ); | |
146 free( out ); | |
147 return ize; | |
148 } | |
149 #endif | |
150 | |
6218 | 151 void guiInit( void ) |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
152 { |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
153 memset( &guiIntfStruct,0,sizeof( guiIntfStruct ) ); |
6898 | 154 guiIntfStruct.Balance=50.0f; |
155 guiIntfStruct.StreamType=-1; | |
156 | |
6627 | 157 memset( >kEquChannels,0,sizeof( gtkEquChannels ) ); |
7706 | 158 if ( !gtkAOOSSMixer ) gtkAOOSSMixer=strdup( PATH_DEV_MIXER ); |
159 if ( !gtkAOOSSDevice ) gtkAOOSSDevice=strdup( PATH_DEV_DSP ); | |
7707 | 160 #ifdef HAVE_DXR3 |
7706 | 161 if ( !gtkDXR3Device ) gtkDXR3Device=strdup( "/dev/em8300-0" ); |
7707 | 162 #endif |
7538 | 163 fullscreen=gtkLoadFullscreen; |
6898 | 164 |
165 gtkInit(); | |
6912 | 166 wsXInit( (void *)mDisplay ); |
6218 | 167 appInit( (void*)mDisplay ); |
7538 | 168 |
7009 | 169 if ( plCurrent && !filename ) mplSetFileName( plCurrent->path,plCurrent->name,STREAMTYPE_FILE ); |
6973 | 170 if ( sub_name ) guiSetFilename( guiIntfStruct.Subtitlename,sub_name ); |
6797
06d29dbdf20d
upsz, sorry, i forgott this :) (skin name saving:)
pontscho
parents:
6794
diff
changeset
|
171 #if defined( USE_OSD ) || defined( USE_SUB ) |
06d29dbdf20d
upsz, sorry, i forgott this :) (skin name saving:)
pontscho
parents:
6794
diff
changeset
|
172 guiLoadFont(); |
06d29dbdf20d
upsz, sorry, i forgott this :) (skin name saving:)
pontscho
parents:
6794
diff
changeset
|
173 #endif |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
174 } |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
175 |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
176 void guiDone( void ) |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
177 { |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
178 mp_msg( MSGT_GPLAYER,MSGL_V,"[mplayer] exit.\n" ); |
6794 | 179 cfg_write(); |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
180 gtkDone(); |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
181 wsXDone(); |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
182 } |
4798 | 183 |
4858 | 184 int guiCMDArray[] = |
185 { | |
186 evLoad, | |
187 evLoadSubtitle, | |
188 evAbout, | |
189 evPlay, | |
190 evStop, | |
191 evPlayList, | |
192 evPreferences, | |
193 evFullScreen, | |
194 evSkinBrowser | |
195 }; | |
196 | |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
197 extern ao_functions_t * audio_out; |
6755 | 198 extern vo_functions_t * video_out; |
6794 | 199 extern int frame_dropping; |
200 extern int stream_dump_type; | |
201 extern char ** vo_plugin_args; | |
202 | |
203 #if defined( USE_OSD ) || defined( USE_SUB ) | |
204 void guiLoadFont( void ) | |
205 { | |
7122
0dc9cb756b68
freetype 2.0/2.1+ support - disabled by default until bugs fixed
arpi
parents:
7111
diff
changeset
|
206 #ifdef HAVE_FREETYPE |
0dc9cb756b68
freetype 2.0/2.1+ support - disabled by default until bugs fixed
arpi
parents:
7111
diff
changeset
|
207 load_font(vo_image_width, vo_image_height); |
0dc9cb756b68
freetype 2.0/2.1+ support - disabled by default until bugs fixed
arpi
parents:
7111
diff
changeset
|
208 #else |
6794 | 209 if ( vo_font ) |
210 { | |
211 int i; | |
212 if ( vo_font->name ) free( vo_font->name ); | |
213 if ( vo_font->fpath ) free( vo_font->fpath ); | |
214 for ( i=0;i<16;i++ ) | |
215 if ( vo_font->pic_a[i] ) | |
216 { | |
217 if ( vo_font->pic_a[i]->bmp ) free( vo_font->pic_a[i]->bmp ); | |
218 if ( vo_font->pic_a[i]->pal ) free( vo_font->pic_a[i]->pal ); | |
219 } | |
220 for ( i=0;i<16;i++ ) | |
221 if ( vo_font->pic_b[i] ) | |
222 { | |
223 if ( vo_font->pic_b[i]->bmp ) free( vo_font->pic_b[i]->bmp ); | |
224 if ( vo_font->pic_b[i]->pal ) free( vo_font->pic_b[i]->pal ); | |
225 } | |
226 free( vo_font ); vo_font=NULL; | |
227 } | |
7019 | 228 if ( font_name ) |
6794 | 229 { |
7019 | 230 vo_font=read_font_desc( font_name,font_factor,0 ); |
6794 | 231 if ( !vo_font ) mp_msg( MSGT_CPLAYER,MSGL_ERR,MSGTR_CantLoadFont,font_name ); |
232 } | |
233 else | |
234 { | |
7019 | 235 font_name=gstrdup( get_path( "font/font.desc" ) ); |
236 vo_font=read_font_desc( font_name,font_factor,0 ); | |
6794 | 237 if ( !vo_font ) |
238 { | |
7019 | 239 gfree( (void **)&font_name ); font_name=gstrdup( DATADIR"/font/font.desc" ); |
240 vo_font=read_font_desc( font_name,font_factor,0 ); | |
6794 | 241 } |
242 } | |
7122
0dc9cb756b68
freetype 2.0/2.1+ support - disabled by default until bugs fixed
arpi
parents:
7111
diff
changeset
|
243 #endif |
6794 | 244 } |
245 #endif | |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
246 |
7150 | 247 #ifdef USE_SUB |
7169 | 248 extern mp_osd_obj_t* vo_osd_list; |
249 | |
7150 | 250 void guiLoadSubtitle( char * name ) |
251 { | |
252 if ( guiIntfStruct.Playing == 0 ) | |
253 { | |
254 guiIntfStruct.SubtitleChanged=1; | |
255 return; | |
256 } | |
257 if ( subtitles ) | |
258 { | |
7169 | 259 mp_msg( MSGT_GPLAYER,MSGL_INFO,"[gui] Delete subtitles.\n" ); |
7150 | 260 sub_free( subtitles ); |
7169 | 261 subtitles=NULL; |
7170 | 262 gfree( (void **)&sub_name ); |
7150 | 263 vo_sub=NULL; |
7169 | 264 if ( vo_osd_list ) |
265 { | |
266 int len; | |
267 mp_osd_obj_t * osd = vo_osd_list; | |
268 while ( osd ) | |
269 { | |
270 if ( osd->type == OSDTYPE_SUBTITLE ) break; | |
271 osd=osd->next; | |
272 } | |
273 if ( osd && osd->flags&OSDFLAG_VISIBLE ) | |
274 { | |
275 len=osd->stride * ( osd->bbox.y2 - osd->bbox.y1 ); | |
276 memset( osd->bitmap_buffer,0,len ); | |
277 memset( osd->alpha_buffer,0,len ); | |
278 } | |
279 } | |
7150 | 280 } |
7169 | 281 if ( name ) |
282 { | |
283 mp_msg( MSGT_GPLAYER,MSGL_INFO,"[gui] Delete Load subtitle: %s\n",name ); | |
284 sub_name=gstrdup( name ); | |
285 subtitles=sub_read_file( sub_name,guiIntfStruct.FPS ); | |
286 } | |
7150 | 287 } |
288 #endif | |
289 | |
7009 | 290 static void add_vop( char * str ) |
291 { | |
292 mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[gui] add video filter: %s\n",str ); | |
293 if ( vo_plugin_args ) | |
294 { | |
295 int i = 0; | |
296 while ( vo_plugin_args[i] ) if ( !gstrcmp( vo_plugin_args[i++],str ) ) { i=-1; break; } | |
297 if ( i != -1 ) | |
298 { vo_plugin_args=realloc( vo_plugin_args,( i + 2 ) * sizeof( char * ) ); vo_plugin_args[i]=strdup( str ); vo_plugin_args[i+1]=NULL; } | |
299 } else { vo_plugin_args=malloc( 2 * sizeof( char * ) ); vo_plugin_args[0]=strdup( str ); vo_plugin_args[1]=NULL; } | |
300 } | |
301 | |
302 static void remove_vop( char * str ) | |
303 { | |
304 int n = 0; | |
305 | |
306 if ( !vo_plugin_args ) return; | |
307 | |
308 mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[gui] remove video filter: %s\n",str ); | |
309 | |
310 while ( vo_plugin_args[n++] ); n--; | |
311 if ( n > -1 ) | |
312 { | |
313 int i = 0,m = -1; | |
314 while ( vo_plugin_args[i] ) if ( !gstrcmp( vo_plugin_args[i++],str ) ) { m=i - 1; break; } | |
315 i--; | |
316 if ( m > -1 ) | |
317 { | |
318 if ( n == 1 ) { free( vo_plugin_args[0] ); free( vo_plugin_args ); vo_plugin_args=NULL; } | |
319 else memcpy( &vo_plugin_args[i],&vo_plugin_args[i + 1],( n - i ) * sizeof( char * ) ); | |
320 } | |
321 } | |
322 } | |
323 | |
324 int guiGetEvent( int type,char * arg ) | |
4798 | 325 { |
6280 | 326 stream_t * stream = (stream_t *) arg; |
5672
1f8b34f1e7c0
ifdef reading dvd args, without it non-dvd compilation fails.
eyck
parents:
5665
diff
changeset
|
327 #ifdef USE_DVDREAD |
5665 | 328 dvd_priv_t * dvdp = (dvd_priv_t *) arg; |
5672
1f8b34f1e7c0
ifdef reading dvd args, without it non-dvd compilation fails.
eyck
parents:
5665
diff
changeset
|
329 #endif |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
330 |
4798 | 331 switch ( type ) |
332 { | |
333 case guiXEvent: | |
334 wsEvents( wsDisplay,(XEvent *)arg,NULL ); | |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
335 gtkEventHandling(); |
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
336 break; |
4798 | 337 case guiCEvent: |
4963 | 338 switch ( (int)arg ) |
339 { | |
340 case guiSetPlay: guiIntfStruct.Playing=1; mplState(); break; | |
341 case guiSetStop: guiIntfStruct.Playing=0; mplState(); break; | |
342 case guiSetPause: guiIntfStruct.Playing=2; mplState(); break; | |
343 } | |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
344 break; |
5665 | 345 case guiSetState: |
346 mplState(); | |
347 break; | |
348 case guiSetFileName: | |
349 if ( arg ) guiSetFilename( guiIntfStruct.Filename,arg ); | |
350 break; | |
5789 | 351 case guiSetAudioOnly: |
352 guiIntfStruct.AudioOnly=(int)arg; | |
7009 | 353 if ( (int)arg ) { guiIntfStruct.NoWindow=True; wsVisibleWindow( &appMPlayer.subWindow,wsHideWindow ); } |
5789 | 354 else wsVisibleWindow( &appMPlayer.subWindow,wsShowWindow ); |
355 break; | |
356 case guiReDrawSubWindow: | |
357 wsPostRedisplay( &appMPlayer.subWindow ); | |
358 break; | |
359 case guiSetShVideo: | |
360 { | |
5986 | 361 if ( !appMPlayer.subWindow.isFullScreen ) |
362 { | |
363 wsResizeWindow( &appMPlayer.subWindow,vo_dwidth,vo_dheight ); | |
364 wsMoveWindow( &appMPlayer.subWindow,True,appMPlayer.sub.x,appMPlayer.sub.y ); | |
365 } | |
5955
caac20b1ca79
fix xmga fs, resize to movie size and mouse auto hide + dga
pontscho
parents:
5945
diff
changeset
|
366 guiIntfStruct.MovieWidth=vo_dwidth; |
5997
b5fb9a927bf3
add WM detection, and wm specific fullscreen code. (???)
pontscho
parents:
5986
diff
changeset
|
367 guiIntfStruct.MovieHeight=vo_dheight; |
5789 | 368 } |
369 break; | |
5665 | 370 #ifdef USE_DVDREAD |
371 case guiSetDVD: | |
372 guiIntfStruct.DVD.titles=dvdp->vmg_file->tt_srpt->nr_of_srpts; | |
373 guiIntfStruct.DVD.chapters=dvdp->vmg_file->tt_srpt->title[dvd_title].nr_of_ptts; | |
374 guiIntfStruct.DVD.angles=dvdp->vmg_file->tt_srpt->title[dvd_title].nr_of_angles; | |
375 guiIntfStruct.DVD.nr_of_audio_channels=dvdp->nr_of_channels; | |
376 memcpy( guiIntfStruct.DVD.audio_streams,dvdp->audio_streams,sizeof( dvdp->audio_streams ) ); | |
377 guiIntfStruct.DVD.nr_of_subtitles=dvdp->nr_of_subtitles; | |
378 memcpy( guiIntfStruct.DVD.subtitles,dvdp->subtitles,sizeof( dvdp->subtitles ) ); | |
379 guiIntfStruct.DVD.current_title=dvd_title + 1; | |
380 guiIntfStruct.DVD.current_chapter=dvd_chapter + 1; | |
381 guiIntfStruct.DVD.current_angle=dvd_angle + 1; | |
382 guiIntfStruct.Track=dvd_title + 1; | |
383 break; | |
384 #endif | |
6280 | 385 case guiSetStream: |
386 guiIntfStruct.StreamType=stream->type; | |
387 switch( stream->type ) | |
388 { | |
7150 | 389 #ifdef USE_DVDREAD |
6280 | 390 case STREAMTYPE_DVD: |
391 guiGetEvent( guiSetDVD,(char *)stream->priv ); | |
392 break; | |
7150 | 393 #endif |
6280 | 394 #ifdef HAVE_VCD |
395 case STREAMTYPE_VCD: | |
396 { | |
397 int i; | |
398 for ( i=1;i < 100;i++ ) | |
399 if ( vcd_seek_to_track( stream->fd,i ) < 0 ) break; | |
400 vcd_seek_to_track( stream->fd,vcd_track ); | |
401 guiIntfStruct.VCDTracks=--i; | |
402 mp_msg( MSGT_GPLAYER,MSGL_INFO,"[interface] vcd tracks: %d\n",guiIntfStruct.VCDTracks ); | |
403 guiIntfStruct.Track=vcd_track; | |
404 break; | |
405 } | |
406 #endif | |
7150 | 407 default: break; |
6280 | 408 } |
409 break; | |
4858 | 410 case guiIEvent: |
411 printf( "cmd: %d\n",(int)arg ); | |
412 switch( (int)arg ) | |
413 { | |
414 case MP_CMD_QUIT: | |
415 mplEventHandling( evExit,0 ); | |
416 break; | |
417 case MP_CMD_VO_FULLSCREEN: | |
418 mplEventHandling( evFullScreen,0 ); | |
419 break; | |
420 default: | |
421 mplEventHandling( guiCMDArray[ (int)arg - MP_CMD_GUI_EVENTS - 1 ],0 ); | |
422 } | |
423 break; | |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
424 case guiReDraw: |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
425 mplEventHandling( evRedraw,0 ); |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
426 break; |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
427 case guiSetVolume: |
6903 | 428 if ( audio_out ) |
429 { | |
430 float l,r; | |
431 mixer_getvolume( &l,&r ); | |
432 guiIntfStruct.Volume=(r>l?r:l); | |
433 if ( r != l ) guiIntfStruct.Balance=( ( r - l ) + 100 ) * 0.5f; | |
434 else guiIntfStruct.Balance=50.0f; | |
435 btnModify( evSetVolume,guiIntfStruct.Volume ); | |
436 btnModify( evSetBalance,guiIntfStruct.Balance ); | |
437 } | |
438 break; | |
7009 | 439 case guiSetFileFormat: |
440 guiIntfStruct.FileFormat=(int)arg; | |
441 break; | |
6903 | 442 case guiSetValues: |
6912 | 443 // -- video |
7217 | 444 guiIntfStruct.sh_video=arg; |
6912 | 445 if ( arg ) |
446 { | |
7217 | 447 sh_video_t * sh = (sh_video_t *)arg; |
7150 | 448 guiIntfStruct.FPS=sh->fps; |
6912 | 449 } |
7009 | 450 |
451 if ( guiIntfStruct.NoWindow ) wsVisibleWindow( &appMPlayer.subWindow,wsHideWindow ); | |
452 | |
6794 | 453 // -- audio |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
454 if ( audio_out ) |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
455 { |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
456 float l,r; |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
457 mixer_getvolume( &l,&r ); |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
458 guiIntfStruct.Volume=(r>l?r:l); |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
459 if ( r != l ) guiIntfStruct.Balance=( ( r - l ) + 100 ) * 0.5f; |
6627 | 460 else guiIntfStruct.Balance=50.0f; |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
461 btnModify( evSetVolume,guiIntfStruct.Volume ); |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
462 btnModify( evSetBalance,guiIntfStruct.Balance ); |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
463 } |
6627 | 464 |
6794 | 465 if ( gtkAONoSound ) { if ( !muted ) mixer_mute(); } |
466 else if ( muted ) mixer_mute(); | |
467 | |
6627 | 468 if ( gtkEnableAudioEqualizer ) |
469 { | |
470 equalizer_t eq; | |
471 int i,j; | |
472 for ( i=0;i<6;i++ ) | |
473 for ( j=0;j<10;j++ ) | |
474 { | |
475 eq.channel=i; eq.band=j; eq.gain=gtkEquChannels[i][j]; | |
476 gtkSet( gtkSetEqualizer,0,&eq ); | |
477 } | |
478 } | |
6794 | 479 // -- subtitle |
7009 | 480 #ifdef HAVE_DXR3 |
7582 | 481 if ( video_driver_list && !gstrcmp( video_driver_list[0],"dxr3" ) && guiIntfStruct.FileFormat != DEMUXER_TYPE_MPEG_PS && !gtkVopLAVC && !gtkVopFAME ) |
7009 | 482 { |
483 gtkMessageBox( GTK_MB_FATAL,MSGTR_NEEDLAVCFAME ); | |
484 guiIntfStruct.Playing=0; | |
485 return True; | |
486 } | |
487 #endif | |
6627 | 488 break; |
489 case guiSetDefaults: | |
6857 | 490 if ( filename && !guiIntfStruct.Filename ) |
6794 | 491 { |
492 gtkSet( gtkDelPl,0,NULL ); guiIntfStruct.StreamType=STREAMTYPE_FILE; | |
493 guiSetFilename( guiIntfStruct.Filename,filename ); | |
494 } | |
495 | |
496 guiIntfStruct.DiskChanged=0; | |
497 | |
7009 | 498 // --- video opts |
7019 | 499 |
7582 | 500 if ( !video_driver_list ) |
6794 | 501 { |
6797
06d29dbdf20d
upsz, sorry, i forgott this :) (skin name saving:)
pontscho
parents:
6794
diff
changeset
|
502 int i = 0; |
6903 | 503 while ( video_out_drivers[i++] ) |
504 if ( video_out_drivers[i - 1]->control( VOCTRL_GUISUPPORT,NULL ) == VO_TRUE ) | |
505 { | |
506 const vo_info_t *info = video_out_drivers[i - 1]->get_info(); | |
7582 | 507 gaddlist( &video_driver_list,(char *)info->short_name ); |
6903 | 508 break; |
509 } | |
6794 | 510 } |
511 | |
7582 | 512 if ( !video_driver_list && !video_driver_list[0] ) { gtkMessageBox( GTK_MB_FATAL,MSGTR_IDFGCVD ); exit_player( "gui init" ); } |
7009 | 513 |
514 { | |
515 int i = 0; | |
516 guiIntfStruct.NoWindow=False; | |
517 while ( video_out_drivers[i++] ) | |
518 if ( video_out_drivers[i - 1]->control( VOCTRL_GUISUPPORT,NULL ) == VO_TRUE ) | |
6794 | 519 { |
7009 | 520 const vo_info_t *info = video_out_drivers[i - 1]->get_info(); |
7582 | 521 if ( ( video_driver_list && !gstrcmp( video_driver_list[0],(char *)info->short_name ) )&&( video_out_drivers[i - 1]->control( VOCTRL_GUI_NOWINDOW,NULL ) == VO_TRUE ) ) |
7009 | 522 { guiIntfStruct.NoWindow=True; break; } |
6794 | 523 } |
7009 | 524 } |
525 | |
526 #ifdef HAVE_DXR3 | |
527 remove_vop( "lavc" ); | |
528 remove_vop( "fame" ); | |
7582 | 529 if ( video_driver_list && !gstrcmp( video_driver_list[0],"dxr3" ) ) |
7009 | 530 { |
531 if ( ( guiIntfStruct.StreamType != STREAMTYPE_DVD)&&( guiIntfStruct.StreamType != STREAMTYPE_VCD ) ) | |
532 { | |
533 if ( gtkVopLAVC ) add_vop( "lavc" ); | |
534 if ( gtkVopFAME ) add_vop( "fame" ); | |
535 } | |
536 } | |
537 #endif | |
538 // --- | |
7019 | 539 if ( gtkVopPP ) add_vop( "pp" ); |
540 else remove_vop( "pp" ); | |
6794 | 541 |
542 // --- audio opts | |
543 audio_delay=gtkAODelay; | |
7887
0e5544951425
A small patch to Gui/interface.c; the first fix is a plain bug, the second is
arpi
parents:
7707
diff
changeset
|
544 // if ( ao_plugin_cfg.plugin_list ) { free( ao_plugin_cfg.plugin_list ); ao_plugin_cfg.plugin_list=NULL; } |
6840 | 545 if ( gtkAONorm ) gset( &ao_plugin_cfg.plugin_list,"volnorm" ); |
6794 | 546 if ( gtkEnableAudioEqualizer ) gset( &ao_plugin_cfg.plugin_list,"eq" ); |
547 if ( gtkAOExtraStereo ) | |
548 { | |
549 gset( &ao_plugin_cfg.plugin_list,"extrastereo" ); | |
550 ao_plugin_cfg.pl_extrastereo_mul=gtkAOExtraStereoMul; | |
551 } | |
552 mixer_device=gtkAOOSSMixer; | |
7582 | 553 if ( audio_driver_list && !gstrncmp( audio_driver_list[0],"oss",3 ) && gtkAOOSSDevice ) |
6794 | 554 { |
7019 | 555 char * tmp = calloc( 1,strlen( gtkAOOSSDevice ) + 5 ); |
556 sprintf( tmp,"oss:%s",gtkAOOSSDevice ); | |
7582 | 557 gaddlist( &audio_driver_list,tmp ); |
7019 | 558 } |
6794 | 559 |
560 // -- subtitle | |
561 #ifdef USE_SUB | |
7170 | 562 sub_name=gstrdup( guiIntfStruct.Subtitlename ); |
6794 | 563 stream_dump_type=0; |
564 if ( gtkSubDumpMPSub ) stream_dump_type=4; | |
565 if ( gtkSubDumpSrt ) stream_dump_type=6; | |
566 gtkSubDumpMPSub=gtkSubDumpSrt=0; | |
6627 | 567 #endif |
6794 | 568 #if defined( USE_OSD ) || defined( USE_SUB ) |
569 guiLoadFont(); | |
6627 | 570 #endif |
571 | |
6794 | 572 // --- misc |
6627 | 573 if ( guiIntfStruct.AudioFile ) audio_stream=guiIntfStruct.AudioFile; |
574 else if ( guiIntfStruct.FilenameChanged ) audio_stream=NULL; | |
575 | |
576 break; | |
4798 | 577 } |
7009 | 578 return False; |
4798 | 579 } |
580 | |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
581 extern unsigned int GetTimerMS( void ); |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
582 extern int mplTimer; |
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
583 |
4798 | 584 void guiEventHandling( void ) |
585 { | |
7009 | 586 if ( !guiIntfStruct.Playing || guiIntfStruct.NoWindow ) wsHandleEvents(); |
4818
3473ca9ef158
new gui interface, and gtk moved into mplayer process. fork ... bleh :)
pontscho
parents:
4798
diff
changeset
|
587 gtkEventHandling(); |
6619
f554e7271587
fix volume handling ( step 2 ) -- add balance support and some code cleanup and fix
pontscho
parents:
6280
diff
changeset
|
588 mplTimer=GetTimerMS() / 20; |
4798 | 589 } |
6627 | 590 |
591 // --- | |
592 | |
593 float gtkEquChannels[6][10]; | |
594 | |
6713 | 595 plItem * plCurrent = NULL; |
596 plItem * plList = NULL; | |
597 plItem * plLastPlayed = NULL; | |
598 | |
7092
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
599 URLItem *URLList = NULL; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
600 |
6713 | 601 #if defined( MP_DEBUG ) && 0 |
602 void list( void ) | |
6627 | 603 { |
6713 | 604 plItem * next = plList; |
605 printf( "--- list ---\n" ); | |
606 while( next || next->next ) | |
607 { | |
608 printf( "item: %s/%s\n",next->path,next->name ); | |
609 if ( next->next ) next=next->next; else break; | |
610 } | |
611 printf( "--- end of list ---\n" ); | |
612 } | |
613 #else | |
614 #define list(); | |
615 #endif | |
616 | |
617 void * gtkSet( int cmd,float fparam, void * vparam ) | |
618 { | |
6627 | 619 equalizer_t * eq = (equalizer_t *)vparam; |
6713 | 620 plItem * item = (plItem *)vparam; |
6627 | 621 |
7092
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
622 URLItem * url_item = (URLItem *)vparam; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
623 int is_added = True; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
624 |
6627 | 625 switch ( cmd ) |
626 { | |
6713 | 627 // --- handle playlist |
6755 | 628 case gtkAddPlItem: // add item to playlist |
6713 | 629 if ( plList ) |
630 { | |
631 plItem * next = plList; | |
632 while ( next->next ) { /*printf( "%s\n",next->name );*/ next=next->next; } | |
633 next->next=item; item->prev=next; | |
7092
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
634 } else { item->prev=item->next=NULL; plCurrent=plList=item; } |
6713 | 635 list(); |
636 return NULL; | |
637 case gtkGetNextPlItem: // get current item from playlist | |
638 if ( plCurrent ) | |
639 { | |
640 plCurrent=plCurrent->next; | |
641 if ( !plCurrent && plList ) | |
642 { | |
643 plItem * next = plList; | |
644 while ( next->next ) { if ( !next->next ) break; next=next->next; } | |
645 plCurrent=next; | |
646 } | |
647 return plCurrent; | |
648 } | |
649 return NULL; | |
650 case gtkGetPrevPlItem: | |
651 if ( plCurrent ) | |
652 { | |
653 plCurrent=plCurrent->prev; | |
654 if ( !plCurrent && plList ) plCurrent=plList; | |
655 return plCurrent; | |
656 } | |
6794 | 657 return NULL; |
6713 | 658 case gtkGetCurrPlItem: // get current item |
659 return plCurrent; | |
660 case gtkDelPl: // delete list | |
661 { | |
662 plItem * curr = plList; | |
663 plItem * next; | |
664 if ( !plList ) return NULL; | |
665 if ( !curr->next ) | |
666 { | |
667 if ( curr->path ) free( curr->path ); | |
668 if ( curr->name ) free( curr->name ); | |
669 free( curr ); | |
670 } | |
671 else | |
672 { | |
673 while ( curr->next ) | |
674 { | |
675 next=curr->next; | |
676 if ( curr->path ) free( curr->path ); | |
677 if ( curr->name ) free( curr->name ); | |
678 free( curr ); | |
679 curr=next; | |
680 } | |
681 } | |
682 plList=NULL; plCurrent=NULL; | |
683 } | |
684 return NULL; | |
7092
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
685 // ----- Handle url |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
686 case gtkAddURLItem: |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
687 if ( URLList ) |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
688 { |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
689 URLItem * next_url = URLList; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
690 is_added = False; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
691 while ( next_url->next ) |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
692 { |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
693 if ( !gstrcmp( next_url->url,url_item->url ) ) |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
694 { |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
695 is_added=True; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
696 break; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
697 } |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
698 next_url=next_url->next; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
699 } |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
700 if ( ( !is_added )&&( gstrcmp( next_url->url,url_item->url ) ) ) next_url->next=url_item; |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
701 } else { url_item->next=NULL; URLList=url_item; } |
8e9607c5897e
- warning fixes from Dominik Mierzejewski <dominik@rangers.eu.org>
pontscho
parents:
7019
diff
changeset
|
702 return NULL; |
6794 | 703 // --- subtitle |
704 case gtkSetSubAuto: | |
7019 | 705 sub_auto=(int)fparam; |
6794 | 706 return NULL; |
707 case gtkSetSubDelay: | |
7019 | 708 sub_delay=fparam; |
6794 | 709 return NULL; |
710 case gtkSetSubFPS: | |
7019 | 711 sub_fps=(int)fparam; |
6794 | 712 return NULL; |
713 case gtkSetSubPos: | |
7019 | 714 sub_pos=(int)fparam; |
6794 | 715 return NULL; |
716 #if defined( USE_OSD ) || defined( USE_SUB ) | |
7139 | 717 #ifndef HAVE_FREETYPE |
6794 | 718 case gtkSetFontFactor: |
7019 | 719 font_factor=fparam; |
6794 | 720 guiLoadFont(); |
721 return NULL; | |
7139 | 722 #else |
723 case gtkSetFontOutLine: | |
724 subtitle_font_thickness=( 8.0f / 100.0f ) * fparam; | |
725 guiLoadFont(); | |
726 return NULL; | |
727 case gtkSetFontBlur: | |
728 subtitle_font_radius=( 8.0f / 100.0f ) * fparam; | |
729 guiLoadFont(); | |
730 return NULL; | |
731 case gtkSetFontTextScale: | |
732 text_font_scale_factor=fparam; | |
733 guiLoadFont(); | |
734 return NULL; | |
735 case gtkSetFontOSDScale: | |
736 osd_font_scale_factor=fparam; | |
737 guiLoadFont(); | |
738 return NULL; | |
739 case gtkSetFontEncoding: | |
740 if ( subtitle_font_encoding ) free( subtitle_font_encoding ); | |
741 subtitle_font_encoding=gstrdup( (char *)vparam ); | |
742 guiLoadFont(); | |
743 return NULL; | |
744 case gtkSetFontAutoScale: | |
745 subtitle_autoscale=(int)fparam; | |
746 guiLoadFont(); | |
747 return NULL; | |
748 #endif | |
6794 | 749 #endif |
750 // --- misc | |
751 case gtkClearStruct: | |
7009 | 752 if ( (unsigned int)vparam & guiFilenames ) |
6794 | 753 { |
754 gfree( (void **)&guiIntfStruct.Filename ); | |
755 gfree( (void **)&guiIntfStruct.Subtitlename ); | |
756 gfree( (void **)&guiIntfStruct.AudioFile ); | |
7009 | 757 gtkSet( gtkDelPl,0,NULL ); |
6794 | 758 } |
759 #ifdef USE_DVDREAD | |
7009 | 760 if ( (unsigned int)vparam & guiDVD ) memset( &guiIntfStruct.DVD,0,sizeof( guiDVDStruct ) ); |
6794 | 761 #endif |
762 #ifdef HAVE_VCD | |
7009 | 763 if ( (unsigned int)vparam & guiVCD ) guiIntfStruct.VCDTracks=0; |
6794 | 764 #endif |
765 return NULL; | |
7526 | 766 case gtkSetCacheSize: |
767 stream_cache_size=(int)fparam; | |
768 return NULL; | |
6794 | 769 case gtkSetExtraStereo: |
770 gtkAOExtraStereoMul=fparam; | |
771 audio_plugin_extrastereo.control( AOCONTROL_PLUGIN_ES_SET,(int)>kAOExtraStereoMul ); | |
772 return NULL; | |
773 case gtkSetAudioDelay: | |
774 audio_delay=gtkAODelay=fparam; | |
775 return NULL; | |
776 case gtkSetPanscan: | |
7217 | 777 { |
778 mp_cmd_t * mp_cmd; | |
779 mp_cmd=(mp_cmd_t *)calloc( 1,sizeof( *mp_cmd ) ); | |
780 mp_cmd->id=MP_CMD_PANSCAN; mp_cmd->name=strdup( "panscan" ); | |
781 mp_cmd->args[0].v.f=fparam; mp_cmd->args[1].v.i=1; | |
782 mp_input_queue_cmd( mp_cmd ); | |
783 } | |
6794 | 784 return NULL; |
785 case gtkSetAutoq: | |
7019 | 786 auto_quality=(int)fparam; |
6794 | 787 return NULL; |
6713 | 788 // --- set equalizers |
6627 | 789 case gtkSetContrast: |
7217 | 790 if ( guiIntfStruct.sh_video ) set_video_colors( guiIntfStruct.sh_video,"contrast",(int)fparam ); |
791 return NULL; | |
6627 | 792 case gtkSetBrightness: |
7217 | 793 if ( guiIntfStruct.sh_video ) set_video_colors( guiIntfStruct.sh_video,"brightness",(int)fparam ); |
794 return NULL; | |
6627 | 795 case gtkSetHue: |
7217 | 796 if ( guiIntfStruct.sh_video ) set_video_colors( guiIntfStruct.sh_video,"hue",(int)fparam ); |
797 return NULL; | |
6627 | 798 case gtkSetSaturation: |
7217 | 799 if ( guiIntfStruct.sh_video ) set_video_colors( guiIntfStruct.sh_video,"saturation",(int)fparam ); |
800 return NULL; | |
6627 | 801 case gtkSetEqualizer: |
802 if ( eq ) | |
803 { | |
804 gtkEquChannels[eq->channel][eq->band]=eq->gain; | |
805 audio_plugin_eq.control( AOCONTROL_PLUGIN_EQ_SET_GAIN,(int)eq ); | |
806 } | |
807 else | |
808 { | |
809 int i,j; equalizer_t tmp; tmp.gain=0.0f; | |
810 memset( gtkEquChannels,0,sizeof( gtkEquChannels ) ); | |
811 for ( i=0;i<6;i++ ) | |
812 for ( j=0;j<10;j++ ) | |
813 { tmp.channel=i; tmp.band=j; audio_plugin_eq.control( AOCONTROL_PLUGIN_EQ_SET_GAIN,(int)&tmp ); } | |
814 } | |
6713 | 815 return NULL; |
6627 | 816 } |
6713 | 817 return NULL; |
6627 | 818 } |