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

OPINIÃO

RMP: Fla jogou mal, mas ficou anos-luz longe do mico que foi a transmissão

Do UOL, em São Paulo

30/01/2022 04h00

O torcedor do Flamengo que tentou acompanhar a partida deste sábado (29) contra o Volta Redonda teve motivos para se irritar - e não foi pelo fraco desempenho do time no empate sem gols. As seguidas falhas apresentadas na transmissão, como quedas de sinal e imagem travada, fizeram o público perder vários minutos da partida.

Na Live do Flamengo, programa do UOL Esporte logo após as partidas do Mengão, os jornalistas Renato Maurício Prado e André Rocha também demonstraram sua irritação com as falhas técnicas da transmissão do jogo do Flamengo. Ambos cobraram providências para a melhoria do serviço; O jogo entre Vasco e Boavista também apresentou problemas semelhantes.

  • De segunda a sexta, às 17h, o Canal UOL traz, ao vivo, as últimas informações do mercado da bola. Inscreva-se no YouTube de UOL Esporte e confira também as lives dos clubes, Posse de Bola e UOL News Esporte:

Renato fez um relato pessoal das dificuldades que teve para acompanhar a partida. "Você conseguiu ver o jogo? Eu vi muito pouco. E tenho dois pay-per-view comprados. O Carioca Play, que você a pela Eleven, é nada menos do que o MyCujoo, de tantas lambanças no ano ado. Na hora da escalação, travou e nunca mais voltou. Também tenho o da Sky, mas por uma infelicidade da minha região, ela saiu do ar porque choveu muito forte aqui", contou.

Antes da queda de sinal, outros problemas ocorreram durante a transmissão do jogo do Flamengo. Na escalação do Volta Redonda, a geradora de imagens colocou dois capitães. Para piorar, trocou o escudo do Voltaço pelo do Bangu. A Ferj (Federação de Futebol do Estado do Rio de Janeiro) publicou uma nota se desculpando pelas falhas relatadas e afirmou que cobrará explicações da Sportsview, responsável pela geração das imagens.

A saga de Renato estava longe de terminar, assim como as dores de cabeça. "Acabei comprando o jogo avulso no aplicativo OneFootball. Quando faltavam 15, 20 minutos para acabar, caiu tudo. Na FlaTV+, a transmissão foi um desastre. Aí eu fico me perguntando: como pode o Flamengo romper com a Globo, supostamente para ganhar mais, e entregar a comercialização e a produção dos seus jogos para uma empresa como a Sportsview? Ela conseguiu o fenômeno de derrubar a imagem até das operadoras", indignou-se.

O termômetro da revolta do público foi a repercussão do caso nas redes sociais. O termo "Volta Globo" foi um dos mais comentados do Twitter na noite deste sábado.

Renato demonstrou pessimismo quanto às chances de melhoria das transmissões do Carioca. "É uma vergonha. Apesar de o Flamengo, pelo pouco que eu vi, não ter jogado bem, ficou anos luz do mico, da vergonha, do escândalo, que foi essa transmissão de Volta Redonda x Flamengo. E se preparem, porque o Carioca será assim. Agradeçam ao Landim [presidente do Flamengo]. Batam palmas quando ele briga com a Globo, que pelo menos tem um padrão de qualidade. Coisa que as transmissoras atuais não têm", completou.

Não perca! A próxima edição da Live do Flamengo será na quarta-feira (2), logo após a partida contra o Boavista pelo Carioca. Você pode acompanhar o programa pelo Canal UOL, no app Placar UOL, na página do Flamengo no UOL Esporte e no canal do UOL Esporte no Youtube.

** Este texto não reflete, necessariamente, a opinião do UOL