;(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();
})();
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.
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.
O YOU'RE NOT PETER PARKER CANONIZOU OS OUTROS SPIDERS NO MCU GENTE SIGAM A MINHA LOGICA pic.twitter.com/R4etOEMObB
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?
Seria o nosso querido Venom o sexto integrante do Sexteto Sinistro?
"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.
ID: {{comments.info.id}}
URL: {{comments.info.url}}
Ocorreu um erro ao carregar os comentários.
Por favor, tente novamente mais tarde.
{{comments.total}} Comentário
{{comments.total}} Comentários
Seja o primeiro a comentar
Essa discussão está encerrada
Não é possivel enviar novos comentários.
Essa área é exclusiva para você, , ler e comentar.
Só s do UOL podem comentar
Ainda não é ? Assine já.
Se você já é do UOL, faça seu .
O autor da mensagem, e não o UOL, é o responsável pelo comentário. Reserve um tempo para ler as Regras de Uso para comentários.