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

Robôs fazem "meio de campo" entre pacientes e médicos especialistas em SP

Médico faz videoconferência com paciente via tablet acoplado em robô - Divulgação
Médico faz videoconferência com paciente via tablet acoplado em robô Imagem: Divulgação

Thiago Varella

Colaboração para Tilt

12/07/2020 04h00

Os prontos-socorros de um plano de saúde paulista estão utilizando robôs para atendimentos por videoconferência. O paciente é atendido pessoalmente por um médico emergencista de plantão. Caso seja necessária a opinião de outro especialista para definir o diagnóstico, esse outro médico é consultado por intermédio de um robô.

Segundo o plano Prevent Senior, a medida ajuda a poupar tempo, já que, anteriormente, era necessário chamar o especialista que tinha de enfrentar todo o trânsito de uma megalópole como São Paulo, resultando em uma espera de uma a duas horas, o que, muitas vezes, retardava o início do tratamento. Além disso, em tempos de pandemia de covid-19, o médico não corre o risco de ser contaminado em um pronto-socorro hospitalar.

O serviço começou a funcionar em março e, desde então, mais de 250 mil atendimentos médicos foram feitos por videoconferência, seja via robô, computador, celular ou tablets. São mais de 3.000 videoconferências por dia nos cinco postos de pronto atendimento do plano. Mas, o serviço ainda não funciona 24 horas por dia, algo que deve ser implantado em breve.

Os robôs foram fabricados pela Double Robotics, empresa do Vale do Silício, na Califórnia (EUA). Outros equipamentos estão sendo comprados pelo plano para funcionarem nos hospitais do grupo.

Cada robô tem um tablet, que mostra as imagens da videoconferência. O médico especialista pode conversar com o plantonista, o próprio paciente, seus acompanhantes ou enfermeiros. O equipamento roda livremente pelos corredores dos postos de pronto atendimento e é comandado à distância.

Como é uma novidade, os robôs ainda chamam muito a atenção das pessoas que vão se consultar nos postos.

"As pessoas param para olhar o robozinho ando, e se surpreendem quando o monitor vira para elas, ao mesmo tempo que o médico que controla o robô à distância cumprimenta os pacientes em alto e bom som. Alguns dos beneficiários chegam mesmo a tirar selfies ao lado dos robozinhos", afirmou, em nota, a médica Bruna Prado, coordenadora de telessaúde da Prevent.