openlp-core team mailing list archive
-
openlp-core team
-
Mailing list archive
-
Message #00801
[Merge] lp:~j-corwin/openlp/present into lp:openlp
Jonathan Corwin has proposed merging lp:~j-corwin/openlp/present into lp:openlp.
Requested reviews:
OpenLP Core (openlp-core)
Address some issues with presentations and preview slide controller
--
https://code.launchpad.net/~j-corwin/openlp/present/+merge/14515
Your team OpenLP Core is subscribed to branch lp:openlp.
=== modified file 'openlp/core/ui/maindisplay.py'
--- openlp/core/ui/maindisplay.py 2009-11-05 17:33:38 +0000
+++ openlp/core/ui/maindisplay.py 2009-11-05 23:30:27 +0000
@@ -47,16 +47,16 @@
if type(event) == QtGui.QKeyEvent:
#here accept the event and do something
if event.key() == QtCore.Qt.Key_Up:
- Receiver().send_message(u'slidecontroller_previous')
+ Receiver().send_message(u'live_slidecontroller_previous')
event.accept()
elif event.key() == QtCore.Qt.Key_Down:
- Receiver().send_message(u'slidecontroller_next')
+ Receiver().send_message(u'live_slidecontroller_next')
event.accept()
elif event.key() == QtCore.Qt.Key_PageUp:
- Receiver().send_message(u'slidecontroller_first')
+ Receiver().send_message(u'live_slidecontroller_first')
event.accept()
elif event.key() == QtCore.Qt.Key_PageDown:
- Receiver().send_message(u'slidecontroller_last')
+ Receiver().send_message(u'live_slidecontroller_last')
event.accept()
elif event.key() == QtCore.Qt.Key_Escape:
self.resetDisplay()
@@ -116,9 +116,9 @@
QtCore.QObject.connect(Receiver.get_receiver(),
QtCore.SIGNAL(u'alert_text'), self.displayAlert)
QtCore.QObject.connect(Receiver.get_receiver(),
- QtCore.SIGNAL(u'presentations_start'), self.hideDisplay)
+ QtCore.SIGNAL(u'live_slide_hide'), self.hideDisplay)
QtCore.QObject.connect(Receiver.get_receiver(),
- QtCore.SIGNAL(u'presentations_stop'), self.showDisplay)
+ QtCore.SIGNAL(u'live_slide_show'), self.showDisplay)
QtCore.QObject.connect(self.mediaObject,
QtCore.SIGNAL(u'finished()'), self.onMediaFinish)
QtCore.QObject.connect(Receiver.get_receiver(),
=== modified file 'openlp/core/ui/slidecontroller.py'
--- openlp/core/ui/slidecontroller.py 2009-11-04 01:16:15 +0000
+++ openlp/core/ui/slidecontroller.py 2009-11-05 23:30:27 +0000
@@ -253,16 +253,20 @@
self.Toolbar.makeWidgetsInvisible(self.media_list)
else:
self.Toolbar.makeWidgetsInvisible(self.song_list)
- QtCore.QObject.connect(Receiver.get_receiver(),
- QtCore.SIGNAL(u'slidecontroller_first'), self.onSlideSelectedFirst)
- QtCore.QObject.connect(Receiver.get_receiver(),
- QtCore.SIGNAL(u'slidecontroller_next'), self.onSlideSelectedNext)
- QtCore.QObject.connect(Receiver.get_receiver(),
- QtCore.SIGNAL(u'slidecontroller_previous'), self.onSlideSelectedPrevious)
- QtCore.QObject.connect(Receiver.get_receiver(),
- QtCore.SIGNAL(u'slidecontroller_last'), self.onSlideSelectedLast)
- QtCore.QObject.connect(Receiver.get_receiver(),
- QtCore.SIGNAL(u'slidecontroller_change'), self.onSlideChange)
+ if isLive:
+ prefix = u'live_slidecontroller'
+ else:
+ prefix = u'preview_slidecontroller'
+ QtCore.QObject.connect(Receiver.get_receiver(),
+ QtCore.SIGNAL(u'%s_first' % prefix), self.onSlideSelectedFirst)
+ QtCore.QObject.connect(Receiver.get_receiver(),
+ QtCore.SIGNAL(u'%s_next' % prefix), self.onSlideSelectedNext)
+ QtCore.QObject.connect(Receiver.get_receiver(),
+ QtCore.SIGNAL(u'%s_previous' % prefix), self.onSlideSelectedPrevious)
+ QtCore.QObject.connect(Receiver.get_receiver(),
+ QtCore.SIGNAL(u'%s_last' % prefix), self.onSlideSelectedLast)
+ QtCore.QObject.connect(Receiver.get_receiver(),
+ QtCore.SIGNAL(u'%s_change' % prefix), self.onSlideChange)
def onSongBarHandler(self):
request = self.sender().text()
@@ -350,7 +354,7 @@
if item.service_item_type == ServiceItemType.Command:
Receiver().send_message(u'%s_start' % item.name.lower(), \
[item.shortname, item.service_item_path,
- item.service_frames[0][u'title']])
+ item.service_frames[0][u'title'], self.isLive])
slideno = 0
if self.songEdit:
slideno = self.row
@@ -381,7 +385,7 @@
if item.service_item_type == ServiceItemType.Command:
Receiver().send_message(u'%s_start' % item.name.lower(), \
[item.shortname, item.service_item_path,
- item.service_frames[0][u'title'], slideno])
+ item.service_frames[0][u'title'], slideno, self.isLive])
self.displayServiceManagerItems(item, slideno)
def displayServiceManagerItems(self, serviceitem, slideno):
=== modified file 'openlp/plugins/presentations/lib/messagelistener.py'
--- openlp/plugins/presentations/lib/messagelistener.py 2009-11-03 19:01:53 +0000
+++ openlp/plugins/presentations/lib/messagelistener.py 2009-11-05 23:30:27 +0000
@@ -41,6 +41,7 @@
def __init__(self, controllers):
self.controllers = controllers
self.handler = None
+ self.is_live = None
# messages are sent from core.ui.slidecontroller
QtCore.QObject.connect(Receiver.get_receiver(),
QtCore.SIGNAL(u'presentations_start'), self.startup)
@@ -60,20 +61,25 @@
QtCore.SIGNAL(u'presentations_blank'), self.blank)
QtCore.QObject.connect(Receiver.get_receiver(),
QtCore.SIGNAL(u'presentations_unblank'), self.unblank)
+ self.timer = QtCore.QTimer()
+ self.timer.setInterval(500)
+ QtCore.QObject.connect(self.timer, QtCore.SIGNAL("timeout()"), self.timeout)
def startup(self, message):
"""
Start of new presentation
Save the handler as any new presentations start here
"""
- self.handler, file = self.decodeMessage(message)
+ self.handler, file, self.is_live = self.decodeMessage(message)
self.controller = self.controllers[self.handler]
if self.controller.is_loaded():
self.shutdown(None)
self.controller.load_presentation(file)
- self.controller.start_presentation()
+ if self.is_live:
+ self.controller.start_presentation()
+ Receiver().send_message(u'live_slide_hide')
self.controller.slidenumber = 0
- self.controller.timer.start()
+ self.timer.start()
def activate(self):
if self.controller.is_active():
@@ -85,52 +91,66 @@
self.controller.goto_slide(self.controller.slidenumber)
def slide(self, message):
+ if not self.is_live:
+ return
self.activate()
if message:
self.controller.goto_slide(message[0]+1)
- self.controller.poll_slidenumber()
+ self.controller.poll_slidenumber(self.is_live)
def first(self, message):
"""
Based on the handler passed at startup triggers the first slide
"""
+ if not self.is_live:
+ return
self.activate()
self.controller.start_presentation()
- self.controller.poll_slidenumber()
+ self.controller.poll_slidenumber(self.is_live)
def last(self, message):
"""
Based on the handler passed at startup triggers the first slide
"""
+ if not self.is_live:
+ return
self.activate()
self.controller.goto_slide(self.controller.get_slide_count())
- self.controller.poll_slidenumber()
+ self.controller.poll_slidenumber(self.is_live)
def next(self, message):
"""
Based on the handler passed at startup triggers the next slide event
"""
+ if not self.is_live:
+ return
self.activate()
self.controller.next_step()
- self.controller.poll_slidenumber()
+ self.controller.poll_slidenumber(self.is_live)
def previous(self, message):
"""
Based on the handler passed at startup triggers the previous slide event
"""
+ if not self.is_live:
+ return
self.activate()
self.controller.previous_step()
- self.controller.poll_slidenumber()
+ self.controller.poll_slidenumber(self.is_live)
def shutdown(self, message):
"""
Based on the handler passed at startup triggers slide show to shut down
"""
+ if not self.is_live:
+ Receiver().send_message(u'live_slide_show')
self.controller.close_presentation()
self.controller.slidenumber = 0
- self.controller.timer.shutdown()
+ self.timer.stop()
def blank(self):
+ if not self.is_live:
+ return
if not self.controller.is_loaded():
return
if not self.controller.is_active():
@@ -138,6 +158,8 @@
self.controller.blank_screen()
def unblank(self):
+ if not self.is_live:
+ return
self.activate()
self.controller.unblank_screen()
@@ -149,4 +171,7 @@
Message containing Presentaion handler name and file to be presented.
"""
file = os.path.join(message[1], message[2])
- return message[0], file
+ return message[0], file, message[3]
+
+ def timeout(self):
+ self.controller.poll_slidenumber(self.is_live)
=== modified file 'openlp/plugins/presentations/lib/presentationcontroller.py'
--- openlp/plugins/presentations/lib/presentationcontroller.py 2009-10-30 01:26:45 +0000
+++ openlp/plugins/presentations/lib/presentationcontroller.py 2009-11-05 23:30:27 +0000
@@ -149,9 +149,6 @@
self.thumbnailprefix = u'slide'
if not os.path.isdir(self.thumbnailroot):
os.makedirs(self.thumbnailroot)
- self.timer = QtCore.QTimer()
- self.timer.setInterval(500)
- QtCore.QObject.connect(self.timer, QtCore.SIGNAL("timeout()"), self.poll_slidenumber)
def check_available(self):
"""
@@ -181,13 +178,16 @@
log.debug(u'Kill')
self.close_presentation()
- def load_presentation(self, presentation):
+ def load_presentation(self, presentation, is_live):
"""
Called when a presentation is added to the SlideController.
Loads the presentation and starts it
``presentation``
The file name of the presentations to the run.
+
+ ``is_live``
+ True if Live controller is opening the presentation
"""
pass
@@ -207,9 +207,7 @@
recent than the powerpoint
"""
lastimage = self.get_slide_preview_file(self.get_slide_count())
- if lastimage is None:
- return False
- if not os.path.isfile(lastimage):
+ if not (lastimage and os.path.isfile(lastimage)):
return False
imgdate = os.stat(lastimage).st_mtime
pptdate = os.stat(self.filepath).st_mtime
@@ -301,7 +299,7 @@
"""
return None
- def poll_slidenumber(self):
+ def poll_slidenumber(self, is_live):
"""
Check the current slide number
"""
@@ -311,5 +309,9 @@
if current == self.slidenumber:
return
self.slidenumber = current
- Receiver().send_message(u'slidecontroller_change', self.slidenumber - 1)
-
\ No newline at end of file
+ if is_live:
+ prefix = u'live'
+ else:
+ prefix = u'preview'
+ Receiver().send_message(u'%s_slidecontroller_change' % prefix,
+ self.slidenumber - 1)
Follow ups