forked from openlp/openlp
Fixed scrolling bug display
This commit is contained in:
parent
e8edb7e52f
commit
2076851555
@ -1,14 +1,7 @@
|
|||||||
/* Animation key frames for horizontal scrolling of alert */
|
@keyframes alert-scrolling-text {
|
||||||
/* @keyframes alert-scrolling-text {
|
0% { transform: translateX(100%); opacity: 1; }
|
||||||
from { margin-left: 100%; }
|
99% { opacity: 1; }
|
||||||
to { margin-left: -300% }
|
100% { transform: translateX(-105%); opacity: 0;}
|
||||||
} */
|
|
||||||
|
|
||||||
.horizontal-scroll-animation {
|
|
||||||
animation-duration: 10s;
|
|
||||||
animation-iteration-count: 2;
|
|
||||||
animation-timing-function: linear;
|
|
||||||
animation-name: alert-scrolling-text;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ALERT BACKGROUND STYLING */
|
/* ALERT BACKGROUND STYLING */
|
||||||
@ -24,10 +17,16 @@
|
|||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
transform: translate(0,0);
|
transform: translate(0,0);
|
||||||
transition: min-height 1s ease-out .5s;
|
transition: min-height 1s ease-out .5s;
|
||||||
|
white-space: nowrap;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
align-content: center;
|
/* align-content: center; */
|
||||||
|
}
|
||||||
|
|
||||||
|
.bg-default span {
|
||||||
|
display: inline-block;
|
||||||
|
padding-left: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.show-bg {
|
.show-bg {
|
||||||
@ -59,14 +58,12 @@
|
|||||||
/* ALERT TEXT STYLING */
|
/* ALERT TEXT STYLING */
|
||||||
#alert {
|
#alert {
|
||||||
z-index: 100;
|
z-index: 100;
|
||||||
overflow: visible;
|
overflow: visible;
|
||||||
white-space: nowrap;
|
|
||||||
color: #ffffff;
|
color: #ffffff;
|
||||||
font-size: 40pt;
|
font-size: 40pt;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
transform: translateX(120%);
|
|
||||||
transition: opacity .5s linear;
|
transition: opacity .5s linear;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,9 +24,7 @@
|
|||||||
visibility: visible;
|
visibility: visible;
|
||||||
z-index: -1;
|
z-index: -1;
|
||||||
}
|
}
|
||||||
|
</style>
|
||||||
</style>
|
|
||||||
<style type="text/css" id="keyframeStyles"></style>
|
|
||||||
<link rel="stylesheet" type="text/css" href="display.css"></link>
|
<link rel="stylesheet" type="text/css" href="display.css"></link>
|
||||||
<script type="text/javascript" src="qrc:///qtwebchannel/qwebchannel.js"></script>
|
<script type="text/javascript" src="qrc:///qtwebchannel/qwebchannel.js"></script>
|
||||||
<script type="text/javascript" src="reveal.js"></script>
|
<script type="text/javascript" src="reveal.js"></script>
|
||||||
@ -35,7 +33,7 @@
|
|||||||
|
|
||||||
<body>
|
<body>
|
||||||
<div class="alert-container">
|
<div class="alert-container">
|
||||||
<div id="alert-background" class="bg-default"><p id="alert">Testing alerts</p></div>
|
<div id="alert-background" class="bg-default"><span id="alert">Testing alerts</span></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="reveal">
|
<div class="reveal">
|
||||||
<div id="global-background" class="slide-background present" data-loaded="true"></div>
|
<div id="global-background" class="slide-background present" data-loaded="true"></div>
|
||||||
|
@ -437,10 +437,7 @@ var Display = {
|
|||||||
var settings = JSON.parse(alert_settings);
|
var settings = JSON.parse(alert_settings);
|
||||||
this._alertSettings = settings;
|
this._alertSettings = settings;
|
||||||
Display.setAlertText(text);
|
Display.setAlertText(text);
|
||||||
Display.setAlertLocation(settings.location);
|
Display.setAlertLocation(settings.location, settings.font_color, settings.font_face, settings.font_size);
|
||||||
if (settings.scroll === true) {
|
|
||||||
Display.setAlertKeyframes(alertText.scrollWidth);
|
|
||||||
}
|
|
||||||
/* Check if the alert is a queued alert */
|
/* Check if the alert is a queued alert */
|
||||||
if (Display._alertState !== AlertState.DisplayingFromQueue) {
|
if (Display._alertState !== AlertState.DisplayingFromQueue) {
|
||||||
Display._alertState = AlertState.Displaying;
|
Display._alertState = AlertState.Displaying;
|
||||||
@ -465,24 +462,13 @@ var Display = {
|
|||||||
* Set Alert Text
|
* Set Alert Text
|
||||||
* @param {string} text - The alert text to display
|
* @param {string} text - The alert text to display
|
||||||
*/
|
*/
|
||||||
setAlertText: function (text) {
|
setAlertText: function (text, color, font_face, font_size) {
|
||||||
var alertText = $("#alert")[0];
|
var alertText = $("#alert")[0];
|
||||||
alertText.textContent = text;
|
alertText.textContent = text;
|
||||||
},
|
alertText.style.color = color;
|
||||||
/**
|
alertText.style.fontFamily = font_face;
|
||||||
* Set the keyframe styles for the scrolling text
|
alertText.style.fontSize = font_size + "pt";
|
||||||
* @param {int} scrollWidth - The length of the paragraph with the alert text
|
},
|
||||||
*/
|
|
||||||
setAlertKeyframes: function (scrollWidth) {
|
|
||||||
var keyframeStyle = $('#keyframeStyles')[0];
|
|
||||||
var scrollWidthPercentage = Math.ceil((((scrollWidth / screen.width) * 100) + 1) / 10) * 10;
|
|
||||||
scrollWidthPercentage += 110; // Scroll the full text length
|
|
||||||
var keyframes = "@keyframes alert-scrolling-text {" +
|
|
||||||
"from { transform: translateX(110%); } " +
|
|
||||||
"to { transform: translateX(-" + scrollWidthPercentage + "%);}";
|
|
||||||
keyframeStyle.innerHTML = keyframes;
|
|
||||||
return keyframes;
|
|
||||||
},
|
|
||||||
/**
|
/**
|
||||||
* The alertTransitionEndEvent called after a transition has ended
|
* The alertTransitionEndEvent called after a transition has ended
|
||||||
*/
|
*/
|
||||||
@ -577,11 +563,7 @@ var Display = {
|
|||||||
* @param {json} settings object - The settings to use for the animation
|
* @param {json} settings object - The settings to use for the animation
|
||||||
*/
|
*/
|
||||||
showAlertText: function (settings) {
|
showAlertText: function (settings) {
|
||||||
var alertText = $("#alert")[0];
|
var alertText = $("#alert")[0];
|
||||||
alertText.style.opacity = 1;
|
|
||||||
alertText.style.color = settings.font_color;
|
|
||||||
alertText.style.fontFamily = settings.font_face;
|
|
||||||
alertText.style.fontSize = settings.font_size + "pt";
|
|
||||||
|
|
||||||
if (settings.scroll) {
|
if (settings.scroll) {
|
||||||
var animationSettings = "alert-scrolling-text " + settings.timeout +
|
var animationSettings = "alert-scrolling-text " + settings.timeout +
|
||||||
@ -606,7 +588,7 @@ var Display = {
|
|||||||
hideAlertText: function () {
|
hideAlertText: function () {
|
||||||
var alertText = $('#alert')[0];
|
var alertText = $('#alert')[0];
|
||||||
Display._animationState = AnimationState.NoAnimation;
|
Display._animationState = AnimationState.NoAnimation;
|
||||||
alertText.classList.add("hide-text");
|
alertText.style.animation = "";
|
||||||
Display.hideAlertBackground();
|
Display.hideAlertBackground();
|
||||||
Display.resetAlertKeyframes();
|
Display.resetAlertKeyframes();
|
||||||
},
|
},
|
||||||
@ -622,13 +604,6 @@ var Display = {
|
|||||||
else {
|
else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
},
|
|
||||||
/**
|
|
||||||
* Reset animation keyframes after displaying alert
|
|
||||||
*/
|
|
||||||
resetAlertKeyframes: function () {
|
|
||||||
var keyframeStyle = document.getElementById('keyframeStyles');
|
|
||||||
keyframeStyle.innerHTML = "";
|
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* Clears the alert settings after displaying an alert
|
* Clears the alert settings after displaying an alert
|
||||||
|
Loading…
Reference in New Issue
Block a user