abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 15:22 | IT novinky

    Eric Lengyel dobrovolně uvolnil jako volné dílo svůj patentovaný algoritmus Slug. Algoritmus vykresluje text a vektorovou grafiku na GPU přímo z dat Bézierových křivek, aniž by využíval texturové mapy obsahující jakékoli předem vypočítané nebo uložené obrázky a počítá přesné pokrytí pro ostré a škálovatelné zobrazení písma, referenční ukázka implementace v HLSL shaderech je na GitHubu. Slug je volným dílem od 17. března letošního

    … více »
    NUKE GAZA! 🎆 | Komentářů: 0
    včera 15:11 | Zajímavý projekt

    Sashiko (GitHub) je open source automatizovaný systém pro revizi kódu linuxového jádra. Monitoruje veřejné mailing listy a hodnotí navrhované změny pomocí umělé inteligence. Výpočetní zdroje a LLM tokeny poskytuje Google.

    Ladislav Hagara | Komentářů: 3
    včera 04:44 | Zajímavý software

    Cambalache, tj. RAD (rapid application development) nástroj pro GTK 4 a GTK 3, dospěl po pěti letech vývoje do verze 1.0. Instalovat jej lze i z Flathubu.

    Ladislav Hagara | Komentářů: 0
    20.3. 14:55 | Nová verze

    KiCad (Wikipedie), sada svobodných softwarových nástrojů pro počítačový návrh elektronických zařízení (EDA), byl vydán v nové major verzi 10.0.0 (𝕏). Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    20.3. 13:22 | IT novinky

    Letošní Turingovou cenu (2025 ACM A.M. Turing Award, Nobelova cena informatiky) získali Charles H. Bennett a Gilles Brassard za základní přínosy do oboru kvantové informatiky, které převrátily pojetí bezpečné neprolomitelné komunikace a výpočetní techniky. Jejich protokol BB84 z roku 1984 umožnil fyzikálně zaručený bezpečný přenos šifrovacích klíčů, zatímco jejich práce o kvantové teleportaci položila teoretické základy pro budoucí kvantový internet. Jejich práce spojila fyziku s informatikou a ovlivnila celou generaci vědců.

    Ladislav Hagara | Komentářů: 7
    20.3. 04:44 | Zajímavý článek

    Firefox 149 dostupný od 24. března přinese bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně (s CZ a SK se zatím nepočítá) a zobrazení dvou webových stránek vedle sebe v jednom panelu (split view). Firefox Labs 149 umožní přidat poznámky k panelům (tab notes, videoukázka).

    Ladislav Hagara | Komentářů: 2
    20.3. 00:33 | Nová verze

    Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    20.3. 00:11 | Zajímavý software

    Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.

    Ladislav Hagara | Komentářů: 7
    19.3. 19:22 | Nová verze

    GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.

    Ladislav Hagara | Komentářů: 0
    19.3. 04:00 | Bezpečnostní upozornění

    Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1125 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník

    Dotaz: Přerušení kódu ve funkci setTimeout z jiné funkce - Javascript

    7.8.2015 08:58 Saša
    Přerušení kódu ve funkci setTimeout z jiné funkce - Javascript
    Přečteno: 302×
    Ahoj, mám problém s kódem v javascriptu, respektive s řešením problému

    1. v HTML souboru mám prvky button reagující na onlick="start()", cancas s funkcí reagující na onclick="stop" 2. po spuštění funkce start se volá funkce nahravej, ve které se nahrává obrázek do canvasu a v jeho funkci img.onLoad se spouští funkce setTimeout. Po ukončení funkce setTimeout se vyvolá dialog 3. Při kliknutí na canvas se zavolá funkce stop, která skryje nějaká pole na stránce a odstraní obrázek z canvasu

    Problém Kliknu na canvas, zobrazí se dialog o ukončení, potvrdím ho, provede se změna na html stránce (skytí polí, odstranění img z canvasu) ale vyběhne dialog po doběhnutí funkce setTimeout. Jak upravit kód, aby vyvolání funkce zastavilo i provádení kódu ve funkci setTimeout, respektive zobrazení dialogu?

    Díky za případnou radu

    var start = function () {
        isRuns = true;
        $('#pageMainImgDiv').hide(); 
        nahravej();
        
    };
    
    var stop = function () {
        // vynechan dialog ohledne ukonceni a dalsi akce ohledne manipulace s prvky na html strance
        isRuns = false;
        $('#pageMainImgDiv').show();
    };
    
    
    var nahravej = function () {
        var timing = 5000;
        var newSrc = "mujImage.png";
    
            var img = new Image();
            img.src = 'images/' + newSrc;
            img.onload = function () {
                var canvas = document.getElementById('mainCanvas');
                var context = canvas.getContext('2d');
                context.canvas.width = window.innerWidth;
                context.canvas.height = window.innerHeight;
                var x = (canvas.width - img.width ) * 0.5;
                var y = (canvas.height - img.height) * 0.5;
                img.width = img.width * 0.50;
                img.height = img.height * 0.50;
                context.drawImage(img, x, y);
    
                if (isRuns) {
                    setTimeout(function () {
                        console.log('Probiha timer');
                        context.clearRect(0, 0, canvas.width, canvas.height);
    
                        
    
                            var res = prompt("Vlož čas", "5");
                            if (isNaN(res)) {
    
                                alert('Chyba není číslo!');
    
                            } else {
    
                                console.log('Vlozeno ' + res);
                                nahravej();
                            }
                    }, timing);
                }else {
                    context.clearRect(0, 0, canvas.width, canvas.height);
                }
            };
        }
    
    
    };
    

    Řešení dotazu:


    Odpovědi

    AraxoN avatar 7.8.2015 10:52 AraxoN | skóre: 47 | blog: slon_v_porcelane | Košice
    Rozbalit Rozbalit vše Re: Přerušení kódu ve funkci setTimeout z jiné funkce - Javascript
    Volanie setTimeout() vráti ID časovača:
    var id=window.setTimeout(...);
    S tým id sa to potom dá zrušiť volaním clearTimeout():
    window.clearTimeout(id);
    7.8.2015 11:05 Saša
    Rozbalit Rozbalit vše Re: Přerušení kódu ve funkci setTimeout z jiné funkce - Javascript
    Ahoj, díky, ale to jsem zkoušel, že jsem ve funkci stop volal id setTimeru (ten jsem nastavil ve funkci pro nahravej jako globalni proměnou), bohužel dialog i přesto vyběhl.
    Tarmaq avatar 7.8.2015 16:23 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: Přerušení kódu ve funkci setTimeout z jiné funkce - Javascript
    a mohl bys to ukazat? Idealne bez tech nezajimavejch casti kolem.. Mozna by nebylo od veci udelat nejakej jsfiddle na to
    Don't panic!

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.