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

Após interior de SP, tempestade de areia atinge cidade de Mato Grosso

Nuvem de poeira encobre cidade de Primavera do Leste, em Mato Grosso - Reprodução/ Facebook
Nuvem de poeira encobre cidade de Primavera do Leste, em Mato Grosso Imagem: Reprodução/ Facebook

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

15/10/2021 13h00Atualizada em 15/10/2021 13h00

Uma tempestade de areia atingiu a cidade de Primavera do Leste, cidade a 239 km de Cuiabá (MT). O fenômeno deixou o céu escuro e só foi dissipado após uma forte chuva que atingiu a cidade logo em seguida, de forma semelhante ao que aconteceu em 12 municípios do interior de São Paulo.

Segundo os moradores da cidade, a tempestade de poeira começou a se formar por volta das 14h de ontem e durou cerca de 30 minutos. Em seguida, uma intensa chuva atingiu a cidade se estendendo até a noite o que ajudou a dissipar as partículas de poeira. Ainda assim, céu continuou com um tom amarronzado.

Em um vídeo feito por um morador e compartilhado nas redes sociais e aplicativos de mensagens é possível ver a força do vento e a nuvem de areia encobrindo a cidade.

Apesar de assustar os moradores, segundo a prefeitura de Primavera do Leste, o fenômeno não causou transtornos à população e nenhuma ocorrência foi registrada devido a ele.

Hoje, o Instituto Nacional de Meteorologia (Inmet) emitiu um alerta de perigo de chuvas intensas e ventos de até 60 km/h na região.

Tempestades de areia têm se tornado comum no Brasil

Tempestades de areia como a que atingiu Primavera do Leste (MT), já foram registradas neste mês em várias cidades no interior de São Paulo.

Também na tarde de ontem, moradores de Ribeirão Preto, Barretos, Batatais, Pirassununga, São Joaquim da Barra, Pitangueiras, Sertãozinho, Serrana, Brodowski, Jardinópolis e Colômbia registraram as grandes nuvens de poeira encobrindo as cidades.

Segundo o Climatempo a frequência do fenômeno deve aumentar nos próximos anos. Isso porque as tempestades de areia estão sendo estimuladas pelos períodos de estiagem cada vez mais intensos.

O fenômeno é provocado pelo tempo seco aliado a falta de chuvas, que faz com que detritos do solo sejam levados pelo vento formando imensas nuvens.

O site de meteorologia atribui a força das tempestades deste ano a uma sequência ruim de períodos chuvosos, com anos seguidos de precipitação abaixo da média, que deixaram o solo muito seco.