;(function() { window.createMeasureObserver = (measureName) => { var markPrefix = `_uol-measure-${measureName}-${new Date().getTime()}`; performance.mark(`${markPrefix}-start`); return { end: function() { performance.mark(`${markPrefix}-end`); performance.measure(`uol-measure-${measureName}`, `${markPrefix}-start`, `${markPrefix}-end`); performance.clearMarks(`${markPrefix}-start`); performance.clearMarks(`${markPrefix}-end`); } } }; /** * Gerenciador de eventos */ window.gevent = { stack: [], RUN_ONCE: true, on: function(name, callback, once) { this.stack.push([name, callback, !!once]); }, emit: function(name, args) { for (var i = this.stack.length, item; i--;) { item = this.stack[i]; if (item[0] === name) { item[1](args); if (item[2]) { this.stack.splice(i, 1); } } } } }; var runningSearch = false; var hadAnEvent = true; var elementsToWatch = window.elementsToWatch = new Map(); var innerHeight = window.innerHeight; // timestamp da última rodada do requestAnimationFrame // É usado para limitar a procura por elementos visíveis. var lastAnimationTS = 0; // verifica se elemento está no viewport do usuário var isElementInViewport = function(el) { var rect = el.getBoundingClientRect(); var clientHeight = window.innerHeight || document.documentElement.clientHeight; // renderizando antes, evitando troca de conteúdo visível no chartbeat-related-content if(el.className.includes('related-content-front')) return true; // garante que usa ao mínimo 280px de margem para fazer o lazyload var margin = clientHeight + Math.max(280, clientHeight * 0.2); // se a base do componente está acima da altura da tela do usuário, está oculto if(rect.bottom < 0 && rect.bottom > margin * -1) { return false; } // se o topo do elemento está abaixo da altura da tela do usuário, está oculto if(rect.top > margin) { return false; } // se a posição do topo é negativa, verifica se a altura dele ainda // compensa o que já foi scrollado if(rect.top < 0 && rect.height + rect.top < 0) { return false; } return true; }; var asynxNextFreeTime = () => { return new Promise((resolve) => { if(window.requestIdleCallback) { window.requestIdleCallback(resolve, { timeout: 5000, }); } else { window.requestAnimationFrame(resolve); } }); }; var asyncValidateIfElIsInViewPort = function(promise, el) { return promise.then(() => { if(el) { if(isElementInViewport(el) == true) { const cb = elementsToWatch.get(el); // remove da lista para não ser disparado novamente elementsToWatch.delete(el); cb(); } } }).then(asynxNextFreeTime); }; // inicia o fluxo de procura de elementos procurados var look = function() { if(window.requestIdleCallback) { window.requestIdleCallback(findByVisibleElements, { timeout: 5000, }); } else { window.requestAnimationFrame(findByVisibleElements); } }; var findByVisibleElements = function(ts) { var elapsedSinceLast = ts - lastAnimationTS; // se não teve nenhum evento que possa alterar a página if(hadAnEvent == false) { return look(); } if(elementsToWatch.size == 0) { return look(); } if(runningSearch == true) { return look(); } // procura por elementos visíveis apenas 5x/seg if(elapsedSinceLast < 1000/5) { return look(); } // atualiza o último ts lastAnimationTS = ts; // reseta status de scroll para não entrar novamente aqui hadAnEvent = false; // indica que está rodando a procura por elementos no viewport runningSearch = true; const done = Array.from(elementsToWatch.keys()).reduce(asyncValidateIfElIsInViewPort, Promise.resolve()); // obtém todos os elementos que podem ter view contabilizados //elementsToWatch.forEach(function(cb, el) { // if(isElementInViewport(el) == true) { // // remove da lista para não ser disparado novamente // elementsToWatch.delete(el); // cb(el); // } //}); done.then(function() { runningSearch = false; }); // reinicia o fluxo de procura look(); }; /** * Quando o elemento `el` entrar no viewport (-20%), cb será disparado. */ window.lazyload = function(el, cb) { if(el.nodeType != Node.ELEMENT_NODE) { throw new Error("element parameter should be a Element Node"); } if(typeof cb !== 'function') { throw new Error("callback parameter should be a Function"); } elementsToWatch.set(el, cb); } var setEvent = function() { hadAnEvent = true; }; window.addEventListener('scroll', setEvent, { capture: true, ive: true }); window.addEventListener('click', setEvent, { ive: true }); window.addEventListener('resize', setEvent, { ive: true }); window.addEventListener('load', setEvent, { once: true, ive: true }); window.addEventListener('DOMContentLoaded', setEvent, { once: true, ive: true }); window.gevent.on('allJSLoadedAndCreated', setEvent, window.gevent.RUN_ONCE); // inicia a validação look(); })();
  • AssineUOL
Topo

Esse conteúdo é antigo

Cachorro persegue patos, cai em lago congelado e é resgatado nos EUA

O cachorro Lucky caiu em um lago congelado enquanto perseguia patos em Hewlett, Long Island (EUA) - Reprodução/ NBC New York
O cachorro Lucky caiu em um lago congelado enquanto perseguia patos em Hewlett, Long Island (EUA) Imagem: Reprodução/ NBC New York

Colaboração para o UOL, em São Paulo

09/02/2021 15h17

Lucky, um cachorro de 2 anos, foi resgatado na manhã de domingo (07) depois que caiu em um lago congelado em Hewlett, Long Island, nos Estados Unidos. O cão da raça golden retriever se acidentou quando saiu de casa correndo atrás de patos que nadavam no trecho d'água do lago. Apesar do susto, o cachorro foi salvo e não teve qualquer tipo de ferimento.

Curiosamente, em inglês, o nome do cãozinho Lucky pode significar "sortudo". Como que por coincidência, ele teve grande sorte, pois próximo do lago estava uma equipe voluntária de resgate que realizava treinamentos em uma sede de bombeiros no parque Grant Park.

De acordo com a ABC 7, os patos que o cachorro perseguia estavam no meio do lago, onde a água não estava congelada. O animal "atrapalhado" então acabou caindo na água e lutou para nadar por cerca de 30 minutos, ando a baixa temperatura.

A dona do cão, Kalanit Lebouvich, pediu ajuda aos bombeiros para resgatar Lucky. Os profissionais quebraram uma cerca para ter o ao lago, segundo a NBC New York.

Um dos oficiais finalmente adentrou a área e retirou o mascote da água congelante. Veja o resgate do animal:

O peludo caminhou de volta até a dona, que ficou muito aliviada. "Eles [os bombeiros] fizeram um ótimo trabalho, eu nunca vi algo assim antes. Dos mesmos jeitos que resgatariam um ser humano, eles resgataram meu cachorro. Sou muito grata e considero eles heróis", afirmou Kalanit.

O cachorro Lucky foi levado até um veterinário para uma avaliação e foi liberado no mesmo dia depois do susto. Ele a bem e está em casa, saudável, seguro e com a mesma personalidade brincalhona que tinha antes do susto.