abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:00 | IT novinky

    DuckDuckGo AI Chat umožňuje "pokecat si" s GPT-3.5 Turbo od OpenAI nebo Claude 1.2 Instant od Anthropic. Bez vytváření účtu. Všechny chaty jsou soukromé. DuckDuckGo je neukládá ani nepoužívá k trénování modelů umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    dnes 14:22 | IT novinky

    VASA-1, výzkumný projekt Microsoftu. Na vstupu stačí jediná fotka a zvukový záznam. Na výstupu je dokonalá mluvící nebo zpívající hlava. Prý si technologii nechá jenom pro sebe. Žádné demo, API nebo placená služba. Zatím.

    Ladislav Hagara | Komentářů: 2
    dnes 04:44 | Nová verze

    Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 140 (pdf) a HackSpace 77 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 01:00 | Nová verze

    ESPHome, tj. open source systém umožňující nastavovat zařízení s čipy ESP (i dalšími) pomocí konfiguračních souborů a připojit je do domácí automatizace, například do Home Assistantu, byl vydán ve verzi 2024.4.0.

    Ladislav Hagara | Komentářů: 0
    včera 22:11 | IT novinky Ladislav Hagara | Komentářů: 0
    včera 20:55 | Nová verze

    Neziskové průmyslové konsorcium Khronos Group vydalo verzi 1.1 specifikace OpenXR (Wikipedie), tj. standardu specifikujícího přístup k platformám a zařízením pro XR, tj. platformám a zařízením pro AR (rozšířenou realitu) a VR (virtuální realitu). Do základu se z rozšíření dostalo XR_EXT_local_floor. Společnost Collabora implementuje novou verzi specifikace do platformy Monado, tj. open source implementace OpenXR.

    Ladislav Hagara | Komentářů: 2
    včera 17:22 | Nová verze

    Byla vydána nová verze 0.38.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 4.4 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 13
    včera 17:11 | Nová verze

    ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzích 1.3.1, 1.2.3 a 1.0.6. Ve verzi 1.3.1 je mimo jiné řešena bezpečnostní chyba CVE-2024-20380.

    Ladislav Hagara | Komentářů: 2
    včera 12:11 | IT novinky

    Digitální a informační agentura (DIA) oznámila (PDF, X a Facebook), že mobilní aplikace Portál občana je ode dneška oficiálně venku.

    Ladislav Hagara | Komentářů: 10
    včera 05:11 | Komunita

    #HACKUJBRNO 2024, byly zveřejněny výsledky a výstupy hackathonu města Brna nad otevřenými městskými daty, který se konal 13. a 14. dubna 2024.

    Ladislav Hagara | Komentářů: 2
    KDE Plasma 6
     (68%)
     (10%)
     (2%)
     (20%)
    Celkem 564 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    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: 250×
    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.