Mercurial > mplayer.hg
annotate gui/ui/main.c @ 33654:90f7a7266410
Use X11 Bool symbolic constant.
author | ib |
---|---|
date | Mon, 27 Jun 2011 14:08:30 +0000 |
parents | 1f9a31d4f114 |
children | cbb7cfeb8c71 |
rev | line source |
---|---|
26458 | 1 /* |
2 * main window | |
3 * | |
4 * This file is part of MPlayer. | |
5 * | |
6 * MPlayer is free software; you can redistribute it and/or modify | |
7 * it under the terms of the GNU General Public License as published by | |
8 * the Free Software Foundation; either version 2 of the License, or | |
9 * (at your option) any later version. | |
10 * | |
11 * MPlayer is distributed in the hope that it will be useful, | |
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 * GNU General Public License for more details. | |
15 * | |
16 * You should have received a copy of the GNU General Public License along | |
17 * with MPlayer; if not, write to the Free Software Foundation, Inc., | |
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | |
19 */ | |
23077 | 20 |
21 #include <stdlib.h> | |
22 #include <stdio.h> | |
23 #include <sys/stat.h> | |
24 #include <unistd.h> | |
23305
22d3d12c6dfb
Include string.h for memcpy, fastmemcpy.h alone is not enough.
reimar
parents:
23154
diff
changeset
|
25 #include <string.h> |
23077 | 26 |
26382
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
27 #include "config.h" |
23154
e564b9cd7290
Fix several implicit declarations of functions warnings.
diego
parents:
23077
diff
changeset
|
28 #include "gmplayer.h" |
26365
10dfbc523184
Add gui/ prefix to some #include paths so that compilation from the
diego
parents:
26203
diff
changeset
|
29 #include "gui/app.h" |
10dfbc523184
Add gui/ prefix to some #include paths so that compilation from the
diego
parents:
26203
diff
changeset
|
30 #include "gui/skin/font.h" |
10dfbc523184
Add gui/ prefix to some #include paths so that compilation from the
diego
parents:
26203
diff
changeset
|
31 #include "gui/skin/skin.h" |
10dfbc523184
Add gui/ prefix to some #include paths so that compilation from the
diego
parents:
26203
diff
changeset
|
32 #include "gui/wm/ws.h" |
23077 | 33 |
26382
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
34 #include "help_mp.h" |
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
35 #include "libvo/x11_common.h" |
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
36 #include "libvo/fastmemcpy.h" |
33531
84ce059fae34
Get non-multimedia X11 key definitions from libvo/wskeys.h.
ib
parents:
33525
diff
changeset
|
37 #include "libvo/wskeys.h" |
23077 | 38 |
26382
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
39 #include "stream/stream.h" |
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
40 #include "stream/url.h" |
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
41 #include "mixer.h" |
32467 | 42 #include "sub/sub.h" |
26382
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
43 #include "access_mpcontext.h" |
23077 | 44 |
30537
7bebe34b6ad2
Move movie_aspect extern declaration to libmpcodecs/vd.h.
diego
parents:
30516
diff
changeset
|
45 #include "libmpcodecs/vd.h" |
26382
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
46 #include "libmpdemux/demuxer.h" |
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
47 #include "libmpdemux/stheader.h" |
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
48 #include "codec-cfg.h" |
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
49 #include "m_option.h" |
b2f4abcf20ed
Make include paths consistent; do not use ../ in them.
diego
parents:
26365
diff
changeset
|
50 #include "m_property.h" |
30516 | 51 #include "mp_core.h" |
32043
f6249bc89c38
Move extern declarations used by both mplayer.c and mencoder.c to mpcommon.h.
diego
parents:
32041
diff
changeset
|
52 #include "mpcommon.h" |
23077 | 53 |
54 #define GUI_REDRAW_WAIT 375 | |
55 | |
33556 | 56 #include "actions.h" |
23077 | 57 #include "widgets.h" |
58 | |
28051 | 59 unsigned int GetTimerMS( void ); |
23077 | 60 |
33555 | 61 unsigned char * mainDrawBuffer = NULL; |
62 int uiMainRender = 1; | |
23077 | 63 |
33555 | 64 int uiMainAutoPlay = 0; |
65 int uiMiddleMenu = 0; | |
23077 | 66 |
67 int mainVisible = 1; | |
68 | |
69 int boxMoved = 0; | |
70 int sx = 0,sy = 0; | |
71 int i,pot = 0; | |
72 | |
33556 | 73 #include "render.h" |
23077 | 74 |
33555 | 75 void uiMainDraw( void ) |
23077 | 76 { |
77 | |
33555 | 78 if ( guiApp.mainWindow.State == wsWindowClosed ) guiExit( EXIT_QUIT ); |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
79 |
33555 | 80 if ( guiApp.mainWindow.Visible == wsWindowNotVisible || |
23077 | 81 !mainVisible ) return; |
33555 | 82 // !guiApp.mainWindow.Mapped ) return; |
23077 | 83 |
33555 | 84 if ( uiMainRender && guiApp.mainWindow.State == wsWindowExpose ) |
23077 | 85 { |
33555 | 86 btnModify( evSetMoviePosition,guiInfo.Position ); |
87 btnModify( evSetVolume,guiInfo.Volume ); | |
23077 | 88 |
33555 | 89 fast_memcpy( mainDrawBuffer,guiApp.main.Bitmap.Image,guiApp.main.Bitmap.ImageSize ); |
90 RenderAll( &guiApp.mainWindow,guiApp.mainItems,guiApp.IndexOfMainItems,mainDrawBuffer ); | |
91 uiMainRender=0; | |
23077 | 92 } |
33555 | 93 wsPutImage( &guiApp.mainWindow ); |
23077 | 94 // XFlush( wsDisplay ); |
95 } | |
96 | |
97 static unsigned last_redraw_time = 0; | |
98 | |
33555 | 99 void uiEventHandling( int msg,float param ) |
23077 | 100 { |
101 int iparam = (int)param; | |
33555 | 102 mixer_t *mixer = mpctx_get_mixer(guiInfo.mpcontext); |
23077 | 103 |
104 switch( msg ) | |
105 { | |
106 // --- user events | |
107 case evExit: | |
33263 | 108 guiExit( EXIT_QUIT ); |
23077 | 109 break; |
110 | |
111 case evPlayNetwork: | |
33555 | 112 gfree( (void **)&guiInfo.Subtitlename ); |
113 gfree( (void **)&guiInfo.AudioFile ); | |
114 guiInfo.StreamType=STREAMTYPE_STREAM; | |
23077 | 115 goto play; |
116 case evSetURL: | |
117 gtkShow( evPlayNetwork,NULL ); | |
118 break; | |
119 | |
120 case evSetAudio: | |
33555 | 121 if ( !guiInfo.demuxer || audio_id == iparam ) break; |
23077 | 122 audio_id=iparam; |
123 goto play; | |
124 | |
125 case evSetVideo: | |
33555 | 126 if ( !guiInfo.demuxer || video_id == iparam ) break; |
23077 | 127 video_id=iparam; |
128 goto play; | |
129 | |
130 case evSetSubtitle: | |
33555 | 131 mp_property_do("sub",M_PROPERTY_SET,&iparam,guiInfo.mpcontext); |
23077 | 132 break; |
133 | |
27370
14c5017f40d2
Change a bunch of video/audio-output-specific preprocessor directives from
diego
parents:
27341
diff
changeset
|
134 #ifdef CONFIG_VCD |
23077 | 135 case evSetVCDTrack: |
33555 | 136 guiInfo.Track=iparam; |
23077 | 137 case evPlayVCD: |
138 gtkSet( gtkClearStruct,0,(void *)guiALL ); | |
33555 | 139 guiInfo.StreamType=STREAMTYPE_VCD; |
23077 | 140 goto play; |
141 #endif | |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26458
diff
changeset
|
142 #ifdef CONFIG_DVDREAD |
23077 | 143 case evPlayDVD: |
33555 | 144 guiInfo.DVD.current_title=1; |
145 guiInfo.DVD.current_chapter=1; | |
146 guiInfo.DVD.current_angle=1; | |
23077 | 147 play_dvd_2: |
148 gtkSet( gtkClearStruct,0,(void *)(guiALL - guiDVD) ); | |
33555 | 149 guiInfo.StreamType=STREAMTYPE_DVD; |
23077 | 150 goto play; |
151 #endif | |
152 case evPlay: | |
153 case evPlaySwitchToPause: | |
154 play: | |
155 | |
33615
1f9a31d4f114
Replace all playback integer constants by their symbolic constants.
ib
parents:
33614
diff
changeset
|
156 if ( ( msg == evPlaySwitchToPause )&&( guiInfo.Playing == GUI_PAUSE ) ) goto NoPause; |
23077 | 157 |
33555 | 158 if ( gtkSet( gtkGetCurrPlItem,0,NULL ) &&( guiInfo.StreamType == STREAMTYPE_FILE ) ) |
23077 | 159 { |
160 plItem * next = gtkSet( gtkGetCurrPlItem,0,NULL ); | |
161 plLastPlayed=next; | |
33555 | 162 uiSetFileName( next->path,next->name,STREAMTYPE_FILE ); |
23077 | 163 } |
164 | |
33555 | 165 switch ( guiInfo.StreamType ) |
23077 | 166 { |
167 case STREAMTYPE_STREAM: | |
168 case STREAMTYPE_FILE: | |
169 gtkSet( gtkClearStruct,0,(void *)(guiALL - guiFilenames) ); | |
170 break; | |
27370
14c5017f40d2
Change a bunch of video/audio-output-specific preprocessor directives from
diego
parents:
27341
diff
changeset
|
171 #ifdef CONFIG_VCD |
23077 | 172 case STREAMTYPE_VCD: |
173 gtkSet( gtkClearStruct,0,(void *)(guiALL - guiVCD - guiFilenames) ); | |
174 if ( !cdrom_device ) cdrom_device=gstrdup( DEFAULT_CDROM_DEVICE ); | |
33555 | 175 uiSetFileName( NULL,cdrom_device,STREAMTYPE_VCD ); |
33615
1f9a31d4f114
Replace all playback integer constants by their symbolic constants.
ib
parents:
33614
diff
changeset
|
176 if ( guiInfo.Playing != GUI_PAUSE ) |
23077 | 177 { |
33555 | 178 if ( !guiInfo.Track ) |
179 guiInfo.Track=1; | |
180 guiInfo.DiskChanged=1; | |
23077 | 181 } |
182 break; | |
183 #endif | |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26458
diff
changeset
|
184 #ifdef CONFIG_DVDREAD |
23077 | 185 case STREAMTYPE_DVD: |
186 gtkSet( gtkClearStruct,0,(void *)(guiALL - guiDVD - guiFilenames) ); | |
187 if ( !dvd_device ) dvd_device=gstrdup( DEFAULT_DVD_DEVICE ); | |
33555 | 188 uiSetFileName( NULL,dvd_device,STREAMTYPE_DVD ); |
33615
1f9a31d4f114
Replace all playback integer constants by their symbolic constants.
ib
parents:
33614
diff
changeset
|
189 if ( guiInfo.Playing != GUI_PAUSE ) |
23077 | 190 { |
33555 | 191 guiInfo.Title=guiInfo.DVD.current_title; |
192 guiInfo.Chapter=guiInfo.DVD.current_chapter; | |
193 guiInfo.Angle=guiInfo.DVD.current_angle; | |
194 guiInfo.DiskChanged=1; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
195 } |
23077 | 196 break; |
197 #endif | |
198 } | |
33555 | 199 guiInfo.NewPlay=1; |
200 uiPlay(); | |
23077 | 201 break; |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26458
diff
changeset
|
202 #ifdef CONFIG_DVDREAD |
23077 | 203 case evSetDVDSubtitle: |
204 dvdsub_id=iparam; | |
205 goto play_dvd_2; | |
206 break; | |
207 case evSetDVDAudio: | |
208 audio_id=iparam; | |
209 goto play_dvd_2; | |
210 break; | |
211 case evSetDVDChapter: | |
33555 | 212 guiInfo.DVD.current_chapter=iparam; |
23077 | 213 goto play_dvd_2; |
214 break; | |
215 case evSetDVDTitle: | |
33555 | 216 guiInfo.DVD.current_title=iparam; |
217 guiInfo.DVD.current_chapter=1; | |
218 guiInfo.DVD.current_angle=1; | |
23077 | 219 goto play_dvd_2; |
220 break; | |
221 #endif | |
222 | |
223 case evPause: | |
224 case evPauseSwitchToPlay: | |
225 NoPause: | |
33555 | 226 uiPause(); |
23077 | 227 break; |
228 | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
229 case evStop: |
33614 | 230 guiInfo.Playing=GUI_STOP; |
33555 | 231 uiState(); |
232 guiInfo.NoWindow=False; | |
23077 | 233 break; |
234 | |
235 case evLoadPlay: | |
33555 | 236 uiMainAutoPlay=1; |
237 // guiInfo.StreamType=STREAMTYPE_FILE; | |
23077 | 238 case evLoad: |
239 gtkSet( gtkDelPl,0,NULL ); | |
240 gtkShow( evLoad,NULL ); | |
241 break; | |
242 case evLoadSubtitle: gtkShow( evLoadSubtitle,NULL ); break; | |
243 case evDropSubtitle: | |
33555 | 244 gfree( (void **)&guiInfo.Subtitlename ); |
23077 | 245 guiLoadSubtitle( NULL ); |
246 break; | |
247 case evLoadAudioFile: gtkShow( evLoadAudioFile,NULL ); break; | |
33555 | 248 case evPrev: uiPrev(); break; |
249 case evNext: uiNext(); break; | |
23077 | 250 |
251 case evPlayList: gtkShow( evPlayList,NULL ); break; | |
252 case evSkinBrowser: gtkShow( evSkinBrowser,skinName ); break; | |
253 case evAbout: gtkShow( evAbout,NULL ); break; | |
254 case evPreferences: gtkShow( evPreferences,NULL ); break; | |
255 case evEqualizer: gtkShow( evEqualizer,NULL ); break; | |
256 | |
33555 | 257 case evForward10min: uiRelSeek( 600 ); break; |
258 case evBackward10min: uiRelSeek( -600 );break; | |
259 case evForward1min: uiRelSeek( 60 ); break; | |
260 case evBackward1min: uiRelSeek( -60 ); break; | |
261 case evForward10sec: uiRelSeek( 10 ); break; | |
262 case evBackward10sec: uiRelSeek( -10 ); break; | |
263 case evSetMoviePosition: uiAbsSeek( param ); break; | |
23077 | 264 |
265 case evIncVolume: vo_x11_putkey( wsGrayMul ); break; | |
266 case evDecVolume: vo_x11_putkey( wsGrayDiv ); break; | |
267 case evMute: mixer_mute( mixer ); break; | |
268 | |
269 case evSetVolume: | |
33555 | 270 guiInfo.Volume=param; |
23077 | 271 goto set_volume; |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
272 case evSetBalance: |
33555 | 273 guiInfo.Balance=param; |
23077 | 274 set_volume: |
275 { | |
33555 | 276 float l = guiInfo.Volume * ( ( 100.0 - guiInfo.Balance ) / 50.0 ); |
277 float r = guiInfo.Volume * ( ( guiInfo.Balance ) / 50.0 ); | |
278 if ( l > guiInfo.Volume ) l=guiInfo.Volume; | |
279 if ( r > guiInfo.Volume ) r=guiInfo.Volume; | |
280 // printf( "!!! v: %.2f b: %.2f -> %.2f x %.2f\n",guiInfo.Volume,guiInfo.Balance,l,r ); | |
23077 | 281 mixer_setvolume( mixer,l,r ); |
282 } | |
283 if ( osd_level ) | |
284 { | |
285 osd_visible=(GetTimerMS() + 1000) | 1; | |
286 vo_osd_progbar_type=OSD_VOLUME; | |
33555 | 287 vo_osd_progbar_value=( ( guiInfo.Volume ) * 256.0 ) / 100.0; |
23077 | 288 vo_osd_changed( OSDTYPE_PROGBAR ); |
289 } | |
290 break; | |
291 | |
292 | |
293 case evIconify: | |
294 switch ( iparam ) | |
295 { | |
33555 | 296 case 0: wsIconify( guiApp.mainWindow ); break; |
297 case 1: wsIconify( guiApp.subWindow ); break; | |
23077 | 298 } |
299 break; | |
300 case evHalfSize: | |
301 btnSet( evFullScreen,btnReleased ); | |
33555 | 302 if ( guiInfo.Playing ) |
23077 | 303 { |
33555 | 304 if ( guiApp.subWindow.isFullScreen ) |
23077 | 305 { |
33555 | 306 uiFullScreen(); |
23077 | 307 } |
33555 | 308 wsResizeWindow( &guiApp.subWindow, guiInfo.MovieWidth / 2, guiInfo.MovieHeight / 2 ); |
33654 | 309 wsMoveWindow( &guiApp.subWindow, False, |
33555 | 310 ( wsMaxX - guiInfo.MovieWidth/2 )/2 + wsOrgX, |
311 ( wsMaxY - guiInfo.MovieHeight/2 )/2 + wsOrgY ); | |
23077 | 312 } |
313 break; | |
314 case evDoubleSize: | |
315 btnSet( evFullScreen,btnReleased ); | |
33555 | 316 if ( guiInfo.Playing ) |
23077 | 317 { |
33555 | 318 if ( guiApp.subWindow.isFullScreen ) |
23077 | 319 { |
33555 | 320 uiFullScreen(); |
23077 | 321 } |
33555 | 322 wsResizeWindow( &guiApp.subWindow, guiInfo.MovieWidth * 2, guiInfo.MovieHeight * 2 ); |
33654 | 323 wsMoveWindow( &guiApp.subWindow, False, |
33555 | 324 ( wsMaxX - guiInfo.MovieWidth*2 )/2 + wsOrgX, |
325 ( wsMaxY - guiInfo.MovieHeight*2 )/2 + wsOrgY ); | |
23077 | 326 } |
327 break; | |
328 case evNormalSize: | |
329 btnSet( evFullScreen,btnReleased ); | |
33555 | 330 if ( guiInfo.Playing ) |
23077 | 331 { |
33555 | 332 if ( guiApp.subWindow.isFullScreen ) |
23077 | 333 { |
33555 | 334 uiFullScreen(); |
23077 | 335 } |
33555 | 336 wsResizeWindow( &guiApp.subWindow, guiInfo.MovieWidth, guiInfo.MovieHeight ); |
33654 | 337 wsMoveWindow( &guiApp.subWindow, False, |
33555 | 338 ( wsMaxX - guiInfo.MovieWidth )/2 + wsOrgX, |
339 ( wsMaxY - guiInfo.MovieHeight )/2 + wsOrgY ); | |
23077 | 340 break; |
33555 | 341 } else if ( !guiApp.subWindow.isFullScreen ) break; |
23077 | 342 case evFullScreen: |
33555 | 343 if ( !guiInfo.Playing && !gtkShowVideoWindow ) break; |
344 uiFullScreen(); | |
345 if ( guiApp.subWindow.isFullScreen ) btnSet( evFullScreen,btnPressed ); | |
23077 | 346 else btnSet( evFullScreen,btnReleased ); |
347 break; | |
348 | |
349 case evSetAspect: | |
350 switch ( iparam ) | |
351 { | |
352 case 2: movie_aspect=16.0f / 9.0f; break; | |
353 case 3: movie_aspect=4.0f / 3.0f; break; | |
354 case 4: movie_aspect=2.35; break; | |
355 case 1: | |
356 default: movie_aspect=-1; | |
357 } | |
33555 | 358 wsClearWindow( guiApp.subWindow ); |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26458
diff
changeset
|
359 #ifdef CONFIG_DVDREAD |
33555 | 360 if ( guiInfo.StreamType == STREAMTYPE_DVD || guiInfo.StreamType == STREAMTYPE_VCD ) goto play_dvd_2; |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
361 else |
23077 | 362 #endif |
33555 | 363 guiInfo.NewPlay=1; |
23077 | 364 break; |
365 | |
366 // --- timer events | |
367 case evRedraw: | |
368 { | |
369 unsigned now = GetTimerMS(); | |
370 if ((now > last_redraw_time) && | |
371 (now < last_redraw_time + GUI_REDRAW_WAIT) && | |
33555 | 372 !uiPlaybarFade) |
23077 | 373 break; |
374 last_redraw_time = now; | |
375 } | |
33555 | 376 uiMainRender=1; |
377 wsPostRedisplay( &guiApp.mainWindow ); | |
378 wsPostRedisplay( &guiApp.playbarWindow ); | |
23077 | 379 break; |
380 // --- system events | |
381 #ifdef MP_DEBUG | |
382 case evNone: | |
383 mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[mw] event none received.\n" ); | |
384 break; | |
385 default: | |
386 mp_msg( MSGT_GPLAYER,MSGL_STATUS,"[mw] unknown event received ( %d,%.2f ).\n",msg,param ); | |
387 break; | |
388 #endif | |
389 } | |
390 } | |
391 | |
33555 | 392 void uiMainMouseHandle( int Button,int X,int Y,int RX,int RY ) |
23077 | 393 { |
394 static int itemtype = 0; | |
395 int i; | |
396 wItem * item = NULL; | |
397 float value = 0.0f; | |
398 | |
399 static int SelectedItem = -1; | |
400 int currentselected = -1; | |
401 | |
33555 | 402 for ( i=0;i <= guiApp.IndexOfMainItems;i++ ) |
403 if ( ( guiApp.mainItems[i].pressed != btnDisabled )&& | |
404 ( wgIsRect( X,Y,guiApp.mainItems[i].x,guiApp.mainItems[i].y,guiApp.mainItems[i].x+guiApp.mainItems[i].width,guiApp.mainItems[i].y+guiApp.mainItems[i].height ) ) ) | |
23077 | 405 { currentselected=i; break; } |
406 | |
407 switch ( Button ) | |
408 { | |
409 case wsPMMouseButton: | |
410 gtkShow( evHidePopUpMenu,NULL ); | |
33555 | 411 uiShowMenu( RX,RY ); |
23077 | 412 itemtype=itPRMButton; |
413 break; | |
414 case wsRMMouseButton: | |
33555 | 415 uiHideMenu( RX,RY,0 ); |
23077 | 416 break; |
417 | |
418 case wsPLMouseButton: | |
419 gtkShow( evHidePopUpMenu,NULL ); | |
420 sx=X; sy=Y; boxMoved=1; itemtype=itPLMButton; | |
421 SelectedItem=currentselected; | |
422 if ( SelectedItem == -1 ) break; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
423 boxMoved=0; |
33555 | 424 item=&guiApp.mainItems[SelectedItem]; |
23077 | 425 itemtype=item->type; |
426 item->pressed=btnPressed; | |
427 switch( item->type ) | |
428 { | |
429 case itButton: | |
430 if ( ( SelectedItem > -1 ) && | |
32911 | 431 ( ( ( item->message == evPlaySwitchToPause && item->message == evPauseSwitchToPlay ) ) || |
432 ( ( item->message == evPauseSwitchToPlay && item->message == evPlaySwitchToPause ) ) ) ) | |
23077 | 433 { item->pressed=btnDisabled; } |
434 break; | |
435 } | |
436 break; | |
437 case wsRLMouseButton: | |
438 boxMoved=0; | |
33107 | 439 if ( SelectedItem != -1 ) // NOTE TO MYSELF: only if itButton, itHPotmeter or itVPotmeter |
440 { | |
33555 | 441 item=&guiApp.mainItems[SelectedItem]; |
33108 | 442 item->pressed=btnReleased; |
33107 | 443 } |
23077 | 444 SelectedItem=-1; |
445 if ( currentselected == - 1 ) { itemtype=0; break; } | |
446 value=0; | |
447 switch( itemtype ) | |
448 { | |
449 case itPotmeter: | |
450 case itHPotmeter: | |
32911 | 451 btnModify( item->message,(float)( X - item->x ) / item->width * 100.0f ); |
33555 | 452 uiEventHandling( item->message,item->value ); |
23077 | 453 value=item->value; |
454 break; | |
455 case itVPotmeter: | |
32911 | 456 btnModify( item->message, ( 1. - (float)( Y - item->y ) / item->height) * 100.0f ); |
33555 | 457 uiEventHandling( item->message,item->value ); |
23077 | 458 value=item->value; |
459 break; | |
460 } | |
33555 | 461 uiEventHandling( item->message,value ); |
23077 | 462 itemtype=0; |
463 break; | |
464 | |
465 case wsRRMouseButton: | |
466 gtkShow( evShowPopUpMenu,NULL ); | |
467 break; | |
468 | |
469 // --- rolled mouse ... de szar :))) | |
470 case wsP5MouseButton: value=-2.5f; goto rollerhandled; | |
471 case wsP4MouseButton: value= 2.5f; | |
472 rollerhandled: | |
33555 | 473 item=&guiApp.mainItems[currentselected]; |
23077 | 474 if ( ( item->type == itHPotmeter )||( item->type == itVPotmeter )||( item->type == itPotmeter ) ) |
475 { | |
476 item->value+=value; | |
32911 | 477 btnModify( item->message,item->value ); |
33555 | 478 uiEventHandling( item->message,item->value ); |
23077 | 479 } |
480 break; | |
481 | |
482 // --- moving | |
483 case wsMoveMouse: | |
33555 | 484 item=&guiApp.mainItems[SelectedItem]; |
23077 | 485 switch ( itemtype ) |
486 { | |
487 case itPLMButton: | |
33555 | 488 wsMoveWindow( &guiApp.mainWindow,False,RX - abs( sx ),RY - abs( sy ) ); |
489 uiMainRender=0; | |
23077 | 490 break; |
491 case itPRMButton: | |
33555 | 492 uiMenuMouseHandle( X,Y,RX,RY ); |
23077 | 493 break; |
494 case itPotmeter: | |
495 item->value=(float)( X - item->x ) / item->width * 100.0f; | |
496 goto potihandled; | |
497 case itVPotmeter: | |
498 item->value=(1. - (float)( Y - item->y ) / item->height) * 100.0f; | |
499 goto potihandled; | |
500 case itHPotmeter: | |
501 item->value=(float)( X - item->x ) / item->width * 100.0f; | |
502 potihandled: | |
503 if ( item->value > 100.0f ) item->value=100.0f; | |
504 if ( item->value < 0.0f ) item->value=0.0f; | |
33555 | 505 uiEventHandling( item->message,item->value ); |
23077 | 506 break; |
507 } | |
508 break; | |
509 } | |
510 } | |
511 | |
512 int keyPressed = 0; | |
513 | |
33555 | 514 void uiMainKeyHandle( int KeyCode,int Type,int Key ) |
23077 | 515 { |
516 int msg = evNone; | |
517 | |
518 if ( Type != wsKeyPressed ) return; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
519 |
23077 | 520 if ( !Key ) |
521 { | |
522 switch ( KeyCode ) | |
523 { | |
33524 | 524 // NOTE TO MYSELF: This is only for the Acer AirKey V keyboard. |
33536
fc1402410163
Remove support for Acer AirKey V keyboard multimedia keys.
ib
parents:
33535
diff
changeset
|
525 /*case wsXFMMPrev: msg=evPrev; break; |
23077 | 526 case wsXFMMStop: msg=evStop; break; |
527 case wsXFMMPlay: msg=evPlaySwitchToPause; break; | |
528 case wsXFMMNext: msg=evNext; break; | |
529 case wsXFMMVolUp: msg=evIncVolume; break; | |
530 case wsXFMMVolDown: msg=evDecVolume; break; | |
33536
fc1402410163
Remove support for Acer AirKey V keyboard multimedia keys.
ib
parents:
33535
diff
changeset
|
531 case wsXFMMMute: msg=evMute; break;*/ |
23077 | 532 } |
533 } | |
534 else | |
535 { | |
536 switch ( Key ) | |
537 { | |
538 case wsEnter: msg=evPlay; break; | |
539 case wsXF86LowerVolume: msg=evDecVolume; break; | |
540 case wsXF86RaiseVolume: msg=evIncVolume; break; | |
541 case wsXF86Mute: msg=evMute; break; | |
33525 | 542 case wsXF86Pause: |
23077 | 543 case wsXF86Play: msg=evPlaySwitchToPause; break; |
544 case wsXF86Stop: msg=evStop; break; | |
545 case wsXF86Prev: msg=evPrev; break; | |
546 case wsXF86Next: msg=evNext; break; | |
547 case wsXF86Media: msg=evLoad; break; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
548 case wsEscape: |
33555 | 549 if ( guiApp.subWindow.isFullScreen ) |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
550 { |
33555 | 551 if ( guiInfo.event_struct ) ((XEvent *)guiInfo.event_struct)->type=None; |
552 uiEventHandling( evNormalSize,0 ); | |
23077 | 553 return; |
554 } | |
555 default: vo_x11_putkey( Key ); return; | |
556 } | |
557 } | |
33555 | 558 if ( msg != evNone ) uiEventHandling( msg,0 ); |
23077 | 559 } |
560 | |
561 /* this will be used to handle Drag&Drop files */ | |
33555 | 562 void uiDandDHandler(int num,char** files) |
23077 | 563 { |
564 struct stat buf; | |
565 int f = 0; | |
566 | |
567 char* subtitles = NULL; | |
568 char* filename = NULL; | |
569 | |
570 if (num <= 0) | |
571 return; | |
572 | |
573 | |
574 /* now fill it with new items */ | |
575 for(f=0; f < num; f++){ | |
576 char* str = strdup( files[f] ); | |
577 plItem* item; | |
578 | |
24086
f5b32d12b691
remove gconvert_uri_to_filename() and use url_unescape_string() instead.
iive
parents:
23457
diff
changeset
|
579 url_unescape_string(str, files[f]); |
23077 | 580 |
581 if(stat(str,&buf) == 0 && S_ISDIR(buf.st_mode) == 0) { | |
582 /* this is not a directory so try to play it */ | |
583 mp_msg( MSGT_GPLAYER,MSGL_V,"Received D&D %s\n",str ); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
584 |
23077 | 585 /* check if it is a subtitle file */ |
586 { | |
587 char* ext = strrchr(str,'.'); | |
588 if (ext) { | |
589 static char supported[] = "utf/sub/srt/smi/rt//txt/ssa/aqt/"; | |
590 char* type; | |
591 int len; | |
592 if((len=strlen(++ext)) && (type=strstr(supported,ext)) &&\ | |
593 (type-supported)%4 == 0 && *(type+len) == '/'){ | |
594 /* handle subtitle file */ | |
595 gfree((void**)&subtitles); | |
596 subtitles = str; | |
597 continue; | |
598 } | |
599 } | |
600 } | |
601 | |
602 /* clear playlist */ | |
603 if (filename == NULL) { | |
604 filename = files[f]; | |
605 gtkSet(gtkDelPl,0,NULL); | |
606 } | |
607 | |
608 item = calloc(1,sizeof(plItem)); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28051
diff
changeset
|
609 |
23077 | 610 /* FIXME: decompose file name ? */ |
611 /* yes -- Pontscho */ | |
612 if ( strrchr( str,'/' ) ) { | |
613 char * s = strrchr( str,'/' ); *s=0; s++; | |
614 item->name = gstrdup( s ); | |
615 item->path = gstrdup( str ); | |
616 } else { | |
617 item->name = strdup(str); | |
618 item->path = strdup(""); | |
619 } | |
620 gtkSet(gtkAddPlItem,0,(void*)item); | |
621 } else { | |
622 mp_msg( MSGT_GPLAYER,MSGL_WARN,MSGTR_NotAFile,str ); | |
623 } | |
624 free( str ); | |
625 } | |
626 | |
627 if (filename) { | |
33555 | 628 uiSetFileName( NULL,filename,STREAMTYPE_FILE ); |
33615
1f9a31d4f114
Replace all playback integer constants by their symbolic constants.
ib
parents:
33614
diff
changeset
|
629 if ( guiInfo.Playing == GUI_PLAY ) uiEventHandling( evStop,0 ); |
33555 | 630 uiEventHandling( evPlay,0 ); |
23077 | 631 } |
632 if (subtitles) { | |
33555 | 633 gfree((void**)&guiInfo.Subtitlename); |
634 guiInfo.Subtitlename = subtitles; | |
635 guiLoadSubtitle(guiInfo.Subtitlename); | |
23077 | 636 } |
637 } |