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

Após massacre em escola, Netflix dos EUA inclui aviso em 'Stranger Things'

Aviso de violência explícita contra crianças aparece antes do primeiro episódio da 4ª temporada nos Estados Unidos - Reprodução/ Netflix
Aviso de violência explícita contra crianças aparece antes do primeiro episódio da 4ª temporada nos Estados Unidos Imagem: Reprodução/ Netflix

De Splash, em São Paulo

27/05/2022 10h34

Quem for assistir à quarta temporada de "Stranger Things" hoje nos Estados Unidos vai receber um aviso de conteúdo antes da exibição do primeiro episódio.

Após o massacre que deixou 19 crianças e 2 adultos mortos numa escola no Texas, a plataforma de streaming decidiu alertar os espectadores do país sobre o conteúdo sensível na primeira cena.

"Filmamos essa temporada de 'Stranger Things' há um ano. Diante do trágico massacre numa escola no Texas, espectadores podem considerar a primeira cena do episódio 1 perturbadora. Estamos profundamente tristes por essa violência inominável, e nossos pêsames vão para cada família em luto por um ente querido", diz o aviso exibido na tela.

Os avisos de conteúdo da série agora também incluem "imagens perturbadoras", e a sinopse do primeiro episódio foi editada para incluir o seguinte: "Aviso: contém violência explícita envolvendo crianças".

A cena de abertura do primeiro episódio da quarta temporada já havia sido divulgada pela Netflix. Trata-se de um flashback do ano de 1979, quatro anos antes dos primeiros acontecimentos da história, em que o cientista Martin Brenner (Matthew Modine) faz experiências com cobaias humanas em idade infantil no Laboratório Nacional de Hawkins.

Tudo vai 'bem', até que uma das cobaias, conhecida por Ten (Dez), nota uma movimentação violenta no laboratório. A partir daí (alerta de spoiler), o Dr. Brenner é surpreendido por uma vastidão de corpos, adultos e infantis, espalhados por todo o edifício, em meio a um verdadeiro banho de sangue.

Ao buscar pelo autor de tamanho estrago, ele se depara com ninguém menos que Eleven (Millie Bobby Brown), com o rosto ensanguentado após um violento ataque de ira telecinética. "O que você fez?", questiona o cientista, estarrecido.

Stranger Things: Confira o antes e depois do elenco