osd_text.c 4.99 KB
Newer Older
1
2
3
/*****************************************************************************
 * osd_text.c : text manipulation functions
 *****************************************************************************
Jean-Baptiste Kempf's avatar
LGPL    
Jean-Baptiste Kempf committed
4
 * Copyright (C) 1999-2007 VLC authors and VideoLAN
5
6
 * $Id$
 *
7
 * Author: Sigmund Augdal Helberg <dnumgis@videolan.org>
8
 *
Jean-Baptiste Kempf's avatar
LGPL    
Jean-Baptiste Kempf committed
9
10
11
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation; either version 2.1 of the License, or
12
13
14
15
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Jean-Baptiste Kempf's avatar
LGPL    
Jean-Baptiste Kempf committed
16
17
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Lesser General Public License for more details.
18
 *
Jean-Baptiste Kempf's avatar
LGPL    
Jean-Baptiste Kempf committed
19
20
21
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
22
 *****************************************************************************/
23
24
25
26
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif

27
#include <vlc_common.h>
zorglub's avatar
zorglub committed
28
#include <vlc_vout.h>
29
30
31
32
33
34
35
36
37
#include <vlc_block.h>
#include <vlc_filter.h>
#include <vlc_osd.h>

/**
 * \brief Show text on the video for some time
 * \param p_spu pointer to the subpicture queue the text is to be showed on
 * \param i_channel Subpicture channel
 * \param psz_string The text to be shown
basOS G's avatar
basOS G committed
38
 * \param p_style Pointer to a struct with text style info (it is duplicated)
39
40
41
42
43
44
 * \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 osd_ShowTextRelative( spu_t *p_spu, int i_channel,
basOS G's avatar
basOS G committed
45
                           const char *psz_string, const text_style_t *p_style,
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
                           int i_flags, int i_hmargin, int i_vmargin,
                           mtime_t i_duration )
{
    mtime_t i_now = mdate();

    return osd_ShowTextAbsolute( p_spu, i_channel, psz_string,
                                  p_style, i_flags, i_hmargin, i_vmargin,
                                  i_now, i_now + i_duration );
}

/**
 * \brief Show text on the video from a given start date to a given end date
 * \param p_spu pointer to the subpicture queue the text is to be showed on
 * \param i_channel Subpicture channel
 * \param psz_string The text to be shown
basOS G's avatar
basOS G committed
61
 * \param p_style Pointer to a struct with text style info (it is duplicated)
62
63
64
65
66
67
68
69
70
 * \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
 */
int osd_ShowTextAbsolute( spu_t *p_spu_channel, int i_channel,
basOS G's avatar
basOS G committed
71
                           const char *psz_string, const text_style_t *p_style,
72
73
74
75
76
                           int i_flags, int i_hmargin, int i_vmargin,
                           mtime_t i_start, mtime_t i_stop )
{
    subpicture_t *p_spu;
    video_format_t fmt;
77
    (void)p_style;
78
79
80

    if( !psz_string ) return VLC_EGENERIC;

81
    p_spu = subpicture_New( NULL );
82
83
84
85
86
87
88
89
    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->b_ephemer = true;
    p_spu->b_absolute = false;
90
91
92

    /* Create a new subpicture region */
    memset( &fmt, 0, sizeof(video_format_t) );
93
    fmt.i_chroma = VLC_CODEC_TEXT;
94
95
    fmt.i_width = fmt.i_height = 0;
    fmt.i_x_offset = fmt.i_y_offset = 0;
96
    p_spu->p_region = subpicture_region_New( &fmt );
97
98
99
    if( !p_spu->p_region )
    {
        msg_Err( p_spu_channel, "cannot allocate SPU region" );
100
        subpicture_Delete( p_spu );
101
102
103
104
        return VLC_EGENERIC;
    }

    p_spu->p_region->psz_text = strdup( psz_string );
Laurent Aimar's avatar
Laurent Aimar committed
105
    p_spu->p_region->i_align = i_flags & SUBPICTURE_ALIGN_MASK;
106
107
    p_spu->p_region->i_x = i_hmargin;
    p_spu->p_region->i_y = i_vmargin;
108

109
    spu_PutSubpicture( p_spu_channel, p_spu );
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128

    return VLC_SUCCESS;
}


/**
 * \brief Write an informative message at the default location,
 *        for the default duration and only if the OSD option is enabled.
 * \param p_caller The object that called the function.
 * \param i_channel Subpicture channel
 * \param psz_format printf style formatting
 **/
void osd_Message( spu_t *p_spu, int i_channel,
                        char *psz_format, ... )
{
    va_list args;

    if( p_spu )
    {
129
        char *psz_string;
130
        va_start( args, psz_format );
131
132
133
        if( vasprintf( &psz_string, psz_format, args ) != -1 )
        {
            osd_ShowTextRelative( p_spu, i_channel, psz_string, NULL,
Laurent Aimar's avatar
Laurent Aimar committed
134
                    SUBPICTURE_ALIGN_TOP|SUBPICTURE_ALIGN_RIGHT, 30,20,1000000 );
135

136
137
            free( psz_string );
        }
138
139
140
        va_end( args );
    }
}