forked from openlp/openlp
Alert workings
This commit is contained in:
parent
e95ea60d9b
commit
f10e478438
@ -46,7 +46,7 @@ HTMLSRC = u"""
|
|||||||
<script language="javascript">
|
<script language="javascript">
|
||||||
var t = null;
|
var t = null;
|
||||||
var transition = %s;
|
var transition = %s;
|
||||||
|
|
||||||
function startfade(newtext){
|
function startfade(newtext){
|
||||||
var text1 = document.getElementById('lyricsmain');
|
var text1 = document.getElementById('lyricsmain');
|
||||||
var texto1 = document.getElementById('lyricsoutline');
|
var texto1 = document.getElementById('lyricsoutline');
|
||||||
@ -56,7 +56,7 @@ HTMLSRC = u"""
|
|||||||
texto1.innerHTML = newtext;
|
texto1.innerHTML = newtext;
|
||||||
texts1.innerHTML = newtext;
|
texts1.innerHTML = newtext;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var text2 = document.getElementById('lyricsmain2');
|
var text2 = document.getElementById('lyricsmain2');
|
||||||
var texto2 = document.getElementById('lyricsoutline2');
|
var texto2 = document.getElementById('lyricsoutline2');
|
||||||
var texts2 = document.getElementById('lyricsshadow2');
|
var texts2 = document.getElementById('lyricsshadow2');
|
||||||
@ -130,8 +130,10 @@ HTMLSRC = u"""
|
|||||||
<table class="lyricsshadowtable lyricscommon">
|
<table class="lyricsshadowtable lyricscommon">
|
||||||
<tr><td id="lyricsshadow2" class="lyricsshadow lyrics"></td></tr>
|
<tr><td id="lyricsshadow2" class="lyricsshadow lyrics"></td></tr>
|
||||||
</table>
|
</table>
|
||||||
|
<table class="alerttable alertcommon">
|
||||||
|
<tr><td id="alertmain" class="alert"></td></tr>
|
||||||
|
</table>
|
||||||
<div id="footer" class="footer"></div>
|
<div id="footer" class="footer"></div>
|
||||||
<div id="alert"></div>
|
|
||||||
<video id="video"></video>
|
<video id="video"></video>
|
||||||
<blank id="blank"></blank>
|
<blank id="blank"></blank>
|
||||||
%s
|
%s
|
||||||
@ -162,7 +164,6 @@ def build_html(item, screen, alert):
|
|||||||
build_blank(width, height),
|
build_blank(width, height),
|
||||||
"true" if theme and theme.display_slideTransition else "false",
|
"true" if theme and theme.display_slideTransition else "false",
|
||||||
build_image_src(item.bg_frame))
|
build_image_src(item.bg_frame))
|
||||||
print html
|
|
||||||
return html
|
return html
|
||||||
|
|
||||||
def build_video(width, height):
|
def build_video(width, height):
|
||||||
@ -232,7 +233,7 @@ def build_lyrics(item):
|
|||||||
.lyricsshadowtable { z-index:2; %s }
|
.lyricsshadowtable { z-index:2; %s }
|
||||||
.lyrics { %s }
|
.lyrics { %s }
|
||||||
.lyricsoutline { %s }
|
.lyricsoutline { %s }
|
||||||
.lyricsshadow { %s }
|
.lyricsshadow { %s }
|
||||||
table {border=0; margin=0; padding=0; }
|
table {border=0; margin=0; padding=0; }
|
||||||
"""
|
"""
|
||||||
theme = item.themedata
|
theme = item.themedata
|
||||||
@ -247,7 +248,7 @@ def build_lyrics(item):
|
|||||||
lyricscommon = u'width: %spx; height: %spx; ' \
|
lyricscommon = u'width: %spx; height: %spx; ' \
|
||||||
u'font-family %s; font-size: %spx; color: %s; line-height: %d%%' % \
|
u'font-family %s; font-size: %spx; color: %s; line-height: %d%%' % \
|
||||||
(item.main.width(), item.main.height(),
|
(item.main.width(), item.main.height(),
|
||||||
theme.font_main_name, theme.font_main_proportion,
|
theme.font_main_name, theme.font_main_proportion,
|
||||||
theme.font_main_color, 100 + int(theme.font_main_line_adjustment))
|
theme.font_main_color, 100 + int(theme.font_main_line_adjustment))
|
||||||
lyricstable = u'left: %spx; top: %spx;' % \
|
lyricstable = u'left: %spx; top: %spx;' % \
|
||||||
(item.main.x(), item.main.y())
|
(item.main.x(), item.main.y())
|
||||||
@ -281,7 +282,7 @@ def build_lyrics(item):
|
|||||||
else:
|
else:
|
||||||
if theme.display_shadow:
|
if theme.display_shadow:
|
||||||
shadow = u'color: %s;' % (theme.display_shadow_color)
|
shadow = u'color: %s;' % (theme.display_shadow_color)
|
||||||
|
|
||||||
lyrics_html = style % (lyricscommon, lyricstable, outlinetable,
|
lyrics_html = style % (lyricscommon, lyricstable, outlinetable,
|
||||||
shadowtable, lyrics, outline, shadow)
|
shadowtable, lyrics, outline, shadow)
|
||||||
print lyrics_html
|
print lyrics_html
|
||||||
@ -315,20 +316,31 @@ def build_footer(item):
|
|||||||
valign = u'vertical-align:top;'
|
valign = u'vertical-align:top;'
|
||||||
text = u'color:%s; %s %s' % (theme.font_footer_color, align, valign)
|
text = u'color:%s; %s %s' % (theme.font_footer_color, align, valign)
|
||||||
lyrics_html = lyrics % (position, font, text)
|
lyrics_html = lyrics % (position, font, text)
|
||||||
print lyrics_html
|
|
||||||
return lyrics_html
|
return lyrics_html
|
||||||
|
|
||||||
|
|
||||||
def build_alert(width, alertTab):
|
def build_alert(width, alertTab):#
|
||||||
alert = """
|
style = """
|
||||||
#alert { position: absolute; left: 0px; top: 70px;
|
.alertcommon { position: absolute; %s }
|
||||||
width: %spx; height: 10px; z-index:6; font-size: %spx;
|
.alerttable { z-index:8; %s }
|
||||||
}
|
.alert { %s }
|
||||||
#alert p {
|
table {border=0; margin=0; padding=0; }
|
||||||
background-color: %s;
|
"""
|
||||||
}
|
alertcommon = u''
|
||||||
"""
|
alerttable = u''
|
||||||
alertText = u''
|
valign = u''
|
||||||
if alertTab:
|
if alertTab:
|
||||||
alertText = alert % (width, alertTab.font_size, alertTab.bg_color)
|
alertcommon = u'width: %spx; height: %spx; ' \
|
||||||
return alertText
|
u'font-family %s; font-size: %spx; color: %s; ' % \
|
||||||
|
(width, 70, alertTab.font_face, alertTab.font_size,
|
||||||
|
alertTab.bg_color)
|
||||||
|
alerttable = u'left: %spx; top: %spx;' % (0, 0)
|
||||||
|
if alertTab.location == 2:
|
||||||
|
valign = u'vertical-align:bottom;'
|
||||||
|
elif alertTab.location == 1:
|
||||||
|
valign = u'vertical-align:middle;'
|
||||||
|
else:
|
||||||
|
valign = u'vertical-align:top;'
|
||||||
|
alert_html = style % (alertcommon, alerttable, valign)
|
||||||
|
print alert_html
|
||||||
|
return alert_html
|
||||||
|
@ -90,6 +90,7 @@ class MainDisplay(DisplayWidget):
|
|||||||
self.parent = parent
|
self.parent = parent
|
||||||
self.screens = screens
|
self.screens = screens
|
||||||
self.isLive = live
|
self.isLive = live
|
||||||
|
self.alertTab = None
|
||||||
self.setWindowTitle(u'OpenLP Display')
|
self.setWindowTitle(u'OpenLP Display')
|
||||||
self.setWindowFlags(QtCore.Qt.FramelessWindowHint |
|
self.setWindowFlags(QtCore.Qt.FramelessWindowHint |
|
||||||
QtCore.Qt.WindowStaysOnTopHint)
|
QtCore.Qt.WindowStaysOnTopHint)
|
||||||
@ -115,7 +116,6 @@ class MainDisplay(DisplayWidget):
|
|||||||
self.webView.setGeometry(0, 0, self.screen[u'size'].width(), self.screen[u'size'].height())
|
self.webView.setGeometry(0, 0, self.screen[u'size'].width(), self.screen[u'size'].height())
|
||||||
self.page = self.webView.page()
|
self.page = self.webView.page()
|
||||||
self.frame = self.page.mainFrame()
|
self.frame = self.page.mainFrame()
|
||||||
self.alertTab = None
|
|
||||||
QtCore.QObject.connect(self.webView,
|
QtCore.QObject.connect(self.webView,
|
||||||
QtCore.SIGNAL(u'loadFinished(bool)'), self.loaded)
|
QtCore.SIGNAL(u'loadFinished(bool)'), self.loaded)
|
||||||
self.frame.setScrollBarPolicy(QtCore.Qt.Vertical,
|
self.frame.setScrollBarPolicy(QtCore.Qt.Vertical,
|
||||||
@ -175,7 +175,7 @@ class MainDisplay(DisplayWidget):
|
|||||||
The slide text to be displayed
|
The slide text to be displayed
|
||||||
"""
|
"""
|
||||||
log.debug(u'alert')
|
log.debug(u'alert')
|
||||||
self.frame.findFirstElement('div#alert').setInnerXml(text)
|
self.frame.findFirstElement('td#alertmain').setInnerXml(text)
|
||||||
|
|
||||||
def image(self, image):
|
def image(self, image):
|
||||||
"""
|
"""
|
||||||
@ -247,7 +247,7 @@ class MainDisplay(DisplayWidget):
|
|||||||
log.debug(u'buildHtml')
|
log.debug(u'buildHtml')
|
||||||
self.loaded = False
|
self.loaded = False
|
||||||
self.serviceItem = serviceItem
|
self.serviceItem = serviceItem
|
||||||
html = build_html(self.serviceItem, self.screen, self.alertTab)
|
html = build_html(self.serviceItem, self.screen, self.parent.alertTab)
|
||||||
self.webView.setHtml(html)
|
self.webView.setHtml(html)
|
||||||
if serviceItem.footer and serviceItem.foot_text:
|
if serviceItem.footer and serviceItem.foot_text:
|
||||||
self.frame.findFirstElement('div#footer').setInnerXml(serviceItem.foot_text)
|
self.frame.findFirstElement('div#footer').setInnerXml(serviceItem.foot_text)
|
||||||
|
@ -103,9 +103,9 @@ class SlideController(QtGui.QWidget):
|
|||||||
self.songEdit = False
|
self.songEdit = False
|
||||||
self.selectedRow = 0
|
self.selectedRow = 0
|
||||||
self.serviceItem = None
|
self.serviceItem = None
|
||||||
|
self.alertTab = None
|
||||||
self.Panel = QtGui.QWidget(parent.ControlSplitter)
|
self.Panel = QtGui.QWidget(parent.ControlSplitter)
|
||||||
self.slideList = {}
|
self.slideList = {}
|
||||||
self.canDisplay = True
|
|
||||||
# Layout for holding panel
|
# Layout for holding panel
|
||||||
self.PanelLayout = QtGui.QVBoxLayout(self.Panel)
|
self.PanelLayout = QtGui.QVBoxLayout(self.Panel)
|
||||||
self.PanelLayout.setSpacing(0)
|
self.PanelLayout.setSpacing(0)
|
||||||
@ -388,6 +388,7 @@ class SlideController(QtGui.QWidget):
|
|||||||
log.debug(u'screenSizeChanged live = %s' % self.isLive)
|
log.debug(u'screenSizeChanged live = %s' % self.isLive)
|
||||||
# rebuild display as screen size changed
|
# rebuild display as screen size changed
|
||||||
self.display = MainDisplay(self, self.screens, self.isLive)
|
self.display = MainDisplay(self, self.screens, self.isLive)
|
||||||
|
self.display.alertTab = self.alertTab
|
||||||
self.ratio = float(self.screens.current[u'size'].width()) / \
|
self.ratio = float(self.screens.current[u'size'].width()) / \
|
||||||
float(self.screens.current[u'size'].height())
|
float(self.screens.current[u'size'].height())
|
||||||
self.display.setup()
|
self.display.setup()
|
||||||
|
@ -81,9 +81,10 @@ class AlertsPlugin(Plugin):
|
|||||||
log.info(u'Alerts Initialising')
|
log.info(u'Alerts Initialising')
|
||||||
Plugin.initialise(self)
|
Plugin.initialise(self)
|
||||||
self.toolsAlertItem.setVisible(True)
|
self.toolsAlertItem.setVisible(True)
|
||||||
|
self.liveController.alertTab = self.alertsTab
|
||||||
|
|
||||||
def finalise(self):
|
def finalise(self):
|
||||||
log.info(u'Plugin Finalise')
|
log.info(u'Alerts Finaliseing')
|
||||||
Plugin.finalise(self)
|
Plugin.finalise(self)
|
||||||
self.toolsAlertItem.setVisible(False)
|
self.toolsAlertItem.setVisible(False)
|
||||||
|
|
||||||
|
@ -261,7 +261,7 @@ class AlertsTab(SettingsTab):
|
|||||||
self.font_face = unicode(settings.value(
|
self.font_face = unicode(settings.value(
|
||||||
u'font face', QtCore.QVariant(QtGui.QFont().family())).toString())
|
u'font face', QtCore.QVariant(QtGui.QFont().family())).toString())
|
||||||
self.location = settings.value(
|
self.location = settings.value(
|
||||||
u'location', QtCore.QVariant(0)).toInt()[0]
|
u'location', QtCore.QVariant(1)).toInt()[0]
|
||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
self.FontSizeSpinBox.setValue(self.font_size)
|
self.FontSizeSpinBox.setValue(self.font_size)
|
||||||
self.TimeoutSpinBox.setValue(self.timeout)
|
self.TimeoutSpinBox.setValue(self.timeout)
|
||||||
@ -297,9 +297,3 @@ class AlertsTab(SettingsTab):
|
|||||||
self.FontPreview.setStyleSheet(u'background-color: %s; color: %s' %
|
self.FontPreview.setStyleSheet(u'background-color: %s; color: %s' %
|
||||||
(self.bg_color, self.font_color))
|
(self.bg_color, self.font_color))
|
||||||
|
|
||||||
def postSetUp(self):
|
|
||||||
"""
|
|
||||||
Reset screens after initial definition
|
|
||||||
"""
|
|
||||||
self.parent.previewController.display.alertTab = self
|
|
||||||
self.parent.liveController.display.alertTab = self
|
|
||||||
|
Loading…
Reference in New Issue
Block a user