Тревога на фоне с winjs

1 таймер, который я программирую с Winjs и html, но у меня возникает проблема, когда я запускаю свое приложение и переключаюсь на более старую, таймер останавливается, как я могу включить его в фоновом режиме, чтобы он продолжал работать даже при переключении? Спасибо за помощь

моя проблема в том, что когда я запускаю свое приложение и переключаюсь на другое, таймер приостанавливается и останавливается через 10 секунд, и в основном я хочу, чтобы он продолжал работать в фоновом режиме, вы можете мне помочь

Мой HTML:

    <!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>Remember your Break</title>


    <!-- WinJS references -->
    <script src="//Microsoft.WinJS.2.0/js/base.js"></script>
    <script src="//Microsoft.WinJS.2.0/js/ui.js"></script>
    <script src="/pages/home/home.js"></script>
    <!-- CSS references -->
    <link href="//Microsoft.WinJS.2.0/css/ui-dark.css" rel="stylesheet" />
    <link href="/css/default.css" rel="stylesheet" />
    <link href="/pages/home/home.css" rel="stylesheet" />

</head>
<body>
    <!-- The content that will be loaded and displayed. -->
    <div class="fragment homepage">
        <header aria-label="Header content" role="banner">
            <!--<button data-win-control="WinJS.UI.BackButton"></button>-->
            <h1 class="titlearea win-type-ellipsis">
                <span class="pagetitle">Remember your Break</span>
            </h1>
        </header>
        <section aria-label="Main content" role="main">
            <div data-win-control="WinJS.UI.ViewBox" style="top: -19.99px;">
                <div class="fixedlayout">
                    <div class="center" id="divcenter">
                        <div class="center">

                            <p id="radioDiv">
                                <span> Take a Break After &nbsp;</span>
                                <input type="radio" id="r1" name="rate" value="15">15
                                <input type="radio" id="r2" name="rate" value="30">30
                                <input type="radio" id="r3" name="rate" value="60">60
                                <input type="radio" id="r4" name="rate" value="90">90
                                <input type="radio" id="r5" name="rate" value="120">120
                                <span class="Minutes">Minutes</span>
                                <button id="startButton" onclick="start()" class="start">Start</button>
                                <button id="stopButton" onclick="stop()" class="stop">Stop</button>
                            </p>

                        </div>
                        <canvas id="canvas" class="center" height="600" width="600"></canvas>

                    </div>
                </div>
            </div>


        </section>
    </div>
</body>

</html>

и мой код JS

//variables
var minutes = 0;
var seconds = 0;
var running = false;
// function alert 
function alert(content, title) {
    var messageDialog = new Windows.UI.Popups.MessageDialog(content, title);
    messageDialog.showAsync();
}
// function activation radio buttons
function diplaytrue() {
    document.getElementById('radioDiv').disabled = false;
}
//function unactivation radio buttons
function diplayfalse() {
    document.getElementById('radioDiv').disabled = true;
}
//function retun value of selected radion button 
function inputtype() {
    seconds = 60;
    var rates = document.getElementsByName('rate');

        for (var i = 0; i < rates.length; i++) {
            while(rates[i].checked==true) {
                minutes = rates[i].value;
                return (minutes, seconds);
            }
        }
        return alert("", "you should choose a period");

    }


    //function to  start alarm

function start() {

    if (inputtype()) {


        showTime();
        running = true;
        document.getElementById("startButton").style.display = "none";
        document.getElementById("stopButton").style.display = "inline";
        //virified if minute is begger than 0
        if (minutes > 0) {
            setTimeout(update, 1000);
            diplayfalse();
        }
        else clearTimeout(update);
    }
}
// function to stop alarm

function stop() {
    diplaytrue();
    clearTimeout(update);
    running = false;

    document.getElementById("startButton").style.display = "inline";
    document.getElementById("startButton").innerText = "Restart";
    document.getElementById("stopButton").style.display = "none";
}
// function update alarm  
function update() {
    if (!running) return;

    seconds--;
    if (seconds === 0) {
        if (minutes > 0) {
            minutes--;
            if (minutes > 0) {
                seconds = 60;
            }
        }

    }
    showTime(minutes);

    if (running) {

        if (minutes > 0 || seconds > 0) {
            setTimeout(update, 1000);
        }
        else {

            showToast();
            diplaytrue();
            running = false;
            document.getElementById("startButton").style.display = "inline";
            document.getElementById("stopButton").style.display = "none";
        }
    }
}
// function show animation of alarm

function showTime() {
    var canvas = document.getElementById("canvas");
    var context = canvas.getContext("2d");
    var x = canvas.width / 2;
    var y = canvas.height / 2;
    var radius = 200;

    var startAngle = 0 * Math.PI;
    var endAngle = ((minutes) / 30) * Math.PI;
    var counterClockwise = false;

    context.save();
    context.clearRect(0, 0, 600, 600);

    context.fillStyle = "#ffffff";
    context.font = "200px Segoe UI";
    context.textAlign = "center";
    context.textBaseline = "middle";
    context.fillText(minutes.toString(), x, y - 15);
    context.textAlign = "center";

    context.font = 'italic 40pt Calibri';
    context.textBaseline = "hanging";
    context.fillText(seconds.toString(), x , y +80);

    context.translate(x, y);
    context.rotate(-Math.PI / 2);
    context.translate(-x, -y);

    if (minutes > 0 || seconds > 0) {
        context.beginPath();
        context.arc(x, y, radius, startAngle, endAngle, counterClockwise);
        context.lineWidth = 50;
        context.strokeStyle = "orange";
        context.stroke();
    }
    else {
        context.beginPath();
        context.arc(x, y, radius, 0 * Math.PI, 2 * Math.PI, counterClockwise);
        context.lineWidth = 50;
        context.strokeStyle = "green";
        context.stroke();
    }

    radius = 150;

    startAngle = 0 * Math.PI;
    endAngle = ((seconds) / 30) * Math.PI;

    if (minutes === 0 && seconds === 0) {
        context.beginPath();
        context.arc(x, y, radius, 0 * Math.PI, 2 * Math.PI, counterClockwise);
        context.lineWidth = 25;
        context.strokeStyle = "green";
        context.stroke();
    }
    else {
        context.beginPath();
        context.arc(x, y, radius, startAngle, endAngle, counterClockwise);
        context.lineWidth = 25;
        context.strokeStyle = "white";
        context.stroke();
    }

    context.restore();
}
// function show Toast Notification after alarm is done
function showToast() {
    var notifications = Windows.UI.Notifications;
    var modele = notifications.ToastTemplateType.toastImageAndText01;
    var sourceXml = notifications.ToastNotificationManager.getTemplateContent(modele);
    var textes = sourceXml.getElementsByTagName("text");
    textes[0].appendChild(sourceXml.createTextNode("It is Break Time."));
    var images = sourceXml.getElementsByTagName("image");
    images[0].setAttribute("src", "ms-appx:///images/logo.scale-100.png");
    var toastXML = sourceXml.selectSingleNode("/toast");
    var audio = sourceXml.createElement("audio");
    audio.setAttribute("src", "ms-winsoundevent:Notification.Looping.Alarm2");
    toastXML.appendChild(audio);
    toastXML.setAttribute("launch", '{"type":"toast","parametre1":"blablabla","parametre2":"erc"}');
    var notification = new notifications.ToastNotification(sourceXml);

    notifications.ToastNotificationManager.createToastNotifier().show(notification);

};
(function () {
    "use strict";

    WinJS.UI.Pages.define("/pages/home/home.html", {
        // This function is called whenever a user navigates to this page. It
        // populates the page elements with the app's data.
        ready: function (element, options) {
            // TODO: Initialize the page here.
        }
    });


})();

0 ответов

Другие вопросы по тегам