Add Volume slider and document APIs

This commit is contained in:
Tim Bentley 2010-08-02 06:16:07 +01:00
parent c10fc012a3
commit 82aa9c333a
2 changed files with 48 additions and 0 deletions

View File

@ -197,23 +197,40 @@ class MainDisplay(DisplayWidget):
u'src', unicode(u'data:image/png;base64,%s' % image_to_byte(image))) u'src', unicode(u'data:image/png;base64,%s' % image_to_byte(image)))
def resetImage(self): def resetImage(self):
"""
Reset the backgound image to the service item image.
Used after Image plugin has changed the background
"""
log.debug(u'resetImage') log.debug(u'resetImage')
self.frame.findFirstElement(u'img').setAttribute( self.frame.findFirstElement(u'img').setAttribute(
u'src', unicode(u'data:image/png;base64,%s' % image_to_byte(self.serviceItem.bg_frame))) u'src', unicode(u'data:image/png;base64,%s' % image_to_byte(self.serviceItem.bg_frame)))
def resetVideo(self): def resetVideo(self):
"""
Reset the backgound image to the service item image.
Used after Video plugin has changed the background
"""
log.debug(u'resetVideo') log.debug(u'resetVideo')
self.frame.findFirstElement('img').setAttribute(u'src',u'display: none;' ) self.frame.findFirstElement('img').setAttribute(u'src',u'display: none;' )
def videoPlay(self): def videoPlay(self):
"""
Responds to the request to play a loaded video
"""
log.debug(u'videoPlay') log.debug(u'videoPlay')
self.frame.evaluateJavaScript("document.getElementById('video').play()") self.frame.evaluateJavaScript("document.getElementById('video').play()")
def videoPause(self): def videoPause(self):
"""
Responds to the request to pause a loaded video
"""
log.debug(u'videoPause') log.debug(u'videoPause')
self.frame.evaluateJavaScript("document.getElementById('video').pause()") self.frame.evaluateJavaScript("document.getElementById('video').pause()")
def videoStop(self): def videoStop(self):
"""
Responds to the request to stop a loaded video
"""
log.debug(u'videoStop') log.debug(u'videoStop')
self.frame.evaluateJavaScript("document.getElementById('video').pause()") self.frame.evaluateJavaScript("document.getElementById('video').pause()")
self.frame.evaluateJavaScript( self.frame.evaluateJavaScript(
@ -222,10 +239,16 @@ class MainDisplay(DisplayWidget):
"document.getElementById('image').style.visibility = 'visible'") "document.getElementById('image').style.visibility = 'visible'")
def videoVolume(self, amount): def videoVolume(self, amount):
"""
Changes the volume of a running video
"""
log.debug(u'videoVolume') log.debug(u'videoVolume')
self.frame.evaluateJavaScript("document.getElementById('video').volume = 0") self.frame.evaluateJavaScript("document.getElementById('video').volume = 0")
def video(self, videoPath, noSound=False): def video(self, videoPath, noSound=False):
"""
Loads and starts a video to run with the option of sound
"""
log.debug(u'video') log.debug(u'video')
self.frame.findFirstElement('video').setAttribute('src', videoPath) self.frame.findFirstElement('video').setAttribute('src', videoPath)
self.frame.evaluateJavaScript( self.frame.evaluateJavaScript(
@ -243,6 +266,9 @@ class MainDisplay(DisplayWidget):
self.loaded = True self.loaded = True
def preview(self): def preview(self):
"""
Generates a preview of the image displayed.
"""
log.debug(u'preview') log.debug(u'preview')
# Wait for the webview to update before geting the preview. # Wait for the webview to update before geting the preview.
# Important otherwise first preview will miss the background ! # Important otherwise first preview will miss the background !

View File

@ -99,6 +99,7 @@ class SlideController(QtGui.QWidget):
self.songEditList = [ self.songEditList = [
u'Edit Song', u'Edit Song',
] ]
self.volume = 10
self.timer_id = 0 self.timer_id = 0
self.songEdit = False self.songEdit = False
self.selectedRow = 0 self.selectedRow = 0
@ -261,6 +262,15 @@ class SlideController(QtGui.QWidget):
self.volumeSlider.setGeometry(QtCore.QRect(90, 260, 221, 24)) self.volumeSlider.setGeometry(QtCore.QRect(90, 260, 221, 24))
self.volumeSlider.setObjectName(u'volumeSlider') self.volumeSlider.setObjectName(u'volumeSlider')
self.Mediabar.addToolbarWidget(u'Audio Volume', self.volumeSlider) self.Mediabar.addToolbarWidget(u'Audio Volume', self.volumeSlider)
else:
self.volumeSlider = QtGui.QSlider(QtCore.Qt.Horizontal)
self.volumeSlider.setTickInterval(1)
self.volumeSlider.setTickPosition(QtGui.QSlider.TicksAbove)
self.volumeSlider.setMinimum(0)
self.volumeSlider.setMaximum(10)
self.volumeSlider.setGeometry(QtCore.QRect(90, 260, 221, 24))
self.volumeSlider.setObjectName(u'volumeSlider')
self.Mediabar.addToolbarWidget(u'Audio Volume', self.volumeSlider)
self.ControllerLayout.addWidget(self.Mediabar) self.ControllerLayout.addWidget(self.Mediabar)
# Build the Song Toolbar # Build the Song Toolbar
if isLive: if isLive:
@ -379,6 +389,9 @@ class SlideController(QtGui.QWidget):
QtCore.SIGNAL(u'config_screen_changed'), self.screenSizeChanged) QtCore.SIGNAL(u'config_screen_changed'), self.screenSizeChanged)
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.QObject.connect(Receiver.get_receiver(),
QtCore.SIGNAL(u'%s_slide_cache' % self.typePrefix), self.slideCache) QtCore.SIGNAL(u'%s_slide_cache' % self.typePrefix), self.slideCache)
if self.isLive:
QtCore.QObject.connect(self.volumeSlider,
QtCore.SIGNAL(u'sliderReleased()'), self.mediaVolume)
def screenSizeChanged(self): def screenSizeChanged(self):
""" """
@ -925,6 +938,7 @@ class SlideController(QtGui.QWidget):
if self.isLive: if self.isLive:
file = os.path.join(item.get_frame_path(), item.get_frame_title()) file = os.path.join(item.get_frame_path(), item.get_frame_title())
self.display.video(file) self.display.video(file)
self.volumeSlider.setValue(self.volume)
else: else:
self.mediaObject.stop() self.mediaObject.stop()
self.mediaObject.clearQueue() self.mediaObject.clearQueue()
@ -934,6 +948,14 @@ class SlideController(QtGui.QWidget):
self.seekSlider.show() self.seekSlider.show()
self.onMediaPlay() self.onMediaPlay()
def mediaVolume(self):
"""
Respond to the release of Volume Slider
"""
log.debug(u'SlideController mediaVolume')
self.volume = self.volumeSlider.value()
self.display.videoVolume(self.volume)
def onMediaPause(self): def onMediaPause(self):
""" """
Respond to the Pause from the media Toolbar Respond to the Pause from the media Toolbar