Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/simple_tts3.py
blob: 9f4f7b72656d5d4b3fac9167c87b99695c58d0e7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# From http://wiki.sugarlabs.org/go/Activity_Team/gst-plugins-espeak 
from gi.repository import Gtk
#import pygst
#pygst.require("0.10")
from gi.repository import Gst
from gi.repository import Pango

import logging

window = Gtk.Window()
window.connect('destroy',
        lambda sender: Gtk.main_quit())

workspace = Gtk.VBox()
window.add(workspace)

# text widget

scrolled = Gtk.ScrolledWindow()
workspace.pack_start(scrolled, False, False, padding=5)

text = Gtk.TextView()
scrolled.add(text)

buffer = text.props.buffer
buffer.props.text = 'This is a simple text to speech test'

tag = buffer.create_tag()
tag.props.weight = Pango.Weight.BOLD

# play controls

toolbar = Gtk.HBox()
workspace.pack_end(toolbar, False, False, padding=5)

play = Gtk.Button('Play/Resume')
play.connect('clicked',
        lambda sender: pipe.set_state(Gst.State.PLAYING))
toolbar.add(play)

pause = Gtk.Button('Pause')
pause.connect('clicked',
        lambda sender: pipe.set_state(Gst.State.PAUSED))
toolbar.add(pause)

stop = Gtk.Button('Stop')
stop.connect('clicked',
        lambda sender: pipe.set_state(Gst.State.NULL))
toolbar.add(stop)

# gst code

Gst.init_check(None)

pipe = Gst.parse_launch('espeak name=src ! autoaudiosink')

src = pipe.get_by_name('src')
src.props.voice = 'english_wmids'
src.props.text = buffer.props.text
src.props.track = 2 
#src.props.track = 1 # track for words


def tts_cb(bus, message):
    logging.error('gstreamer message %s', message)
    if message is None:
        return
    if message.structure.get_name() != 'espeak-word':
        return

    offset = message.structure['offset']
    len = message.structure['len']

    buffer.remove_tag(tag, buffer.get_start_iter(), buffer.get_end_iter())
    start = buffer.get_iter_at_offset(offset)
    end = buffer.get_iter_at_offset(offset + len)
    buffer.apply_tag(tag, start, end)

bus = pipe.get_bus()
bus.add_signal_watch()
#bus.connect('message::element', tts_cb)
bus.connect('message', tts_cb)

# gtk start

window.show_all()
Gtk.main()