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

Esse conteúdo é antigo

Rio: casal de idosos é morto a facadas em condomínio no Jardim Botânico

Geraldo Coelho e Osélia Coelho junto com o filho - Reprodução
Geraldo Coelho e Osélia Coelho junto com o filho Imagem: Reprodução

Do UOL, em São Paulo

25/06/2022 15h42Atualizada em 25/06/2022 18h50

Um casal de idosos foi encontrado morto na madrugada deste sábado (25), em um apartamento no Jardim Botânico, na Zona Sul do Rio. Os corpos de Geraldo Pereira Coelho, 73 anos, e Osélia da Silva Coelho, 72, estavam no sofá-cama.

O suspeito do crime é o oficial da Marinha Cristiano da Silva Lacerda, 40 anos. Ele foi preso após ser encontrado dentro da cama-baú do quarto do ex-namorado e filho das vítimas, o professor de inglês Felipe da Silva Coelho. O suspeito estava ferido e inconsciente.

Em nota, a Secretaria de Segurança Pública do Rio de Janeiro informou que, de acordo com a Delegacia de Homicídios da Capital, o autor foi detido por policiais militares e autuado em flagrante pela morte do casal.

O oficial da Marinha está internado no Hospital Municipal Miguel Couto, na Gávea, e segue com escolta policial.

Horas após o assassinato, o filho das vítimas postou uma homenagem nas redes sociais: "Pra sempre juntos, nos braços do Pai. Meus amores eternos".

Fim do relacionamento

Em entrevista a O Globo, Felipe disse que conheceu Cristiano há cerca de dois anos. O professor de inglês morava em Fortaleza e se mudou para o Rio por causa do relacionamento.

Em abril deste ano, os dois brigaram, e Cristiano teria agredido o companheiro, segundo Felipe contou a O Globo. Ele resolveu acabar com o relacionamento e afirma que continuou morando com Cristiano até encontrar um apartamento.

​  O oficial da Marinha Cristiano da Silva Lacerda - Reprodução  - Reprodução - Reprodução
O oficial da Marinha Cristiano da Silva Lacerda
Imagem: Reprodução

No dia 17, Geraldo e Osélia vieram para o Rio para visitar o filho e ficaram hospedados no apartamento no Jardim Botânico. Voltariam para Fortaleza no início da próxima semana.

Na noite de sexta-feira, o professor de inglês saiu sozinho, enquanto os pais dele e Cristiano ficaram em casa.

De acordo com Felipe, o oficial da Marinha mandou uma mensagem dizendo que a mãe do professor de inglês estava ando mal. Ele voltou imediatamente. Quando chegou, encontrou os pais mortos. Gritou e pediu ajuda para os vizinhos. Bombeiros e policiais militares foram para o local.