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

Guia Horizon Cup de Wild Rift: horários, times, partidas e mais

Amanda Fleure, do Start

Em São Paulo

13/11/2021 04h00

Neste sábado (13) começa o Wild Rift: Horizon Cup, o primeiro campeonato mundial da versão mobile de League of Legends. As 10 melhores equipes do mundo se reúnem para competir pelo título internacional e US$ 500 mil (mais de R$ 2,7 milhões) em prêmios. A disputa acontece em Singapura, com a final prevista para o dia 21.

Continue lendo para saber mais sobre as equipes qualificadas, o formato do torneio, a seleção de grupos e o cronograma de transmissão.

Equipes qualificadas

Horizon Cup Wild Rift - Divulgação/RiotGames - Divulgação/RiotGames
Imagem: Divulgação/RiotGames
  • Brasil: [TSM] TSM
  • China: [DKG] Da Kun Gaming
  • China: [TT] Thunder Talk Gaming
  • EMEA (Europa, Oriente Médio e África): [TQ] Team Queso
  • Japão: [SG] Sengoku Gaming
  • América Latina: [EBG] eBRO Gaming
  • América do Norte: [TG] Tribe Gaming
  • Sudeste Asiático: [SE] SBTC Esports
  • Sudeste Asiático: [TS] Team Secret
  • Coreia do Sul: [RY] Rolster Y

Formato

As equipes avançarão pelo torneio da seguinte forma:

Fase de Grupos: de 13 a 17

As 10 equipes qualificadas nas Classificatórias Regionais serão divididas em 2 grupos de 5 equipes cada. Em cada grupo, as equipes jogarão uma única rodada Melhor de 3, todos contra todos. As 3 melhores colocadas de cada grupo avançarão para a Fase Eliminatória.

Fase Eliminatória: Quartas-de-final (dia 19), Semifinais (dia 20) e Final (dia 21)

As primeiras colocadas dos Grupos A e B avançarão automaticamente para as Semifinais. A 2ª e a 3ª colocada de cada grupo vão enfrentar uma equipe do outro grupo em uma única Melhor de 5. As vencedoras das Quartas de Final avançarão para as Semifinais, onde competirão com uma das primeiras colocadas do Grupo A e B em uma Melhor de 5.

As vencedoras das Semifinais se enfrentarão na Final, em uma rodada Melhor de 7 valendo o primeiro título internacional.

Grupos

As equipes foram divididas em:

Grupo A:

Brasil: [TSM] TSM
China: [DKG] Da Kun Gaming
América do Norte: [TG] Tribe Gaming
Sudeste Asiático: [SE] SBTC Esports
Coreia do Sul: [RY] Rolster Y

Grupo B:

China: [TT] Thunder Talk Gaming
EMEA (Europa, Oriente Médio e África): [TQ] Team Queso
Japão: [SG] Sengoku Gaming
América Latina: [EBG] eBRO Gaming
Sudeste Asiático: [TS] Team Secret

Para criar os dois grupos, foram estabelecidos os seguintes critérios: duas equipes do mesmo país não poderão começar no mesmo grupo; e cada grupo deve maximizar a diversidade e representação regional.

Transmissão

Estes são os horários de início de cada etapa:

  • Grupos: 13 a 17 de novembro | 7:00 BRT
  • Quartas de Final: 19 de novembro | 7:00 BRT
  • Semifinais: 20 de novembro | 7:00 BRT
  • Final: 21 de novembro | 9:00 BRT

Acompanhe as partidas nos canais oficial do Wild Rift Brasil, com narração em português brasileiro na Twitch, YouTube e Nimo TV.

SIGA O START NAS REDES SOCIAIS

Twitter: https://twitter.com/start_uol
Instagram: https://www.instagram.com/start_uol/
Facebook: https://www.facebook.com/startuol/
TikTok: https://www.tiktok.com/@start_uol?
Twitch: https://www.twitch.tv/startuol