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

Cláudio Castro chama mortos da chacina do Jacarezinho de 'vagabundos'

Governador do Rio de Janeiro, Cláudio Castro (PL) -  WALLACE SILVA/FOTOARENA/FOTOARENA/ESTADÃO CONTEÚDO
Governador do Rio de Janeiro, Cláudio Castro (PL) Imagem: WALLACE SILVA/FOTOARENA/FOTOARENA/ESTADÃO CONTEÚDO

Colaboração para o UOL

30/05/2022 19h04Atualizada em 30/05/2022 19h04

O governador do estado do Rio de Janeiro, Cláudio Castro (PL), chamou as vítimas da chacina no Jacarezinho, em maio de 2021, de "vagabundos", durante pronunciamento para a imprensa hoje (30).

"Cada policial que eu perco, eu perco duas vezes. Por isso que aquele memorial lá, nós tombamos ele. O nome do André [o policial] não merece estar no meio de 27 vagabundos. O único herói que merecia um memorial é o André com seu filho, da idade do meu, que chora até hoje", disse Castro.

O policial civil mencionado por Castro era André Leonardo de Mello Frias, morto durante a operação. Na época, a polícia informou que a homenagem foi negada pela mulher de Frias, por isso seu nome foi retirado.

Durante o pronunciamento, Castro ainda falou sobre a utilização de câmeras nas fardas dos policiais no Rio de Janeiro, que começou a funcionar também hoje (30).

"Nós acreditamos que essa junção entre o policial que está na rua e o centro de monitoramento vai ser a fórmula que essa tecnologia vai dar um grande resultado. Todo aprendizado é aprendizado. Teve-se o aprendizado com as câmeras nas viaturas. Algumas coisas funcionaram e outras não, e essa curva de aprendizado veio para que a gente não erre outra vez", disse.

As imagens obtidas pelas câmeras vão ser preservadas durante um ano.

Entenda o que aconteceu no Jacarezinho

No dia 6 de maio de 2021, a Polícia Civil realizou uma operação contra o tráfico de drogas na comunidade do Jacarezinho, zona norte do Rio de Janeiro. Foi a ação mais letal da história da cidade, com 28 mortos, incluindo o policial citado pelo governador do Rio de Janeiro.

A operação ocorreu após o STF (Supremo Tribunal Federal) restringir operações durante a pandemia e depois de menos de uma semana da posse de Cláudio Castro, causada pelo impeachment do antigo governador, Wilson Witzel (PSC).

Atualmente, outro grande caso de repercussão nacional aconteceu no município de Umbaúba, litoral sul de Sergipe. Genivaldo, um homem negro de 38 anos, não resistiu após uma abordagem policial.

Vídeos do acontecimento mostram os agentes colocando o homem dentro da viatura e usando o que parece ser bomba de gás lacrimogêneo dentro do veículo. A causa da morte foi "insuficiência aguda secundária e asfixia".