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
c57b7837
Commit
c57b7837
authored
Jul 27, 2010
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
freetype: simplify HTML rendering with the new XML API
parent
70faefb1
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
88 additions
and
97 deletions
+88
-97
modules/misc/freetype.c
modules/misc/freetype.c
+88
-97
No files found.
modules/misc/freetype.c
View file @
c57b7837
...
...
@@ -265,7 +265,7 @@ struct filter_sys_t
int
i_display_height
;
#ifdef HAVE_FONTCONFIG
char
*
psz_fontfamily
;
xml_
t
*
p_xml
;
xml_
reader_t
*
p_xml
;
#endif
input_attachment_t
**
pp_font_attachments
;
...
...
@@ -304,7 +304,7 @@ static int Create( vlc_object_t *p_this )
p_filter
->
p_sys
=
p_sys
=
malloc
(
sizeof
(
filter_sys_t
)
);
if
(
!
p_sys
)
return
VLC_ENOMEM
;
#ifdef HAVE_FONTCONFIG
#ifdef HAVE_FONTCONFIG
p_sys
->
psz_fontfamily
=
NULL
;
p_sys
->
p_xml
=
NULL
;
#endif
...
...
@@ -514,7 +514,7 @@ static void Destroy( vlc_object_t *p_this )
}
#ifdef HAVE_FONTCONFIG
if
(
p_sys
->
p_xml
)
xml_Delete
(
p_sys
->
p_xml
);
if
(
p_sys
->
p_xml
)
xml_
Reader
Delete
(
p_sys
->
p_xml
);
free
(
p_sys
->
psz_fontfamily
);
#endif
...
...
@@ -2190,7 +2190,6 @@ static int RenderHtml( filter_t *p_filter, subpicture_region_t *p_region_out,
{
int
rv
=
VLC_SUCCESS
;
stream_t
*
p_sub
=
NULL
;
xml_reader_t
*
p_xml_reader
=
NULL
;
if
(
!
p_region_in
||
!
p_region_in
->
psz_html
)
return
VLC_EGENERIC
;
...
...
@@ -2202,14 +2201,18 @@ static int RenderHtml( filter_t *p_filter, subpicture_region_t *p_region_out,
(
uint8_t
*
)
p_region_in
->
psz_html
,
strlen
(
p_region_in
->
psz_html
),
true
);
if
(
p_sub
)
{
if
(
!
p_filter
->
p_sys
->
p_xml
)
p_filter
->
p_sys
->
p_xml
=
xml_Create
(
p_filter
);
if
(
p_filter
->
p_sys
->
p_xml
)
{
if
(
unlikely
(
p_sub
==
NULL
)
)
return
VLC_SUCCESS
;
xml_reader_t
*
p_xml_reader
=
p_filter
->
p_sys
->
p_xml
;
bool
b_karaoke
=
false
;
p_xml_reader
=
xml_ReaderCreate
(
p_filter
->
p_sys
->
p_xml
,
p_sub
);
if
(
!
p_xml_reader
)
p_xml_reader
=
xml_ReaderCreate
(
p_filter
,
p_sub
);
else
p_xml_reader
=
xml_ReaderReset
(
p_xml_reader
,
p_sub
);
p_filter
->
p_sys
->
p_xml
=
p_xml_reader
;
if
(
p_xml_reader
)
{
/* Look for Root Node */
...
...
@@ -2259,12 +2262,9 @@ static int RenderHtml( filter_t *p_filter, subpicture_region_t *p_region_out,
sizeof
(
uint32_t
)
);
if
(
psz_text
)
{
uint32_t
k
;
rv
=
ProcessNodes
(
p_filter
,
p_xml_reader
,
p_region_in
->
p_style
,
psz_text
,
&
i_len
,
&
i_runs
,
&
pi_run_lengths
,
&
pp_styles
,
b_karaoke
,
&
i_k_runs
,
&
pi_k_run_lengths
,
&
pi_k_durations
);
...
...
@@ -2274,42 +2274,33 @@ static int RenderHtml( filter_t *p_filter, subpicture_region_t *p_region_out,
if
((
rv
==
VLC_SUCCESS
)
&&
(
i_len
>
0
))
{
rv
=
ProcessLines
(
p_filter
,
psz_text
,
i_len
,
i_runs
,
pi_run_lengths
,
pp_styles
,
&
p_lines
,
&
result
,
b_karaoke
,
i_k_runs
,
pi_k_run_length
s
,
pi_k_durations
);
pi_run_lengths
,
pp_styles
,
&
p_lines
,
&
result
,
b_karaoke
,
i_k_run
s
,
pi_k_run_lengths
,
pi_k_durations
);
}
for
(
k
=
0
;
k
<
i_runs
;
k
++
)
for
(
uint_fast32_t
k
=
0
;
k
<
i_runs
;
k
++
)
DeleteStyle
(
pp_styles
[
k
]
);
free
(
pp_styles
);
free
(
pi_run_lengths
);
free
(
psz_text
);
/* Don't attempt to render text that couldn't be layed out
* properly.
*/
* properly. */
if
((
rv
==
VLC_SUCCESS
)
&&
(
i_len
>
0
))
{
if
(
var_InheritBool
(
p_filter
,
"freetype-yuvp"
)
)
{
Render
(
p_filter
,
p_region_out
,
p_lines
,
result
.
x
,
result
.
y
);
}
else
{
RenderYUVA
(
p_filter
,
p_region_out
,
p_lines
,
result
.
x
,
result
.
y
);
}
}
}
xml_ReaderReset
(
p_xml_reader
,
NULL
);
FreeLines
(
p_lines
);
xml_ReaderDelete
(
p_xml_reader
);
}
}
stream_Delete
(
p_sub
);
}
return
rv
;
}
...
...
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