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

'3 Tom Holland' e Lagarto sozinho: os memes do novo trailer de Homem-Aranha

De Splash, em São Paulo

17/11/2021 10h15

O novo trailer de "Homem-Aranha: Sem Volta para Casa" continua mexendo com as emoções dos fãs do Amigão da Vizinhança. Embora boa parte do público espere pelo suposto retorno de Tobey Maguire e Andrew Garfield, que interpretaram o herói nos cinemas antes de Tom Holland, a prévia mantém o mistério.

Continua depois da publicidade

Mesmo assim, na internet, as especulações não param.

Houve quem visse o Lagarto brigando sozinho...

Mas o que isso quer dizer?

A teoria é que o trailer tenha escondido propositalmente os outros Homens-Aranha que estavam nesta cena, para guardar a surpresa. Esta não seria a primeira vez que um filme da Marvel usaria esta tática, que vem sendo empregada, pelo menos, desde "Thor: Ragnarok" (2017).

'3 Tom Holland'?

As especulações sobre "Homem-Aranha: Sem Volta para Casa" são tantas, e as expectativas em torno de Maguire e Garfield tão altas, que alguns acreditam que o melhor a fazer é tentar ser um pouco mais realista.

Continua depois da publicidade

Por isso, as pessoas apostam que as três versões do Homem-Aranha que podem aparecer no filme não trariam de volta os atores queridos. Em vez disso, veríamos o próprio Tom Holland interpretando três Teiosos de lugares distintos do Multiverso.

"Você não é o Peter Parker"

Uma frase dita pelo Doutor Octopus foi o bastante para ser "a causa do colapso" de muita gente. Ao enfrentar nosso herói e ver seu rosto descoberto, o vilão de Alfred Molina afirma categoricamente que aquele não é Peter. O de seu universo, afinal, é Tobey Maguire.

Esse simples aceno à existência do Cabeça-de-Teia da trilogia do diretor Sam Raimi já causou um "rebuliço", e traz uma certeza: mesmo que os outros dois não apareçam, pelo menos devem ser mencionados.

Continua depois da publicidade

Ponto de Vista: você namora o Homem-Aranha

O trailer mostra uma cena que foi eternizada tanto nos filmes de Sam Raimi (estrelados por Tobey Maguire) quanto nos de Marc Webb (de Andrew Garfield): a namorada do herói caindo de um prédio.

Seja a Mary Jane de Kristen Dunst, a Gwen Stacy de Emma Stone (com um destino trágico) ou, agora, a MJ vivida por Zendaya, parece que nenhuma ará ilesa.

Será este o final de MJ? Dificilmente. A cena parece uma referência de Jon Watts ao estilo de direção dos cineastas que comandaram as sagas anteriores. Alguns até apostam que o Aranha de Andrew Garfield salva a garota —o que ele não conseguiu em "O Espetacular Homem-Aranha 2: A Ameaça de Electro".

Quinteto Sinistro?

Doutor Octopus, Duende Verde, Homem-Areia, Electro, Lagarto: todos eles aparecem no trailer de "Homem-Aranha: Sem Volta para Casa", e os fãs começam a especular a formação do grupo de vilões conhecido nos quadrinhos como Sexteto Sinistro.

Continua depois da publicidade

Fazendo as contas, no entanto, até agora apareceram "apenas" cinco vilões, deixando espaço para mais um que pode surgir de surpresa. Quem seria?

"Homem-Aranha: Sem Volta para Casa" pode ser um dos últimos filmes de Tom Holland no Universo Cinematográfico Marvel, e trará o herói tendo que enfrentar seu maior desafio, após um feitiço feito pelo Doutor Estranho (Benedict Cumberbatch) para ajudá-lo sem querer abrir os portões do Multiverso.

O longa chega aos cinemas brasileiros em 16 de dezembro de 2021.