Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-gpu
Commits
feeb6d30
Commit
feeb6d30
authored
Sep 26, 2009
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
OMAP framebuffer: let the window manage key presses instead
parent
814c1673
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
3 additions
and
50 deletions
+3
-50
modules/video_output/omapfb.c
modules/video_output/omapfb.c
+3
-50
No files found.
modules/video_output/omapfb.c
View file @
feeb6d30
...
@@ -40,7 +40,6 @@
...
@@ -40,7 +40,6 @@
/* Embedded window handling */
/* Embedded window handling */
#include <X11/Xlib.h>
#include <X11/Xlib.h>
#include <X11/Xutil.h>
#include <X11/Xutil.h>
#include <X11/keysym.h>
#ifdef HAVE_OSSO
#ifdef HAVE_OSSO
#include <libosso.h>
#include <libosso.h>
...
@@ -48,7 +47,6 @@
...
@@ -48,7 +47,6 @@
#include <vlc_common.h>
#include <vlc_common.h>
#include <vlc_plugin.h>
#include <vlc_plugin.h>
#include <vlc_keys.h>
#include <vlc_vout.h>
#include <vlc_vout.h>
#include <vlc_vout_window.h>
#include <vlc_vout_window.h>
#include <vlc_playlist.h>
#include <vlc_playlist.h>
...
@@ -404,50 +402,9 @@ static int Manage( vout_thread_t *p_vout )
...
@@ -404,50 +402,9 @@ static int Manage( vout_thread_t *p_vout )
p_vout
->
p_sys
->
i_time_button_last_pressed
=
p_vout
->
p_sys
->
i_time_button_last_pressed
=
((
XButtonEvent
*
)
&
xevent
)
->
time
;
((
XButtonEvent
*
)
&
xevent
)
->
time
;
}
}
else
if
(
xevent
.
type
==
KeyPress
)
{
KeySym
x_key_symbol
;
vlc_value_t
val
;
x_key_symbol
=
XKeycodeToKeysym
(
p_vout
->
p_sys
->
p_display
,
xevent
.
xkey
.
keycode
,
0
);
switch
(
x_key_symbol
)
{
case
XK_Return
:
val
.
i_int
=
ACTIONID_PLAY_PAUSE
;
break
;
case
XK_Escape
:
val
.
i_int
=
ACTIONID_QUIT
;
break
;
case
XK_Down
:
val
.
i_int
=
ACTIONID_JUMP_BACKWARD_MEDIUM
;
break
;
case
XK_Up
:
val
.
i_int
=
ACTIONID_JUMP_FORWARD_MEDIUM
;
break
;
case
XK_Right
:
val
.
i_int
=
ACTIONID_JUMP_FORWARD_SHORT
;
break
;
case
XK_Left
:
val
.
i_int
=
ACTIONID_JUMP_BACKWARD_SHORT
;
break
;
case
XK_F6
:
val
.
i_int
=
ACTIONID_TOGGLE_FULLSCREEN
;
break
;
case
XK_F7
:
val
.
i_int
=
ACTIONID_VOL_UP
;
break
;
case
XK_F8
:
val
.
i_int
=
ACTIONID_VOL_DOWN
;
break
;
}
var_SetInteger
(
p_vout
->
p_libvlc
,
"key-action"
,
val
.
i_int
);
}
else
if
(
(
xevent
.
type
==
VisibilityNotify
&&
xevent
.
xvisibility
.
state
==
VisibilityUnobscured
)
||
xevent
.
type
==
FocusIn
)
{
p_vout
->
p_sys
->
b_video_enabled
=
true
;
p_vout
->
p_sys
->
p_output_picture
->
p
->
p_pixels
=
p_vout
->
p_sys
->
p_center
;
XSetInputFocus
(
p_vout
->
p_sys
->
p_display
,
p_vout
->
p_sys
->
window
,
RevertToParent
,
CurrentTime
);
}
else
if
(
(
xevent
.
type
==
VisibilityNotify
&&
else
if
(
(
xevent
.
type
==
VisibilityNotify
&&
xevent
.
xvisibility
.
state
!=
VisibilityUnobscured
)
||
xevent
.
xvisibility
.
state
!=
VisibilityUnobscured
)
||
xevent
.
type
==
FocusOut
||
xevent
.
type
==
UnmapNotify
)
xevent
.
type
==
UnmapNotify
)
{
{
UpdateScreen
(
p_vout
,
0
,
0
,
UpdateScreen
(
p_vout
,
0
,
0
,
p_vout
->
p_sys
->
fb_vinfo
.
xres
,
p_vout
->
p_sys
->
fb_vinfo
.
xres
,
...
@@ -675,7 +632,6 @@ static int InitWindow( vout_thread_t *p_vout )
...
@@ -675,7 +632,6 @@ static int InitWindow( vout_thread_t *p_vout )
p_sys
->
main_window
=
p_sys
->
embedded_window
;
p_sys
->
main_window
=
p_sys
->
embedded_window
;
// We have to create a new window to get some events
// We have to create a new window to get some events
// (ButtonPress for example)
CreateWindow
(
p_sys
);
CreateWindow
(
p_sys
);
}
}
else
else
...
@@ -697,7 +653,8 @@ static void CreateWindow( vout_sys_t *p_sys )
...
@@ -697,7 +653,8 @@ static void CreateWindow( vout_sys_t *p_sys )
xwindow_attributes
.
backing_store
=
Always
;
xwindow_attributes
.
backing_store
=
Always
;
xwindow_attributes
.
background_pixel
=
xwindow_attributes
.
background_pixel
=
BlackPixel
(
p_sys
->
p_display
,
DefaultScreen
(
p_sys
->
p_display
)
);
BlackPixel
(
p_sys
->
p_display
,
DefaultScreen
(
p_sys
->
p_display
)
);
xwindow_attributes
.
event_mask
=
ExposureMask
|
StructureNotifyMask
;
xwindow_attributes
.
event_mask
=
ExposureMask
|
StructureNotifyMask
|
VisibilityChangeMask
;
p_sys
->
window
=
XCreateWindow
(
p_sys
->
p_display
,
p_sys
->
window
=
XCreateWindow
(
p_sys
->
p_display
,
p_sys
->
owner_window
->
handle
.
xid
,
p_sys
->
owner_window
->
handle
.
xid
,
0
,
0
,
0
,
0
,
...
@@ -709,11 +666,7 @@ static void CreateWindow( vout_sys_t *p_sys )
...
@@ -709,11 +666,7 @@ static void CreateWindow( vout_sys_t *p_sys )
&
xwindow_attributes
);
&
xwindow_attributes
);
XMapWindow
(
p_sys
->
p_display
,
p_sys
->
window
);
XMapWindow
(
p_sys
->
p_display
,
p_sys
->
window
);
XSelectInput
(
p_sys
->
p_display
,
p_sys
->
window
,
KeyPressMask
|
ButtonPressMask
|
StructureNotifyMask
|
VisibilityChangeMask
|
FocusChangeMask
);
XSelectInput
(
p_sys
->
p_display
,
p_sys
->
owner_window
->
handle
.
xid
,
XSelectInput
(
p_sys
->
p_display
,
p_sys
->
owner_window
->
handle
.
xid
,
StructureNotifyMask
);
StructureNotifyMask
);
XSetInputFocus
(
p_sys
->
p_display
,
p_sys
->
window
,
RevertToParent
,
CurrentTime
);
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment