Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
a04be50a
Commit
a04be50a
authored
Sep 10, 2004
by
Gildas Bazin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* modules/video_filter/logo.c: complete rewrite using the alpha-blending module.
parent
2a2d47d7
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
208 additions
and
279 deletions
+208
-279
modules/video_filter/logo.c
modules/video_filter/logo.c
+208
-279
No files found.
modules/video_filter/logo.c
View file @
a04be50a
...
...
@@ -5,6 +5,7 @@
* $Id$
*
* Authors: Simon Latapie <garf@videolan.org>
* Gildas Bazin <gbazin@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
...
...
@@ -32,9 +33,9 @@
#include <vlc/vlc.h>
#include <vlc/vout.h>
#include "vlc_filter.h"
#include "filter_common.h"
/*****************************************************************************
* Local prototypes
*****************************************************************************/
...
...
@@ -47,22 +48,22 @@ static void Render ( vout_thread_t *, picture_t * );
static
int
SendEvents
(
vlc_object_t
*
,
char
const
*
,
vlc_value_t
,
vlc_value_t
,
void
*
);
static
int
MouseEvent
(
vlc_object_t
*
,
char
const
*
,
static
int
MouseEvent
(
vlc_object_t
*
,
char
const
*
,
vlc_value_t
,
vlc_value_t
,
void
*
);
static
int
Control
(
vout_thread_t
*
,
int
,
va_list
);
/*****************************************************************************
* Module descriptor
*****************************************************************************/
#define FILE_TEXT N_("Logo filename")
#define FILE_LONGTEXT N_("The file must be in PNG RGBA 8bits format (for now).")
#define POSX_TEXT N_("X coordinate of the logo")
#define POSX_LONGTEXT N_("You can move the logo by left-clicking on it." )
#define POSY_TEXT N_("Y coordinate of the logo")
#define POSY_LONGTEXT N_("You can move the logo by left-clicking on it." )
#define TRANS_TEXT N_("Transparency of the logo (255-0)")
#define TRANS_LONGTEXT N_("You can change it by middle-clicking and moving mouse left or right.")
#define TRANS_TEXT N_("Transparency of the logo")
#define TRANS_LONGTEXT N_("You can set the logo transparency value here " \
"(from 0 for full transparency to 255 for full opacity)." )
vlc_module_begin
();
set_description
(
_
(
"Logo video filter"
)
);
...
...
@@ -87,25 +88,99 @@ vlc_module_end();
struct
vout_sys_t
{
vout_thread_t
*
p_vout
;
png_uint_32
height
;
int
bit_depth
;
png_uint_32
width
;
uint8_t
*
png_image
[
3
];
uint8_t
*
png_image_u
;
uint8_t
*
png_image_v
;
uint8_t
*
png_image_a
[
3
];
uint8_t
*
png_image_a_little
;
int
error
;
filter_t
*
p_blend
;
picture_t
*
p_pic
;
int
i_width
,
i_height
;
int
posx
,
posy
;
int
trans
;
};
/*****************************************************************************
*
Control: control facility for the vout (forwards to child vout)
*
LoadPNG: loads the PNG logo into memory
*****************************************************************************/
static
int
Control
(
vout_thread_t
*
p_vout
,
int
i_query
,
va_list
arg
s
)
static
picture_t
*
LoadPNG
(
vlc_object_t
*
p_thi
s
)
{
return
vout_vaControl
(
p_vout
->
p_sys
->
p_vout
,
i_query
,
args
);
picture_t
*
p_pic
;
char
*
psz_filename
;
vlc_value_t
val
;
FILE
*
file
;
int
i
,
j
,
i_trans
;
png_uint_32
i_width
,
i_height
;
int
i_color_type
,
i_interlace_type
,
i_compression_type
,
i_filter_type
;
int
i_bit_depth
;
png_bytep
*
p_row_pointers
;
png_structp
p_png
;
png_infop
p_info
,
p_end_info
;
var_Create
(
p_this
,
"logo-file"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_this
,
"logo-file"
,
&
val
);
psz_filename
=
val
.
psz_string
;
if
(
!
psz_filename
)
return
0
;
if
(
!
(
file
=
fopen
(
psz_filename
,
"rb"
))
)
{
msg_Err
(
p_this
,
"logo file (%s) not found"
,
psz_filename
);
free
(
psz_filename
);
return
0
;
}
free
(
psz_filename
);
p_png
=
png_create_read_struct
(
PNG_LIBPNG_VER_STRING
,
0
,
0
,
0
);
p_info
=
png_create_info_struct
(
p_png
);
p_end_info
=
png_create_info_struct
(
p_png
);
png_init_io
(
p_png
,
file
);
png_read_info
(
p_png
,
p_info
);
png_get_IHDR
(
p_png
,
p_info
,
&
i_width
,
&
i_height
,
&
i_bit_depth
,
&
i_color_type
,
&
i_interlace_type
,
&
i_compression_type
,
&
i_filter_type
);
p_row_pointers
=
malloc
(
sizeof
(
png_bytep
)
*
i_height
);
for
(
i
=
0
;
i
<
(
int
)
i_height
;
i
++
)
{
p_row_pointers
[
i
]
=
malloc
(
4
*
(
i_bit_depth
+
7
)
/
8
*
i_width
);
}
png_read_image
(
p_png
,
p_row_pointers
);
png_read_end
(
p_png
,
p_end_info
);
fclose
(
file
);
png_destroy_read_struct
(
&
p_png
,
&
p_info
,
&
p_end_info
);
/* Convert to YUVA */
p_pic
=
malloc
(
sizeof
(
picture_t
)
);
if
(
vout_AllocatePicture
(
p_this
,
p_pic
,
VLC_FOURCC
(
'Y'
,
'U'
,
'V'
,
'A'
),
i_width
,
i_height
,
VOUT_ASPECT_FACTOR
)
!=
VLC_SUCCESS
)
{
free
(
p_row_pointers
);
return
0
;
}
var_Create
(
p_this
,
"logo-transparency"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_this
,
"logo-transparency"
,
&
val
);
i_trans
=
val
.
i_int
;
for
(
j
=
0
;
j
<
(
int
)
i_height
;
j
++
)
{
for
(
i
=
0
;
i
<
(
int
)
i_width
;
i
++
)
{
uint8_t
(
*
p
)[
4
];
int
i_offset
=
i
+
j
*
p_pic
->
p
[
Y_PLANE
].
i_pitch
;
p
=
(
void
*
)
p_row_pointers
[
j
];
p_pic
->
p
[
Y_PLANE
].
p_pixels
[
i_offset
]
=
(
p
[
i
][
0
]
*
257L
+
p
[
i
][
1
]
*
504
+
p
[
i
][
2
]
*
98
)
/
1000
+
16
;
p_pic
->
p
[
U_PLANE
].
p_pixels
[
i_offset
]
=
(
p
[
i
][
2
]
*
439L
-
p
[
i
][
0
]
*
148
-
p
[
i
][
1
]
*
291
)
/
1000
+
128
;
p_pic
->
p
[
V_PLANE
].
p_pixels
[
i_offset
]
=
(
p
[
i
][
0
]
*
439L
-
p
[
i
][
1
]
*
368
-
p
[
i
][
2
]
*
71
)
/
1000
+
128
;
p_pic
->
p
[
A_PLANE
].
p_pixels
[
i_offset
]
=
(
p
[
i
][
3
]
*
i_trans
)
/
255
;
}
}
free
(
p_row_pointers
);
return
p_pic
;
}
/*****************************************************************************
...
...
@@ -116,10 +191,12 @@ static int Control( vout_thread_t *p_vout, int i_query, va_list args )
static
int
Create
(
vlc_object_t
*
p_this
)
{
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
vout_sys_t
*
p_sys
;
vlc_value_t
val
;
/* Allocate structure */
p_vout
->
p_sys
=
malloc
(
sizeof
(
vout_sys_t
)
);
if
(
p_
vout
->
p_
sys
==
NULL
)
p_
sys
=
p_
vout
->
p_sys
=
malloc
(
sizeof
(
vout_sys_t
)
);
if
(
p_sys
==
NULL
)
{
msg_Err
(
p_vout
,
"out of memory"
);
return
VLC_ENOMEM
;
...
...
@@ -132,6 +209,23 @@ static int Create( vlc_object_t *p_this )
p_vout
->
pf_display
=
NULL
;
p_vout
->
pf_control
=
Control
;
var_Create
(
p_this
,
"logo-x"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_this
,
"logo-x"
,
&
val
);
p_sys
->
posx
=
val
.
i_int
;
var_Create
(
p_this
,
"logo-y"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_this
,
"logo-y"
,
&
val
);
p_sys
->
posy
=
val
.
i_int
;
p_sys
->
p_pic
=
LoadPNG
(
p_this
);
if
(
!
p_sys
->
p_pic
)
{
free
(
p_sys
);
return
VLC_EGENERIC
;
}
p_sys
->
i_width
=
p_sys
->
p_pic
->
p
[
Y_PLANE
].
i_visible_pitch
;
p_sys
->
i_height
=
p_sys
->
p_pic
->
p
[
Y_PLANE
].
i_visible_lines
;
return
VLC_SUCCESS
;
}
...
...
@@ -140,122 +234,9 @@ static int Create( vlc_object_t *p_this )
*****************************************************************************/
static
int
Init
(
vout_thread_t
*
p_vout
)
{
int
i_index
;
vout_sys_t
*
p_sys
=
p_vout
->
p_sys
;
picture_t
*
p_pic
;
char
*
filename
;
FILE
*
fp
;
int
color_type
;
int
interlace_type
;
int
compression_type
;
int
filter_type
;
png_structp
png_ptr
;
png_bytep
*
row_pointers
;
png_infop
info_ptr
;
unsigned
int
i
;
// unsigned int j;
unsigned
int
x
;
unsigned
int
y
;
int
temp
;
int
i_size
;
int
i_parity_width
;
int
i_parity_height
;
/* read png file */
filename
=
config_GetPsz
(
p_vout
,
"logo-file"
);
fp
=
fopen
(
filename
,
"rb"
);
png_ptr
=
png_create_read_struct
(
PNG_LIBPNG_VER_STRING
,
NULL
,
NULL
,
NULL
);
info_ptr
=
png_create_info_struct
(
png_ptr
);
if
(
fp
==
NULL
)
{
p_vout
->
p_sys
->
error
=
1
;
msg_Err
(
p_vout
,
"file not found %s"
,
filename
);
free
(
filename
);
}
else
{
free
(
filename
);
p_vout
->
p_sys
->
error
=
0
;
png_init_io
(
png_ptr
,
fp
);
png_read_info
(
png_ptr
,
info_ptr
);
png_get_IHDR
(
png_ptr
,
info_ptr
,
&
p_vout
->
p_sys
->
width
,
&
p_vout
->
p_sys
->
height
,
&
p_vout
->
p_sys
->
bit_depth
,
&
color_type
,
&
interlace_type
,
&
compression_type
,
&
filter_type
);
row_pointers
=
malloc
(
sizeof
(
png_bytep
)
*
p_vout
->
p_sys
->
height
);
for
(
i
=
0
;
i
<
p_vout
->
p_sys
->
height
;
i
++
)
{
row_pointers
[
i
]
=
malloc
(
4
*
(
p_vout
->
p_sys
->
bit_depth
+
7
)
/
8
*
p_vout
->
p_sys
->
width
);
}
png_read_image
(
png_ptr
,
row_pointers
);
fclose
(
fp
);
/* finish to read the image in the file. Now We have to convert it YUV */
/* initialize yuv plans of the image */
i_parity_width
=
p_vout
->
p_sys
->
width
%
2
;
i_parity_height
=
p_vout
->
p_sys
->
height
%
2
;
p_vout
->
p_sys
->
height
=
p_vout
->
p_sys
->
height
+
(
p_vout
->
p_sys
->
height
%
2
);
p_vout
->
p_sys
->
width
=
p_vout
->
p_sys
->
width
+
(
p_vout
->
p_sys
->
width
%
2
);
i_size
=
p_vout
->
p_sys
->
height
*
p_vout
->
p_sys
->
width
;
p_vout
->
p_sys
->
png_image
[
0
]
=
malloc
(
i_size
);
p_vout
->
p_sys
->
png_image
[
1
]
=
malloc
(
i_size
/
4
);
p_vout
->
p_sys
->
png_image
[
2
]
=
malloc
(
i_size
/
4
);
p_vout
->
p_sys
->
png_image_a
[
0
]
=
malloc
(
i_size
);
p_vout
->
p_sys
->
png_image_a
[
1
]
=
malloc
(
i_size
/
4
);
p_vout
->
p_sys
->
png_image_a
[
2
]
=
p_vout
->
p_sys
->
png_image_a
[
1
];
for
(
y
=
0
;
y
<
p_vout
->
p_sys
->
height
;
y
++
)
{
for
(
x
=
0
;
x
<
p_vout
->
p_sys
->
width
;
x
++
)
{
uint8_t
(
*
p
)[
4
];
int
idx
;
int
idxc
;
/* FIXME FIXME */
p
=
(
void
*
)
row_pointers
[
y
];
idx
=
x
+
y
*
p_vout
->
p_sys
->
width
;
idxc
=
x
/
2
+
(
y
/
2
)
*
(
p_vout
->
p_sys
->
width
/
2
);
if
(
((
i_parity_width
==
0
)
||
(
x
!=
(
p_vout
->
p_sys
->
width
-
1
)))
&&
((
i_parity_height
==
0
)
||
(
y
!=
(
p_vout
->
p_sys
->
height
-
1
))))
{
p_vout
->
p_sys
->
png_image_a
[
0
][
idx
]
=
p
[
x
][
3
];
p_vout
->
p_sys
->
png_image
[
0
][
idx
]
=
(
p
[
x
][
0
]
*
257
+
p
[
x
][
1
]
*
504
+
p
[
x
][
2
]
*
98
)
/
1000
+
16
;
if
(
(
x
%
2
==
0
)
&&
(
y
%
2
==
0
)
)
{
temp
=
(
p
[
x
][
2
]
*
439
-
p
[
x
][
0
]
*
148
-
p
[
x
][
1
]
*
291
)
/
1000
+
128
;
temp
=
__MAX
(
__MIN
(
temp
,
255
),
0
);
p_vout
->
p_sys
->
png_image
[
1
][
idxc
]
=
temp
;
temp
=
(
p
[
x
][
0
]
*
439
-
p
[
x
][
1
]
*
368
-
p
[
x
][
2
]
*
71
)
/
1000
+
128
;
temp
=
__MAX
(
__MIN
(
temp
,
255
),
0
);
p_vout
->
p_sys
->
png_image
[
2
][
idxc
]
=
temp
;
p_vout
->
p_sys
->
png_image_a
[
1
][
idxc
]
=
p_vout
->
p_sys
->
png_image_a
[
0
][
idx
];
}
}
else
{
p_vout
->
p_sys
->
png_image_a
[
0
][
idx
]
=
0
;
}
}
}
/* now we can free row_pointers*/
free
(
row_pointers
);
}
int
i_index
;
I_OUTPUTPICTURES
=
0
;
...
...
@@ -265,35 +246,61 @@ static int Init( vout_thread_t *p_vout )
p_vout
->
output
.
i_height
=
p_vout
->
render
.
i_height
;
p_vout
->
output
.
i_aspect
=
p_vout
->
render
.
i_aspect
;
/* Load the video blending filter */
p_sys
->
p_blend
=
vlc_object_create
(
p_vout
,
sizeof
(
filter_t
)
);
vlc_object_attach
(
p_sys
->
p_blend
,
p_vout
);
p_sys
->
p_blend
->
fmt_out
.
video
.
i_x_offset
=
p_sys
->
p_blend
->
fmt_out
.
video
.
i_y_offset
=
0
;
p_sys
->
p_blend
->
fmt_in
.
video
.
i_x_offset
=
p_sys
->
p_blend
->
fmt_in
.
video
.
i_y_offset
=
0
;
p_sys
->
p_blend
->
fmt_out
.
video
.
i_aspect
=
p_vout
->
render
.
i_aspect
;
p_sys
->
p_blend
->
fmt_out
.
video
.
i_chroma
=
p_vout
->
output
.
i_chroma
;
p_sys
->
p_blend
->
fmt_in
.
video
.
i_chroma
=
VLC_FOURCC
(
'Y'
,
'U'
,
'V'
,
'A'
);
p_sys
->
p_blend
->
fmt_in
.
video
.
i_aspect
=
VOUT_ASPECT_FACTOR
;
p_sys
->
p_blend
->
fmt_in
.
video
.
i_width
=
p_sys
->
p_blend
->
fmt_in
.
video
.
i_visible_width
=
p_sys
->
p_pic
->
p
[
Y_PLANE
].
i_visible_pitch
;
p_sys
->
p_blend
->
fmt_in
.
video
.
i_height
=
p_sys
->
p_blend
->
fmt_in
.
video
.
i_visible_height
=
p_sys
->
p_pic
->
p
[
Y_PLANE
].
i_visible_lines
;
p_sys
->
p_blend
->
fmt_out
.
video
.
i_width
=
p_sys
->
p_blend
->
fmt_out
.
video
.
i_visible_width
=
p_vout
->
output
.
i_width
;
p_sys
->
p_blend
->
fmt_out
.
video
.
i_height
=
p_sys
->
p_blend
->
fmt_out
.
video
.
i_visible_height
=
p_vout
->
output
.
i_height
;
p_sys
->
p_blend
->
p_module
=
module_Need
(
p_sys
->
p_blend
,
"video blending"
,
0
,
0
);
if
(
!
p_sys
->
p_blend
->
p_module
)
{
msg_Err
(
p_vout
,
"can't open blending filter, aborting"
);
vlc_object_detach
(
p_sys
->
p_blend
);
vlc_object_destroy
(
p_sys
->
p_blend
);
return
VLC_EGENERIC
;
}
/* Try to open the real video output */
msg_Dbg
(
p_vout
,
"spawning the real video output"
);
p_
vout
->
p_sys
->
p_vout
=
vout_Create
(
p_vout
,
p_vout
->
render
.
i_width
,
p_vout
->
render
.
i_height
,
p_
sys
->
p_vout
=
vout_Create
(
p_vout
,
p_vout
->
render
.
i_width
,
p_vout
->
render
.
i_height
,
p_vout
->
render
.
i_chroma
,
p_vout
->
render
.
i_aspect
);
/* Everything failed */
if
(
p_
vout
->
p_
sys
->
p_vout
==
NULL
)
if
(
p_sys
->
p_vout
==
NULL
)
{
msg_Err
(
p_vout
,
"can't open vout, aborting"
);
return
VLC_EGENERIC
;
}
var_AddCallback
(
p_vout
->
p_sys
->
p_vout
,
"mouse-x"
,
MouseEvent
,
p_vout
);
var_AddCallback
(
p_vout
->
p_sys
->
p_vout
,
"mouse-y"
,
MouseEvent
,
p_vout
);
var_AddCallback
(
p_sys
->
p_vout
,
"mouse-x"
,
MouseEvent
,
p_vout
);
var_AddCallback
(
p_sys
->
p_vout
,
"mouse-y"
,
MouseEvent
,
p_vout
);
ALLOCATE_DIRECTBUFFERS
(
VOUT_MAX_PICTURES
);
ADD_CALLBACKS
(
p_vout
->
p_sys
->
p_vout
,
SendEvents
);
ADD_CALLBACKS
(
p_sys
->
p_vout
,
SendEvents
);
ADD_PARENT_CALLBACKS
(
SendEventsToChild
);
p_vout
->
p_sys
->
posx
=
config_GetInt
(
p_vout
,
"logo-x"
);
p_vout
->
p_sys
->
posy
=
config_GetInt
(
p_vout
,
"logo-y"
);
p_vout
->
p_sys
->
trans
=
config_GetInt
(
p_vout
,
"logo-transparency"
);
return
VLC_SUCCESS
;
}
...
...
@@ -302,6 +309,7 @@ static int Init( vout_thread_t *p_vout )
*****************************************************************************/
static
void
End
(
vout_thread_t
*
p_vout
)
{
vout_sys_t
*
p_sys
=
p_vout
->
p_sys
;
int
i_index
;
/* Free the fake output buffers we allocated */
...
...
@@ -311,27 +319,20 @@ static void End( vout_thread_t *p_vout )
free
(
PP_OUTPUTPICTURE
[
i_index
]
->
p_data_orig
);
}
var_DelCallback
(
p_
vout
->
p_
sys
->
p_vout
,
"mouse-x"
,
MouseEvent
,
p_vout
);
var_DelCallback
(
p_
vout
->
p_
sys
->
p_vout
,
"mouse-y"
,
MouseEvent
,
p_vout
);
var_DelCallback
(
p_sys
->
p_vout
,
"mouse-x"
,
MouseEvent
,
p_vout
);
var_DelCallback
(
p_sys
->
p_vout
,
"mouse-y"
,
MouseEvent
,
p_vout
);
if
(
p_
vout
->
p_
sys
->
p_vout
)
if
(
p_sys
->
p_vout
)
{
DEL_CALLBACKS
(
p_
vout
->
p_
sys
->
p_vout
,
SendEvents
);
vlc_object_detach
(
p_
vout
->
p_
sys
->
p_vout
);
vout_Destroy
(
p_
vout
->
p_
sys
->
p_vout
);
DEL_CALLBACKS
(
p_sys
->
p_vout
,
SendEvents
);
vlc_object_detach
(
p_sys
->
p_vout
);
vout_Destroy
(
p_sys
->
p_vout
);
}
config_PutInt
(
p_vout
,
"logo-x"
,
p_vout
->
p_sys
->
posx
);
config_PutInt
(
p_vout
,
"logo-y"
,
p_vout
->
p_sys
->
posy
);
if
(
p_vout
->
p_sys
->
error
==
0
)
{
free
(
p_vout
->
p_sys
->
png_image
[
0
]);
free
(
p_vout
->
p_sys
->
png_image
[
1
]);
free
(
p_vout
->
p_sys
->
png_image
[
2
]);
free
(
p_vout
->
p_sys
->
png_image_a
[
0
]);
free
(
p_vout
->
p_sys
->
png_image_a
[
1
]);
}
if
(
p_sys
->
p_blend
->
p_module
)
module_Unneed
(
p_sys
->
p_blend
,
p_sys
->
p_blend
->
p_module
);
vlc_object_detach
(
p_sys
->
p_blend
);
vlc_object_destroy
(
p_sys
->
p_blend
);
}
/*****************************************************************************
...
...
@@ -342,96 +343,39 @@ static void End( vout_thread_t *p_vout )
static
void
Destroy
(
vlc_object_t
*
p_this
)
{
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
vout_sys_t
*
p_sys
=
p_vout
->
p_sys
;
DEL_PARENT_CALLBACKS
(
SendEventsToChild
);
free
(
p_vout
->
p_sys
);
if
(
p_sys
->
p_pic
&&
p_sys
->
p_pic
->
p_data_orig
)
free
(
p_sys
->
p_pic
->
p_data_orig
);
if
(
p_sys
->
p_pic
)
free
(
p_sys
->
p_pic
);
free
(
p_sys
);
}
/*****************************************************************************
* Render: displays previously rendered output
*****************************************************************************
* This function send the currently rendered image to Invert image, waits
* until it is displayed and switch the two rendering buffers, preparing next
* frame.
* Render: render the logo onto the video
*****************************************************************************/
static
void
Render
(
vout_thread_t
*
p_vout
,
picture_t
*
p_pic
)
{
vout_sys_t
*
p_sys
=
p_vout
->
p_sys
;
picture_t
*
p_outpic
;
int
i_index
;
int
tr
;
/* This is a new frame. Get a structure from the video_output. */
while
(
(
p_outpic
=
vout_CreatePicture
(
p_vout
->
p_sys
->
p_vout
,
0
,
0
,
0
)
)
==
NULL
)
{
if
(
p_vout
->
b_die
||
p_vout
->
b_error
)
while
(
!
(
p_outpic
=
vout_CreatePicture
(
p_sys
->
p_vout
,
0
,
0
,
0
))
)
{
return
;
}
if
(
p_vout
->
b_die
||
p_vout
->
b_error
)
return
;
msleep
(
VOUT_OUTMEM_SLEEP
);
}
vout_DatePicture
(
p_vout
->
p_sys
->
p_vout
,
p_outpic
,
p_pic
->
date
);
vout_LinkPicture
(
p_vout
->
p_sys
->
p_vout
,
p_outpic
);
tr
=
p_vout
->
p_sys
->
trans
;
for
(
i_index
=
0
;
i_index
<
p_pic
->
i_planes
;
i_index
++
)
{
memcpy
(
p_outpic
->
p
[
i_index
].
p_pixels
,
p_pic
->
p
[
i_index
].
p_pixels
,
p_pic
->
p
[
i_index
].
i_visible_lines
*
p_pic
->
p
[
i_index
].
i_pitch
);
if
(
p_vout
->
p_sys
->
error
==
0
)
{
unsigned
int
i
;
unsigned
int
j
;
uint8_t
*
p_out
,
*
p_in_a
,
*
p_in
;
int
i_delta
;
unsigned
int
i_max
;
unsigned
int
j_max
;
if
(
i_index
==
0
)
{
p_out
=
p_outpic
->
p
[
i_index
].
p_pixels
+
p_vout
->
p_sys
->
posy
*
p_outpic
->
p
[
i_index
].
i_pitch
+
p_vout
->
p_sys
->
posx
;
i_max
=
p_vout
->
p_sys
->
height
;
j_max
=
p_vout
->
p_sys
->
width
;
}
else
{
p_out
=
p_outpic
->
p
[
i_index
].
p_pixels
+
p_vout
->
p_sys
->
posy
/
2
*
p_outpic
->
p
[
i_index
].
i_pitch
+
p_vout
->
p_sys
->
posx
/
2
;
i_max
=
p_vout
->
p_sys
->
height
/
2
;
j_max
=
p_vout
->
p_sys
->
width
/
2
;
}
i_delta
=
p_outpic
->
p
[
i_index
].
i_pitch
-
j_max
;
p_in_a
=
p_vout
->
p_sys
->
png_image_a
[
i_index
];
p_in
=
p_vout
->
p_sys
->
png_image
[
i_index
];
for
(
i
=
0
;
i
<
i_max
;
i
++
)
{
for
(
j
=
0
;
j
<
j_max
;
j
++
)
{
*
p_out
=
(
*
p_out
*
(
65025
-
*
p_in_a
*
tr
)
+
*
p_in
*
*
p_in_a
*
tr
)
>>
16
;
p_out
++
;
p_in
++
;
p_in_a
++
;
}
p_out
+=
i_delta
;
}
}
}
vout_CopyPicture
(
p_vout
,
p_outpic
,
p_pic
);
vout_DatePicture
(
p_sys
->
p_vout
,
p_outpic
,
p_pic
->
date
);
vout_UnlinkPicture
(
p_vout
->
p_sys
->
p_vout
,
p_outpic
);
p_sys
->
p_blend
->
pf_video_blend
(
p_sys
->
p_blend
,
p_outpic
,
p_outpic
,
p_sys
->
p_pic
,
p_sys
->
posx
,
p_sys
->
posy
);
vout_DisplayPicture
(
p_
vout
->
p_
sys
->
p_vout
,
p_outpic
);
vout_DisplayPicture
(
p_sys
->
p_vout
,
p_outpic
);
}
/*****************************************************************************
...
...
@@ -441,37 +385,25 @@ static int SendEvents( vlc_object_t *p_this, char const *psz_var,
vlc_value_t
oldval
,
vlc_value_t
newval
,
void
*
p_data
)
{
var_Set
(
(
vlc_object_t
*
)
p_data
,
psz_var
,
newval
);
return
VLC_SUCCESS
;
}
/*****************************************************************************
* MouseEvent: callback for mouse events
*****************************************************************************
*
/
*****************************************************************************/
static
int
MouseEvent
(
vlc_object_t
*
p_this
,
char
const
*
psz_var
,
vlc_value_t
oldval
,
vlc_value_t
newval
,
void
*
p_data
)
{
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_data
;
vout_sys_t
*
p_sys
=
p_vout
->
p_sys
;
vlc_value_t
valb
;
int
i_delta
;
#define posx p_vout->p_sys->posx
#define posy p_vout->p_sys->posy
#define width p_vout->p_sys->width
#define height p_vout->p_sys->height
#define trans p_vout->p_sys->trans
var_Get
(
p_vout
->
p_sys
->
p_vout
,
"mouse-button-down"
,
&
valb
);
i_delta
=
newval
.
i_int
-
oldval
.
i_int
;
if
((
valb
.
i_int
&
0x2
)
==
2
&&
psz_var
[
6
]
==
'x'
)
{
trans
=
__MIN
(
__MAX
(
trans
+
i_delta
,
0
)
,
255
);
return
VLC_SUCCESS
;
}
if
((
valb
.
i_int
&
0x1
)
==
0
)
if
(
(
valb
.
i_int
&
0x1
)
==
0
)
{
return
VLC_SUCCESS
;
}
...
...
@@ -480,43 +412,40 @@ static int MouseEvent( vlc_object_t *p_this, char const *psz_var,
{
vlc_value_t
valy
;
var_Get
(
p_vout
->
p_sys
->
p_vout
,
"mouse-y"
,
&
valy
);
if
((
newval
.
i_int
>=
(
int
)
posx
)
&&
(
valy
.
i_int
>=
(
int
)
posy
)
&&
(
newval
.
i_int
<=
(
int
)(
posx
+
width
))
&&
(
valy
.
i_int
<=
(
int
)(
posy
+
height
)))
if
(
newval
.
i_int
>=
(
int
)
p_sys
->
posx
&&
valy
.
i_int
>=
(
int
)
p_sys
->
posy
&&
newval
.
i_int
<=
(
int
)(
p_sys
->
posx
+
p_sys
->
i_width
)
&&
valy
.
i_int
<=
(
int
)(
p_sys
->
posy
+
p_sys
->
i_height
)
)
{
posx
=
__MIN
(
__MAX
(
posx
+
i_delta
,
0
)
,
p_vout
->
output
.
i_width
-
width
);
p_sys
->
posx
=
__MIN
(
__MAX
(
p_sys
->
posx
+
i_delta
,
0
),
p_vout
->
output
.
i_width
-
p_sys
->
i_width
);
}
}
else
if
(
psz_var
[
6
]
==
'y'
)
{
vlc_value_t
valx
;
var_Get
(
p_vout
->
p_sys
->
p_vout
,
"mouse-x"
,
&
valx
);
if
((
valx
.
i_int
>=
(
int
)
posx
)
&&
(
newval
.
i_int
>=
(
int
)
posy
)
&&
(
valx
.
i_int
<=
(
int
)(
posx
+
width
))
&&
(
newval
.
i_int
<=
(
int
)(
posy
+
height
)))
{
posy
=
__MIN
(
__MAX
(
posy
+
i_delta
,
0
)
,
p_vout
->
output
.
i_height
-
height
);
}
}
else
if
(
psz_var
[
6
]
==
'c'
)
{
if
((
valb
.
i_int
&
0x8
)
==
1
)
if
(
valx
.
i_int
>=
(
int
)
p_sys
->
posx
&&
newval
.
i_int
>=
(
int
)
p_sys
->
posy
&&
valx
.
i_int
<=
(
int
)(
p_sys
->
posx
+
p_sys
->
i_width
)
&&
newval
.
i_int
<=
(
int
)(
p_sys
->
posy
+
p_sys
->
i_height
)
)
{
p_vout
->
p_sys
->
trans
++
;
}
else
if
((
valb
.
i_int
&
0x10
)
==
1
)
{
p_vout
->
p_sys
->
trans
--
;
p_sys
->
posy
=
__MIN
(
__MAX
(
p_sys
->
posy
+
i_delta
,
0
),
p_vout
->
output
.
i_height
-
p_sys
->
i_height
);
}
}
#undef posx
#undef posy
#undef width
#undef height
#undef trans
return
VLC_SUCCESS
;
}
/*****************************************************************************
* Control: control facility for the vout (forwards to child vout)
*****************************************************************************/
static
int
Control
(
vout_thread_t
*
p_vout
,
int
i_query
,
va_list
args
)
{
return
vout_vaControl
(
p_vout
->
p_sys
->
p_vout
,
i_query
,
args
);
}
/*****************************************************************************
* SendEventsToChild: forward events to the child/children vout
*****************************************************************************/
...
...
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