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

Gabriel Vaquer

REPORTAGEM

Texto que relata acontecimentos, baseado em fatos e dados observados ou verificados diretamente pelo jornalista ou obtidos pelo o a fontes jornalísticas reconhecidas e confiáveis.

SBT mantém Libertadores às terças contra BBB21 e define alvos para estreia

Téo José continua como principal nome da Libertadores no SBT em 2021 - Gabriel Cardoso/SBT
Téo José continua como principal nome da Libertadores no SBT em 2021 Imagem: Gabriel Cardoso/SBT

28/02/2021 04h00

O SBT já definiu o esquema de transmissão para a Libertadores da América, que volta a ser atração no dia 9 de março. A emissora de Silvio Santos manterá os jogos nas noites de terça, às 21h30 (horário de Brasília). Com isso, até maio, as partidas irão disputar com o paredão do "Big Brother Brasil 21". O motivo da manutenção é a cultura esportiva que o canal quer criar no telespectador.

A coluna apurou que o primeiro jogo que será exibido na segunda fase preliminar da Libertadores será entre Ayacucho, do Peru, contra Fluminense ou Grêmio. Tudo ainda vai depender da final da Copa do Brasil —que começa hoje, em Porto Alegre. Se o tricolor gaúcho vencer o Palmeiras, o Flu enfrenta os peruanos. Se o Palmeiras ganhar, o Flu vai direto para a fase de grupos e o Grêmio viaja até o interior do país vizinho.

Uma troca de horário para as noites de quarta-feira foi discutida, dia em que o programa da Globo não é tão forte. Mas o SBT decidiu priorizar a cultura de Esporte que se deseja criar. Para isso, diretores entendem que mover novamente os horários do futebol prejudicaria a fidelização do público que gosta de futebol.

Um exemplo do trabalho que o SBT quer fazer em relação ao horário foi a compra do Campeonato Paranaense pela Rede Massa, sua afiliada no Paraná que pertence ao apresentador Ratinho. O horário escolhido para os jogos foi terças a partir das 21h30. As transmissões no estado não vão coincidir com os jogos da Libertadores, o que faz o público se acostumar com o programa esportivo.

A equipe de transmissão da Libertadores deve ser a mesma da temporada 2020. Estão confirmados Téo José e Luiz Alano na narração, Mauro Beting nos comentários e André Galvão e Fernanda Arantes na reportagem. O ex-jogador e técnico Jorginho ainda negocia sua continuidade, mas o departamento de Esportes do SBT quer que ele continue.

O SBT tem os direitos da Libertadores até a temporada 2022. O Fox Sports exibe jogos na TV por e existe o pay-per-view Conmebol TV, que também mostra algumas partidas da competição juntamente com a Copa Sul-Americana.