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

Aprendiz de motorista confunde freio com acelerador e mata jovem de 20 anos

Krystal Hamilton, 20, atropelada por aprendiz de motorista - Reprodução/Facebook
Krystal Hamilton, 20, atropelada por aprendiz de motorista Imagem: Reprodução/Facebook

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

18/12/2020 21h58

Uma garota de 24 anos atropelou e matou outra de 20, enquanto aprendia a dirigir com o namorado, no Reino Unido. Ela e o namorado fugiram sem prestar socorro e foram sentenciados a 30 e 20 meses de prisão, respectivamente.

A jovem Kennedy Lucas, 24, só tinha feito cinco aulas de direção com sua família quando pediu para pegar o volante do namorado, Vinny Guess, 28, para treinar um pouco com ele. O carro era um at, da marca Volkswagen.

Na mesma hora, Krystal Hamilton, 20, voltava para casa quando foi atingida pelo at. Kennedy teria tentado frear, mas pisou no acelerador por engano. Após o atropelamento, ela ainda bateu num muro.

O acidente aconteceu às 23h do dia 6 de fevereiro, no pacato bairro de Grange Park, na cidade inglesa de Northampton. Krystal estava a apenas 50 metros de distância de sua casa. Ela teve um traumatismo craniano e ou dez dias no hospital lutando pela vida, mas não resistiu.

Imediatamente após a batida, o namorado assumiu o volante e fugiu do local, deixando Kennedy sozinha com a vítima. Ela então foi abordada por uma vizinha e afirmou ter visto o atropelamento, mas negou estar envolvida. Dois minutos depois, foi embora do local, a pé.

Em uma postagem no Facebook, vizinhos procuravam pela "menina que viu o acidente e sumiu". Após verem a publicação, Kennedy e o namorado se entregaram à polícia.

A aprendiz de motorista itiu a culpa por direção perigosa e obstrução da justiça e foi condenada a 30 meses de prisão. O namorado foi condenado a 20 meses de prisão por obstrução da justiça.

No tribunal, a mãe de Krystal, Anne-Marie Hamilton, segurou uma mecha de cabelo da filha e falou ao júri: "Isso é tudo que restou da minha filha. Assistir minha filha lutar pela vida foi a coisa mais difícil que já fiz. Desejei todos os dias poder trocar de lugar com ela. A frustração e dor que eu senti ao saber que quem fez isso com ela fugiu deixando-a machucada e sozinha. Acordo todos os dias em um mundo onde não posso ver o rosto perfeito da minha filha", disse.