]> git.sesse.net Git - vlc/blobdiff - src/video_output/video_text.c
Used a vout object for vout_OSDMessage/OSDSlider/OSDIcon.
[vlc] / src / video_output / video_text.c
index d5a8f6244bb2ee1263d20a6197c202a459bb81b6..11fb81b9e9b71d4723ec14fdcc0c9116029c6395 100644 (file)
@@ -24,6 +24,7 @@
 #ifdef HAVE_CONFIG_H
 # include "config.h"
 #endif
+#include <assert.h>
 
 #include <vlc_common.h>
 #include <vlc_vout.h>
 #include <vlc_filter.h>
 #include <vlc_osd.h>
 
-/**
- * \brief Show text on the video for some time
- * \param p_vout pointer to the vout the text is to be showed on
- * \param i_channel Subpicture channel
- * \param psz_string The text to be shown
- * \param p_style Pointer to a struct with text style info (it is duplicated if non NULL)
- * \param i_flags flags for alignment and such
- * \param i_hmargin horizontal margin in pixels
- * \param i_vmargin vertical margin in pixels
- * \param i_duration Amount of time the text is to be shown.
- */
-int vout_ShowTextRelative( vout_thread_t *p_vout, int i_channel,
-                           char *psz_string, const text_style_t *p_style,
-                           int i_flags, int i_hmargin, int i_vmargin,
-                           mtime_t i_duration )
-{
-    mtime_t i_now = mdate();
-
-    return vout_ShowTextAbsolute( p_vout, i_channel, psz_string,
-                                  p_style, i_flags, i_hmargin, i_vmargin,
-                                  i_now, i_now + i_duration );
-}
+/* TODO remove access to private vout data */
+#include "vout_internal.h"
 
 /**
  * \brief Show text on the video from a given start date to a given end date
@@ -63,28 +44,25 @@ int vout_ShowTextRelative( vout_thread_t *p_vout, int i_channel,
  * \param i_flags flags for alignment and such
  * \param i_hmargin horizontal margin in pixels
  * \param i_vmargin vertical margin in pixels
- * \param i_start the time when this string is to appear on the video
- * \param i_stop the time when this string should stop to be displayed
- *               if this is 0 the string will be shown untill the next string
- *               is about to be shown
+ * \param i_duration Amount of time the text is to be shown.
  */
-int vout_ShowTextAbsolute( vout_thread_t *p_vout, int i_channel,
+int vout_ShowTextRelative( vout_thread_t *p_vout, int i_channel,
                            const char *psz_string, const text_style_t *p_style,
                            int i_flags, int i_hmargin, int i_vmargin,
-                           mtime_t i_start, mtime_t i_stop )
+                           mtime_t i_duration )
 {
     subpicture_t *p_spu;
     video_format_t fmt;
 
     if( !psz_string ) return VLC_EGENERIC;
 
-    p_spu = subpicture_New();
+    p_spu = subpicture_New( NULL );
     if( !p_spu )
         return VLC_EGENERIC;
 
     p_spu->i_channel = i_channel;
-    p_spu->i_start = i_start;
-    p_spu->i_stop = i_stop;
+    p_spu->i_start = mdate();
+    p_spu->i_stop  = p_spu->i_start + i_duration;
     p_spu->b_ephemer = true;
     p_spu->b_absolute = false;
     p_spu->b_fade = true;
@@ -93,7 +71,6 @@ int vout_ShowTextAbsolute( vout_thread_t *p_vout, int i_channel,
     /* Create a new subpicture region */
     memset( &fmt, 0, sizeof(video_format_t) );
     fmt.i_chroma = VLC_CODEC_TEXT;
-    fmt.i_aspect = 0;
     fmt.i_width = fmt.i_height = 0;
     fmt.i_x_offset = fmt.i_y_offset = 0;
     p_spu->p_region = subpicture_region_New( &fmt );
@@ -111,12 +88,11 @@ int vout_ShowTextAbsolute( vout_thread_t *p_vout, int i_channel,
     if( p_style )
         p_spu->p_region->p_style = text_style_Duplicate( p_style );
 
-    spu_DisplaySubpicture( p_vout->p_spu, p_spu );
+    spu_DisplaySubpicture( vout_GetSpu( p_vout ), p_spu );
 
     return VLC_SUCCESS;
 }
 
-
 /**
  * \brief Write an informative message at the default location,
  *        for the default duration and only if the OSD option is enabled.
@@ -124,96 +100,26 @@ int vout_ShowTextAbsolute( vout_thread_t *p_vout, int i_channel,
  * \param i_channel Subpicture channel
  * \param psz_format printf style formatting
  **/
-void __vout_OSDMessage( vlc_object_t *p_caller, int i_channel,
-                        const char *psz_format, ... )
+void vout_OSDMessage( vout_thread_t *p_vout, int i_channel,
+                      const char *psz_format, ... )
 {
-    vout_thread_t *p_vout;
-    char *psz_string = NULL;
-    va_list args;
+    if( !var_InheritBool( p_vout, "osd" ) )
+        return;
 
-    if( !config_GetInt( p_caller, "osd" ) ) return;
+    va_list args;
+    va_start( args, psz_format );
 
-    p_vout = vlc_object_find( p_caller, VLC_OBJECT_VOUT, FIND_ANYWHERE );
-    if( p_vout )
+    char *psz_string;
+    if( vasprintf( &psz_string, psz_format, args ) != -1 )
     {
-        va_start( args, psz_format );
-        if( vasprintf( &psz_string, psz_format, args ) != -1 )
-        {
-            vout_ShowTextRelative( p_vout, i_channel, psz_string, NULL,
-                                   OSD_ALIGN_TOP|OSD_ALIGN_RIGHT,
-                                   30 + p_vout->fmt_in.i_width
-                                      - p_vout->fmt_in.i_visible_width
-                                      - p_vout->fmt_in.i_x_offset,
-                                   20 + p_vout->fmt_in.i_y_offset, 1000000 );
-            free( psz_string );
-        }
-        vlc_object_release( p_vout );
-        va_end( args );
+        vout_ShowTextRelative( p_vout, i_channel, psz_string, NULL,
+                               SUBPICTURE_ALIGN_TOP|SUBPICTURE_ALIGN_RIGHT,
+                               30 + p_vout->p->fmt_in.i_width
+                                  - p_vout->p->fmt_in.i_visible_width
+                                  - p_vout->p->fmt_in.i_x_offset,
+                               20 + p_vout->p->fmt_in.i_y_offset, 1000000 );
+        free( psz_string );
     }
-}
-
-/* */
-text_style_t *text_style_New( void )
-{
-    text_style_t *p_style = calloc( 1, sizeof(*p_style) );
-    if( !p_style )
-        return NULL;
-
-    /* initialize to default text style */
-    p_style->psz_fontname = NULL;
-    p_style->i_font_size = 22;
-    p_style->i_font_color = 0xffffff;
-    p_style->i_font_alpha = 0xff;
-    p_style->i_style_flags = STYLE_OUTLINE;
-    p_style->i_outline_color = 0x000000;
-    p_style->i_outline_alpha = 0xff;
-    p_style->i_shadow_color = 0x000000;
-    p_style->i_shadow_alpha = 0xff;
-    p_style->i_background_color = 0xffffff;
-    p_style->i_background_alpha = 0x80;
-    p_style->i_karaoke_background_color = 0xffffff;
-    p_style->i_karaoke_background_alpha = 0xff;
-    p_style->i_outline_width = 1;
-    p_style->i_shadow_width = 0;
-    p_style->i_spacing = -1;
-
-    return p_style;
-}
-
-text_style_t *text_style_Copy( text_style_t *p_dst, const text_style_t *p_src )
-{
-    if( !p_src )
-        return p_dst;
-
-    /* */
-    if( p_dst->psz_fontname )
-        free( p_dst->psz_fontname );
-
-    /* */
-    *p_dst = *p_src;
-
-    /* */
-    if( p_dst->psz_fontname )
-        p_dst->psz_fontname = strdup( p_dst->psz_fontname );
-
-    return p_dst;
-}
-
-text_style_t *text_style_Duplicate( const text_style_t *p_src )
-{
-    if( !p_src )
-        return NULL;
-
-    text_style_t *p_dst = calloc( 1, sizeof(*p_dst) );
-    if( p_dst )
-        text_style_Copy( p_dst, p_src );
-    return p_dst;
-}
-
-void text_style_Delete( text_style_t *p_style )
-{
-    if( p_style )
-        free( p_style->psz_fontname );
-    free( p_style );
+    va_end( args );
 }