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

Solar Orbiter registra em vídeo imagens inéditas do planeta Vênus

O telescópio Solar Orbiter Heliospheric Imager, ou SoloHI, capturou uma visão inesperada e brilhante do planeta - Reprodução/NASA
O telescópio Solar Orbiter Heliospheric Imager, ou SoloHI, capturou uma visão inesperada e brilhante do planeta Imagem: Reprodução/NASA

Colaboração para o Tilt, em Santos

13/08/2021 15h54Atualizada em 13/08/2021 15h54

A sonda Solar Orbiter, da Agência Especial Europeia (ESA) e Agência Espacial Americana (Nasa), conseguiu obter imagens inéditas ao chegar a menos de 8 mil km da superfície do planeta Vênus.

Nos dias que antecederam a aproximação, o telescópio Solar Orbiter Heliospheric Imager, ou SoloHI, a bordo da sonda, capturou uma visão inesperada e brilhante do planeta.

As imagens mostram Vênus a esquerda do vídeo, cada vez mais de perto, enquanto o Sol está fora do quadro, no canto superior direito. O lado do planeta que está oposto ao Sol aparece como um semicírculo escuro cercado por um crescente de luz - o brilho do lado "incrivelmente brilhante" de Vênus, iluminado pelo astro, segundo a Nasa.

"Idealmente, teríamos sido capazes de observar algumas características no lado noturno do planeta, mas havia sinais demais do lado diurno", explicou Phillip Hess, astrofísico do Laboratório de Pesquisa Naval em Washington, EUA.

"Apenas uma fatia do lado diurno aparece nas imagens, mas reflete luz solar suficiente para causar o crescente brilhante e os raios difratados que parecem vir da superfície", completou.

Além de Vênus, duas estrelas brilhantes também são visíveis ao fundo, no início da sequência, antes de serem eclipsadas pelo planeta. A mais à direita é Omicron Tauri. Acima, à esquerda dela, está Xi Tauri, que é na verdade um sistema estelar quádruplo. Ambas fazem parte da constelação de Touro.

Este foi o segundo sobrevoo da Solar Orbiter sobre Vênus. Outros seis sobrevoos estão programados para ocorrer de 2022 a 2030.

A sonda usa a gravidade de Vênus para atraí-lo para mais perto do Sol e inclinar sua órbita, girando-a para cima e para fora, para conseguir avistar o astro ao "olhar para baixo". A partir desse ponto de vista, a Solar Orbiter irá eventualmente capturar as primeiras imagens dos polos norte e sul do Sol.