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

Flamengo

Bruno Henrique abre mão de férias e acelera tratamento por volta no Fla

Bruno Henrique, de amarelo, recebe tratamento do fisioterapeuta Márcio Puglia ao lado do jovem Daniel Cabral - Reprodução / Instagram
Bruno Henrique, de amarelo, recebe tratamento do fisioterapeuta Márcio Puglia ao lado do jovem Daniel Cabral Imagem: Reprodução / Instagram

Do UOL, no Rio de Janeiro

24/11/2022 04h00

Do elenco do Flamengo, há quem esteja na Copa do Mundo ou desfrutando de dias de descanso. Para Bruno Henrique, no entanto, os dias de férias tem sido de trabalho no Ninho do Urubu. Em recuperação de lesão multiligamentar no joelho direito, o atacante tem ido ao centro de treinamento para acelerar seu tratamento.

A contusão aconteceu no dia 15 de junho, em partida contra o Cuiabá, pelo Campeonato Brasileiro. Por conta da gravidade, o prazo de retorno aos gramados foi dado entre 10 a 12 meses, mas o jogador tem se esforçado para tentar antecipar o retorno, embora essa estimativa siga mantida, no momento, pelo departamento médico rubro-negro.

Quem acompanha Bruno Henrique, porém, garante que o atleta tem evoluído na recuperação. Ele já não usa muletas e acompanhou a delegação em Guayaquil (EQU), no mês ado, quando o Flamengo sagrou-se tricampeão da Libertadores. Na comemoração no trio elétrico no Centro (RJ), há duas semanas, ele também esteve presente.

Na última segunda-feira, o atacante postou uma foto no CT sob os cuidados do fisioterapeuta Márcio Puglia e ao lado do jovem Daniel Cabral, que também se recupera de lesão (foto acima).

Já o zagueiro Rodrigo Caio, outro que ou por cirurgia no joelho, também tem feito tratamento nas férias, mas sem a necessidade de comparecer ao centro de treinamento rubro-negro. O jogador está um pouco à frente de Bruno Henrique no estágio de evolução e terminou a temporada realizando alguns treinamentos com bola, inclusive em Guayaquil, antes da final contra o Athletico-PR.

Quando o elenco se reapresentar para a pré-temporada mês que vem, o departamento médico definirá os próximos os para a dupla.

Games e lives para arejar a cabeça

Bruno Henrique encontrou nos games e nas transmissões ao vivo uma espécie de refúgio durante o período de recuperação no Flamengo. O camisa 27 criou um canal na Twitch e, além de estar próximo de uma antiga paixão, também consegue interagir com os torcedores.

Seus games preferidos são "Counter-Strike" e "Call of Duty", jogando on-line e off-line com os irmãos e alguns amigos já há bastante tempo. Com a Twitch — serviço de streaming de vídeo ao vivo — , ou a acompanhar ainda mais de perto os jogadores destas plataformas e até fez amizade com alguns virtualmente, praticando com eles em horários fora da agenda do elenco rubro-negro.

O jogador até foi procurado para um uso comercial do canal, mas recusou as investidas. Dentre os pontos analisados, é justamente ver a iniciativa como um divertimento, sem obrigações de publicações temporais ou coisas do tipo.

Bruno vê o canal como uma forma de ar o tempo e também de interagir enquanto não pisa novamente no campo. Além disso, aproveita este momento para arejar um pouco a cabeça durante o período de recuperação, que significa também um desgaste físico e mental.

Bruno Henrique, atacante do Flamengo, criou canal na Twitch - Reprodução - Reprodução
Imagem: Reprodução

Flamengo