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

Conheça as ilhas pintadas de roxo que atraem turistas para a Coreia do Sul

Ilhas roxas atraem turistas - DAEWOUNG KIM/REUTERS
Ilhas roxas atraem turistas Imagem: DAEWOUNG KIM/REUTERS

De Nossa

16/03/2021 18h18

Em duas pequenas regiões sul-coreanas, a vida não é rosa, como diz a famosa canção La Vie en Rose, mas roxa.

Chamadas de Banwol e Bakji, as duas ilhas começaram a chamar a atenção de turistas desde 2015, quando o governo decidiu pintar pontes, telhados e cabines telefônicas com tons de lilás.

Para acompanhar o projeto, os habitantes das ilhas plantaram flores roxas, como lavanda e aster, e costumam dar preferência para sair às ruas com roupas roxas.

Ilhas roxas -  Coreia do Sul - DAEWOUNG KIM/REUTERS - DAEWOUNG KIM/REUTERS
Chão pintado com a cor da cidade
Imagem: DAEWOUNG KIM/REUTERS

Localizadas no condado de Shinan, que conta com 1.000 ilhotas, Banwol e Bakji ficam a cerca de seis horas de carro de Seul, capital do país asiático. Em determinado momento do trajeto, no entanto, é preciso estacionar o veículo num estacionamento e atravessar a ponte roxa a pé ou de bike.

Outra particularidade é a exigência do pagamento de uma taxa para caminhar pelo espaço. A boa notícia é que se você optar por usar um look lilás, o valor é reduzido a zero — e aqui está mais um motivo para entrar na brincadeira.

Com economia baseada na agricultura, o lugar não apresenta grandes atividades turísticas, mas é possível visitar alguns pequenos restaurantes, lojas de conveniência, sorveterias e cafés.

Também não espere grandes multidões: ambos os povoados somam cerca de 150 pessoas, majoritariamente idosos. Shin Deok-im, morador de 70 anos, disse à Reuters:

Idosos como nós têm uma vida isolada aqui, já que todos os jovens deixaram a cidade".

Salva-vidas para a pandemia

O governo coreano lançou a campanha das ilhas roxas em 2015 como parte de uma iniciativa para "criar destinos insulares atraentes". Inspirados nos campanários roxos que crescem nas ilhas, 400 telhados foram pintados de roxo. Desde então, o condado investiu mais de 4,25 milhões de dólares.

A proposta tem, de forma previsível e lucrativa, provado ser alimento para o Instagram. Também acabou sendo uma espécie de salva-vidas durante a pandemia.

Desde 2018, mais de 490.000 pessoas visitaram as ilhas, de acordo com a CNN Travel. Entre junho e agosto de 2020, o número foi de visitantes foi de 100.000, 20% a mais que em a 2019.

Como a quarentena de 14 dias é obrigatória ao entrar na Coreia do Sul, o destino tornou-se opção de turismo doméstico.