-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathpp_messageplayer.py
267 lines (205 loc) · 9.99 KB
/
pp_messageplayer.py
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
from tkinter import NW,N,W,CENTER,LEFT,RIGHT,FLAT
from pp_utils import StopWatch,calculate_text_position
from pp_player import Player
from tk_html_widgets import HTMLText
import os
class MessagePlayer(Player):
""" Displays a message on a canvas for a period of time. Message display can be interrupted
Differs from other players in that text is passed as parameter rather than file containing the text
__init_ just makes sure that all the things the player needs are available
load and unload loads and unloads the track
show shows the track,close closes the track after pause at end
input-pressed receives user input while the track is playing.
"""
def __init__(self,
show_id,
showlist,
root,
canvas,
show_params,
track_params ,
pp_dir,
pp_home,
pp_profile,
end_callback,
command_callback):
# initialise items common to all players
Player.__init__( self,
show_id,
showlist,
root,
canvas,
show_params,
track_params ,
pp_dir,
pp_home,
pp_profile,
end_callback,
command_callback)
# stopwatch for timing functions
StopWatch.global_enable=False
self.sw=StopWatch()
self.sw.off()
self.mon.trace(self,'')
# and initilise things for this player
# get duration from profile
if self.track_params['duration'] != "":
self.duration_text= self.track_params['duration']
else:
self.duration_text= self.show_params['duration']
self.html_message_text_obj = None
self.track_obj=None
# initialise the state machine
self.play_state='initialised'
# LOAD - loads the images and text
def load(self,text,loaded_callback,enable_menu):
# instantiate arguments
self.track=text
self.loaded_callback=loaded_callback # callback when loaded
self.mon.trace(self,'')
# do common bits of load
Player.pre_load(self)
# parse the duration
status,message,self.duration=Player.parse_duration(self.duration_text)
if status == 'error':
self.mon.err(self, message)
self.play_state='load-failed'
self.loaded_callback('error',message)
return
# load the plugin, this may modify self.track and enable the plugin drawing to canvas
if self.track_params['plugin'] != '':
status,message=self.load_plugin()
# can modify self.track with new text, does not touch message location
if status == 'error':
self.mon.err(self,message)
self.play_state='load-failed'
if self.loaded_callback is not None:
self.loaded_callback('error',message)
return
# load the images and text including message text
status,message=self.load_x_content(enable_menu)
if status == 'error':
self.mon.err(self,message)
self.play_state='load-failed'
if self.loaded_callback is not None:
self.loaded_callback('error',message)
return
else:
self.play_state='loaded'
if self.loaded_callback is not None:
self.loaded_callback('loaded','message track loaded')
# UNLOAD - abort a load when omplayer is loading or loaded
def unload(self):
self.mon.trace(self,'')
# nothing to do for Messageplayer
self.mon.log(self,">unload received from show Id: "+ str(self.show_id))
self.play_state='unloaded'
# SHOW - show a track from its loaded state
def show(self,ready_callback,finished_callback,closed_callback):
# instantiate arguments
self.ready_callback=ready_callback # callback when ready to show an image -
self.finished_callback=finished_callback # callback when finished showing
self.closed_callback=closed_callback # callback when closed - not used by Messageplayer
self.mon.trace(self,'')
# init state and signals
self.tick = 100 # tick time for image display (milliseconds)
self.dwell = self.duration
self.dwell_counter=0
self.quit_signal=False
# do common bits
Player.pre_show(self)
# start show state machine
self.start_dwell()
# CLOSE - nothing to do in messageplayer - x content is removed by ready callback
def close(self,closed_callback):
self.mon.trace(self,'')
self.closed_callback=closed_callback
self.mon.log(self,">close received from show Id: "+ str(self.show_id))
if self.tick_timer!= None:
self.canvas.after_cancel(self.tick_timer)
self.play_state='closed'
if self.closed_callback is not None:
self.closed_callback('normal','Messageplayer closed')
def input_pressed(self,symbol):
if symbol == 'stop':
self.stop()
def stop(self):
self.quit_signal=True
# ******************************************
# Sequencing
# ********************************************
def start_dwell(self):
self.play_state='showing'
self.tick_timer=self.canvas.after(self.tick, self.do_dwell)
def do_dwell(self):
if self.quit_signal is True:
self.mon.log(self,"quit received")
if self.finished_callback is not None:
self.finished_callback('pause_at_end','user quit or duration exceeded')
# use finish so that the show will call close
else:
if self.dwell !=0:
self.dwell_counter=self.dwell_counter+1
if self.dwell != 0 and self.dwell_counter == self.dwell:
if self.finished_callback is not None:
self.finished_callback('pause_at_end','user quit or duration exceeded')
# use finish and pause_at_end so that the show will call close
else:
self.tick_timer=self.canvas.after(self.tick, self.do_dwell)
# *****************
# x content
# *****************
# called from Player, load_x_content
def load_track_content(self):
# load message text
# print 'show canvas',self.show_canvas_x1,self.show_canvas_y1,self.show_canvas_x2,self.show_canvas_y2
# print 'canvas width/height/centre',self.show_canvas_width,self.show_canvas_height,self.show_canvas_centre_x,self.show_canvas_centre_y
# print
self.message_html_background_colour= self.track_params['message-html-background-colour']
if self.track_params['message-html-width'] == '':
self.message_html_width=self.show_canvas_x2-self.show_canvas_x1
else:
self.message_html_width=self.track_params['message-html-width']
if self.track_params['message-html-height'] == '':
self.message_html_height=self.show_canvas_y2-self.show_canvas_y1
else:
self.message_html_height=self.track_params['message-html-height']
self.message_text_type=self.track_params['message-text-type']
if self.track_params['message-text-location'] != '':
text_path=self.complete_path(self.track_params['message-text-location'])
if not os.path.exists(text_path):
return 'error',"Message Text file not found "+ text_path
with open(text_path) as f:
message_text=f.read()
else:
message_text= self.track
x,y,anchor,justify=calculate_text_position(self.track_params['message-x'],self.track_params['message-y'],
self.show_canvas_x1,self.show_canvas_y1,
self.show_canvas_centre_x,self.show_canvas_centre_y,
self.show_canvas_x2,self.show_canvas_y2,self.track_params['message-justify'])
if self.message_text_type=='html':
self.html_message_text_obj = HTMLText(self.canvas,background=self.message_html_background_colour,
relief=FLAT)
# self.html_text.pack(fill="both", expand=True)
self.html_message_text_obj.set_html(message_text,self.pp_home,self.pp_profile)
# self.html_text.fit_height()
self.track_obj=self.canvas.create_window(x,y,window=self.html_message_text_obj,
anchor=anchor,width=self.message_html_width,
height=self.message_html_height)
else:
self.track_obj=self.canvas.create_text(x,y,
text=message_text.rstrip('\n'),
fill=self.track_params['message-colour'],
font=self.track_params['message-font'],
justify=justify,
anchor = anchor)
self.canvas.itemconfig(self.track_obj,state='hidden')
return 'normal','message loaded'
def show_track_content(self):
self.canvas.itemconfig(self.track_obj,state='normal')
def hide_track_content(self):
if self.track_obj!= None:
self.canvas.itemconfig(self.track_obj,state='hidden')
if self.html_message_text_obj != None:
self.html_message_text_obj.delete_parser()
self.canvas.delete(self.track_obj)