;(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 perder 75 quilos, filho de Solange Almeida lança primeiro EP

Rafa Almeida pesava 151 kg antes fazer a cirurgia bariátrica - Reprodução/Instagram
Rafa Almeida pesava 151 kg antes fazer a cirurgia bariátrica Imagem: Reprodução/Instagram

Colaboração para Splash, em São Paulo

12/05/2022 22h19

Após se submeter a uma cirurgia bariátrica, o filho da cantora Solange Almeida, Rafa Almeida, perdeu cerca de 75 quilos e decidiu investir na carreira musical. Com foco na carreira de cantor há um ano, o jovem lançará amanhã o seu primeiro EP com músicas de sertanejo pop.

"Resolvi mudar. Não tinha ânimo, não tinha autoestima, não tinha roupa que eu gostava que desse em mim. Entrei numa depressão louca, galera, só sabia descontar na comida. Fiz a cirurgia bariátrica pensando muito na minha saúde física e mental", disse ele para o site Gshow. Há quase três anos, ele decidiu fazer a operação após chegar a pesar quase 151 kg.

Em um post publicado no ano ado no Instagram, ele disse que tinha 19 anos e não conseguia viver como um garoto da sua idade. "Eu me escondia para não aparecer em foto, dava desculpas para sair, para viajar com meus amigos, eu estava só existindo", desabafou.

Com o lançamento do EP amanhã, três faixas inéditas serão divulgadas nas plataformas de música. As músicas fazem parte do primeiro DVD de Rafa, chamado de "Impacto". O EP conta com composição em conjunto com Lucas Amad na música "Fuzuê", além das autorais "Fala de Amor" e "Minutinho de Fraqueza", a última em parceria com Matheus Fernandes.

Além dessas, há ainda seis faixas para serem divulgadas, como a regravação de "Sotaque", que já havia sido lançada durante a pandemia do coronavírus. A música foi feita em homenagem às mulheres nordestinas e, em especial, para Juliette, vencedora do "Big Brother Brasil 21". Junto com "Sotaque", o cantor também lançou outro single no período de isolamento social.