mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 18:05:37 +00:00
ext/pango/gsttextoverlay.*: If input is plain text, escape it before passing it to pango_layout_set_markup().
Original commit message from CVS: * ext/pango/gsttextoverlay.c: (gst_text_overlay_init), (gst_text_overlay_setcaps_txt), (gst_text_overlay_video_chain): * ext/pango/gsttextoverlay.h: If input is plain text, escape it before passing it to pango_layout_set_markup().
This commit is contained in:
parent
ab6f99ab60
commit
b80668c623
3 changed files with 41 additions and 2 deletions
|
@ -1,3 +1,11 @@
|
||||||
|
2006-03-07 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
|
* ext/pango/gsttextoverlay.c: (gst_text_overlay_init),
|
||||||
|
(gst_text_overlay_setcaps_txt), (gst_text_overlay_video_chain):
|
||||||
|
* ext/pango/gsttextoverlay.h:
|
||||||
|
If input is plain text, escape it before passing it to
|
||||||
|
pango_layout_set_markup().
|
||||||
|
|
||||||
2006-03-07 Tim-Philipp Müller <tim at centricular dot net>
|
2006-03-07 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
* gst-libs/gst/audio/gstaudiofilter.c: (gst_audio_filter_chain):
|
* gst-libs/gst/audio/gstaudiofilter.c: (gst_audio_filter_chain):
|
||||||
|
|
|
@ -234,6 +234,7 @@ static GstStateChangeReturn gst_text_overlay_change_state (GstElement * element,
|
||||||
|
|
||||||
static GstCaps *gst_text_overlay_getcaps (GstPad * pad);
|
static GstCaps *gst_text_overlay_getcaps (GstPad * pad);
|
||||||
static gboolean gst_text_overlay_setcaps (GstPad * pad, GstCaps * caps);
|
static gboolean gst_text_overlay_setcaps (GstPad * pad, GstCaps * caps);
|
||||||
|
static gboolean gst_text_overlay_setcaps_txt (GstPad * pad, GstCaps * caps);
|
||||||
static gboolean gst_text_overlay_src_event (GstPad * pad, GstEvent * event);
|
static gboolean gst_text_overlay_src_event (GstPad * pad, GstEvent * event);
|
||||||
|
|
||||||
static gboolean gst_text_overlay_video_event (GstPad * pad, GstEvent * event);
|
static gboolean gst_text_overlay_video_event (GstPad * pad, GstEvent * event);
|
||||||
|
@ -397,6 +398,8 @@ gst_text_overlay_init (GstTextOverlay * overlay, GstTextOverlayClass * klass)
|
||||||
overlay->text_sinkpad =
|
overlay->text_sinkpad =
|
||||||
gst_pad_new_from_template (gst_static_pad_template_get
|
gst_pad_new_from_template (gst_static_pad_template_get
|
||||||
(&text_sink_template_factory), "text_sink");
|
(&text_sink_template_factory), "text_sink");
|
||||||
|
gst_pad_set_setcaps_function (overlay->text_sinkpad,
|
||||||
|
GST_DEBUG_FUNCPTR (gst_text_overlay_setcaps_txt));
|
||||||
gst_pad_set_event_function (overlay->text_sinkpad,
|
gst_pad_set_event_function (overlay->text_sinkpad,
|
||||||
GST_DEBUG_FUNCPTR (gst_text_overlay_text_event));
|
GST_DEBUG_FUNCPTR (gst_text_overlay_text_event));
|
||||||
gst_pad_set_chain_function (overlay->text_sinkpad,
|
gst_pad_set_chain_function (overlay->text_sinkpad,
|
||||||
|
@ -468,6 +471,23 @@ gst_text_overlay_update_wrap_mode (GstTextOverlay * overlay)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_text_overlay_setcaps_txt (GstPad * pad, GstCaps * caps)
|
||||||
|
{
|
||||||
|
GstTextOverlay *overlay;
|
||||||
|
GstStructure *structure;
|
||||||
|
|
||||||
|
overlay = GST_TEXT_OVERLAY (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
|
structure = gst_caps_get_structure (caps, 0);
|
||||||
|
overlay->have_pango_markup =
|
||||||
|
gst_structure_has_name (structure, "text/x-pango-markup");
|
||||||
|
|
||||||
|
gst_object_unref (overlay);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
/* FIXME: upstream nego (e.g. when the video window is resized) */
|
/* FIXME: upstream nego (e.g. when the video window is resized) */
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
@ -1256,9 +1276,18 @@ gst_text_overlay_video_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
/* Push the video frame */
|
/* Push the video frame */
|
||||||
ret = gst_pad_push (overlay->srcpad, buffer);
|
ret = gst_pad_push (overlay->srcpad, buffer);
|
||||||
} else {
|
} else {
|
||||||
|
const gchar *in_text;
|
||||||
|
gsize in_size;
|
||||||
|
|
||||||
|
in_text = (const gchar *) GST_BUFFER_DATA (overlay->text_buffer);
|
||||||
|
in_size = GST_BUFFER_SIZE (overlay->text_buffer);
|
||||||
|
|
||||||
/* Get the string */
|
/* Get the string */
|
||||||
text = g_strndup ((gchar *) GST_BUFFER_DATA (overlay->text_buffer),
|
if (overlay->have_pango_markup) {
|
||||||
GST_BUFFER_SIZE (overlay->text_buffer));
|
text = g_strndup (in_text, in_size);
|
||||||
|
} else {
|
||||||
|
text = g_markup_escape_text (in_text, in_size);
|
||||||
|
}
|
||||||
|
|
||||||
if (text != NULL && *text != '\0') {
|
if (text != NULL && *text != '\0') {
|
||||||
gint text_len = strlen (text);
|
gint text_len = strlen (text);
|
||||||
|
|
|
@ -109,6 +109,8 @@ struct _GstTextOverlay {
|
||||||
gboolean need_render;
|
gboolean need_render;
|
||||||
|
|
||||||
gint shading_value; /* for timeoverlay subclass */
|
gint shading_value; /* for timeoverlay subclass */
|
||||||
|
|
||||||
|
gboolean have_pango_markup;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _GstTextOverlayClass {
|
struct _GstTextOverlayClass {
|
||||||
|
|
Loading…
Reference in a new issue