;(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

Animal marinho com aspecto de 'monstro' é visto no litoral de São Paulo

Fotógrafa registrou momento em que animal com aspecto de "mostro" apareceu em praia de São Paulo - Arquivo Pessoal / Monica Novaes
Fotógrafa registrou momento em que animal com aspecto de 'mostro' apareceu em praia de São Paulo Imagem: Arquivo Pessoal / Monica Novaes

Do UOL, em São Paulo

05/03/2022 15h15Atualizada em 08/03/2022 11h39

Um animal marinho de quase dois metros, com aparência de uma cobra, foi encontrado morto na faixa de areia da Praia da Trincheira, no extremo sul de Ilha Comprida, em São Paulo. A imagem foi compartilhada por uma fotógrafa nas redes sociais e intrigou seguidores, com suposições sobre qual seria a espécie.

Ao UOL, Monica Novaes, de 47 anos, disse que fotografou o animal na terça de Carnaval, por volta das 7h. Na ocasião, ela estava acompanhada de uma cliente, gestante, para um ensaio a beira do mar.

"Eu estava em cima de umas pedras fotografando, foi quando olhei para baixo e vi esse bicho morto perto das rochas. Me chamou muita atenção por ser um bicho muito diferente de qualquer outro que eu já vi, mesmo tendo visto muitas moreias por aqui, que é um bicho marinho fácil de ser visto", explicou.

Segundo ela, o animal já estava morto no momento em que o encontrou. Na imagem é possível ver marcas no dorso do animal. "Não sei se foi ataque de outro peixe, ou se foi rede que o machucou", diz a fotógrafa.

No dia anterior, a mulher diz que a localidade recebeu fortes pancadas de chuva, o que a faz acreditar ter favorecido que as correntes marítimas arrastassem o animal para a praia.

Mas, afinal, se trata de um 'monstro'?

Em detalhes, um post de Monica, feito no Instagram com a colaboração de biólogos desvendou o mistério sobre qual seria a espécie do animal com características de 'monstro' marinho.

"A foto desse bicho esquisitão aí causou curiosidade por aqui e, na dúvida, perguntei aos biólogos de plantão se se tratava de uma MOREIA ou uma ENGUIA. Vários biólogos seguidores contribuíram, obrigada!. A principal característica que difere as duas espécies é a de que a Moreia não possui barbatana, diferente das enguias", explica o post.

O biólogo e ambientalista David Victor confirmou ao UOL que a foto retrata uma moreia, animal que integra a família de peixes ósseos. Uma das principais características desses animais é o corpo longo e cilíndrico, similar ao de uma serpente.

"As enguias têm barbatanas laterais, e na foto não é possível ver barbatanas. Por essa característica, eu classifico [esse animal] como moreia" Aqui na nossa região não existem corais próximos, então foi bem inusitado, porque não é comum. Na verdade, é totalmente incomum a aparição dessa espécie, principalmente no litoral sul do estado de São Paulo".

De acordo com Victor, as moreias vivem em todo o oceano, mais comumente em alguns corais e que a espécie não é agressiva.