CINXE.COM
Hankook Tire Global Official Website – Driving Emotion
<!DOCTYPE html> <html lang="en" data-sitecd="global-en" data-author="0"> <head> <script type="application/ld+json"> { "@context": "https://schema.org/", "@type": "WebSite", "name": "Hankook", "url": "https://www.hankooktire.com" } </script> <meta http-equiv="X-UA-Compatible" content="IE=edge"/> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0"/> <!-- Start of global snippet: Please do not remove Place this snippet between the <head> and </head> tags on every page of your site. --> <!-- Global site tag (gtag.js) - Google Marketing Platform --> <script async src="https://www.googletagmanager.com/gtag/js?id=DC-11980900"></script> <script> var getSitecd = document.getElementsByTagName('html')[0].dataset.sitecd; var cookiepopNames = "cookiePop_" + getSitecd; var cookies = document.cookie.match('(^|;) ?' + cookiepopNames + '=([^;]*)(;|$)'); var cookiesChk = cookies ? cookies[2] : null; window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'DC-11980900'); </script> <!-- End of global snippet: Please do not remove --> <script> gtag('event', 'conversion', { 'allow_custom_scripts': true, 'send_to': 'DC-11980900/pagev0/hanko0+standard' }); </script> <noscript> <img src="https://ad.doubleclick.net/ddm/activity/src=11980900;type=pagev0;cat=hanko0;dc_lat=;dc_rdid=;tag_for_child_directed_treatment=;tfua=;npa=;gdpr=;gdpr_consent=;ord=1?" width="1" height="1" alt=""/> </noscript> <meta name="format-detection" content="telephone=no"/> <title>Hankook Tire Global Official Website – Driving Emotion</title> <meta name="description" content="Hankook Tire is realizing the way for innovative mobility that goes beyond tires. Explore the brand vision, diverse lineups, and new future possibilities."/> <meta name="google-site-verification" content="7vq8DcCX3ROmhbO6OTlh29mszMVCgGKCFmBRwk7TqmM"/> <meta property="og:site_name" content="Hankook"/> <meta property="og:title" content="Hankook Tire Global Official Website – Driving Emotion"/> <meta property="og:description" content="Hankook Tire is realizing the way for innovative mobility that goes beyond tires. Explore the brand vision, diverse lineups, and new future possibilities."/> <meta property="og:image" content="https://www.hankooktire.com/content/dam/hankooktire/global/link_thumb_white.jpg"/> <meta property="og:image:width" content="1200"/> <meta property="og:image:height" content="630"/> <meta property="og:type" content="website"/> <meta property="og:url" content="https://www.hankooktire.com/global/en/home.html"/> <meta name="twitter:card" content="summary"/> <meta name="twitter:title" content="Hankook Tire Global Official Website – Driving Emotion"/> <meta name="twitter:description" content="Hankook Tire is realizing the way for innovative mobility that goes beyond tires. Explore the brand vision, diverse lineups, and new future possibilities."/> <meta name="twitter:url" content="https://www.hankooktire.com/global/en/home.html"/> <meta name="twitter:image"/> <meta name="facebook-domain-verification" content="x1t2krkqhiybfa9tjap0jsq467fl62"/> <link rel="canonical" href="https://www.hankooktire.com/global/en/home.html"/> <link rel="alternate" hreflang="en" href="https://www.hankooktire.com/global/en/home.html"/> <link rel="alternate" hreflang="ko" href="https://www.hankooktire.com/global/ko/home.html"/> <script> (function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start': new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0], j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src= 'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f); })(window,document,'script','dataLayer','GTM-M692H37'); </script> <script type="application/ld+json"> { "@context": "https://schema.org", "@type": "Organization", "name": "HANKOOK TIRE & TECHNOLOGY", "url": "https://www.hankooktire.com/content/hankooktire/global/en/home.html", "logo": "https://www.hankooktire.com/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/logo-up.svg" } </script> <script src="/etc.clientlibs/core/wcm/components/commons/site/clientlibs/container.min.js"></script> <script src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base.min.js"></script> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global.min.css" type="text/css"> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/clientlibs/clientlib-lang/en.min.css" type="text/css"> <link rel="apple-touch-icon" sizes="180x180" href="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/favicon/apple-touch-icon.png"/> <link rel="icon" type="image/png" sizes="32x32" href="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/favicon/favicon-32x32.png"/> <link rel="icon" type="image/png" sizes="16x16" href="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/favicon/favicon-16x16.png"/> <link rel="manifest" href="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/favicon/site.webmanifest"/> <link rel="mask-icon" href="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/favicon/safari-pinned-tab.svg" color="#5bbad5"/> <meta name="msapplication-TileColor" content="#da532c"/> <meta name="theme-color" content="#ffffff"/> <script> const __pathname = location.pathname; const __location_search = location.search; function ispreventCrawling(){ const __href = location.href; const __preventCrawlingServerNameArray = ['prd-www', 'stg-www', 'dev-www', 'www-dev', 'stg-asset', 'dev-asset']; for(var i = 0; i < __preventCrawlingServerNameArray.length; i++){ if(__href.indexOf(__preventCrawlingServerNameArray[i]) > -1){ return true; } } return false; } if(__pathname.indexOf('/content/') > -1 || (__location_search && __location_search.indexOf('keyword=') > -1 ) || ispreventCrawling()){ $('head').append('<meta name="robots" CONTENT="noindex,nofollow"/>'); } </script> <!-- <script type="application/ld+json"> { "@context": "http://schema.org", "@type": "Organization", "name": "HANKOOK TIRE & TECHNOLOGY", "url": "https://www.hankooktire.com", "sameAs": [ "https://blog.naver.com/happydriving", "https://www.facebook.com/hankooktire.korea", "https://www.youtube.com/channel/UC86f2_-Etmdmi1KpTjYHupQ", "https://brand.naver.com/hankooktire" ] } </script> --> <!-- 20230904 [HK] 네이버 연관 채널 schema markup 요청 --> <script type="application/ld+json"> { "@context": "http://schema.org", "@type": "Organization", "name": "HANKOOK TIRE & TECHNOLOGY", "url": "https://www.hankooktire.com", "sameAs": [ "https://www.instagram.com/hankooktire.kr/", "https://blog.naver.com/happydriving", "https://www.facebook.com/hankooktire.korea", "https://www.youtube.com/channel/UC86f2_-Etmdmi1KpTjYHupQ", "https://brand.naver.com/hankooktire" ] } </script> <!-- ga4 2023-06-14 Scroll Action Tracking --> <script> $(window).on("load", function(){ //if(isGA4ScrollActionTrackingPage()){ setTimeout(() => GA4ScrollEvent(), 100); //} }); function GA4ScrollEvent(){ if(window.locomotive){ window.locomotive.on('scroll', GA4ScrollHandler); } } var isGA4Push25 = false; var isGA4Push50 = false; var isGA4Push75 = false; var isGA4Push99 = false; function GA4ScrollHandler(e) { var limitScrollY = window.locomotive.scroll.instance.limit.y; var currentScrollY = window.locomotive.scroll.instance.scroll.y; if(!isGA4Push25){ var currentPercent = currentScrollY/limitScrollY * 100; if(currentPercent >= 25){ isGA4Push25 = true; dataLayer.push({ 'event': 'customEvent', 'ga4event': 'scroll', 'customEventCategory': 'Scroll', 'customEventAction': 'Scroll - 25 %'}); //alert('push Success'); } } if(!isGA4Push50){ var currentPercent = currentScrollY/limitScrollY * 100; if(currentPercent >= 50){ isGA4Push50 = true; dataLayer.push({ 'event': 'customEvent', 'ga4event': 'scroll', 'customEventCategory': 'Scroll', 'customEventAction': 'Scroll - 50 %'}); //alert('push Success'); } } if(!isGA4Push75){ var currentPercent = currentScrollY/limitScrollY * 100; if(currentPercent >= 75){ isGA4Push75 = true; dataLayer.push({ 'event': 'customEvent', 'ga4event': 'scroll', 'customEventCategory': 'Scroll', 'customEventAction': 'Scroll - 75 %'}); //alert('push 75% Success'); } } if(!isGA4Push99){ var currentPercent = currentScrollY/limitScrollY * 100; if(currentPercent >= 99){ isGA4Push99 = true; dataLayer.push({ 'event': 'customEvent', 'ga4event': 'scroll', 'customEventCategory': 'Scroll', 'customEventAction': 'Scroll - 99 %'}); //alert('push Success'); } } } //���Ŀ� dbȭ ���Ѽ� �ٲܰ� function isGA4ScrollActionTrackingPage(){ var __siteCd = document.getElementsByTagName('html')[0].dataset.sitecd; var __path = location.pathname;//'/us/en/tire/ventus/s1evo3-k127.html' var scrollActionTrackingPages = [ "/us/en/tire/ventus/s1evo3-k127.html" ]; for(var i = 0; i < scrollActionTrackingPages.length; i++){ if(__path.indexOf(scrollActionTrackingPages[i]) > -1){ return true; } } return false; } </script> <script>!function(e){var n="https://s.go-mpulse.net/boomerang/";if("False"=="True")e.BOOMR_config=e.BOOMR_config||{},e.BOOMR_config.PageParams=e.BOOMR_config.PageParams||{},e.BOOMR_config.PageParams.pci=!0,n="https://s2.go-mpulse.net/boomerang/";if(window.BOOMR_API_key="CQLT4-7LTQC-8QFTM-MWR6D-LR8GP",function(){function e(){if(!o){var e=document.createElement("script");e.id="boomr-scr-as",e.src=window.BOOMR.url,e.async=!0,i.parentNode.appendChild(e),o=!0}}function t(e){o=!0;var n,t,a,r,d=document,O=window;if(window.BOOMR.snippetMethod=e?"if":"i",t=function(e,n){var t=d.createElement("script");t.id=n||"boomr-if-as",t.src=window.BOOMR.url,BOOMR_lstart=(new Date).getTime(),e=e||d.body,e.appendChild(t)},!window.addEventListener&&window.attachEvent&&navigator.userAgent.match(/MSIE [67]\./))return window.BOOMR.snippetMethod="s",void t(i.parentNode,"boomr-async");a=document.createElement("IFRAME"),a.src="about:blank",a.title="",a.role="presentation",a.loading="eager",r=(a.frameElement||a).style,r.width=0,r.height=0,r.border=0,r.display="none",i.parentNode.appendChild(a);try{O=a.contentWindow,d=O.document.open()}catch(_){n=document.domain,a.src="javascript:var d=document.open();d.domain='"+n+"';void(0);",O=a.contentWindow,d=O.document.open()}if(n)d._boomrl=function(){this.domain=n,t()},d.write("<bo"+"dy onload='document._boomrl();'>");else if(O._boomrl=function(){t()},O.addEventListener)O.addEventListener("load",O._boomrl,!1);else if(O.attachEvent)O.attachEvent("onload",O._boomrl);d.close()}function a(e){window.BOOMR_onload=e&&e.timeStamp||(new Date).getTime()}if(!window.BOOMR||!window.BOOMR.version&&!window.BOOMR.snippetExecuted){window.BOOMR=window.BOOMR||{},window.BOOMR.snippetStart=(new Date).getTime(),window.BOOMR.snippetExecuted=!0,window.BOOMR.snippetVersion=12,window.BOOMR.url=n+"CQLT4-7LTQC-8QFTM-MWR6D-LR8GP";var i=document.currentScript||document.getElementsByTagName("script")[0],o=!1,r=document.createElement("link");if(r.relList&&"function"==typeof r.relList.supports&&r.relList.supports("preload")&&"as"in r)window.BOOMR.snippetMethod="p",r.href=window.BOOMR.url,r.rel="preload",r.as="script",r.addEventListener("load",e),r.addEventListener("error",function(){t(!0)}),setTimeout(function(){if(!o)t(!0)},3e3),BOOMR_lstart=(new Date).getTime(),i.parentNode.appendChild(r);else t(!1);if(window.addEventListener)window.addEventListener("load",a,!1);else if(window.attachEvent)window.attachEvent("onload",a)}}(),"".length>0)if(e&&"performance"in e&&e.performance&&"function"==typeof e.performance.setResourceTimingBufferSize)e.performance.setResourceTimingBufferSize();!function(){if(BOOMR=e.BOOMR||{},BOOMR.plugins=BOOMR.plugins||{},!BOOMR.plugins.AK){var n=""=="true"?1:0,t="",a="bdpnbeqx2exbmz64gqgq-f-0bc0d54f0-clientnsv4-s.akamaihd.net",i="false"=="true"?2:1,o={"ak.v":"39","ak.cp":"1753777","ak.ai":parseInt("1139636",10),"ak.ol":"0","ak.cr":1,"ak.ipv":4,"ak.proto":"http/1.1","ak.rid":"7ef4b793","ak.r":46558,"ak.a2":n,"ak.m":"b","ak.n":"ff","ak.bpcip":"8.222.208.0","ak.cport":59702,"ak.gh":"173.222.132.157","ak.quicv":"","ak.tlsv":"tls1.2","ak.0rtt":"","ak.0rtt.ed":"","ak.csrc":"-","ak.acc":"bbr","ak.t":"1742484493","ak.ak":"hOBiQwZUYzCg5VSAfCLimQ==CgUtT96NqeiCDUxqXpoBh3EF0PqAQL9yoFxwrT0s/zHzDzHz2BiYMMyFLq+u0NmaZ1Eo8Kzh6NQXo9ht3MhPlFGT8K5GgKat0ryuNGcxILAqmscu6KJHkot86Lf6pCGxoitZ6J827n9+rIQhVyvzA/RDWGGWVbz5CgyGSZKM1KbSTlMDJj/t9Z/kBtQ5hXqCYSlflMuAge/b8zM/YEwSxvx5AQhXC6Pvd0E+2bhKaCY7Oln8AvjtPveop1Yq8T4a6I6WebnPC4BMhbOJiCG1lSZnrvOp025ofLIFHTvrljnnQ3Hn0AeUBA1x319RO8ZC26yXpSp1qhpYOsXduqLnI1PoxwI2ijJOC18QVs8JbArBQChC9yf/lRzVuNUT3mutXvZyTTsQbBNwpp7q1+iECciiH1ROU/LNiAuZIsjA01g=","ak.pv":"24","ak.dpoabenc":"","ak.tf":i};if(""!==t)o["ak.ruds"]=t;var r={i:!1,av:function(n){var t="http.initiator";if(n&&(!n[t]||"spa_hard"===n[t]))o["ak.feo"]=void 0!==e.aFeoApplied?1:0,BOOMR.addVar(o)},rv:function(){var e=["ak.bpcip","ak.cport","ak.cr","ak.csrc","ak.gh","ak.ipv","ak.m","ak.n","ak.ol","ak.proto","ak.quicv","ak.tlsv","ak.0rtt","ak.0rtt.ed","ak.r","ak.acc","ak.t","ak.tf"];BOOMR.removeVar(e)}};BOOMR.plugins.AK={akVars:o,akDNSPreFetchDomain:a,init:function(){if(!r.i){var e=BOOMR.subscribe;e("before_beacon",r.av,null,null),e("onbeacon",r.rv,null,null),r.i=!0}return this},is_complete:function(){return!0}}}}()}(window);</script></head> <body> <!-- <noscript> <iframe src="https://www.googletagmanager.com/ns.html?id=GTM-M692H37" height="0" width="0" style="display:none;visibility:hidden"></iframe> </noscript>--> <!-- <noscript><iframe src=https://www.googletagmanager.com/ns.html?id=GTM-5S2XSXN height="0" width="0" style="display:none;visibility:hidden"></iframe></noscript>--> <script> if(!(!(cookiesChk == 'N') || getSitecd == 'us-en' || getSitecd == 'kr-ko' || getSitecd == 'ca-en' || getSitecd == 'ca-fr' || getSitecd == 'au-en' || getSitecd == 'cn-zh' || getSitecd == 'mea-en' || getSitecd == 'mea-ar' || getSitecd == 'my-en' || getSitecd == 'jp-ja' || getSitecd == 'id-id' || getSitecd == 'th-th' || getSitecd == 'mx-es' || getSitecd == 'co-es' || getSitecd == 'cl-es' || getSitecd == 'br-pt' //|| getSitecd == 'ru-ru' || getSitecd == 'de-de' || getSitecd == 'uk-en' || getSitecd == 'hu-hu' || getSitecd == 'pl-pl' || getSitecd == 'nl-nl' || getSitecd == 'es-es' || getSitecd == 'se-sv' || getSitecd == 'fr-fr' || getSitecd == 'it-it' || getSitecd == 'tr-tr' || getSitecd == 'cz-cs' )){ var nos = document.getElementsByTagName('noscript'); var noslength = nos.length; for(var i=0; i<noslength; i++){ nos[0].remove(); } } if( /MSIE \d|Trident.*rv:/.test(navigator.userAgent) ) { window.location = 'microsoft-edge:'+window.location; setTimeout( function() { window.location = 'https://support.microsoft.com/en-us/topic/占쎌뵠-占쎌럲-占쎄텢占쎌뵠占쎈뱜占쎈뮉-microsoft-edge占쎈퓠占쎄퐣-占쎈쐭-占쎌삋-占쎌삂占쎈짗占쎈�占쎈빍占쎈뼄-160fa918-d581-4932-9e4e-1075c4713595'; }, 0 ); } </script> <script> document.documentElement.style.setProperty('--mobile-cover-height', window.innerHeight+'px'); commonCode = { countryCode : 'hr'}; </script> <a href="#main" id="skipnav">go to main prd</a> <div class="cookie-pop hidden eu-cookie-pop" data-sitecd="go-en"> <div class="txt-wrap"> <p class="tit">Cookies & Privacy</p> <p class="desc">I agree to the use of cookies and tracking mechanisms which are used to analyse my activity on this website in order to improve my user experience. <br /> <a href="/global/en/footer/privacy-policy.html" class="learn-more">Learn more</a></p> </div> <div class="btn-wrap"> <a href="javascript:setCookiePopup('Y');" class="cookie-btn agree">I agree</a> <a href="javascript:setCookiePopup('N');" class="cookie-btn disagree" id="cookieDisagreeBtn" data-disagree-url="/content/hankooktire/global/en/footer/privacy-policy.html">Manage my preference</a> </div> </div> <script src="/etc.clientlibs/hankooktire/components/content/local/common/cookie-popup/clientlibs.min.js"></script> <header class="header " id="header"> <script src="/etc.clientlibs/hankooktire/components/content/global/common/header/clientlibs.min.js"></script> <div class="back-panel" role="presentation"></div> <a class="home" href="/global/en/home.html" target="_self"> <img class="logo default" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/logo.svg" alt="Hankook Tire"/> <img class="logo up" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/logo-up.svg" alt="Hankook Tire"/> </a> <nav class="gnb" data-bread-text="Home" data-bread-url="/content/hankooktire/global/en/home.html"> <ul class="d1"> <li class="d1__menu"> <a href="/global/en/inside-hankook.html" target="_self">Inside Hankook</a> </li> <li class="d1__menu"> <a>Innovation</a> <div class="d2-wrap "> <strong class="d2-title">Innovation</strong> <ul class="d2"> <li class="d2__menu"> <a class="btn--round btn--plus" href="/global/en/innovation/technology-innovation.html" target="_self">Technology for Innovation</a> <ul class="d3"> <li class="d3__menu "> <a class="btn--round" href="/global/en/innovation/technology-innovation/technology-innovation-overview.html" target="_self"> Overview </a> </li> <li class="d3__menu "> <a class="btn--round" href="/global/en/innovation/technology-innovation/driving.html" target="_self"> Driving </a> </li> <li class="d3__menu "> <a class="btn--round" href="/global/en/innovation/technology-innovation/intelligence.html" target="_self"> Intelligence </a> </li> <li class="d3__menu "> <a class="btn--round" href="/global/en/innovation/technology-innovation/sustainability.html" target="_self"> Sustainability </a> </li> </ul> </li> <li class="d2__menu "> <a class="btn--round " href="/global/en/innovation/design-innovation.html" target="_self">Design Innovation</a> </li> <li class="d2__menu "> <a class="btn--round " href="/global/en/innovation/technodome.html" target="_self">Hankook Technodome</a> </li> <li class="d2__menu "> <a class="btn--round " href="/global/en/innovation/technoring.html" target="_self">Hankook Technoring</a> </li> </ul> </div> </li> <li class="d1__menu"> <a>Experience</a> <div class="d2-wrap "> <strong class="d2-title">Experience</strong> <ul class="d2"> <li class="d2__menu "> <a class="btn--round " href="/global/en/experience/driving-emotion.html" target="_self">Driving Emotion</a> </li> <li class="d2__menu "> <a class="btn--round " href="https://www.hankook-motorsports.com/en/main.html" target="_blank" rel="noopener noreferrer">Motorsports</a> </li> </ul> </div> </li> <li class="d1__menu"> <a>Tires</a> <div class="d2-wrap d2-wrap--extended"> <strong class="d2-title">Tires</strong> <ul class="d2"> <li class="d2__menu"> <a class="btn--round btn--plus" href="/global/en/home.html">Hankook</a> <ul class="d3"> <li class="d3__menu "> <a class="btn--round" href="/global/en/tires/tires-overview.html"> By Vehicle </a> </li> <li class="d3__menu "> <a class="btn--round btn--plus" href="/global/en/tires/ion.html"> By Brand </a> <ul class="d4"> <li class="d4__menu "> <a class="btn--round" href="/global/en/tires/ion.html"> iON </a> </li> <li class="d4__menu "> <a class="btn--round" href="/global/en/tires/ventus.html"> Ventus </a> </li> <li class="d4__menu "> <a class="btn--round" href="/global/en/tires/dynapro.html"> Dynapro </a> </li> <li class="d4__menu "> <a class="btn--round" href="/global/en/tires/weatherflex.html"> Weatherflex </a> </li> <li class="d4__menu "> <a class="btn--round" href="/global/en/tires/kinergy.html"> Kinergy </a> </li> <li class="d4__menu "> <a class="btn--round" href="/global/en/tires/winter-i-cept-winter-i-pike.html"> Winter i*cept & Winter i*pike </a> </li> <li class="d4__menu "> <a class="btn--round" href="/global/en/tires/vantra.html" target="_self"> Vantra </a> </li> <li class="d4__menu "> <a class="btn--round" href="/global/en/tires/smart.html"> Smart </a> </li> </ul> </li> </ul> </li> <li class="d2__menu "> <a class="btn--round " href="https://www.laufenn.com/" target="_blank" rel="noopener noreferrer">Laufenn</a> </li> </ul> </div> </li> </ul> </nav> <div class="util"> <a href="/global/en/tech-in-motion-list.html" target="_self" class="util__item t_none" id="util-tech"> <img class="default" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/technology-in-motion.svg" alt="Technology in motion"/> <img class="up" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/technology-in-motion-up.svg" alt="Technology in motion"/> <span class="a11y">Technology in motion</span> </a> <a href="#" class="util__item" id="util-search"> <img class="default" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/search.svg" alt="Search"/> <img class="up" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/search-up.svg" alt="Search"/> <img class="active" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/search-active.svg" alt="Search"/> <span class="a11y">Search</span> </a> <a href="#" class="util__item" id="util-menu"> <img class="default" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/menu.svg" alt="Menu"/> <img class="up" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-base/resources/img/common/menu-up.svg" alt="Menu"/> <span class="a11y">Menu</span> </a> </div> <div class="ggb" id="ggb"> <div class="search-back-pannel"> <div class="section--sm"> <div class="search-box-wrap"> <div class="input-wrap"> <form action="/global/en/search.html" method="get"> <input type="text" class="font_body_1_main" placeholder="Search" name="keyword"/> <button type="submit" class="btn btn--search"> <span class="a11y">search</span> </button> </form> </div> </div> <div class="search-recommend-list"> <a href="/global/en/search.html?keyword=iON" class="recomment-list">iON</a> <a href="/global/en/search.html?keyword=Electric%20Vehicle" class="recomment-list">Electric Vehicle</a> <a href="/global/en/search.html?keyword=SUV" class="recomment-list">SUV</a> <a href="/global/en/search.html?keyword=Brands" class="recomment-list">Brands</a> <a href="/global/en/search.html?keyword=Company" class="recomment-list">Company</a> <a href="/global/en/search.html?keyword=Investor" class="recomment-list">Investor</a> <a href="/global/en/search.html?keyword=Career" class="recomment-list">Career</a> <a href="/global/en/search.html?keyword=Innovation" class="recomment-list">Innovation</a> </div> </div> </div> </div> </header> <nav class="sidenav"> <div class="content"> <div class="cmd"> <ul class="lang-wrap t_none"> <li class="lang"> <a href="/global/en/home.html" target="_self" class="is-active"> English </a> </li> <li class="lang"> <a href="/global/ko/home.html" target="_blank" rel="noopener noreferrer"> Korean </a> </li> </ul> <a class="side__logo w_none" href="/global/en/home.html" title="홈"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/svg/logo.svg" alt="Hankook Tire"/> </a> <button class="btn btn--close"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/svg/w_close_white.svg" alt="Close"/> <span class="a11y">Close</span> </button> </div> <div class="menu__list"> <h4 class="menu__title w_none">Main</h4> <ul class="d1" data-side-type="main"> <li class="d1__menu"> <a href="/global/en/inside-hankook.html" target="_self" class="d1__link">Inside Hankook <i></i></a> <div class="d2-wrap "> </div> </li> <li class="d1__menu"> <a class="d1__link">Innovation <i></i></a> <div class="d2-wrap "> <ul class="d2"> <li class="d2__menu"> <a href="/global/en/innovation/technology-innovation/technology-innovation-overview.html" target="_self" class="d2__link"> <span>Technology for Innovation</span> </a> <ul class="d3"> <li class="d3__menu"> <a href="/global/en/innovation/technology-innovation/technology-innovation-overview.html" target="_self" class="d3__link "> <span>Overview</span> </a> </li> <li class="d3__menu"> <a href="/global/en/innovation/technology-innovation/driving.html" target="_self" class="d3__link "> <span>Driving</span> </a> </li> <li class="d3__menu"> <a href="/global/en/innovation/technology-innovation/intelligence.html" target="_self" class="d3__link "> <span>Intelligence</span> </a> </li> <li class="d3__menu"> <a href="/global/en/innovation/technology-innovation/sustainability.html" target="_self" class="d3__link "> <span>Sustainability</span> </a> </li> </ul> </li> <li class="d2__menu"> <a href="/global/en/innovation/design-innovation.html" target="_self" class="d2__link "> <span>Design Innovation</span> </a> </li> <li class="d2__menu"> <a href="/global/en/innovation/technodome.html" target="_self" class="d2__link "> <span>Hankook Technodome</span> </a> </li> <li class="d2__menu"> <a href="/global/en/innovation/technoring.html" target="_self" class="d2__link "> <span>Hankook Technoring</span> </a> </li> </ul> </div> </li> <li class="d1__menu"> <a class="d1__link">Experience <i></i></a> <div class="d2-wrap "> <ul class="d2"> <li class="d2__menu"> <a href="/global/en/experience/driving-emotion.html" target="_self" class="d2__link "> <span>Driving Emotion</span> </a> </li> <li class="d2__menu"> <a href="https://www.hankook-motorsports.com/en/main.html" target="_blank" rel="noopener noreferrer" class="d2__link "> <span>Motorsports</span> </a> </li> </ul> </div> </li> <li class="d1__menu"> <a class="d1__link">Tires <i></i></a> <div class="d2-wrap d2-wrap--extended"> <ul class="d2"> <li class="d2__menu"> <a href="/global/en/home.html" class="d2__link"> <span>Hankook</span> </a> <ul class="d3"> <li class="d3__menu"> <a href="/global/en/tires/tires-overview.html" class="d3__link "> <span>By Vehicle</span> </a> </li> <li class="d3__menu"> <a href="/global/en/tires/ion.html" class="d3__link "> <span>By Brand</span> </a> <ul class="d4"> <li class="d4__menu "> <a href="/global/en/tires/ion.html" class="d4__link "> <span>iON</span> </a> </li> <li class="d4__menu "> <a href="/global/en/tires/ventus.html" class="d4__link "> <span>Ventus</span> </a> </li> <li class="d4__menu "> <a href="/global/en/tires/dynapro.html" class="d4__link "> <span>Dynapro</span> </a> </li> <li class="d4__menu "> <a href="/global/en/tires/weatherflex.html" class="d4__link "> <span>Weatherflex</span> </a> </li> <li class="d4__menu "> <a href="/global/en/tires/kinergy.html" class="d4__link "> <span>Kinergy</span> </a> </li> <li class="d4__menu "> <a href="/global/en/tires/winter-i-cept-winter-i-pike.html" class="d4__link "> <span>Winter i*cept & Winter i*pike</span> </a> </li> <li class="d4__menu "> <a href="/global/en/tires/vantra.html" class="d4__link "> <span>Vantra</span> </a> </li> <li class="d4__menu "> <a href="/global/en/tires/smart.html" class="d4__link "> <span>Smart</span> </a> </li> </ul> </li> </ul> </li> <li class="d2__menu"> <a href="https://www.laufenn.com/" target="_blank" rel="noopener noreferrer" class="d2__link "> <span>Laufenn</span> </a> </li> </ul> </div> </li> <li class="w_none"> <a href="/global/en/tech-in-motion-list.html" target="_self" class="util__item util__link"> <img class="default" src="https://asset.hankooktire.com/content/dam/hankooktire/global/svg/gl_sidenavi_technology-in-motion-m_new.svg" alt="Technology in motion"/> <span class="a11y">Technology in motion</span> </a> </li> </ul> <h4 class="menu__title w_none">Company</h4> <ul class="d1" data-side-type="company"> <li class="d1__menu"> <a href="#" class="d1__link">Company <i></i></a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu"> <a href="/global/en/company/company-overview.html" class="d2__link "> <span>Company Overview</span> </a> </li> <li class="d2__menu"> <a href="/global/en/company/global-network.html" class="d2__link "> <span>Global Network</span> </a> </li> <li class="d2__menu"> <a href="/global/en/company/global-automotive-partnership.html" class="d2__link "> <span>Global Automotive Partnership</span> </a> </li> <li class="d2__menu"> <a href="/global/en/company/media-list.html" class="d2__link "> <span>Media Center</span> </a> </li> <li class="d2__menu"> <a href="/global/en/company/awards/design-award.html" target="_self" class="d2__link"> <span>Awards</span> </a> <ul class="d3"> <li class="d3__menu"> <a href="/global/en/company/awards/design-award.html" target="_self" class="d3__link "> <span>Design Award</span> </a> </li> <li class="d3__menu"> <a href="/global/en/company/awards/esg-award.html" target="_self" class="d3__link "> <span>ESG Award</span> </a> </li> </ul> </li> <li class="d2__menu"> <a href="/global/en/company/brand-identity.html" target="_self" class="d2__link "> <span>Brand Identity</span> </a> </li> </ul> </div> </li> <li class="d1__menu"> <a href="#" class="d1__link">ESG <i></i></a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu"> <a href="/global/en/esg/hankook-tire-esg/esg-overview.html" target="_self" class="d2__link"> <span>Hankook Tire ESG</span> </a> <ul class="d3"> <li class="d3__menu"> <a href="/global/en/esg/hankook-tire-esg/esg-overview.html" target="_self" class="d3__link "> <span>ESG Overview</span> </a> </li> <li class="d3__menu"> <a href="/global/en/esg/hankook-tire-esg/esg-management.html" target="_self" class="d3__link "> <span>ESG Management</span> </a> </li> <li class="d3__menu"> <a href="/global/en/esg/hankook-tire-esg/esg-policy.html" target="_self" class="d3__link "> <span>ESG Policy</span> </a> </li> </ul> </li> <li class="d2__menu"> <a href="/global/en/esg/governance.html" target="_self" class="d2__link "> <span>Governance</span> </a> </li> <li class="d2__menu"> <a href="/global/en/esg/eco-value-chain.html" target="_self" class="d2__link "> <span>Eco Value Chain</span> </a> </li> <li class="d2__menu"> <a href="/global/en/esg/sustainable-product.html" target="_self" class="d2__link "> <span>Sustainable Product</span> </a> </li> <li class="d2__menu"> <a href="/global/en/esg/responsible-engagement.html" target="_self" class="d2__link "> <span>Responsible Engagement</span> </a> </li> <li class="d2__menu"> <a href="/global/en/esg/esg-report.html" target="_self" class="d2__link "> <span>ESG Report</span> </a> </li> <li class="d2__menu"> <a href="/global/en/misconduct-reporting/misconduct-reporting-guide.html" class="d2__link "> <span>Misconduct Reporting </span> </a> </li> </ul> </div> </li> <li class="d1__menu"> <a href="#" class="d1__link">Investors <i></i></a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu"> <a href="/global/en/investors/financial-information-results/key-figures.html" target="_self" class="d2__link"> <span>Financial Information & Results</span> </a> <ul class="d3"> <li class="d3__menu"> <a href="/global/en/investors/financial-information-results/key-figures.html" target="_self" class="d3__link "> <span>Key Figures</span> </a> </li> <li class="d3__menu"> <a href="/global/en/investors/financial-information-results/financial-results.html" target="_self" class="d3__link "> <span>Financial Results</span> </a> </li> <li class="d3__menu"> <a href="/global/en/investors/financial-information-results/credit-ratings.html" target="_self" class="d3__link "> <span>Credit Ratings</span> </a> </li> <li class="d3__menu"> <a href="/global/en/investors/financial-information-results/external-auditor.html" target="_self" class="d3__link "> <span>External Auditor</span> </a> </li> </ul> </li> <li class="d2__menu"> <a href="/global/en/investors/shares-shareholders/distribution-shares.html" target="_self" class="d2__link"> <span>Shares & Shareholders</span> </a> <ul class="d3"> <li class="d3__menu"> <a href="/global/en/investors/shares-shareholders/distribution-shares.html" target="_self" class="d3__link "> <span>Distribution of Shares</span> </a> </li> <li class="d3__menu"> <a href="/global/en/investors/shares-shareholders/stock-market-data.html" target="_self" class="d3__link "> <span>Stock Market Data</span> </a> </li> <li class="d3__menu"> <a href="/global/en/investors/shares-shareholders/dividends.html" target="_self" class="d3__link "> <span>Dividends</span> </a> </li> </ul> </li> <li class="d2__menu"> <a href="/global/en/investors/financial-reports/annual-reports.html" target="_self" class="d2__link"> <span>Financial Reports </span> </a> <ul class="d3"> <li class="d3__menu"> <a href="/global/en/investors/financial-reports/annual-reports.html" target="_self" class="d3__link "> <span>Annual Reports</span> </a> </li> <li class="d3__menu"> <a href="/global/en/investors/financial-reports/quarterly-reports.html" target="_self" class="d3__link "> <span>Quarterly Reports</span> </a> </li> <li class="d3__menu"> <a href="/global/en/investors/financial-reports/krx-disclosure.html" target="_self" class="d3__link "> <span>KRX Disclosure</span> </a> </li> <li class="d3__menu"> <a href="/global/en/investors/financial-reports/audit-reports.html" target="_self" class="d3__link "> <span>Audit Reports</span> </a> </li> </ul> </li> </ul> </div> </li> <li class="d1__menu"> <a href="#" class="d1__link">Careers <i></i></a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu"> <a href="/global/en/career/proactive-leader.html" target="_self" class="d2__link "> <span>Proactive Leader</span> </a> </li> <li class="d2__menu"> <a href="/global/en/career/proactive-culture.html" target="_self" class="d2__link "> <span>Proactive Culture</span> </a> </li> <li class="d2__menu"> <a href="/global/en/career/job-announcement.html" target="_self" class="d2__link "> <span>Job Announcement</span> </a> </li> </ul> </div> </li> </ul> <ul class="outlink t_none"> <li class="outlink__item"> <a href="/global/en/company/global-network.html" target="_self" class="link ">Global Network</a> </li> <li class="outlink__item"> <a href="/global/en/misconduct-reporting/misconduct-reporting-guide.html" target="_self" class="link ">Misconduct Reporting </a> </li> </ul> </div> <ul class="lang-wrap w_none"> <li class="lang"> <a href="/global/en/home.html" target="_self" class="is-active"> English </a> </li> <li class="lang"> <a href="/global/ko/home.html" target="_blank" rel="noopener noreferrer"> Korean </a> </li> </ul> </div> <div class="region"> <a href="/global/en/hankook-in-your-location.html" target="_self"><span class="region__link">Hankook in Your Location</span></a> <span class="region__current">Croatia</span> </div> <div class="sidenav_footer"> <ul class="social"> <li class="social__item"> <a href="https://ko-kr.facebook.com/hankooktire.global/" class="icon icon--facebook" target="_blank" rel="noopener noreferrer"> <span class="a11y">Facebook</span> </a> </li> <li class="social__item"> <a href="https://www.youtube.com/user/hankooktireglobal" class="icon icon--youtube" target="_blank" rel="noopener noreferrer"> <span class="a11y">Youtube</span> </a> </li> <li class="social__item"> <a href="https://www.instagram.com/hankooktire.global/" class="icon icon--instagram" target="_blank" rel="noopener noreferrer"> <span class="a11y">Instagram</span> </a> </li> <li class="social__item"> <a href="https://www.linkedin.com/company/hankook-tire-global/" class="icon icon--linkedin" target="_blank" rel="noopener noreferrer"> <span class="a11y">Linkedin</span> </a> </li> <li class="social__item"> <a href="https://www.tiktok.com/@hankooktire.official" class="icon icon--tiktok" target="_blank" rel="noopener noreferrer"> <span class="a11y">TikTok</span> </a> </li> </ul> </div> </nav> <div data-scroll-container data-direction> <main id="main" class="main"> <div class="index"> <div class="global-home-top-banner parbase"> <div> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/components/content/global/global-home-top-banner/clientlibs.min.css" type="text/css"> <section class="ghtb"> <!-- HT-388 --> <div class="ghtb__swiper"> <div class="swiper-wrapper"> <div class="ghtb__item swiper-slide"> <video class="ghtb__bg _m" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_hankookWRC_MonteCarlo_2025_03_390_844_250306.mp4" type="video/mp4" media="(max-width: 767px)"/> </video> <video class="ghtb__bg _t" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_hankookWRC_MonteCarlo_2025_03_1024_1366_250306.mp4" type="video/mp4" media="(max-width: 1024px)"/> </video> <video class="ghtb__bg _w" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_hankookWRC_MonteCarlo_2025_03_1920_1080_250306.mp4" type="video/mp4"/> </video> <picture class="poster"> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_hankookWRC_MonteCarlo_2025_03_390_844_250306.jpg" media="(max-width: 767px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_hankookWRC_MonteCarlo_2025_03_1024_1366_250306.jpg" media="(max-width: 1024px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_hankookWRC_MonteCarlo_2025_03_1920_1080_250306.jpg"/> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/LC_VentusxRST_19LC_VentusxRST_1920_970_23103020_970_231030.jpg" alt=""/> </picture> <div class="progress"><div class="thumb"></div></div> <a class="btn btn--round" href="https://www.hankook-motorsports.com/en/wrc/about-wrc.html" target="_blank">View World Rally Championship</a> </div> <div class="ghtb__item swiper-slide"> <video class="ghtb__bg _m" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ventus_lamborghini_2024_12_390_844_241202.mp4" type="video/mp4" media="(max-width: 767px)"/> </video> <video class="ghtb__bg _t" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ventus_lamborghini_2024_12_1024_1366_241202.mp4" type="video/mp4" media="(max-width: 1024px)"/> </video> <video class="ghtb__bg _w" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ventus_lamborghini_2024_12_1920_1080_250114.mp4" type="video/mp4"/> </video> <picture class="poster"> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ventus_lamborghini_2024_12_390_844_241202.jpg" media="(max-width: 767px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ventus_lamborghini_2024_12_1024_1366_241202.jpg" media="(max-width: 1024px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ventus_lamborghini_2024_12_1920_1080_250114.jpg"/> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/LC_VentusxRST_19LC_VentusxRST_1920_970_23103020_970_231030.jpg" alt=""/> </picture> <div class="progress"><div class="thumb"></div></div> </div> <div class="ghtb__item swiper-slide"> <video class="ghtb__bg _m" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_dynapro_2024_12_390_844_241202.mp4" type="video/mp4" media="(max-width: 767px)"/> </video> <video class="ghtb__bg _t" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_dynapro_2024_12_1024_1366_241202.mp4" type="video/mp4" media="(max-width: 1024px)"/> </video> <video class="ghtb__bg _w" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_dynapro_2024_12_1920_1080_241202.mp4" type="video/mp4"/> </video> <picture class="poster"> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_dynapro_2024_12_390_844_241202.jpg" media="(max-width: 767px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_dynapro_2024_12_1024_1366_241202.jpg" media="(max-width: 1024px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_dynapro_2024_12_1920_1080_241202.jpg"/> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/LC_VentusxRST_19LC_VentusxRST_1920_970_23103020_970_231030.jpg" alt=""/> </picture> <div class="progress"><div class="thumb"></div></div> </div> <div class="ghtb__item swiper-slide"> <video class="ghtb__bg _m" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_fe_maker_film_390_844_240730.mp4" type="video/mp4" media="(max-width: 767px)"/> </video> <video class="ghtb__bg _t" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_fe_maker_film_1024_1366_240730.mp4" type="video/mp4" media="(max-width: 1024px)"/> </video> <video class="ghtb__bg _w" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_fe_maker_film_1920_1080_240807.mp4" type="video/mp4"/> </video> <picture class="poster"> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_fe_maker_film_390_844_240730.jpg" media="(max-width: 767px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_fe_maker_film_1024_1366_240730.jpg" media="(max-width: 1024px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_fe_maker_film_1920_1080_240801.jpg"/> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/LC_VentusxRST_19LC_VentusxRST_1920_970_23103020_970_231030.jpg" alt=""/> </picture> <div class="progress"><div class="thumb"></div></div> </div> <div class="ghtb__item swiper-slide"> <video class="ghtb__bg _m" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ionic5_brandfilmnew_390_844_240318.mp4" type="video/mp4" media="(max-width: 767px)"/> </video> <video class="ghtb__bg _t" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ionic5_brandfilmnew_1024_1366_240318.mp4" type="video/mp4" media="(max-width: 1024px)"/> </video> <video class="ghtb__bg _w" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ionic5_brandfilmnew_1920_1080_240319.mp4" type="video/mp4"/> </video> <picture class="poster"> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ionic5_brandfilmnew_390_844_240318.jpg" media="(max-width: 767px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ionic5_brandfilmnew_1024_1366_240318.jpg" media="(max-width: 1024px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_hkt_ionic5_brandfilmnew_1920_1080_240319.jpg"/> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/LC_VentusxRST_19LC_VentusxRST_1920_970_23103020_970_231030.jpg" alt=""/> </picture> <div class="progress"><div class="thumb"></div></div> </div> <div class="ghtb__item swiper-slide"> <video class="ghtb__bg _m" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_kinergy_390_844_230523.mp4" type="video/mp4" media="(max-width: 767px)"/> </video> <video class="ghtb__bg _t" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_kinergy_390_844_230523.mp4" type="video/mp4" media="(max-width: 1024px)"/> </video> <video class="ghtb__bg _w" muted playsinline preload="none" decoding="async" loding="lazy" data-first-load="true"> <source src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_kinergy_1920_1080_230523.mp4" type="video/mp4"/> </video> <picture class="poster"> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_kinergy_390_844_230523.jpg" media="(max-width: 767px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_kinergy_390_844_230523.jpg" media="(max-width: 1024px)"/> <source srcset="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/GL_kinergy_1920_1080_230523.jpg"/> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/LC_VentusxRST_19LC_VentusxRST_1920_970_23103020_970_231030.jpg" alt=""/> </picture> <div class="progress"><div class="thumb"></div></div> <a class="btn btn--round" href="/global/en/tires/kinergy.html">View Kinergy Brand</a> </div> </div> <div class="ghtb__pagination swiper-pagination"></div> </div> <!-- // HT-388 --> </section> <script src="/etc.clientlibs/hankooktire/components/content/global/global-home-top-banner/clientlibs.min.js"></script> </div> </div> <div class="global-home-image-list parbase"> <div class="pt-xl pb-xs "> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/components/content/global/global-home-image-list/clientlibs.min.css" type="text/css"> <section class="ghil"> <div class="ghil-container section--full"> <aside class="ghil-menu" data-partial> <div class="ghil-menu__inner"> <a href="/global/en/tech-in-motion-list.html" class="ghil-menu__logo" target="_self"> <!-- [DOES] 220216 이미지 영역에 a태그 추가--> <img class="ghil-menu__tit" src="https://asset.hankooktire.com/content/dam/hankooktire/global/svg/gl_imagelist_logo_technology-in-motion.svg" alt="logo - technology in motion"/> </a> <div class="ghil-menu__wrap"> <div class="ghil-menu__container"> <div class="ghil-menu__container-inner"> <ul class="ghil-menu__list"> <li class="ghil-menu__item"> <a class="is-active" href="#" data-cmd data-case="all">All</a> </li> <li class="ghil-menu__item"> <a href="#">High-Tech</a> </li> <li class="ghil-menu__item"> <a href="#">Brand</a> </li> <li class="ghil-menu__item"> <a href="#">Design</a> </li> <li class="ghil-menu__item"> <a href="#">People & Culture</a> </li> <li class="ghil-menu__item"> <a href="#">Mobility Culture</a> </li> </ul> <ul class="ghil-menu__company" data-cate="Company"> <li class="ghil-menu__item"><a href="#" data-cmd class="grid-tripple">For Investors</a></li> <li class="ghil-menu__item"><a href="#" data-cmd>About Hankook</a></li> <li class="ghil-menu__item"><a href="#" data-cmd>Hankooktire ESG</a></li> </ul> </div> </div> </div> </div> </aside> <div class="ghil-list" data-partial> <ul class="ghil-list__list"> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/design-innovation-a-10-year-journey.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/design-innovation-a-10-year-journey/Design-Innovation-th.jpg" alt="Hankook Tire's 'Design Innovation', a 10-year journey"/> </div> <ul class="tags"> <li>Brand</li> <li>Design</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Hankook Tire's 'Design Innovation', a 10-year journey</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/drive-with-culture-and-art.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/culture-brand-drive-and-art/240609_BC_DM_DRIVE_001-th.jpg" alt=""DRIVE with Culture and Art! (Interview ver.)""/> </div> <ul class="tags"> <li>Brand</li> <li>Design</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">"DRIVE with Culture and Art! (Interview ver.)"</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/made-in-hankook2022.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/made-in-hankook/kv-th.jpg" alt=" Innovation + Future + Culture = MADE IN HANKOOK "/> </div> <ul class="tags"> <li>Brand</li> <li>Design</li> <li>People & Culture</li> </ul> <strong class="font_body_1"> Innovation + Future + Culture = MADE IN HANKOOK </strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/ion-x-formula-e-season-9-on-the-fast-track-towards-sustainability.html"> <div class="thumb thumb--sm"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/fe-season-9-results/00_FE_Season_9_Results_t.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">iON X Formula E Season 9, On the fast track towards sustainability</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/ion-quietness.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/ion-completes-the-intrinsic-value-of-ev-the-quietness/iON-Main-th.jpg" alt="iON Completes the Intrinsic Value of EV - The Quietness"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">iON Completes the Intrinsic Value of EV - The Quietness</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/the-most-perfect-tire-from-the-state-of-the-art-test-track.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/the-most-perfect-tire-from-the-state-of-the-art-test-track/test-track-th.jpg" alt="The Most Perfect Tire from the State-of-the-Art Test Track"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">The Most Perfect Tire from the State-of-the-Art Test Track</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/tire-wear-story.html"> <div class="thumb thumb--md"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/peaches-collaboration/collab_th_1_1.jpg" alt="Tire Wear Story"/> </div> <ul class="tags"> <li>Brand</li> <li>Design</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Tire Wear Story</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/dynapro.html"> <div class="thumb thumb--md"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/tech-in-motion_thumbnail/686x686/03_Dynapro_686x686.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">Dynapro: Driving Fearlessly through Intense Conditions</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/the-center-of-a-new-mobility-culture-hankook-tire-drive.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/the-center-of-a-new-mobility-culture-hankook-tire-drive/240609_BC_DM_DRIVE_001-th002.jpg" alt="The center of a new mobility culture, Hankook Tire ‘DRIVE’"/> </div> <ul class="tags"> <li>Brand</li> <li>Design</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">The center of a new mobility culture, Hankook Tire ‘DRIVE’</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/technodome.html"> <div class="thumb thumb--lg"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/technodome_1/technodome_th.jpg" alt="A Lab Built for the Future "/> </div> <ul class="tags"> <li>High-Tech</li> <li>Design</li> </ul> <strong class="font_body_1">A Lab Built for the Future </strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/design-innovation-creating-future-mobility-vision.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/design-innovation-creating-future-mobility-vision/design-innovation-th.jpg" alt="Design innovation, Creating ‘Future Mobility Vision’"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Design</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Design innovation, Creating ‘Future Mobility Vision’</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/ventus-maintains-a-comfortable-ride-even-in-extreme-situations.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/ventus-maintains-a-comfortable-ride-even-in-extreme-situations/ventus_maintains_th.jpg" alt="Ventus maintains a comfortable ride even in extreme situations"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">Ventus maintains a comfortable ride even in extreme situations</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/the-test-bed-built-for-testing-extreme-tire-technology.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/flagship-proving-ground-hankook-technoring/flagship-proving-ground-hankook-technoring-th.jpg" alt="The Test Bed Built for Testing Extreme Tire Technology"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">The Test Bed Built for Testing Extreme Tire Technology</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/leading-sustainability-with-esg-management.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/leading-sustainability-with-esg-management/th-esg-management.png" alt="Leading Sustainability with ESG Management"/> </div> <ul class="tags"> <li>Brand</li> <li>People & Culture</li> </ul> <strong class="font_body_1">Leading Sustainability with ESG Management</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/ev-tire.html"> <div class="thumb thumb--sm"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/tech-in-motion/8_ev_tire/2_686x520.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">EV Tires, Standing at the Inflection Point</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/24-series-dubai.html"> <div class="thumb thumb--md"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/tech-in-motion_thumbnail/686x686/dubai_686x686_new1.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Dubai 24 Hour Race, A Dash to the Finish Line</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/test-result.html"> <div class="thumb thumb--md"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/article-thumb-5.jpg" alt="Magazine Test, A Stage to Evaluate A Brand’s Technology"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">Magazine Test, A Stage to Evaluate A Brand’s Technology</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/kinergy-tire.html"> <div class="thumb thumb--md"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/kinergy_tire/kinergy_4S2X_th.jpg" alt="Kinergy 4S2X Responds to the Calls of the Market"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">Kinergy 4S2X Responds to the Calls of the Market</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/iscc.html"> <div class="thumb thumb--lg"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/iscc/iscc_th_3.jpg" alt="Hankook receives ISCC PLUS Certification"/> </div> <ul class="tags"> <li>Brand</li> <li>People & Culture</li> </ul> <strong class="font_body_1">Hankook receives ISCC PLUS Certification</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/new-tire-new-formula-e.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/new-tire-new-formula-e/hankook_1285_PC_th.jpg" alt="New Tire, New Formula E "/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">New Tire, New Formula E </strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/the-intrinsic-value-of-ev-ion.html"> <div class="thumb thumb--sm"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/the-intrinsic-value-of-ev-ion/th_03.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">The Intrinsic Value of EV enjoyed with iON</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/making-bespoke-tires.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/make-bespoke-tires/KV_1372-1040.jpg" alt="Making Bespoke Tires"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>People & Culture</li> </ul> <strong class="font_body_1">Making Bespoke Tires</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/empowering-mobility-innovation-through-oe-tire-business.html"> <div class="thumb thumb--sm"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/empowering-mobility-innovation-through-oe-tire-business/00_(686x520)new.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">Empowering Mobility Innovation through ‘OE Tire Business’ </strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/motorsport-circuit.html"> <div class="thumb thumb--md"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/The_Holy_Land_of_Speed_img_thumbnail.png" alt="Motorsport Circuit: The Holy Land of Speed"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Motorsport Circuit: The Holy Land of Speed</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/hip-next-generation.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/hip-next-generation/kv_th.jpg" alt="HIP, A Visible Approach to the Next-gen Mobility Landscape"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">HIP, A Visible Approach to the Next-gen Mobility Landscape</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/creating-brand-familiarization-through-collaboration.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/creating-brand-familiarization-through-collaboration/KV-TH.jpg" alt="Creating Brand Familiarization through ‘Collaboration’"/> </div> <ul class="tags"> <li>Brand</li> <li>Design</li> <li>People & Culture</li> </ul> <strong class="font_body_1">Creating Brand Familiarization through ‘Collaboration’</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/ev-test.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/ev_test/ev_test_th_new.jpg" alt="EV Tires: Advancement Achieved through Testing"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">EV Tires: Advancement Achieved through Testing</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/fe-season-10-sponsorship.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/fe-season-10-sponsorship/FE-Season-10-Sponsorship-th.jpg" alt="Formula E Season 10, A Fast Sprint with iON"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Formula E Season 10, A Fast Sprint with iON</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/road-risk-detection-solution.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/road-risk-detection-solution/sound_th.jpg" alt="Detecting Road Hazards with Sound"/> </div> <ul class="tags"> <li>High-Tech</li> </ul> <strong class="font_body_1">Detecting Road Hazards with Sound</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/intelligence.html"> <div class="thumb thumb--lg"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/intelligence/intelligence_th.jpg" alt="Leading Next-gen Driving, Intelligent Tires "/> </div> <ul class="tags"> <li>High-Tech</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Leading Next-gen Driving, Intelligent Tires </strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/formula-e-opens-the-door-to-the-next-era.html"> <div class="thumb thumb--md"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/formula-e-opens-the-door-to-the-next-era/FE-MONACO_686x686.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Formula E Opens the Door to the Next Era</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/a-future-that-removes-air-and-adds-innovation.html"> <div class="thumb thumb--sm"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/a-future-that-removes-air-and-adds-innovation/01_686x520.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> </ul> <strong class="font_body_1">A future that removes air and adds innovation</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/brand-collaboration.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/brand-collaboration/collab_th_2.jpg" alt="Collaboration – A key to Building Brand Value"/> </div> <ul class="tags"> <li>Brand</li> <li>Design</li> <li>People & Culture</li> </ul> <strong class="font_body_1">Collaboration – A key to Building Brand Value</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/champions-of-the-extreme.html"> <div class="thumb thumb--sm"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/nuerburgring-24h/nuerburgring_thumbnail.jpg" alt="Champions of the Extreme"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Champions of the Extreme</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/long-time-partner-of-the-uefa-europa-league.html"> <div class="thumb thumb--sm"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/long-time-partner-of-the-uefa-europa-league/Main_686x520.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>Brand</li> <li>People & Culture</li> </ul> <strong class="font_body_1">Long-Time Partner of the UEFA Europa League</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/hankook-tire-and-formula-e-deliver-a-new-motorsport-experience.html"> <div class="thumb thumb--sm"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/hankook-tire-and-formula-e-deliver-a-new-motorsport-experience-/01_Main_MO.mp4" muted playsinline autoplay loop></video> </div> <ul class="tags"> <li>High-Tech</li> <li>Brand</li> <li>Mobility Culture</li> </ul> <strong class="font_body_1">Hankook Tire and Formula E Deliver a New Motorsport Experience</strong> </a> </li> <li class="ghil-list__item"> <a href="/global/en/tech-in-motion/technoplex.html"> <div class="thumb thumb--md"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/technology-in-motion/technoplex/technoplex_th.jpg" alt="Technoplex, Changes the Way We Work"/> </div> <ul class="tags"> <li>High-Tech</li> <li>Design</li> <li>People & Culture</li> </ul> <strong class="font_body_1">Technoplex, Changes the Way We Work</strong> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/investors/financial-information-results/key-figures.html" target="_blank" rel="noopener noreferrer"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/for-investors1.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>For Investors</li> </ul> <strong class="font_body_1">Financial Information & Results</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/investors/shares-shareholders/distribution-shares.html" target="_self"> <div class="thumb thumb--lg"> <img src="/content/dam/hankooktire/global/images/home/company_banner/for-investors2.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>For Investors</li> </ul> <strong class="font_body_1">Distribution of Shares</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/investors/financial-reports/annual-reports.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/for-investors3.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>For Investors</li> </ul> <strong class="font_body_1">Financial Reports</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/company/company-overview.html" target="_self"> <div class="thumb thumb--lg"> <img src="/content/dam/hankooktire/global/images/home/company_banner/for-investors4.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>For Investors</li> </ul> <strong class="font_body_1">Company Overview</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/company/awards/design-award.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/about-hankook5.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>For Investors</li> </ul> <strong class="font_body_1">Award</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/company/global-network.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/for-investors6.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>For Investors</li> </ul> <strong class="font_body_1">Global Network</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/inside-hankook.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/about-hankook1.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>About Hankook</li> </ul> <strong class="font_body_1">Inside Hankook</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/innovation/technodome.html" target="_self"> <div class="thumb thumb--lg"> <img src="/content/dam/hankooktire/global/images/home/company_banner/about-hankook2.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>About Hankook</li> </ul> <strong class="font_body_1">Technodome</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/innovation/design-innovation.html" target="_self"> <div class="thumb thumb--sm"> <img src="/content/dam/hankooktire/global/images/home/company_banner/about-hankook3.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>About Hankook</li> </ul> <strong class="font_body_1">Design Innovation</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/company/global-automotive-partnership.html" target="_self"> <div class="thumb thumb--lg"> <img src="/content/dam/hankooktire/global/images/home/company_banner/about-hankook4.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>About Hankook</li> </ul> <strong class="font_body_1">Global Automotive Partnership</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/company/awards/brand-award.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/about-hankook5.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>About Hankook</li> </ul> <strong class="font_body_1">Award</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/esg/hankook-tire-esg/esg-overview.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/esg1.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>Hankooktire ESG</li> </ul> <strong class="font_body_1">Hankook Tire ESG</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/esg/governance.html" target="_self"> <div class="thumb thumb--lg"> <img src="/content/dam/hankooktire/global/images/home/company_banner/esg2.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>Hankooktire ESG</li> </ul> <strong class="font_body_1">Governance</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/esg/esg-report.html" target="_self"> <div class="thumb thumb--lg"> <img src="/content/dam/hankooktire/global/images/home/company_banner/esg3.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>Hankooktire ESG</li> </ul> <strong class="font_body_1">ESG Report</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/esg/sustainable-product.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/esg4.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>Hankooktire ESG</li> </ul> <strong class="font_body_1">Sustainable Product</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/esg/eco-value-chain.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/esg5.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>Hankooktire ESG</li> </ul> <strong class="font_body_1">Eco Value Chain</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/esg/responsible-engagement.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/esg6.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>Hankooktire ESG</li> </ul> <strong class="font_body_1">Responsible Engagement</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/company/awards/esg-award.html" target="_self"> <div class="thumb thumb--md"> <img src="/content/dam/hankooktire/global/images/home/company_banner/about-hankook5.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>Hankooktire ESG</li> </ul> <strong class="font_body_1">ESG Award</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> <li class="ghil-list__item hidden"> <a href="/global/en/company/media-list.html" target="_self"> <div class="thumb thumb--lg"> <img src="/content/dam/hankooktire/global/images/home/company_banner/esg8.jpg"/> </div> <div class="title-wrap"> <div class="tags-wrap"> <ul class="tags company"> <li>Hankooktire ESG</li> </ul> <strong class="font_body_1">Media Center</strong> </div> <button class="btn btn--round btn--invert"></button> </div> </a> </li> </ul> <div class="no_data font_body_1_main">No Data</div> <a href="/global/en/tech-in-motion-list.html" class="btn btn--round btn--line btn--plus btn-more" target="_self"> Show More </a> </div> </div> </section> <script src="/etc.clientlibs/hankooktire/components/content/global/global-home-image-list/clientlibs.min.js"></script> </div> </div> <div class="free-coding-component parbase"> <div> <section class="fcc"> <style> .ghbs{padding-top:16rem}@media all and (max-width:1024px){.ghbs{padding-top:8.8rem}}.ghbs .display{display:none;position:absolute;width:100%;height:100%;background-color:#010101}.ghbs .display>a{display:block}.ghbs .display.is-active{display:flex}.ghbs .display .display__wrap{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;justify-content:center;align-items:center;z-index:3;width:100%;height:100%;pointer-events:none}@media all and (max-width:1024px){.ghbs .display .display__wrap{top:9.375vw;transform:translateX(-50%);height:auto}}@media all and (max-width:767px){.ghbs .display .display__wrap{top:18vw}}.ghbs .display .display__wrap .display__lottie{width:21.875vw}@media all and (max-width:1024px){.ghbs .display .display__wrap .display__lottie{width:37.5vw}}@media all and (max-width:767px){.ghbs .display .display__wrap .display__lottie{width:max(22rem,50vw)}}.ghbs .display .display__ghbs{display:block;position:relative;width:auto;height:100%;margin:0 auto}.ghbs .display .svg_wrap{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%}.ghbs .display .display__bg{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;object-fit:cover}.ghbs .display .display__blur{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;backdrop-filter:blur(40px)}.ghbs .display .mask_img{width:100%;height:100%}@keyframes clipPathFrame{0%{clip-path:polygon(0% 0%,100% 0%,100% 100%,-20% 100%)}70%{clip-path:polygon(120% 0%,100% 0%,100% 100%,100% 100%)}100%{clip-path:polygon(120% 0%,100% 0%,100% 100%,100% 100%)}}@keyframes clipPathStroke{0%{clip-path:polygon(0% 0%,100% 0%,100% 100%,-20% 100%)}30%{clip-path:polygon(0% 0%,100% 0%,100% 100%,-20% 100%)}100%{clip-path:polygon(120% 0%,100% 0%,100% 100%,100% 100%)}}@keyframes clipPathBlur{0%{clip-path:polygon(0% 0%,0% 0%,-20% 100%,0% 100%)}30%{clip-path:polygon(0% 0%,0% 0%,-20% 100%,0% 100%)}100%{clip-path:polygon(0% 0%,120% 0%,100% 100%,0% 100%)}}.ghbs .display .display__logo_stroke{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-width:none;width:100%;height:100%}.ghbs .display .display__logo_stroke path{stroke:#fafafa;stroke-width:.2rem;fill:transparent}@media all and (max-width:1024px){.ghbs .display .display__logo_stroke path{stroke-width:.1rem}}.ghbs .display .display__logo_blur{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-width:none;width:100%;height:100%;background:rgba(255,255,255,.5);backdrop-filter:blur(40px);clip-path:polygon(0% 0%,0% 0%,-10% 100%,0% 100%)}.ghbs .display .display__logo_frame_wrap,.ghbs .display .display__logo_frame{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;max-width:none;width:100%;height:100%}.ghbs .display .display__logo_frame_wrap path,.ghbs .display .display__logo_frame path{stroke:#fafafa;stroke-width:.2rem;fill:#fafafa}.ghbs .display .display__logo_frame_wrap .content,.ghbs .display .display__logo_frame .content{z-index:2}.ghbs .display .display__logo_frame_wrap .content *,.ghbs .display .display__logo_frame .content *{color:#000}.ghbs .display .display__logo_frame_wrap .content .btn:after,.ghbs .display .display__logo_frame .content .btn:after{background-color:rgba(0,0,0,.05)}.ghbs .display.is-animation .display__logo_stroke{animation:clipPathStroke 1s ease-in;clip-path:polygon(120% 0%,100% 0%,100% 100%,100% 100%)}.ghbs .display.is-animation .display__logo_blur{animation:clipPathBlur 1s ease-in;clip-path:polygon(0% 0%,120% 0%,100% 100%,0% 100%)}.ghbs .display.is-animation .display__logo_frame_wrap{animation:clipPathFrame 1s ease-in;clip-path:polygon(120% 0%,100% 0%,100% 100%,100% 100%)}.ghbs .display.no-animation .display__logo_frame_wrap{animation:none;clip-path:polygon(120% 0%,100% 0%,100% 100%,100% 100%)}.ghbs .content{position:absolute;right:0;bottom:8%;width:38%}@media all and (max-width:1366px){.ghbs .content{bottom:7%}.ghbs .content br{display:none}}@media all and (max-width:1024px){.ghbs .content{bottom:5rem;left:50%;max-width:26.2rem;transform:translateX(-50%)}}@media all and (max-width:767px){.ghbs .content{width:74%;max-width:inherit;left:17vw;bottom:15vw;transform:none}}.ghbs .content .btn,.ghbs .content .desc{color:#fff}.ghbs .content .btn{margin-top:1.6rem}@media all and (max-width:1366px){.ghbs .content .btn{margin-top:1.2rem}}@media all and (max-width:1024px){.ghbs .content .btn{margin-top:1.1rem}}.ghbs .content .btn:after{background-color:#fff}.ghbs .content .desc{font-size:2.4rem;font-weight:500;letter-spacing:-.015em;line-height:1.4}@media all and (max-width:1366px){.ghbs .content .desc{font-size:2rem}}@media all and (max-width:1024px){.ghbs .content .desc{font-size:1.6rem}}.ghbs__display{position:relative;overflow:hidden;height:0;padding-bottom:41%}@media all and (max-width:1024px){.ghbs__display{padding-bottom:93%}}@media all and (max-width:767px){.ghbs__display{padding-bottom:160%}}.ghbs__container{position:relative;overflow:hidden;margin-top:2rem}@media all and (max-width:1366px){.ghbs__container{margin-left:max(-8rem,-4.17vw);margin-right:max(-8rem,-4.17vw)}}@media all and (max-width:767px){.ghbs__container{margin-left:-2rem;margin-right:-2rem}}.ghbs__container+.divider::before{background-color:rgba(0,0,0,.15)}@media all and (max-width:1024px){.ghbs__container{margin-top:.4rem}}.ghbs__list{display:flex;justify-content:center;white-space:nowrap}@media all and (max-width:1366px){.ghbs__list{justify-content:initial}}@media all and (max-width:1024px){.ghbs__list{min-width:108rem}}.ghbs__item{position:relative;display:flex;align-items:center;justify-content:center;flex:1;height:8rem;transition:border .3s;background-repeat:no-repeat;background-position:center;min-width:22rem}@media all and (max-width:1024px){.ghbs__item{min-width:20rem;height:6.8rem;background-size:30rem auto}.ghbs__item.ghbs__item-weather-flex{background-size:20rem auto;}.ghbs__item.ghbs__item-smart{background-size:14rem auto;}.ghbs__item.ghbs__item-vantra{background-size:11.6rem auto}}@media all and (max-width:767px){.ghbs__item{min-width:18rem;height:6.8rem;background-size:30rem auto}.ghbs__item.ghbs__item-weather-flex{background-size:17rem auto;}}.ghbs__item:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:.1rem;background-color:transparent;transition:background .3s}.ghbs__item.is-active:after{background-color:#000}.ghbs__item.ghbs__item-weather-flex{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/weather-flex/tab-logo.svg);}.ghbs__item.ghbs__item-weather-flex:hover,.ghbs__item.ghbs__item-weather-flex.is-active{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/weather-flex/tab-logo-hov.svg);}.ghbs__item.ghbs__item-weather-flex.is-active:after{background-color:#007934;}.ghbs__item.ghbs__item-ion{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ion/tab-logo.svg)}.ghbs__item.ghbs__item-ion:hover,.ghbs__item.ghbs__item-ion.is-active{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ion/tab-logo-hov.svg)}.ghbs__item.ghbs__item-ion.is-active:after{background-color:#00bac6}.ghbs__item.ghbs__item-ventus{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ventus/tab-logo.svg)}.ghbs__item.ghbs__item-ventus:hover,.ghbs__item.ghbs__item-ventus.is-active{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ventus/tab-logo-hov.svg)}.ghbs__item.ghbs__item-ventus.is-active:after{background-color:#eb5803}.ghbs__item.ghbs__item-dynapro{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/dynapro/tab-logo.svg)}.ghbs__item.ghbs__item-dynapro:hover,.ghbs__item.ghbs__item-dynapro.is-active{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/dynapro/tab-logo-hov.svg)}.ghbs__item.ghbs__item-dynapro.is-active:after{background-color:#a58800}.ghbs__item.ghbs__item-kinergy{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/kinergy/tab-logo.svg)}.ghbs__item.ghbs__item-kinergy:hover,.ghbs__item.ghbs__item-kinergy.is-active{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/kinergy/tab-logo-hov.svg)}.ghbs__item.ghbs__item-kinergy.is-active:after{background-color:#6fba2c}.ghbs__item.ghbs__item-winter-icept{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/winter-icept/tab-logo.svg)}.ghbs__item.ghbs__item-winter-icept:hover,.ghbs__item.ghbs__item-winter-icept.is-active{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/winter-icept/tab-logo-hov.svg)}.ghbs__item.ghbs__item-winter-icept.is-active:after{background-color:#0095d9}.ghbs__item.ghbs__item-smart{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/smart/tab-logo.svg)}.ghbs__item.ghbs__item-smart:hover,.ghbs__item.ghbs__item-smart.is-active{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/smart/tab-logo-hov.svg)}.ghbs__item.ghbs__item-smart.is-active:after{background-color:#727171}.ghbs__item.ghbs__item-vantra{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/vantra/tab-logo.svg);}.ghbs__item.ghbs__item-vantra:hover,.ghbs__item.ghbs__item-vantra.is-active{background-image:url(/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/vantra/tab-logo-hov.svg);}.ghbs__item.ghbs__item-vantra.is-active:after{background-color:#002856;}.ghbs__item a{display:block;width:100%;height:100%;text-align:center} </style> <section class="ghbs"> <div class="section--full"> <div class="ghbs__display"> <div class="display is-active" data-id="ion"> <a href="/global/en/tires/ion.html"> <img class="display__bg t_none" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ion/bg.jpg" alt="배경이미지"> <img class="display__bg t_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ion/bg-m.jpg" alt="배경이미지"> <img class="display__bg m_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ion/bg-m.jpg" alt="배경이미지"> <div class="display__wrap"> <div class="display__lottie"></div> </div> <!-- 웹 --> <div class="svg_wrap t_none"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape1" d="M-3006-8314H-4766v-720h1760v720Zm-941.921-434.347a226.092,226.092,0,0,0-48.233,4.856,145.794,145.794,0,0,0-39.423,14.413,100.39,100.39,0,0,0-29.062,23.729,90.222,90.222,0,0,0-17.153,32.811l-7.951,27.73c-5.716,19.938-3.918,36.313,5.345,48.668a49.285,49.285,0,0,0,12.8,11.7,78.024,78.024,0,0,0,18.318,8.447c13.991,4.532,31.647,6.883,52.478,6.985h2.9a230.2,230.2,0,0,0,48.528-5.016,141.2,141.2,0,0,0,38.875-14.418,104.246,104.246,0,0,0,15.524-10.683,92.228,92.228,0,0,0,12.757-12.971,89.8,89.8,0,0,0,9.874-15.235,96.878,96.878,0,0,0,6.872-17.482l7.951-27.73c2.814-9.809,3.736-18.893,2.74-27a43.548,43.548,0,0,0-8.422-21.2c-6.813-9.043-17.541-15.986-31.884-20.64C-3909.348-8746-3927.123-8748.347-3947.921-8748.347Zm189.969,51.525a3.937,3.937,0,0,1,3.471,2l60.9,108.029c5.085,8.59,8.759,14.795,23.01,14.795h30.156c15.991,0,25.547-7.286,30.075-22.929l39.237-136.141a18.912,18.912,0,0,0,.775-4.6v-.726a8.182,8.182,0,0,0-1.5-4.747c-2.078-2.791-6.435-4.206-12.948-4.206h-12.982c-12.417,0-20.2,5.115-23.13,15.2L-3651.477-8624a4.4,4.4,0,0,1-3.535,3.124,4.291,4.291,0,0,1-.658.052,3.924,3.924,0,0,1-3.455-1.994l-60.292-106.536-.011-.02c-5.889-10.63-8.845-15.966-24.076-15.966h-29.291c-16.175,0-25.819,7.282-30.351,22.917l-40.3,135.746c-1.287,4.407-1.091,7.784.581,10.037,2.064,2.8,6.544,4.217,13.315,4.217h13.032c12.2,0,19.882-5.114,22.817-15.2l31.569-106.055a4.413,4.413,0,0,1,3.555-3.1A4.215,4.215,0,0,1-3757.951-8696.821Zm-388.185-48.523a13.987,13.987,0,0,0-8.478,2.837,13.985,13.985,0,0,0-5.065,7.365l-41.771,145.183a14.218,14.218,0,0,0-.551,3.625v.556a13.894,13.894,0,0,0,1.154,5.273,14.148,14.148,0,0,0,2.984,4.389,13.967,13.967,0,0,0,9.953,4.116h22.4a13.985,13.985,0,0,0,8.479-2.837,13.971,13.971,0,0,0,5.063-7.363l41.774-145.183a13.97,13.97,0,0,0-2.294-12.356,13.971,13.971,0,0,0-11.248-5.6Zm54.6-57.8a13.977,13.977,0,0,0-8.478,2.837,13.973,13.973,0,0,0-5.064,7.364l-7.7,26.88a16.089,16.089,0,0,0,2.639,14.234,16.351,16.351,0,0,0,5.553,4.686,16.064,16.064,0,0,0,7.406,1.775h19.528a13.955,13.955,0,0,0,8.466-2.832,13.952,13.952,0,0,0,5.053-7.359l8.49-29.635a13.96,13.96,0,0,0-2.291-12.348,13.959,13.959,0,0,0-11.24-5.6Zm100.8,204.1a131.988,131.988,0,0,1-15.219-.8,72.247,72.247,0,0,1-12.456-2.479,39.767,39.767,0,0,1-9.656-4.269,25.47,25.47,0,0,1-6.82-6.166,23.439,23.439,0,0,1-3.407-6.432,29.84,29.84,0,0,1-1.52-7.793,46.137,46.137,0,0,1,.388-9.215,76.407,76.407,0,0,1,2.316-10.694l6.761-23.57a83.3,83.3,0,0,1,4.33-11.81,64.372,64.372,0,0,1,5.7-10,55.157,55.157,0,0,1,7.077-8.259,54.078,54.078,0,0,1,8.476-6.594c11.94-7.522,27.717-11.18,48.234-11.18a130.416,130.416,0,0,1,15.2.812,71.9,71.9,0,0,1,12.439,2.5,39.8,39.8,0,0,1,9.645,4.289,25.612,25.612,0,0,1,6.815,6.176,23.573,23.573,0,0,1,3.418,6.439,29.878,29.878,0,0,1,1.531,7.789,45.917,45.917,0,0,1-.375,9.19,75.576,75.576,0,0,1-2.3,10.645l-6.759,23.57c-4.863,16.963-13.238,28.984-25.6,36.753C-3954.406-8602.672-3970.176-8599.042-3990.733-8599.042Z" transform="translate(4766 9034)" /> </defs> <clipPath id="clipPath1"> <use xlink:href="#polygonShape1"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath1);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ion/bg.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M-3006-8314H-4766v-720h1760v720Zm-941.921-434.347a226.092,226.092,0,0,0-48.233,4.856,145.794,145.794,0,0,0-39.423,14.413,100.39,100.39,0,0,0-29.062,23.729,90.222,90.222,0,0,0-17.153,32.811l-7.951,27.73c-5.716,19.938-3.918,36.313,5.345,48.668a49.285,49.285,0,0,0,12.8,11.7,78.024,78.024,0,0,0,18.318,8.447c13.991,4.532,31.647,6.883,52.478,6.985h2.9a230.2,230.2,0,0,0,48.528-5.016,141.2,141.2,0,0,0,38.875-14.418,104.246,104.246,0,0,0,15.524-10.683,92.228,92.228,0,0,0,12.757-12.971,89.8,89.8,0,0,0,9.874-15.235,96.878,96.878,0,0,0,6.872-17.482l7.951-27.73c2.814-9.809,3.736-18.893,2.74-27a43.548,43.548,0,0,0-8.422-21.2c-6.813-9.043-17.541-15.986-31.884-20.64C-3909.348-8746-3927.123-8748.347-3947.921-8748.347Zm189.969,51.525a3.937,3.937,0,0,1,3.471,2l60.9,108.029c5.085,8.59,8.759,14.795,23.01,14.795h30.156c15.991,0,25.547-7.286,30.075-22.929l39.237-136.141a18.912,18.912,0,0,0,.775-4.6v-.726a8.182,8.182,0,0,0-1.5-4.747c-2.078-2.791-6.435-4.206-12.948-4.206h-12.982c-12.417,0-20.2,5.115-23.13,15.2L-3651.477-8624a4.4,4.4,0,0,1-3.535,3.124,4.291,4.291,0,0,1-.658.052,3.924,3.924,0,0,1-3.455-1.994l-60.292-106.536-.011-.02c-5.889-10.63-8.845-15.966-24.076-15.966h-29.291c-16.175,0-25.819,7.282-30.351,22.917l-40.3,135.746c-1.287,4.407-1.091,7.784.581,10.037,2.064,2.8,6.544,4.217,13.315,4.217h13.032c12.2,0,19.882-5.114,22.817-15.2l31.569-106.055a4.413,4.413,0,0,1,3.555-3.1A4.215,4.215,0,0,1-3757.951-8696.821Zm-388.185-48.523a13.987,13.987,0,0,0-8.478,2.837,13.985,13.985,0,0,0-5.065,7.365l-41.771,145.183a14.218,14.218,0,0,0-.551,3.625v.556a13.894,13.894,0,0,0,1.154,5.273,14.148,14.148,0,0,0,2.984,4.389,13.967,13.967,0,0,0,9.953,4.116h22.4a13.985,13.985,0,0,0,8.479-2.837,13.971,13.971,0,0,0,5.063-7.363l41.774-145.183a13.97,13.97,0,0,0-2.294-12.356,13.971,13.971,0,0,0-11.248-5.6Zm54.6-57.8a13.977,13.977,0,0,0-8.478,2.837,13.973,13.973,0,0,0-5.064,7.364l-7.7,26.88a16.089,16.089,0,0,0,2.639,14.234,16.351,16.351,0,0,0,5.553,4.686,16.064,16.064,0,0,0,7.406,1.775h19.528a13.955,13.955,0,0,0,8.466-2.832,13.952,13.952,0,0,0,5.053-7.359l8.49-29.635a13.96,13.96,0,0,0-2.291-12.348,13.959,13.959,0,0,0-11.24-5.6Zm100.8,204.1a131.988,131.988,0,0,1-15.219-.8,72.247,72.247,0,0,1-12.456-2.479,39.767,39.767,0,0,1-9.656-4.269,25.47,25.47,0,0,1-6.82-6.166,23.439,23.439,0,0,1-3.407-6.432,29.84,29.84,0,0,1-1.52-7.793,46.137,46.137,0,0,1,.388-9.215,76.407,76.407,0,0,1,2.316-10.694l6.761-23.57a83.3,83.3,0,0,1,4.33-11.81,64.372,64.372,0,0,1,5.7-10,55.157,55.157,0,0,1,7.077-8.259,54.078,54.078,0,0,1,8.476-6.594c11.94-7.522,27.717-11.18,48.234-11.18a130.416,130.416,0,0,1,15.2.812,71.9,71.9,0,0,1,12.439,2.5,39.8,39.8,0,0,1,9.645,4.289,25.612,25.612,0,0,1,6.815,6.176,23.573,23.573,0,0,1,3.418,6.439,29.878,29.878,0,0,1,1.531,7.789,45.917,45.917,0,0,1-.375,9.19,75.576,75.576,0,0,1-2.3,10.645l-6.759,23.57c-4.863,16.963-13.238,28.984-25.6,36.753C-3954.406-8602.672-3970.176-8599.042-3990.733-8599.042Z" transform="translate(4766 9034)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M-3006-8314H-4766v-720h1760v720Zm-941.921-434.347a226.092,226.092,0,0,0-48.233,4.856,145.794,145.794,0,0,0-39.423,14.413,100.39,100.39,0,0,0-29.062,23.729,90.222,90.222,0,0,0-17.153,32.811l-7.951,27.73c-5.716,19.938-3.918,36.313,5.345,48.668a49.285,49.285,0,0,0,12.8,11.7,78.024,78.024,0,0,0,18.318,8.447c13.991,4.532,31.647,6.883,52.478,6.985h2.9a230.2,230.2,0,0,0,48.528-5.016,141.2,141.2,0,0,0,38.875-14.418,104.246,104.246,0,0,0,15.524-10.683,92.228,92.228,0,0,0,12.757-12.971,89.8,89.8,0,0,0,9.874-15.235,96.878,96.878,0,0,0,6.872-17.482l7.951-27.73c2.814-9.809,3.736-18.893,2.74-27a43.548,43.548,0,0,0-8.422-21.2c-6.813-9.043-17.541-15.986-31.884-20.64C-3909.348-8746-3927.123-8748.347-3947.921-8748.347Zm189.969,51.525a3.937,3.937,0,0,1,3.471,2l60.9,108.029c5.085,8.59,8.759,14.795,23.01,14.795h30.156c15.991,0,25.547-7.286,30.075-22.929l39.237-136.141a18.912,18.912,0,0,0,.775-4.6v-.726a8.182,8.182,0,0,0-1.5-4.747c-2.078-2.791-6.435-4.206-12.948-4.206h-12.982c-12.417,0-20.2,5.115-23.13,15.2L-3651.477-8624a4.4,4.4,0,0,1-3.535,3.124,4.291,4.291,0,0,1-.658.052,3.924,3.924,0,0,1-3.455-1.994l-60.292-106.536-.011-.02c-5.889-10.63-8.845-15.966-24.076-15.966h-29.291c-16.175,0-25.819,7.282-30.351,22.917l-40.3,135.746c-1.287,4.407-1.091,7.784.581,10.037,2.064,2.8,6.544,4.217,13.315,4.217h13.032c12.2,0,19.882-5.114,22.817-15.2l31.569-106.055a4.413,4.413,0,0,1,3.555-3.1A4.215,4.215,0,0,1-3757.951-8696.821Zm-388.185-48.523a13.987,13.987,0,0,0-8.478,2.837,13.985,13.985,0,0,0-5.065,7.365l-41.771,145.183a14.218,14.218,0,0,0-.551,3.625v.556a13.894,13.894,0,0,0,1.154,5.273,14.148,14.148,0,0,0,2.984,4.389,13.967,13.967,0,0,0,9.953,4.116h22.4a13.985,13.985,0,0,0,8.479-2.837,13.971,13.971,0,0,0,5.063-7.363l41.774-145.183a13.97,13.97,0,0,0-2.294-12.356,13.971,13.971,0,0,0-11.248-5.6Zm54.6-57.8a13.977,13.977,0,0,0-8.478,2.837,13.973,13.973,0,0,0-5.064,7.364l-7.7,26.88a16.089,16.089,0,0,0,2.639,14.234,16.351,16.351,0,0,0,5.553,4.686,16.064,16.064,0,0,0,7.406,1.775h19.528a13.955,13.955,0,0,0,8.466-2.832,13.952,13.952,0,0,0,5.053-7.359l8.49-29.635a13.96,13.96,0,0,0-2.291-12.348,13.959,13.959,0,0,0-11.24-5.6Zm100.8,204.1a131.988,131.988,0,0,1-15.219-.8,72.247,72.247,0,0,1-12.456-2.479,39.767,39.767,0,0,1-9.656-4.269,25.47,25.47,0,0,1-6.82-6.166,23.439,23.439,0,0,1-3.407-6.432,29.84,29.84,0,0,1-1.52-7.793,46.137,46.137,0,0,1,.388-9.215,76.407,76.407,0,0,1,2.316-10.694l6.761-23.57a83.3,83.3,0,0,1,4.33-11.81,64.372,64.372,0,0,1,5.7-10,55.157,55.157,0,0,1,7.077-8.259,54.078,54.078,0,0,1,8.476-6.594c11.94-7.522,27.717-11.18,48.234-11.18a130.416,130.416,0,0,1,15.2.812,71.9,71.9,0,0,1,12.439,2.5,39.8,39.8,0,0,1,9.645,4.289,25.612,25.612,0,0,1,6.815,6.176,23.573,23.573,0,0,1,3.418,6.439,29.878,29.878,0,0,1,1.531,7.789,45.917,45.917,0,0,1-.375,9.19,75.576,75.576,0,0,1-2.3,10.645l-6.759,23.57c-4.863,16.963-13.238,28.984-25.6,36.753C-3954.406-8602.672-3970.176-8599.042-3990.733-8599.042Z" transform="translate(4766 9034)" /> </svg> <div class="content"> <p class="desc">EVolutionized for EV fitment</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 태블릿 --> <div class="svg_wrap t_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape111" d="M-10464-10492h-350v-560h350v560Zm-191.245-204.826a60.3,60.3,0,0,0-12.862,1.295,38.878,38.878,0,0,0-10.513,3.844,26.776,26.776,0,0,0-7.748,6.328,24.046,24.046,0,0,0-4.574,8.75l-2.122,7.395c-1.524,5.316-1.044,9.683,1.427,12.978,1.765,2.355,4.559,4.164,8.3,5.376a46.994,46.994,0,0,0,14,1.861h.732c9.47-.043,17.316-1.785,23.323-5.179a24.59,24.59,0,0,0,12.016-15.036l2.119-7.395c1.5-5.212.985-9.536-1.515-12.854-1.817-2.412-4.678-4.264-8.5-5.5A46.33,46.33,0,0,0-10655.246-10696.826Zm50.658,13.74a1.064,1.064,0,0,1,.927.533l16.242,28.807c1.355,2.292,2.335,3.947,6.136,3.947h8.041c4.265,0,6.813-1.943,8.019-6.116l10.465-36.3a5.212,5.212,0,0,0,.206-1.218v-.216a2.191,2.191,0,0,0-.4-1.254c-.553-.744-1.715-1.121-3.454-1.121h-3.461c-3.311,0-5.386,1.363-6.169,4.053l-8.157,28.306a1.17,1.17,0,0,1-.943.832,1.07,1.07,0,0,1-.177.015,1.043,1.043,0,0,1-.919-.532l-16.079-28.41c-1.572-2.838-2.361-4.263-6.424-4.263h-7.811c-4.312,0-6.884,1.942-8.094,6.113l-10.745,36.2a3.011,3.011,0,0,0,.155,2.676c.551.746,1.746,1.124,3.551,1.124h3.476c3.255,0,5.3-1.363,6.085-4.053l8.418-28.28a1.173,1.173,0,0,1,.946-.827A1.366,1.366,0,0,1-10604.588-10683.086Zm-103.517-12.939a3.768,3.768,0,0,0-3.608,2.722l-11.14,38.715a3.742,3.742,0,0,0-.146.974v.133a3.743,3.743,0,0,0,1.1,2.582,3.723,3.723,0,0,0,2.656,1.1h5.972a3.777,3.777,0,0,0,3.611-2.721l11.14-38.716a3.727,3.727,0,0,0-.611-3.295,3.727,3.727,0,0,0-3-1.5Zm14.562-15.413a3.773,3.773,0,0,0-3.611,2.721l-2.052,7.168a4.288,4.288,0,0,0,.7,3.8,4.29,4.29,0,0,0,3.457,1.724h5.206a3.765,3.765,0,0,0,3.605-2.719l2.264-7.9a3.719,3.719,0,0,0-.61-3.292,3.723,3.723,0,0,0-3-1.5Zm26.88,54.428c-6.067,0-9.919-1.2-11.773-3.658-1.562-2.073-1.755-5.051-.592-9.1l1.8-6.282c1.289-4.5,3.52-7.7,6.818-9.777,3.185-2.006,7.393-2.981,12.863-2.981,6.05,0,9.9,1.2,11.76,3.673,1.565,2.078,1.765,5.05.608,9.086l-1.8,6.282c-1.3,4.524-3.53,7.73-6.828,9.8C-10656.975-10657.979-10661.181-10657.011-10666.663-10657.011Z" transform="translate(10814.001 11022)" /> </defs> <clipPath id="clipPath111"> <use xlink:href="#polygonShape111"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath111);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ion/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-10464-10492h-350v-560h350v560Zm-191.245-204.826a60.3,60.3,0,0,0-12.862,1.295,38.878,38.878,0,0,0-10.513,3.844,26.776,26.776,0,0,0-7.748,6.328,24.046,24.046,0,0,0-4.574,8.75l-2.122,7.395c-1.524,5.316-1.044,9.683,1.427,12.978,1.765,2.355,4.559,4.164,8.3,5.376a46.994,46.994,0,0,0,14,1.861h.732c9.47-.043,17.316-1.785,23.323-5.179a24.59,24.59,0,0,0,12.016-15.036l2.119-7.395c1.5-5.212.985-9.536-1.515-12.854-1.817-2.412-4.678-4.264-8.5-5.5A46.33,46.33,0,0,0-10655.246-10696.826Zm50.658,13.74a1.064,1.064,0,0,1,.927.533l16.242,28.807c1.355,2.292,2.335,3.947,6.136,3.947h8.041c4.265,0,6.813-1.943,8.019-6.116l10.465-36.3a5.212,5.212,0,0,0,.206-1.218v-.216a2.191,2.191,0,0,0-.4-1.254c-.553-.744-1.715-1.121-3.454-1.121h-3.461c-3.311,0-5.386,1.363-6.169,4.053l-8.157,28.306a1.17,1.17,0,0,1-.943.832,1.07,1.07,0,0,1-.177.015,1.043,1.043,0,0,1-.919-.532l-16.079-28.41c-1.572-2.838-2.361-4.263-6.424-4.263h-7.811c-4.312,0-6.884,1.942-8.094,6.113l-10.745,36.2a3.011,3.011,0,0,0,.155,2.676c.551.746,1.746,1.124,3.551,1.124h3.476c3.255,0,5.3-1.363,6.085-4.053l8.418-28.28a1.173,1.173,0,0,1,.946-.827A1.366,1.366,0,0,1-10604.588-10683.086Zm-103.517-12.939a3.768,3.768,0,0,0-3.608,2.722l-11.14,38.715a3.742,3.742,0,0,0-.146.974v.133a3.743,3.743,0,0,0,1.1,2.582,3.723,3.723,0,0,0,2.656,1.1h5.972a3.777,3.777,0,0,0,3.611-2.721l11.14-38.716a3.727,3.727,0,0,0-.611-3.295,3.727,3.727,0,0,0-3-1.5Zm14.562-15.413a3.773,3.773,0,0,0-3.611,2.721l-2.052,7.168a4.288,4.288,0,0,0,.7,3.8,4.29,4.29,0,0,0,3.457,1.724h5.206a3.765,3.765,0,0,0,3.605-2.719l2.264-7.9a3.719,3.719,0,0,0-.61-3.292,3.723,3.723,0,0,0-3-1.5Zm26.88,54.428c-6.067,0-9.919-1.2-11.773-3.658-1.562-2.073-1.755-5.051-.592-9.1l1.8-6.282c1.289-4.5,3.52-7.7,6.818-9.777,3.185-2.006,7.393-2.981,12.863-2.981,6.05,0,9.9,1.2,11.76,3.673,1.565,2.078,1.765,5.05.608,9.086l-1.8,6.282c-1.3,4.524-3.53,7.73-6.828,9.8C-10656.975-10657.979-10661.181-10657.011-10666.663-10657.011Z" transform="translate(10814.001 11022)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-10464-10492h-350v-560h350v560Zm-191.245-204.826a60.3,60.3,0,0,0-12.862,1.295,38.878,38.878,0,0,0-10.513,3.844,26.776,26.776,0,0,0-7.748,6.328,24.046,24.046,0,0,0-4.574,8.75l-2.122,7.395c-1.524,5.316-1.044,9.683,1.427,12.978,1.765,2.355,4.559,4.164,8.3,5.376a46.994,46.994,0,0,0,14,1.861h.732c9.47-.043,17.316-1.785,23.323-5.179a24.59,24.59,0,0,0,12.016-15.036l2.119-7.395c1.5-5.212.985-9.536-1.515-12.854-1.817-2.412-4.678-4.264-8.5-5.5A46.33,46.33,0,0,0-10655.246-10696.826Zm50.658,13.74a1.064,1.064,0,0,1,.927.533l16.242,28.807c1.355,2.292,2.335,3.947,6.136,3.947h8.041c4.265,0,6.813-1.943,8.019-6.116l10.465-36.3a5.212,5.212,0,0,0,.206-1.218v-.216a2.191,2.191,0,0,0-.4-1.254c-.553-.744-1.715-1.121-3.454-1.121h-3.461c-3.311,0-5.386,1.363-6.169,4.053l-8.157,28.306a1.17,1.17,0,0,1-.943.832,1.07,1.07,0,0,1-.177.015,1.043,1.043,0,0,1-.919-.532l-16.079-28.41c-1.572-2.838-2.361-4.263-6.424-4.263h-7.811c-4.312,0-6.884,1.942-8.094,6.113l-10.745,36.2a3.011,3.011,0,0,0,.155,2.676c.551.746,1.746,1.124,3.551,1.124h3.476c3.255,0,5.3-1.363,6.085-4.053l8.418-28.28a1.173,1.173,0,0,1,.946-.827A1.366,1.366,0,0,1-10604.588-10683.086Zm-103.517-12.939a3.768,3.768,0,0,0-3.608,2.722l-11.14,38.715a3.742,3.742,0,0,0-.146.974v.133a3.743,3.743,0,0,0,1.1,2.582,3.723,3.723,0,0,0,2.656,1.1h5.972a3.777,3.777,0,0,0,3.611-2.721l11.14-38.716a3.727,3.727,0,0,0-.611-3.295,3.727,3.727,0,0,0-3-1.5Zm14.562-15.413a3.773,3.773,0,0,0-3.611,2.721l-2.052,7.168a4.288,4.288,0,0,0,.7,3.8,4.29,4.29,0,0,0,3.457,1.724h5.206a3.765,3.765,0,0,0,3.605-2.719l2.264-7.9a3.719,3.719,0,0,0-.61-3.292,3.723,3.723,0,0,0-3-1.5Zm26.88,54.428c-6.067,0-9.919-1.2-11.773-3.658-1.562-2.073-1.755-5.051-.592-9.1l1.8-6.282c1.289-4.5,3.52-7.7,6.818-9.777,3.185-2.006,7.393-2.981,12.863-2.981,6.05,0,9.9,1.2,11.76,3.673,1.565,2.078,1.765,5.05.608,9.086l-1.8,6.282c-1.3,4.524-3.53,7.73-6.828,9.8C-10656.975-10657.979-10661.181-10657.011-10666.663-10657.011Z" transform="translate(10814.001 11022)" /> </svg> <div class="content"> <p class="desc">EVolutionized for EV fitment</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 모바일 --> <div class="svg_wrap m_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape111-m" d="M-10464-10492h-350v-560h350v560Zm-191.245-204.826a60.3,60.3,0,0,0-12.862,1.295,38.878,38.878,0,0,0-10.513,3.844,26.776,26.776,0,0,0-7.748,6.328,24.046,24.046,0,0,0-4.574,8.75l-2.122,7.395c-1.524,5.316-1.044,9.683,1.427,12.978,1.765,2.355,4.559,4.164,8.3,5.376a46.994,46.994,0,0,0,14,1.861h.732c9.47-.043,17.316-1.785,23.323-5.179a24.59,24.59,0,0,0,12.016-15.036l2.119-7.395c1.5-5.212.985-9.536-1.515-12.854-1.817-2.412-4.678-4.264-8.5-5.5A46.33,46.33,0,0,0-10655.246-10696.826Zm50.658,13.74a1.064,1.064,0,0,1,.927.533l16.242,28.807c1.355,2.292,2.335,3.947,6.136,3.947h8.041c4.265,0,6.813-1.943,8.019-6.116l10.465-36.3a5.212,5.212,0,0,0,.206-1.218v-.216a2.191,2.191,0,0,0-.4-1.254c-.553-.744-1.715-1.121-3.454-1.121h-3.461c-3.311,0-5.386,1.363-6.169,4.053l-8.157,28.306a1.17,1.17,0,0,1-.943.832,1.07,1.07,0,0,1-.177.015,1.043,1.043,0,0,1-.919-.532l-16.079-28.41c-1.572-2.838-2.361-4.263-6.424-4.263h-7.811c-4.312,0-6.884,1.942-8.094,6.113l-10.745,36.2a3.011,3.011,0,0,0,.155,2.676c.551.746,1.746,1.124,3.551,1.124h3.476c3.255,0,5.3-1.363,6.085-4.053l8.418-28.28a1.173,1.173,0,0,1,.946-.827A1.366,1.366,0,0,1-10604.588-10683.086Zm-103.517-12.939a3.768,3.768,0,0,0-3.608,2.722l-11.14,38.715a3.742,3.742,0,0,0-.146.974v.133a3.743,3.743,0,0,0,1.1,2.582,3.723,3.723,0,0,0,2.656,1.1h5.972a3.777,3.777,0,0,0,3.611-2.721l11.14-38.716a3.727,3.727,0,0,0-.611-3.295,3.727,3.727,0,0,0-3-1.5Zm14.562-15.413a3.773,3.773,0,0,0-3.611,2.721l-2.052,7.168a4.288,4.288,0,0,0,.7,3.8,4.29,4.29,0,0,0,3.457,1.724h5.206a3.765,3.765,0,0,0,3.605-2.719l2.264-7.9a3.719,3.719,0,0,0-.61-3.292,3.723,3.723,0,0,0-3-1.5Zm26.88,54.428c-6.067,0-9.919-1.2-11.773-3.658-1.562-2.073-1.755-5.051-.592-9.1l1.8-6.282c1.289-4.5,3.52-7.7,6.818-9.777,3.185-2.006,7.393-2.981,12.863-2.981,6.05,0,9.9,1.2,11.76,3.673,1.565,2.078,1.765,5.05.608,9.086l-1.8,6.282c-1.3,4.524-3.53,7.73-6.828,9.8C-10656.975-10657.979-10661.181-10657.011-10666.663-10657.011Z" transform="translate(10814.001 11052)" /> </defs> <clipPath id="clipPath111-m"> <use xlink:href="#polygonShape111-m"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath111-m);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ion/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-10464-10492h-350v-560h350v560Zm-191.245-204.826a60.3,60.3,0,0,0-12.862,1.295,38.878,38.878,0,0,0-10.513,3.844,26.776,26.776,0,0,0-7.748,6.328,24.046,24.046,0,0,0-4.574,8.75l-2.122,7.395c-1.524,5.316-1.044,9.683,1.427,12.978,1.765,2.355,4.559,4.164,8.3,5.376a46.994,46.994,0,0,0,14,1.861h.732c9.47-.043,17.316-1.785,23.323-5.179a24.59,24.59,0,0,0,12.016-15.036l2.119-7.395c1.5-5.212.985-9.536-1.515-12.854-1.817-2.412-4.678-4.264-8.5-5.5A46.33,46.33,0,0,0-10655.246-10696.826Zm50.658,13.74a1.064,1.064,0,0,1,.927.533l16.242,28.807c1.355,2.292,2.335,3.947,6.136,3.947h8.041c4.265,0,6.813-1.943,8.019-6.116l10.465-36.3a5.212,5.212,0,0,0,.206-1.218v-.216a2.191,2.191,0,0,0-.4-1.254c-.553-.744-1.715-1.121-3.454-1.121h-3.461c-3.311,0-5.386,1.363-6.169,4.053l-8.157,28.306a1.17,1.17,0,0,1-.943.832,1.07,1.07,0,0,1-.177.015,1.043,1.043,0,0,1-.919-.532l-16.079-28.41c-1.572-2.838-2.361-4.263-6.424-4.263h-7.811c-4.312,0-6.884,1.942-8.094,6.113l-10.745,36.2a3.011,3.011,0,0,0,.155,2.676c.551.746,1.746,1.124,3.551,1.124h3.476c3.255,0,5.3-1.363,6.085-4.053l8.418-28.28a1.173,1.173,0,0,1,.946-.827A1.366,1.366,0,0,1-10604.588-10683.086Zm-103.517-12.939a3.768,3.768,0,0,0-3.608,2.722l-11.14,38.715a3.742,3.742,0,0,0-.146.974v.133a3.743,3.743,0,0,0,1.1,2.582,3.723,3.723,0,0,0,2.656,1.1h5.972a3.777,3.777,0,0,0,3.611-2.721l11.14-38.716a3.727,3.727,0,0,0-.611-3.295,3.727,3.727,0,0,0-3-1.5Zm14.562-15.413a3.773,3.773,0,0,0-3.611,2.721l-2.052,7.168a4.288,4.288,0,0,0,.7,3.8,4.29,4.29,0,0,0,3.457,1.724h5.206a3.765,3.765,0,0,0,3.605-2.719l2.264-7.9a3.719,3.719,0,0,0-.61-3.292,3.723,3.723,0,0,0-3-1.5Zm26.88,54.428c-6.067,0-9.919-1.2-11.773-3.658-1.562-2.073-1.755-5.051-.592-9.1l1.8-6.282c1.289-4.5,3.52-7.7,6.818-9.777,3.185-2.006,7.393-2.981,12.863-2.981,6.05,0,9.9,1.2,11.76,3.673,1.565,2.078,1.765,5.05.608,9.086l-1.8,6.282c-1.3,4.524-3.53,7.73-6.828,9.8C-10656.975-10657.979-10661.181-10657.011-10666.663-10657.011Z" transform="translate(10814.001 11052)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-10464-10492h-350v-560h350v560Zm-191.245-204.826a60.3,60.3,0,0,0-12.862,1.295,38.878,38.878,0,0,0-10.513,3.844,26.776,26.776,0,0,0-7.748,6.328,24.046,24.046,0,0,0-4.574,8.75l-2.122,7.395c-1.524,5.316-1.044,9.683,1.427,12.978,1.765,2.355,4.559,4.164,8.3,5.376a46.994,46.994,0,0,0,14,1.861h.732c9.47-.043,17.316-1.785,23.323-5.179a24.59,24.59,0,0,0,12.016-15.036l2.119-7.395c1.5-5.212.985-9.536-1.515-12.854-1.817-2.412-4.678-4.264-8.5-5.5A46.33,46.33,0,0,0-10655.246-10696.826Zm50.658,13.74a1.064,1.064,0,0,1,.927.533l16.242,28.807c1.355,2.292,2.335,3.947,6.136,3.947h8.041c4.265,0,6.813-1.943,8.019-6.116l10.465-36.3a5.212,5.212,0,0,0,.206-1.218v-.216a2.191,2.191,0,0,0-.4-1.254c-.553-.744-1.715-1.121-3.454-1.121h-3.461c-3.311,0-5.386,1.363-6.169,4.053l-8.157,28.306a1.17,1.17,0,0,1-.943.832,1.07,1.07,0,0,1-.177.015,1.043,1.043,0,0,1-.919-.532l-16.079-28.41c-1.572-2.838-2.361-4.263-6.424-4.263h-7.811c-4.312,0-6.884,1.942-8.094,6.113l-10.745,36.2a3.011,3.011,0,0,0,.155,2.676c.551.746,1.746,1.124,3.551,1.124h3.476c3.255,0,5.3-1.363,6.085-4.053l8.418-28.28a1.173,1.173,0,0,1,.946-.827A1.366,1.366,0,0,1-10604.588-10683.086Zm-103.517-12.939a3.768,3.768,0,0,0-3.608,2.722l-11.14,38.715a3.742,3.742,0,0,0-.146.974v.133a3.743,3.743,0,0,0,1.1,2.582,3.723,3.723,0,0,0,2.656,1.1h5.972a3.777,3.777,0,0,0,3.611-2.721l11.14-38.716a3.727,3.727,0,0,0-.611-3.295,3.727,3.727,0,0,0-3-1.5Zm14.562-15.413a3.773,3.773,0,0,0-3.611,2.721l-2.052,7.168a4.288,4.288,0,0,0,.7,3.8,4.29,4.29,0,0,0,3.457,1.724h5.206a3.765,3.765,0,0,0,3.605-2.719l2.264-7.9a3.719,3.719,0,0,0-.61-3.292,3.723,3.723,0,0,0-3-1.5Zm26.88,54.428c-6.067,0-9.919-1.2-11.773-3.658-1.562-2.073-1.755-5.051-.592-9.1l1.8-6.282c1.289-4.5,3.52-7.7,6.818-9.777,3.185-2.006,7.393-2.981,12.863-2.981,6.05,0,9.9,1.2,11.76,3.673,1.565,2.078,1.765,5.05.608,9.086l-1.8,6.282c-1.3,4.524-3.53,7.73-6.828,9.8C-10656.975-10657.979-10661.181-10657.011-10666.663-10657.011Z" transform="translate(10814.001 11052)" /> </svg> <div class="content"> <p class="desc">EVolutionized for EV fitment</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <div class="content"> <p class="desc">EVolutionized for EV fitment</p> <span class="btn btn--round">Learn more</span> </div> </a> </div> <div class="display" data-id="ventus"> <a href="/global/en/tires/ventus.html"> <img class="display__bg t_none" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ventus/bg.jpg" alt="배경이미지"> <img class="display__bg t_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ventus/bg-m.jpg" alt="배경이미지"> <img class="display__bg m_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ventus/bg-m.jpg" alt="배경이미지"> <div class="display__wrap"> <div class="display__lottie"></div> </div> <!-- 웹 --> <div class="svg_wrap t_none"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape2" d="M1760,720H0V0H1760V720ZM764.082,352.313h0l61.542,97.773,78.738,0,39.1-154.993H864.738l-24.67,97.767L778.523,295.09H699.789L660.657,450.084h78.735l24.691-97.77h0v0h0ZM140,295.094l42.813,112.474h.029a64.02,64.02,0,0,0,7.619,15,61.624,61.624,0,0,0,12.823,13.687,62.413,62.413,0,0,0,18.633,9.973,78.478,78.478,0,0,0,25.051,3.858h56.006L419.8,295.094H341.043l-81.255,107.8-41.04-107.8Zm364.7,0a172.692,172.692,0,0,0-28.4,2.214,121.269,121.269,0,0,0-22.256,5.836,83.43,83.43,0,0,0-28.988,17.71,67.374,67.374,0,0,0-8.184,9.459,60.15,60.15,0,0,0-4.947,8.251,39.434,39.434,0,0,0-3.086,8.05l-9.975,40.031a50.281,50.281,0,0,0-1.094,21.039,37.411,37.411,0,0,0,6.818,15.738,51.2,51.2,0,0,0,16.778,14.049,91.645,91.645,0,0,0,19.788,7.8,124.247,124.247,0,0,0,23.395,4.072l19-.1h149.1l8.378-33.217H501.484a43.241,43.241,0,0,1-15.773-2.549,21.315,21.315,0,0,1-8.717-6.073,18.513,18.513,0,0,1-3.126-5.421,21.065,21.065,0,0,1-1.182-5.088,20.37,20.37,0,0,1,.074-5.248l1.78-7.049H649.01l6.5-26.121a66.638,66.638,0,0,0,1.943-12.532,47.455,47.455,0,0,0-.614-10.763,37.627,37.627,0,0,0-7.429-16.757,48.662,48.662,0,0,0-16.446-13.05,86.522,86.522,0,0,0-19.748-6.98,134.853,134.853,0,0,0-28.7-3.315c-.667,0-1.083.009-1.2.011H504.7Zm543.213,31.547h83.506l-18.482,73.1a29.674,29.674,0,0,0,4.976,27c5.073,6.759,13.071,12.4,23.13,16.318a87.575,87.575,0,0,0,16.693,4.567,113.331,113.331,0,0,0,19.394,1.615l167.07,0,38.89-154.154h-78.923l-24.813,99.061-.016.014-5.458,21.862h-46.553c-12.076,0-22.236-3.937-27.18-10.532a14.815,14.815,0,0,1-2.426-13.5l24.543-96.9H1055.984l8.991-35.177H981.486l-35.3,139.827a29.675,29.675,0,0,0,4.97,27.005c5.071,6.758,13.067,12.4,23.122,16.314a87.55,87.55,0,0,0,16.689,4.566,113.346,113.346,0,0,0,19.391,1.615h51.052l8.383-33.216h-9.24c-12.073,0-22.233-3.937-27.177-10.53a14.786,14.786,0,0,1-2.428-13.47l16.965-65.383Zm335.81,82.331-10.183,40.27,151.114,0c16.79,0,31.625-2.359,44.094-7.011a72.653,72.653,0,0,0,25.238-15.424,58.706,58.706,0,0,0,7.128-8.238,52.435,52.435,0,0,0,4.309-7.186,34.436,34.436,0,0,0,2.689-7.011l2.113-8.53a44.2,44.2,0,0,0-.914-17.9,38.143,38.143,0,0,0-3.03-7.8,35.423,35.423,0,0,0-4.578-6.74,34.138,34.138,0,0,0-12.03-8.906,39.222,39.222,0,0,0-16.06-3.267h-93.354c-3.978,0-8.894-1.19-10.761-4.531a6.059,6.059,0,0,1-.685-3.724,12.314,12.314,0,0,1,1.9-4.923,27.98,27.98,0,0,1,7.845-6.88,35.583,35.583,0,0,1,8.308-3.569,37.806,37.806,0,0,1,9.269-1.551h116.04L1620,295.087H1480.555c-16.8,0-31.641,2.358-44.115,7.009a72.661,72.661,0,0,0-25.245,15.42,58.667,58.667,0,0,0-7.127,8.236,52.364,52.364,0,0,0-4.308,7.185,34.441,34.441,0,0,0-2.687,7.009l-2.148,8.626h.057a32.785,32.785,0,0,0,1.113,12.73,25.693,25.693,0,0,0,5.59,9.845,32.044,32.044,0,0,0,13.28,8.451,55.68,55.68,0,0,0,18.517,2.874h91.474a17.262,17.262,0,0,1,6.842,1.241,8.612,8.612,0,0,1,4.093,3.361,7.063,7.063,0,0,1,1.01,3.934,10.915,10.915,0,0,1-1.33,4.688,17.779,17.779,0,0,1-5.717,6.267,32.874,32.874,0,0,1-8.415,4.1,62.181,62.181,0,0,1-19.016,2.91h-118.7ZM574.47,352.414H482.78a31.8,31.8,0,0,1,8.176-14.866,35.022,35.022,0,0,1,11.727-7.7,45.575,45.575,0,0,1,15.088-3.333h33.05c6.257,0,11.45.835,15.438,2.481a16.209,16.209,0,0,1,7.654,5.992,14.461,14.461,0,0,1,2.163,5.91,20.264,20.264,0,0,1-.039,5.637,24.617,24.617,0,0,1-1.566,5.88Z" transform="translate(0 0)" /> </defs> <clipPath id="clipPath2"> <use xlink:href="#polygonShape2"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath2);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ventus/bg.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M1760,720H0V0H1760V720ZM764.082,352.313h0l61.542,97.773,78.738,0,39.1-154.993H864.738l-24.67,97.767L778.523,295.09H699.789L660.657,450.084h78.735l24.691-97.77h0v0h0ZM140,295.094l42.813,112.474h.029a64.02,64.02,0,0,0,7.619,15,61.624,61.624,0,0,0,12.823,13.687,62.413,62.413,0,0,0,18.633,9.973,78.478,78.478,0,0,0,25.051,3.858h56.006L419.8,295.094H341.043l-81.255,107.8-41.04-107.8Zm364.7,0a172.692,172.692,0,0,0-28.4,2.214,121.269,121.269,0,0,0-22.256,5.836,83.43,83.43,0,0,0-28.988,17.71,67.374,67.374,0,0,0-8.184,9.459,60.15,60.15,0,0,0-4.947,8.251,39.434,39.434,0,0,0-3.086,8.05l-9.975,40.031a50.281,50.281,0,0,0-1.094,21.039,37.411,37.411,0,0,0,6.818,15.738,51.2,51.2,0,0,0,16.778,14.049,91.645,91.645,0,0,0,19.788,7.8,124.247,124.247,0,0,0,23.395,4.072l19-.1h149.1l8.378-33.217H501.484a43.241,43.241,0,0,1-15.773-2.549,21.315,21.315,0,0,1-8.717-6.073,18.513,18.513,0,0,1-3.126-5.421,21.065,21.065,0,0,1-1.182-5.088,20.37,20.37,0,0,1,.074-5.248l1.78-7.049H649.01l6.5-26.121a66.638,66.638,0,0,0,1.943-12.532,47.455,47.455,0,0,0-.614-10.763,37.627,37.627,0,0,0-7.429-16.757,48.662,48.662,0,0,0-16.446-13.05,86.522,86.522,0,0,0-19.748-6.98,134.853,134.853,0,0,0-28.7-3.315c-.667,0-1.083.009-1.2.011H504.7Zm543.213,31.547h83.506l-18.482,73.1a29.674,29.674,0,0,0,4.976,27c5.073,6.759,13.071,12.4,23.13,16.318a87.575,87.575,0,0,0,16.693,4.567,113.331,113.331,0,0,0,19.394,1.615l167.07,0,38.89-154.154h-78.923l-24.813,99.061-.016.014-5.458,21.862h-46.553c-12.076,0-22.236-3.937-27.18-10.532a14.815,14.815,0,0,1-2.426-13.5l24.543-96.9H1055.984l8.991-35.177H981.486l-35.3,139.827a29.675,29.675,0,0,0,4.97,27.005c5.071,6.758,13.067,12.4,23.122,16.314a87.55,87.55,0,0,0,16.689,4.566,113.346,113.346,0,0,0,19.391,1.615h51.052l8.383-33.216h-9.24c-12.073,0-22.233-3.937-27.177-10.53a14.786,14.786,0,0,1-2.428-13.47l16.965-65.383Zm335.81,82.331-10.183,40.27,151.114,0c16.79,0,31.625-2.359,44.094-7.011a72.653,72.653,0,0,0,25.238-15.424,58.706,58.706,0,0,0,7.128-8.238,52.435,52.435,0,0,0,4.309-7.186,34.436,34.436,0,0,0,2.689-7.011l2.113-8.53a44.2,44.2,0,0,0-.914-17.9,38.143,38.143,0,0,0-3.03-7.8,35.423,35.423,0,0,0-4.578-6.74,34.138,34.138,0,0,0-12.03-8.906,39.222,39.222,0,0,0-16.06-3.267h-93.354c-3.978,0-8.894-1.19-10.761-4.531a6.059,6.059,0,0,1-.685-3.724,12.314,12.314,0,0,1,1.9-4.923,27.98,27.98,0,0,1,7.845-6.88,35.583,35.583,0,0,1,8.308-3.569,37.806,37.806,0,0,1,9.269-1.551h116.04L1620,295.087H1480.555c-16.8,0-31.641,2.358-44.115,7.009a72.661,72.661,0,0,0-25.245,15.42,58.667,58.667,0,0,0-7.127,8.236,52.364,52.364,0,0,0-4.308,7.185,34.441,34.441,0,0,0-2.687,7.009l-2.148,8.626h.057a32.785,32.785,0,0,0,1.113,12.73,25.693,25.693,0,0,0,5.59,9.845,32.044,32.044,0,0,0,13.28,8.451,55.68,55.68,0,0,0,18.517,2.874h91.474a17.262,17.262,0,0,1,6.842,1.241,8.612,8.612,0,0,1,4.093,3.361,7.063,7.063,0,0,1,1.01,3.934,10.915,10.915,0,0,1-1.33,4.688,17.779,17.779,0,0,1-5.717,6.267,32.874,32.874,0,0,1-8.415,4.1,62.181,62.181,0,0,1-19.016,2.91h-118.7ZM574.47,352.414H482.78a31.8,31.8,0,0,1,8.176-14.866,35.022,35.022,0,0,1,11.727-7.7,45.575,45.575,0,0,1,15.088-3.333h33.05c6.257,0,11.45.835,15.438,2.481a16.209,16.209,0,0,1,7.654,5.992,14.461,14.461,0,0,1,2.163,5.91,20.264,20.264,0,0,1-.039,5.637,24.617,24.617,0,0,1-1.566,5.88Z" transform="translate(0 0)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M1760,720H0V0H1760V720ZM764.082,352.313h0l61.542,97.773,78.738,0,39.1-154.993H864.738l-24.67,97.767L778.523,295.09H699.789L660.657,450.084h78.735l24.691-97.77h0v0h0ZM140,295.094l42.813,112.474h.029a64.02,64.02,0,0,0,7.619,15,61.624,61.624,0,0,0,12.823,13.687,62.413,62.413,0,0,0,18.633,9.973,78.478,78.478,0,0,0,25.051,3.858h56.006L419.8,295.094H341.043l-81.255,107.8-41.04-107.8Zm364.7,0a172.692,172.692,0,0,0-28.4,2.214,121.269,121.269,0,0,0-22.256,5.836,83.43,83.43,0,0,0-28.988,17.71,67.374,67.374,0,0,0-8.184,9.459,60.15,60.15,0,0,0-4.947,8.251,39.434,39.434,0,0,0-3.086,8.05l-9.975,40.031a50.281,50.281,0,0,0-1.094,21.039,37.411,37.411,0,0,0,6.818,15.738,51.2,51.2,0,0,0,16.778,14.049,91.645,91.645,0,0,0,19.788,7.8,124.247,124.247,0,0,0,23.395,4.072l19-.1h149.1l8.378-33.217H501.484a43.241,43.241,0,0,1-15.773-2.549,21.315,21.315,0,0,1-8.717-6.073,18.513,18.513,0,0,1-3.126-5.421,21.065,21.065,0,0,1-1.182-5.088,20.37,20.37,0,0,1,.074-5.248l1.78-7.049H649.01l6.5-26.121a66.638,66.638,0,0,0,1.943-12.532,47.455,47.455,0,0,0-.614-10.763,37.627,37.627,0,0,0-7.429-16.757,48.662,48.662,0,0,0-16.446-13.05,86.522,86.522,0,0,0-19.748-6.98,134.853,134.853,0,0,0-28.7-3.315c-.667,0-1.083.009-1.2.011H504.7Zm543.213,31.547h83.506l-18.482,73.1a29.674,29.674,0,0,0,4.976,27c5.073,6.759,13.071,12.4,23.13,16.318a87.575,87.575,0,0,0,16.693,4.567,113.331,113.331,0,0,0,19.394,1.615l167.07,0,38.89-154.154h-78.923l-24.813,99.061-.016.014-5.458,21.862h-46.553c-12.076,0-22.236-3.937-27.18-10.532a14.815,14.815,0,0,1-2.426-13.5l24.543-96.9H1055.984l8.991-35.177H981.486l-35.3,139.827a29.675,29.675,0,0,0,4.97,27.005c5.071,6.758,13.067,12.4,23.122,16.314a87.55,87.55,0,0,0,16.689,4.566,113.346,113.346,0,0,0,19.391,1.615h51.052l8.383-33.216h-9.24c-12.073,0-22.233-3.937-27.177-10.53a14.786,14.786,0,0,1-2.428-13.47l16.965-65.383Zm335.81,82.331-10.183,40.27,151.114,0c16.79,0,31.625-2.359,44.094-7.011a72.653,72.653,0,0,0,25.238-15.424,58.706,58.706,0,0,0,7.128-8.238,52.435,52.435,0,0,0,4.309-7.186,34.436,34.436,0,0,0,2.689-7.011l2.113-8.53a44.2,44.2,0,0,0-.914-17.9,38.143,38.143,0,0,0-3.03-7.8,35.423,35.423,0,0,0-4.578-6.74,34.138,34.138,0,0,0-12.03-8.906,39.222,39.222,0,0,0-16.06-3.267h-93.354c-3.978,0-8.894-1.19-10.761-4.531a6.059,6.059,0,0,1-.685-3.724,12.314,12.314,0,0,1,1.9-4.923,27.98,27.98,0,0,1,7.845-6.88,35.583,35.583,0,0,1,8.308-3.569,37.806,37.806,0,0,1,9.269-1.551h116.04L1620,295.087H1480.555c-16.8,0-31.641,2.358-44.115,7.009a72.661,72.661,0,0,0-25.245,15.42,58.667,58.667,0,0,0-7.127,8.236,52.364,52.364,0,0,0-4.308,7.185,34.441,34.441,0,0,0-2.687,7.009l-2.148,8.626h.057a32.785,32.785,0,0,0,1.113,12.73,25.693,25.693,0,0,0,5.59,9.845,32.044,32.044,0,0,0,13.28,8.451,55.68,55.68,0,0,0,18.517,2.874h91.474a17.262,17.262,0,0,1,6.842,1.241,8.612,8.612,0,0,1,4.093,3.361,7.063,7.063,0,0,1,1.01,3.934,10.915,10.915,0,0,1-1.33,4.688,17.779,17.779,0,0,1-5.717,6.267,32.874,32.874,0,0,1-8.415,4.1,62.181,62.181,0,0,1-19.016,2.91h-118.7ZM574.47,352.414H482.78a31.8,31.8,0,0,1,8.176-14.866,35.022,35.022,0,0,1,11.727-7.7,45.575,45.575,0,0,1,15.088-3.333h33.05c6.257,0,11.45.835,15.438,2.481a16.209,16.209,0,0,1,7.654,5.992,14.461,14.461,0,0,1,2.163,5.91,20.264,20.264,0,0,1-.039,5.637,24.617,24.617,0,0,1-1.566,5.88Z" transform="translate(0 0)" /> </svg> <div class="content"> <p class="desc">Maximize your performance</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 태블릿 --> <div class="svg_wrap t_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape222" d="M-3424-10492h-350v-560h350v560Zm-212.753-194.6-8.127,32.6h16.351l5.128-20.562v0l12.777,20.562h16.351l8.121-32.6H-3602.5l-5.123,20.566-12.781-20.565Zm-116.248,0,8.89,23.656h.008a13.2,13.2,0,0,0,4.245,6.033,14.2,14.2,0,0,0,9.071,2.909h11.63l24.259-32.6h-16.354l-16.875,22.672-8.521-22.672Zm75.735,0a29.843,29.843,0,0,0-10.52,1.693,17.287,17.287,0,0,0-6.02,3.725,12.029,12.029,0,0,0-3.367,5.418l-2.072,8.421a8.939,8.939,0,0,0,1.225,7.784c1.046,1.409,3.211,3.342,7.584,4.554a25.232,25.232,0,0,0,4.832.849l3.944-.022h30.963l1.742-6.986h-28.979c-2.37,0-4.075-.6-5.068-1.791a4.425,4.425,0,0,1-.9-3.335l.372-1.484h36.23l1.351-5.494c.844-3.441.4-6.292-1.305-8.472-3.628-4.626-11.832-4.86-13.439-4.86-.149,0-.236,0-.249,0Zm182.539,23.953h0l-2.114,8.468h31.382a25.975,25.975,0,0,0,9.156-1.475,15.058,15.058,0,0,0,5.241-3.245,10.562,10.562,0,0,0,2.933-4.719l.438-1.795a9.4,9.4,0,0,0-.2-3.792,7.669,7.669,0,0,0-1.606-3.07,7.517,7.517,0,0,0-5.8-2.521h-19.385a2.565,2.565,0,0,1-2.23-.944,1.777,1.777,0,0,1,.247-1.828,7.4,7.4,0,0,1,5.281-2.522h24.095l1.625-6.513h-28.957a26,26,0,0,0-9.161,1.475,15.055,15.055,0,0,0-5.242,3.243,10.566,10.566,0,0,0-2.933,4.718l-.447,1.814h.011a5.967,5.967,0,0,0,1.419,4.777c1.382,1.518,3.718,2.354,6.578,2.354h19a2.543,2.543,0,0,1,2.262.958,1.829,1.829,0,0,1-.06,1.824c-1.059,2.062-4.37,2.793-6.884,2.793Zm-69.733-17.319h17.341l-3.839,15.375a6.31,6.31,0,0,0,1.069,5.728c2.21,2.934,6.793,4.685,12.261,4.685h34.693l8.077-32.424h-16.39l-5.154,20.836h0l0,0-1.132,4.6h-9.669c-2.49,0-4.594-.819-5.626-2.191a3.15,3.15,0,0,1-.521-2.862l5.1-20.384h-34.53l1.867-7.4h-17.338l-7.328,29.409a6.309,6.309,0,0,0,1.066,5.729c2.208,2.933,6.791,4.684,12.258,4.684h10.6l1.742-6.986h-1.919c-2.49,0-4.593-.819-5.625-2.19a3.145,3.145,0,0,1-.522-2.858l3.522-13.751Zm-98.319,5.423h-19.039a6.721,6.721,0,0,1,1.7-3.128,7.26,7.26,0,0,1,2.435-1.62,9.28,9.28,0,0,1,3.133-.7h6.865c2.406,0,4.015.593,4.781,1.762a4.308,4.308,0,0,1,.129,3.688Z" transform="translate(3774 11022)" /> </defs> <clipPath id="clipPath222"> <use xlink:href="#polygonShape222"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath222);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ventus/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-3424-10492h-350v-560h350v560Zm-212.753-194.6-8.127,32.6h16.351l5.128-20.562v0l12.777,20.562h16.351l8.121-32.6H-3602.5l-5.123,20.566-12.781-20.565Zm-116.248,0,8.89,23.656h.008a13.2,13.2,0,0,0,4.245,6.033,14.2,14.2,0,0,0,9.071,2.909h11.63l24.259-32.6h-16.354l-16.875,22.672-8.521-22.672Zm75.735,0a29.843,29.843,0,0,0-10.52,1.693,17.287,17.287,0,0,0-6.02,3.725,12.029,12.029,0,0,0-3.367,5.418l-2.072,8.421a8.939,8.939,0,0,0,1.225,7.784c1.046,1.409,3.211,3.342,7.584,4.554a25.232,25.232,0,0,0,4.832.849l3.944-.022h30.963l1.742-6.986h-28.979c-2.37,0-4.075-.6-5.068-1.791a4.425,4.425,0,0,1-.9-3.335l.372-1.484h36.23l1.351-5.494c.844-3.441.4-6.292-1.305-8.472-3.628-4.626-11.832-4.86-13.439-4.86-.149,0-.236,0-.249,0Zm182.539,23.953h0l-2.114,8.468h31.382a25.975,25.975,0,0,0,9.156-1.475,15.058,15.058,0,0,0,5.241-3.245,10.562,10.562,0,0,0,2.933-4.719l.438-1.795a9.4,9.4,0,0,0-.2-3.792,7.669,7.669,0,0,0-1.606-3.07,7.517,7.517,0,0,0-5.8-2.521h-19.385a2.565,2.565,0,0,1-2.23-.944,1.777,1.777,0,0,1,.247-1.828,7.4,7.4,0,0,1,5.281-2.522h24.095l1.625-6.513h-28.957a26,26,0,0,0-9.161,1.475,15.055,15.055,0,0,0-5.242,3.243,10.566,10.566,0,0,0-2.933,4.718l-.447,1.814h.011a5.967,5.967,0,0,0,1.419,4.777c1.382,1.518,3.718,2.354,6.578,2.354h19a2.543,2.543,0,0,1,2.262.958,1.829,1.829,0,0,1-.06,1.824c-1.059,2.062-4.37,2.793-6.884,2.793Zm-69.733-17.319h17.341l-3.839,15.375a6.31,6.31,0,0,0,1.069,5.728c2.21,2.934,6.793,4.685,12.261,4.685h34.693l8.077-32.424h-16.39l-5.154,20.836h0l0,0-1.132,4.6h-9.669c-2.49,0-4.594-.819-5.626-2.191a3.15,3.15,0,0,1-.521-2.862l5.1-20.384h-34.53l1.867-7.4h-17.338l-7.328,29.409a6.309,6.309,0,0,0,1.066,5.729c2.208,2.933,6.791,4.684,12.258,4.684h10.6l1.742-6.986h-1.919c-2.49,0-4.593-.819-5.625-2.19a3.145,3.145,0,0,1-.522-2.858l3.522-13.751Zm-98.319,5.423h-19.039a6.721,6.721,0,0,1,1.7-3.128,7.26,7.26,0,0,1,2.435-1.62,9.28,9.28,0,0,1,3.133-.7h6.865c2.406,0,4.015.593,4.781,1.762a4.308,4.308,0,0,1,.129,3.688Z" transform="translate(3774 11022)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-3424-10492h-350v-560h350v560Zm-212.753-194.6-8.127,32.6h16.351l5.128-20.562v0l12.777,20.562h16.351l8.121-32.6H-3602.5l-5.123,20.566-12.781-20.565Zm-116.248,0,8.89,23.656h.008a13.2,13.2,0,0,0,4.245,6.033,14.2,14.2,0,0,0,9.071,2.909h11.63l24.259-32.6h-16.354l-16.875,22.672-8.521-22.672Zm75.735,0a29.843,29.843,0,0,0-10.52,1.693,17.287,17.287,0,0,0-6.02,3.725,12.029,12.029,0,0,0-3.367,5.418l-2.072,8.421a8.939,8.939,0,0,0,1.225,7.784c1.046,1.409,3.211,3.342,7.584,4.554a25.232,25.232,0,0,0,4.832.849l3.944-.022h30.963l1.742-6.986h-28.979c-2.37,0-4.075-.6-5.068-1.791a4.425,4.425,0,0,1-.9-3.335l.372-1.484h36.23l1.351-5.494c.844-3.441.4-6.292-1.305-8.472-3.628-4.626-11.832-4.86-13.439-4.86-.149,0-.236,0-.249,0Zm182.539,23.953h0l-2.114,8.468h31.382a25.975,25.975,0,0,0,9.156-1.475,15.058,15.058,0,0,0,5.241-3.245,10.562,10.562,0,0,0,2.933-4.719l.438-1.795a9.4,9.4,0,0,0-.2-3.792,7.669,7.669,0,0,0-1.606-3.07,7.517,7.517,0,0,0-5.8-2.521h-19.385a2.565,2.565,0,0,1-2.23-.944,1.777,1.777,0,0,1,.247-1.828,7.4,7.4,0,0,1,5.281-2.522h24.095l1.625-6.513h-28.957a26,26,0,0,0-9.161,1.475,15.055,15.055,0,0,0-5.242,3.243,10.566,10.566,0,0,0-2.933,4.718l-.447,1.814h.011a5.967,5.967,0,0,0,1.419,4.777c1.382,1.518,3.718,2.354,6.578,2.354h19a2.543,2.543,0,0,1,2.262.958,1.829,1.829,0,0,1-.06,1.824c-1.059,2.062-4.37,2.793-6.884,2.793Zm-69.733-17.319h17.341l-3.839,15.375a6.31,6.31,0,0,0,1.069,5.728c2.21,2.934,6.793,4.685,12.261,4.685h34.693l8.077-32.424h-16.39l-5.154,20.836h0l0,0-1.132,4.6h-9.669c-2.49,0-4.594-.819-5.626-2.191a3.15,3.15,0,0,1-.521-2.862l5.1-20.384h-34.53l1.867-7.4h-17.338l-7.328,29.409a6.309,6.309,0,0,0,1.066,5.729c2.208,2.933,6.791,4.684,12.258,4.684h10.6l1.742-6.986h-1.919c-2.49,0-4.593-.819-5.625-2.19a3.145,3.145,0,0,1-.522-2.858l3.522-13.751Zm-98.319,5.423h-19.039a6.721,6.721,0,0,1,1.7-3.128,7.26,7.26,0,0,1,2.435-1.62,9.28,9.28,0,0,1,3.133-.7h6.865c2.406,0,4.015.593,4.781,1.762a4.308,4.308,0,0,1,.129,3.688Z" transform="translate(3774 11022)" /> </svg> <div class="content"> <p class="desc">Maximize your performance</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 모바일 --> <div class="svg_wrap m_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape222-m" d="M-3424-10492h-350v-560h350v560Zm-212.753-194.6-8.127,32.6h16.351l5.128-20.562v0l12.777,20.562h16.351l8.121-32.6H-3602.5l-5.123,20.566-12.781-20.565Zm-116.248,0,8.89,23.656h.008a13.2,13.2,0,0,0,4.245,6.033,14.2,14.2,0,0,0,9.071,2.909h11.63l24.259-32.6h-16.354l-16.875,22.672-8.521-22.672Zm75.735,0a29.843,29.843,0,0,0-10.52,1.693,17.287,17.287,0,0,0-6.02,3.725,12.029,12.029,0,0,0-3.367,5.418l-2.072,8.421a8.939,8.939,0,0,0,1.225,7.784c1.046,1.409,3.211,3.342,7.584,4.554a25.232,25.232,0,0,0,4.832.849l3.944-.022h30.963l1.742-6.986h-28.979c-2.37,0-4.075-.6-5.068-1.791a4.425,4.425,0,0,1-.9-3.335l.372-1.484h36.23l1.351-5.494c.844-3.441.4-6.292-1.305-8.472-3.628-4.626-11.832-4.86-13.439-4.86-.149,0-.236,0-.249,0Zm182.539,23.953h0l-2.114,8.468h31.382a25.975,25.975,0,0,0,9.156-1.475,15.058,15.058,0,0,0,5.241-3.245,10.562,10.562,0,0,0,2.933-4.719l.438-1.795a9.4,9.4,0,0,0-.2-3.792,7.669,7.669,0,0,0-1.606-3.07,7.517,7.517,0,0,0-5.8-2.521h-19.385a2.565,2.565,0,0,1-2.23-.944,1.777,1.777,0,0,1,.247-1.828,7.4,7.4,0,0,1,5.281-2.522h24.095l1.625-6.513h-28.957a26,26,0,0,0-9.161,1.475,15.055,15.055,0,0,0-5.242,3.243,10.566,10.566,0,0,0-2.933,4.718l-.447,1.814h.011a5.967,5.967,0,0,0,1.419,4.777c1.382,1.518,3.718,2.354,6.578,2.354h19a2.543,2.543,0,0,1,2.262.958,1.829,1.829,0,0,1-.06,1.824c-1.059,2.062-4.37,2.793-6.884,2.793Zm-69.733-17.319h17.341l-3.839,15.375a6.31,6.31,0,0,0,1.069,5.728c2.21,2.934,6.793,4.685,12.261,4.685h34.693l8.077-32.424h-16.39l-5.154,20.836h0l0,0-1.132,4.6h-9.669c-2.49,0-4.594-.819-5.626-2.191a3.15,3.15,0,0,1-.521-2.862l5.1-20.384h-34.53l1.867-7.4h-17.338l-7.328,29.409a6.309,6.309,0,0,0,1.066,5.729c2.208,2.933,6.791,4.684,12.258,4.684h10.6l1.742-6.986h-1.919c-2.49,0-4.593-.819-5.625-2.19a3.145,3.145,0,0,1-.522-2.858l3.522-13.751Zm-98.319,5.423h-19.039a6.721,6.721,0,0,1,1.7-3.128,7.26,7.26,0,0,1,2.435-1.62,9.28,9.28,0,0,1,3.133-.7h6.865c2.406,0,4.015.593,4.781,1.762a4.308,4.308,0,0,1,.129,3.688Z" transform="translate(3774 11052)" /> </defs> <clipPath id="clipPath222-m"> <use xlink:href="#polygonShape222-m"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath222-m);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/ventus/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-3424-10492h-350v-560h350v560Zm-212.753-194.6-8.127,32.6h16.351l5.128-20.562v0l12.777,20.562h16.351l8.121-32.6H-3602.5l-5.123,20.566-12.781-20.565Zm-116.248,0,8.89,23.656h.008a13.2,13.2,0,0,0,4.245,6.033,14.2,14.2,0,0,0,9.071,2.909h11.63l24.259-32.6h-16.354l-16.875,22.672-8.521-22.672Zm75.735,0a29.843,29.843,0,0,0-10.52,1.693,17.287,17.287,0,0,0-6.02,3.725,12.029,12.029,0,0,0-3.367,5.418l-2.072,8.421a8.939,8.939,0,0,0,1.225,7.784c1.046,1.409,3.211,3.342,7.584,4.554a25.232,25.232,0,0,0,4.832.849l3.944-.022h30.963l1.742-6.986h-28.979c-2.37,0-4.075-.6-5.068-1.791a4.425,4.425,0,0,1-.9-3.335l.372-1.484h36.23l1.351-5.494c.844-3.441.4-6.292-1.305-8.472-3.628-4.626-11.832-4.86-13.439-4.86-.149,0-.236,0-.249,0Zm182.539,23.953h0l-2.114,8.468h31.382a25.975,25.975,0,0,0,9.156-1.475,15.058,15.058,0,0,0,5.241-3.245,10.562,10.562,0,0,0,2.933-4.719l.438-1.795a9.4,9.4,0,0,0-.2-3.792,7.669,7.669,0,0,0-1.606-3.07,7.517,7.517,0,0,0-5.8-2.521h-19.385a2.565,2.565,0,0,1-2.23-.944,1.777,1.777,0,0,1,.247-1.828,7.4,7.4,0,0,1,5.281-2.522h24.095l1.625-6.513h-28.957a26,26,0,0,0-9.161,1.475,15.055,15.055,0,0,0-5.242,3.243,10.566,10.566,0,0,0-2.933,4.718l-.447,1.814h.011a5.967,5.967,0,0,0,1.419,4.777c1.382,1.518,3.718,2.354,6.578,2.354h19a2.543,2.543,0,0,1,2.262.958,1.829,1.829,0,0,1-.06,1.824c-1.059,2.062-4.37,2.793-6.884,2.793Zm-69.733-17.319h17.341l-3.839,15.375a6.31,6.31,0,0,0,1.069,5.728c2.21,2.934,6.793,4.685,12.261,4.685h34.693l8.077-32.424h-16.39l-5.154,20.836h0l0,0-1.132,4.6h-9.669c-2.49,0-4.594-.819-5.626-2.191a3.15,3.15,0,0,1-.521-2.862l5.1-20.384h-34.53l1.867-7.4h-17.338l-7.328,29.409a6.309,6.309,0,0,0,1.066,5.729c2.208,2.933,6.791,4.684,12.258,4.684h10.6l1.742-6.986h-1.919c-2.49,0-4.593-.819-5.625-2.19a3.145,3.145,0,0,1-.522-2.858l3.522-13.751Zm-98.319,5.423h-19.039a6.721,6.721,0,0,1,1.7-3.128,7.26,7.26,0,0,1,2.435-1.62,9.28,9.28,0,0,1,3.133-.7h6.865c2.406,0,4.015.593,4.781,1.762a4.308,4.308,0,0,1,.129,3.688Z" transform="translate(3774 11052)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-3424-10492h-350v-560h350v560Zm-212.753-194.6-8.127,32.6h16.351l5.128-20.562v0l12.777,20.562h16.351l8.121-32.6H-3602.5l-5.123,20.566-12.781-20.565Zm-116.248,0,8.89,23.656h.008a13.2,13.2,0,0,0,4.245,6.033,14.2,14.2,0,0,0,9.071,2.909h11.63l24.259-32.6h-16.354l-16.875,22.672-8.521-22.672Zm75.735,0a29.843,29.843,0,0,0-10.52,1.693,17.287,17.287,0,0,0-6.02,3.725,12.029,12.029,0,0,0-3.367,5.418l-2.072,8.421a8.939,8.939,0,0,0,1.225,7.784c1.046,1.409,3.211,3.342,7.584,4.554a25.232,25.232,0,0,0,4.832.849l3.944-.022h30.963l1.742-6.986h-28.979c-2.37,0-4.075-.6-5.068-1.791a4.425,4.425,0,0,1-.9-3.335l.372-1.484h36.23l1.351-5.494c.844-3.441.4-6.292-1.305-8.472-3.628-4.626-11.832-4.86-13.439-4.86-.149,0-.236,0-.249,0Zm182.539,23.953h0l-2.114,8.468h31.382a25.975,25.975,0,0,0,9.156-1.475,15.058,15.058,0,0,0,5.241-3.245,10.562,10.562,0,0,0,2.933-4.719l.438-1.795a9.4,9.4,0,0,0-.2-3.792,7.669,7.669,0,0,0-1.606-3.07,7.517,7.517,0,0,0-5.8-2.521h-19.385a2.565,2.565,0,0,1-2.23-.944,1.777,1.777,0,0,1,.247-1.828,7.4,7.4,0,0,1,5.281-2.522h24.095l1.625-6.513h-28.957a26,26,0,0,0-9.161,1.475,15.055,15.055,0,0,0-5.242,3.243,10.566,10.566,0,0,0-2.933,4.718l-.447,1.814h.011a5.967,5.967,0,0,0,1.419,4.777c1.382,1.518,3.718,2.354,6.578,2.354h19a2.543,2.543,0,0,1,2.262.958,1.829,1.829,0,0,1-.06,1.824c-1.059,2.062-4.37,2.793-6.884,2.793Zm-69.733-17.319h17.341l-3.839,15.375a6.31,6.31,0,0,0,1.069,5.728c2.21,2.934,6.793,4.685,12.261,4.685h34.693l8.077-32.424h-16.39l-5.154,20.836h0l0,0-1.132,4.6h-9.669c-2.49,0-4.594-.819-5.626-2.191a3.15,3.15,0,0,1-.521-2.862l5.1-20.384h-34.53l1.867-7.4h-17.338l-7.328,29.409a6.309,6.309,0,0,0,1.066,5.729c2.208,2.933,6.791,4.684,12.258,4.684h10.6l1.742-6.986h-1.919c-2.49,0-4.593-.819-5.625-2.19a3.145,3.145,0,0,1-.522-2.858l3.522-13.751Zm-98.319,5.423h-19.039a6.721,6.721,0,0,1,1.7-3.128,7.26,7.26,0,0,1,2.435-1.62,9.28,9.28,0,0,1,3.133-.7h6.865c2.406,0,4.015.593,4.781,1.762a4.308,4.308,0,0,1,.129,3.688Z" transform="translate(3774 11052)" /> </svg> <div class="content"> <p class="desc">Maximize your performance</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <div class="content"> <p class="desc">Maximize your performance</p> <span class="btn btn--round">Learn more</span> </div> </a> </div> <div class="display" data-id="dynapro"> <a href="/global/en/tires/dynapro.html"> <img class="display__bg t_none" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/dynapro/bg.jpg" alt="배경이미지"> <img class="display__bg t_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/dynapro/bg-m.jpg" alt="배경이미지"> <img class="display__bg m_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/dynapro/bg-m.jpg" alt="배경이미지"> <div class="display__wrap"> <div class="display__lottie"></div> </div> <!-- 웹 --> <div class="svg_wrap t_none"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape3" d="M3081-5870H1321v-720H3081v720ZM1657.245-6158.214l-5.68,22.357h118.086l1.006-.02c17.726-.345,33.035-.643,44.935-5.286a36.472,36.472,0,0,0,15.26-10.775c4.344-5.228,7.517-11.964,9.7-20.594l1.48-6.879,28.8-113.748h-70.018l-19.079,75.423c-.133.46-.264.921-.408,1.432-1.058,3.74-2.151,7.6-4.446,10.526a11.8,11.8,0,0,1-4.494,3.55,17.111,17.111,0,0,1-7.181,1.358h-9.723c-7.418,0-11.618-1.144-13.619-3.708a8.333,8.333,0,0,1-1.46-5.652,40.937,40.937,0,0,1,1.461-8.409l18.9-74.52h-70.276l-17.214,68.073c-2.046,8.072-2.927,14.67-2.694,20.171.25,5.906,1.776,10.582,4.663,14.292a21.451,21.451,0,0,0,5.5,4.917,32.645,32.645,0,0,0,7.858,3.5c6.111,1.878,13.81,2.792,23.537,2.792h59.885l-1.449,5.785c-1.37,5.41-2.664,9.025-5.223,11.5-2.8,2.708-7.038,3.915-13.732,3.915h-94.37Zm696.8-134.3-39.989,156.04h73.627l11.653-44.858h66.37a135.2,135.2,0,0,0,19.762-1.247,60.915,60.915,0,0,0,16.835-4.731c10.828-5.021,17.617-13.476,20.753-25.849l11.976-47.31a34.714,34.714,0,0,0,1.135-12.639,17.824,17.824,0,0,0-3.54-8.891c-3.117-4.006-8.154-6.773-15.4-8.46-6.019-1.4-13.45-2.054-23.386-2.054h-139.8Zm-361.826,20.8H2005c5.563,0,8.9.958,10.5,3.014a6.884,6.884,0,0,1,1.221,4.535,30.2,30.2,0,0,1-1.1,6.525l-25.154,100.005h70.706l24.2-97.932a42.063,42.063,0,0,0,1.338-15.122,22.912,22.912,0,0,0-4.547-11.584,25.43,25.43,0,0,0-11.751-8.074,56.43,56.43,0,0,0-18.978-2.816H1915.419l-33.908,135.528h70.217l25.7-103.013c1.03-4.025,2.433-6.585,4.549-8.3C1984.306-6270.832,1987.562-6271.711,1992.221-6271.711Zm163.4,28.435c-10.2,0-19.352,2.2-26.453,6.364a32.84,32.84,0,0,0-9.4,8.132,31.206,31.206,0,0,0-5.6,11.591l-5.95,28.167c-2.492,9.833-1.806,17.051,2.1,22.066,2.6,3.342,6.605,5.708,12.24,7.232,5.184,1.4,11.751,2.083,20.077,2.083h137.573l25.847-103.241c2.138-8.428.96-15.879-3.407-21.549a25.575,25.575,0,0,0-11.067-7.992,46.691,46.691,0,0,0-16.8-2.964l-121.235.227-5.457,21.442h76.25c5.046,0,10.142.218,12.166,2.823.957,1.231,1.156,2.874.608,5.021l-5.282,20.6Zm-695-70.725L1421-6157.641h146.389a76.482,76.482,0,0,0,23.335-3.339,52.46,52.46,0,0,0,17.332-9.3c9.151-7.5,15.573-18.316,19.089-32.142l16.906-66.822a54.686,54.686,0,0,0,1.832-18.456,27.14,27.14,0,0,0-5.354-14.331c-6.183-7.945-17.471-11.973-33.551-11.973H1460.619Zm1117.409,20.563-35.2,135.537h73.621l11.655-44.856h27.623l16.683,44.856h73.622l-17.959-48.291a48.257,48.257,0,0,0,9.435-3.857,36.368,36.368,0,0,0,7.9-5.79,34.912,34.912,0,0,0,6.141-8.061,44.385,44.385,0,0,0,4.143-10.667l7.193-26.808a34.734,34.734,0,0,0,1.135-12.647,17.838,17.838,0,0,0-3.543-8.9c-3.118-4.007-8.155-6.775-15.4-8.463-6.018-1.4-13.448-2.056-23.382-2.056Zm278.588,0a77.22,77.22,0,0,0-17.849,2.313,90.811,90.811,0,0,0-18.141,6.493,59.146,59.146,0,0,0-14.9,10c-4.259,4.06-6.991,8.378-8.119,12.837l-15.714,63.438a25.545,25.545,0,0,0,.8,12.315,36.658,36.658,0,0,0,6.752,12.493,40.815,40.815,0,0,0,6.271,6.165,42.419,42.419,0,0,0,7.954,4.965,47.293,47.293,0,0,0,20.66,4.516h80.577c12.519,0,26.4-4.184,38.094-11.478a62.44,62.44,0,0,0,14.545-12.271,37,37,0,0,0,8.058-14.783l15.1-60.994c1.075-5.652-.775-11.561-5.35-17.087a40.847,40.847,0,0,0-8.294-7.453,58.665,58.665,0,0,0-11.2-5.987,76.484,76.484,0,0,0-28.622-5.433l-13.9-.01ZM2215.57-6179.114h-26.584c-6.054,0-9.742-1.112-11.607-3.5-1.759-2.252-1.942-5.66-.6-11.052l4.49-13.867a19.035,19.035,0,0,1,2.9-6.446,16.56,16.56,0,0,1,4.895-4.524,22.706,22.706,0,0,1,6.829-2.666,39.706,39.706,0,0,1,8.7-.874h21.925l-10.945,42.928Zm-686.7-4.341H1502.3l26.535-104.773h26.588c7.7,0,12.026,1.151,14.035,3.732,2.4,3.083,1.353,8.212-.264,14.6l-17.3,68.15a58.75,58.75,0,0,1-2.494,8.11,15.937,15.937,0,0,1-3.721,5.7,14.646,14.646,0,0,1-6.371,3.371A40.33,40.33,0,0,1,1528.866-6183.455Zm1346.057-6.02H2871.3c-6.436,0-11.854-2.142-14.866-5.875a9.836,9.836,0,0,1-1.865-3.528,7.409,7.409,0,0,1-.136-3.592l11.435-48.259a21.307,21.307,0,0,1,4.37-5.626,14.369,14.369,0,0,1,5.03-2.89c3.627-1.217,7.768-1.217,13.01-1.217h4.708a23.858,23.858,0,0,1,8.347,1.293,11.17,11.17,0,0,1,4.975,3.479c2.1,2.68,2.64,6.406,1.563,10.774l-9.716,41.054a14.332,14.332,0,0,1-2.658,5.305,20.945,20.945,0,0,1-5.029,4.606,26.228,26.228,0,0,1-6.994,3.247A29.8,29.8,0,0,1,2874.922-6189.475Zm-441.074-17.232h-28.064l15.3-60.452h31.706a26.4,26.4,0,0,1,7.056.751,7,7,0,0,1,3.793,2.288c1.808,2.33,1.356,6.013.121,10.826l-7.237,28.6c-1.712,6.738-2.912,11.01-5.876,13.833a13.253,13.253,0,0,1-6.191,3.16A44.833,44.833,0,0,1,2433.848-6206.707Zm228.769-21.414h-28.07l10.52-39.951h31.707a26.473,26.473,0,0,1,7.058.75,7,7,0,0,1,3.793,2.286c1.807,2.327,1.356,6.012.124,10.828l-2.454,8.107c-1.714,6.735-2.915,11.006-5.88,13.827a13.261,13.261,0,0,1-6.19,3.157A44.856,44.856,0,0,1,2662.616-6228.121Z" transform="translate(-1321 6590)" /> </defs> <clipPath id="clipPath3"> <use xlink:href="#polygonShape3"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath3);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/dynapro/bg.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M3081-5870H1321v-720H3081v720ZM1657.245-6158.214l-5.68,22.357h118.086l1.006-.02c17.726-.345,33.035-.643,44.935-5.286a36.472,36.472,0,0,0,15.26-10.775c4.344-5.228,7.517-11.964,9.7-20.594l1.48-6.879,28.8-113.748h-70.018l-19.079,75.423c-.133.46-.264.921-.408,1.432-1.058,3.74-2.151,7.6-4.446,10.526a11.8,11.8,0,0,1-4.494,3.55,17.111,17.111,0,0,1-7.181,1.358h-9.723c-7.418,0-11.618-1.144-13.619-3.708a8.333,8.333,0,0,1-1.46-5.652,40.937,40.937,0,0,1,1.461-8.409l18.9-74.52h-70.276l-17.214,68.073c-2.046,8.072-2.927,14.67-2.694,20.171.25,5.906,1.776,10.582,4.663,14.292a21.451,21.451,0,0,0,5.5,4.917,32.645,32.645,0,0,0,7.858,3.5c6.111,1.878,13.81,2.792,23.537,2.792h59.885l-1.449,5.785c-1.37,5.41-2.664,9.025-5.223,11.5-2.8,2.708-7.038,3.915-13.732,3.915h-94.37Zm696.8-134.3-39.989,156.04h73.627l11.653-44.858h66.37a135.2,135.2,0,0,0,19.762-1.247,60.915,60.915,0,0,0,16.835-4.731c10.828-5.021,17.617-13.476,20.753-25.849l11.976-47.31a34.714,34.714,0,0,0,1.135-12.639,17.824,17.824,0,0,0-3.54-8.891c-3.117-4.006-8.154-6.773-15.4-8.46-6.019-1.4-13.45-2.054-23.386-2.054h-139.8Zm-361.826,20.8H2005c5.563,0,8.9.958,10.5,3.014a6.884,6.884,0,0,1,1.221,4.535,30.2,30.2,0,0,1-1.1,6.525l-25.154,100.005h70.706l24.2-97.932a42.063,42.063,0,0,0,1.338-15.122,22.912,22.912,0,0,0-4.547-11.584,25.43,25.43,0,0,0-11.751-8.074,56.43,56.43,0,0,0-18.978-2.816H1915.419l-33.908,135.528h70.217l25.7-103.013c1.03-4.025,2.433-6.585,4.549-8.3C1984.306-6270.832,1987.562-6271.711,1992.221-6271.711Zm163.4,28.435c-10.2,0-19.352,2.2-26.453,6.364a32.84,32.84,0,0,0-9.4,8.132,31.206,31.206,0,0,0-5.6,11.591l-5.95,28.167c-2.492,9.833-1.806,17.051,2.1,22.066,2.6,3.342,6.605,5.708,12.24,7.232,5.184,1.4,11.751,2.083,20.077,2.083h137.573l25.847-103.241c2.138-8.428.96-15.879-3.407-21.549a25.575,25.575,0,0,0-11.067-7.992,46.691,46.691,0,0,0-16.8-2.964l-121.235.227-5.457,21.442h76.25c5.046,0,10.142.218,12.166,2.823.957,1.231,1.156,2.874.608,5.021l-5.282,20.6Zm-695-70.725L1421-6157.641h146.389a76.482,76.482,0,0,0,23.335-3.339,52.46,52.46,0,0,0,17.332-9.3c9.151-7.5,15.573-18.316,19.089-32.142l16.906-66.822a54.686,54.686,0,0,0,1.832-18.456,27.14,27.14,0,0,0-5.354-14.331c-6.183-7.945-17.471-11.973-33.551-11.973H1460.619Zm1117.409,20.563-35.2,135.537h73.621l11.655-44.856h27.623l16.683,44.856h73.622l-17.959-48.291a48.257,48.257,0,0,0,9.435-3.857,36.368,36.368,0,0,0,7.9-5.79,34.912,34.912,0,0,0,6.141-8.061,44.385,44.385,0,0,0,4.143-10.667l7.193-26.808a34.734,34.734,0,0,0,1.135-12.647,17.838,17.838,0,0,0-3.543-8.9c-3.118-4.007-8.155-6.775-15.4-8.463-6.018-1.4-13.448-2.056-23.382-2.056Zm278.588,0a77.22,77.22,0,0,0-17.849,2.313,90.811,90.811,0,0,0-18.141,6.493,59.146,59.146,0,0,0-14.9,10c-4.259,4.06-6.991,8.378-8.119,12.837l-15.714,63.438a25.545,25.545,0,0,0,.8,12.315,36.658,36.658,0,0,0,6.752,12.493,40.815,40.815,0,0,0,6.271,6.165,42.419,42.419,0,0,0,7.954,4.965,47.293,47.293,0,0,0,20.66,4.516h80.577c12.519,0,26.4-4.184,38.094-11.478a62.44,62.44,0,0,0,14.545-12.271,37,37,0,0,0,8.058-14.783l15.1-60.994c1.075-5.652-.775-11.561-5.35-17.087a40.847,40.847,0,0,0-8.294-7.453,58.665,58.665,0,0,0-11.2-5.987,76.484,76.484,0,0,0-28.622-5.433l-13.9-.01ZM2215.57-6179.114h-26.584c-6.054,0-9.742-1.112-11.607-3.5-1.759-2.252-1.942-5.66-.6-11.052l4.49-13.867a19.035,19.035,0,0,1,2.9-6.446,16.56,16.56,0,0,1,4.895-4.524,22.706,22.706,0,0,1,6.829-2.666,39.706,39.706,0,0,1,8.7-.874h21.925l-10.945,42.928Zm-686.7-4.341H1502.3l26.535-104.773h26.588c7.7,0,12.026,1.151,14.035,3.732,2.4,3.083,1.353,8.212-.264,14.6l-17.3,68.15a58.75,58.75,0,0,1-2.494,8.11,15.937,15.937,0,0,1-3.721,5.7,14.646,14.646,0,0,1-6.371,3.371A40.33,40.33,0,0,1,1528.866-6183.455Zm1346.057-6.02H2871.3c-6.436,0-11.854-2.142-14.866-5.875a9.836,9.836,0,0,1-1.865-3.528,7.409,7.409,0,0,1-.136-3.592l11.435-48.259a21.307,21.307,0,0,1,4.37-5.626,14.369,14.369,0,0,1,5.03-2.89c3.627-1.217,7.768-1.217,13.01-1.217h4.708a23.858,23.858,0,0,1,8.347,1.293,11.17,11.17,0,0,1,4.975,3.479c2.1,2.68,2.64,6.406,1.563,10.774l-9.716,41.054a14.332,14.332,0,0,1-2.658,5.305,20.945,20.945,0,0,1-5.029,4.606,26.228,26.228,0,0,1-6.994,3.247A29.8,29.8,0,0,1,2874.922-6189.475Zm-441.074-17.232h-28.064l15.3-60.452h31.706a26.4,26.4,0,0,1,7.056.751,7,7,0,0,1,3.793,2.288c1.808,2.33,1.356,6.013.121,10.826l-7.237,28.6c-1.712,6.738-2.912,11.01-5.876,13.833a13.253,13.253,0,0,1-6.191,3.16A44.833,44.833,0,0,1,2433.848-6206.707Zm228.769-21.414h-28.07l10.52-39.951h31.707a26.473,26.473,0,0,1,7.058.75,7,7,0,0,1,3.793,2.286c1.807,2.327,1.356,6.012.124,10.828l-2.454,8.107c-1.714,6.735-2.915,11.006-5.88,13.827a13.261,13.261,0,0,1-6.19,3.157A44.856,44.856,0,0,1,2662.616-6228.121Z" transform="translate(-1321 6590)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M3081-5870H1321v-720H3081v720ZM1657.245-6158.214l-5.68,22.357h118.086l1.006-.02c17.726-.345,33.035-.643,44.935-5.286a36.472,36.472,0,0,0,15.26-10.775c4.344-5.228,7.517-11.964,9.7-20.594l1.48-6.879,28.8-113.748h-70.018l-19.079,75.423c-.133.46-.264.921-.408,1.432-1.058,3.74-2.151,7.6-4.446,10.526a11.8,11.8,0,0,1-4.494,3.55,17.111,17.111,0,0,1-7.181,1.358h-9.723c-7.418,0-11.618-1.144-13.619-3.708a8.333,8.333,0,0,1-1.46-5.652,40.937,40.937,0,0,1,1.461-8.409l18.9-74.52h-70.276l-17.214,68.073c-2.046,8.072-2.927,14.67-2.694,20.171.25,5.906,1.776,10.582,4.663,14.292a21.451,21.451,0,0,0,5.5,4.917,32.645,32.645,0,0,0,7.858,3.5c6.111,1.878,13.81,2.792,23.537,2.792h59.885l-1.449,5.785c-1.37,5.41-2.664,9.025-5.223,11.5-2.8,2.708-7.038,3.915-13.732,3.915h-94.37Zm696.8-134.3-39.989,156.04h73.627l11.653-44.858h66.37a135.2,135.2,0,0,0,19.762-1.247,60.915,60.915,0,0,0,16.835-4.731c10.828-5.021,17.617-13.476,20.753-25.849l11.976-47.31a34.714,34.714,0,0,0,1.135-12.639,17.824,17.824,0,0,0-3.54-8.891c-3.117-4.006-8.154-6.773-15.4-8.46-6.019-1.4-13.45-2.054-23.386-2.054h-139.8Zm-361.826,20.8H2005c5.563,0,8.9.958,10.5,3.014a6.884,6.884,0,0,1,1.221,4.535,30.2,30.2,0,0,1-1.1,6.525l-25.154,100.005h70.706l24.2-97.932a42.063,42.063,0,0,0,1.338-15.122,22.912,22.912,0,0,0-4.547-11.584,25.43,25.43,0,0,0-11.751-8.074,56.43,56.43,0,0,0-18.978-2.816H1915.419l-33.908,135.528h70.217l25.7-103.013c1.03-4.025,2.433-6.585,4.549-8.3C1984.306-6270.832,1987.562-6271.711,1992.221-6271.711Zm163.4,28.435c-10.2,0-19.352,2.2-26.453,6.364a32.84,32.84,0,0,0-9.4,8.132,31.206,31.206,0,0,0-5.6,11.591l-5.95,28.167c-2.492,9.833-1.806,17.051,2.1,22.066,2.6,3.342,6.605,5.708,12.24,7.232,5.184,1.4,11.751,2.083,20.077,2.083h137.573l25.847-103.241c2.138-8.428.96-15.879-3.407-21.549a25.575,25.575,0,0,0-11.067-7.992,46.691,46.691,0,0,0-16.8-2.964l-121.235.227-5.457,21.442h76.25c5.046,0,10.142.218,12.166,2.823.957,1.231,1.156,2.874.608,5.021l-5.282,20.6Zm-695-70.725L1421-6157.641h146.389a76.482,76.482,0,0,0,23.335-3.339,52.46,52.46,0,0,0,17.332-9.3c9.151-7.5,15.573-18.316,19.089-32.142l16.906-66.822a54.686,54.686,0,0,0,1.832-18.456,27.14,27.14,0,0,0-5.354-14.331c-6.183-7.945-17.471-11.973-33.551-11.973H1460.619Zm1117.409,20.563-35.2,135.537h73.621l11.655-44.856h27.623l16.683,44.856h73.622l-17.959-48.291a48.257,48.257,0,0,0,9.435-3.857,36.368,36.368,0,0,0,7.9-5.79,34.912,34.912,0,0,0,6.141-8.061,44.385,44.385,0,0,0,4.143-10.667l7.193-26.808a34.734,34.734,0,0,0,1.135-12.647,17.838,17.838,0,0,0-3.543-8.9c-3.118-4.007-8.155-6.775-15.4-8.463-6.018-1.4-13.448-2.056-23.382-2.056Zm278.588,0a77.22,77.22,0,0,0-17.849,2.313,90.811,90.811,0,0,0-18.141,6.493,59.146,59.146,0,0,0-14.9,10c-4.259,4.06-6.991,8.378-8.119,12.837l-15.714,63.438a25.545,25.545,0,0,0,.8,12.315,36.658,36.658,0,0,0,6.752,12.493,40.815,40.815,0,0,0,6.271,6.165,42.419,42.419,0,0,0,7.954,4.965,47.293,47.293,0,0,0,20.66,4.516h80.577c12.519,0,26.4-4.184,38.094-11.478a62.44,62.44,0,0,0,14.545-12.271,37,37,0,0,0,8.058-14.783l15.1-60.994c1.075-5.652-.775-11.561-5.35-17.087a40.847,40.847,0,0,0-8.294-7.453,58.665,58.665,0,0,0-11.2-5.987,76.484,76.484,0,0,0-28.622-5.433l-13.9-.01ZM2215.57-6179.114h-26.584c-6.054,0-9.742-1.112-11.607-3.5-1.759-2.252-1.942-5.66-.6-11.052l4.49-13.867a19.035,19.035,0,0,1,2.9-6.446,16.56,16.56,0,0,1,4.895-4.524,22.706,22.706,0,0,1,6.829-2.666,39.706,39.706,0,0,1,8.7-.874h21.925l-10.945,42.928Zm-686.7-4.341H1502.3l26.535-104.773h26.588c7.7,0,12.026,1.151,14.035,3.732,2.4,3.083,1.353,8.212-.264,14.6l-17.3,68.15a58.75,58.75,0,0,1-2.494,8.11,15.937,15.937,0,0,1-3.721,5.7,14.646,14.646,0,0,1-6.371,3.371A40.33,40.33,0,0,1,1528.866-6183.455Zm1346.057-6.02H2871.3c-6.436,0-11.854-2.142-14.866-5.875a9.836,9.836,0,0,1-1.865-3.528,7.409,7.409,0,0,1-.136-3.592l11.435-48.259a21.307,21.307,0,0,1,4.37-5.626,14.369,14.369,0,0,1,5.03-2.89c3.627-1.217,7.768-1.217,13.01-1.217h4.708a23.858,23.858,0,0,1,8.347,1.293,11.17,11.17,0,0,1,4.975,3.479c2.1,2.68,2.64,6.406,1.563,10.774l-9.716,41.054a14.332,14.332,0,0,1-2.658,5.305,20.945,20.945,0,0,1-5.029,4.606,26.228,26.228,0,0,1-6.994,3.247A29.8,29.8,0,0,1,2874.922-6189.475Zm-441.074-17.232h-28.064l15.3-60.452h31.706a26.4,26.4,0,0,1,7.056.751,7,7,0,0,1,3.793,2.288c1.808,2.33,1.356,6.013.121,10.826l-7.237,28.6c-1.712,6.738-2.912,11.01-5.876,13.833a13.253,13.253,0,0,1-6.191,3.16A44.833,44.833,0,0,1,2433.848-6206.707Zm228.769-21.414h-28.07l10.52-39.951h31.707a26.473,26.473,0,0,1,7.058.75,7,7,0,0,1,3.793,2.286c1.807,2.327,1.356,6.012.124,10.828l-2.454,8.107c-1.714,6.735-2.915,11.006-5.88,13.827a13.261,13.261,0,0,1-6.19,3.157A44.856,44.856,0,0,1,2662.616-6228.121Z" transform="translate(-1321 6590)" /> </svg> <div class="content"> <p class="desc">Journey longer and stronger</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 태블릿 --> <div class="svg_wrap t_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape333" d="M-5184-10492h-350v-560h350v560Zm-280.264-168.841-1.1,4.327h22.861l.195,0h.009c3.428-.066,6.389-.124,8.69-1.022a7.061,7.061,0,0,0,2.954-2.087,9.9,9.9,0,0,0,1.878-3.987l.286-1.329,5.575-22.022h-13.555l-3.692,14.6-.062.216-.017.06c-.416,1.472-.845,2.992-3.122,2.992h-1.883c-1.436,0-2.249-.222-2.636-.717-.432-.555-.327-1.419,0-2.726l3.659-14.426h-13.6l-3.334,13.178c-.806,3.183-.684,5.3.383,6.674,1.152,1.481,3.421,2.171,7.142,2.171h11.591l-.28,1.118c-.511,2.028-1.04,2.984-3.669,2.984Zm134.893-26-7.741,30.209h14.254l2.255-8.685h12.851a16.9,16.9,0,0,0,7.083-1.157,7.071,7.071,0,0,0,4.017-5l2.319-9.159c.459-1.812.307-3.177-.466-4.169-1.4-1.8-4.75-2.036-7.508-2.036Zm-70.046,4.03h2.474c1.077,0,1.724.186,2.034.583.354.454.265,1.184.024,2.141l-4.871,19.358h13.688l4.685-18.959c.556-2.187.347-3.926-.619-5.168-1.088-1.4-3.09-2.109-5.949-2.109h-26.333l-6.565,26.236h13.594l4.976-19.94C-5401.945-10681.992-5401.349-10682.812-5399.418-10682.812Zm-102.912-8.187-7.669,30.27h28.339a12.082,12.082,0,0,0,7.873-2.446,11.437,11.437,0,0,0,3.7-6.222l3.273-12.937c.694-2.739.464-4.875-.682-6.347-1.2-1.538-3.383-2.318-6.5-2.318Zm134.546,13.69c-4.224,0-7.223,1.889-8.024,5.051l-1.151,5.451c-.482,1.9-.35,3.3.406,4.273.958,1.23,2.946,1.8,6.256,1.8h26.63l5-19.987a4.711,4.711,0,0,0-.66-4.171c-1.036-1.345-2.952-2.1-5.395-2.12l-23.468.042-1.057,4.151h14.762c.977,0,1.963.042,2.354.547a1.074,1.074,0,0,1,.117.971l-1.021,3.988Zm81.774-9.71-6.815,26.238h14.251l2.258-8.683h5.348l3.229,8.684h14.254l-3.478-9.35a7.223,7.223,0,0,0,5.348-5.492l1.393-5.189c.459-1.813.306-3.178-.467-4.171-1.4-1.8-4.75-2.036-7.507-2.036Zm53.931,0a16.748,16.748,0,0,0-6.968,1.7c-2.456,1.2-4.039,2.77-4.457,4.42l-3.04,12.282a5.968,5.968,0,0,0,1.459,4.8,8.457,8.457,0,0,0,6.756,3.031h15.6a14.4,14.4,0,0,0,7.376-2.222,9.427,9.427,0,0,0,4.376-5.239l2.923-11.808a3.987,3.987,0,0,0-1.035-3.3c-1.837-2.22-5.494-3.654-9.316-3.654l-6.9-.006Zm-124.1,22.131h-5.145c-1.173,0-1.888-.216-2.25-.678-.34-.437-.375-1.1-.114-2.138l.868-2.685a3.341,3.341,0,0,1,1.51-2.125,5.767,5.767,0,0,1,3.006-.685h4.244l-2.119,8.309Zm-132.937-.841h-5.146l5.137-20.283h5.148c1.489,0,2.327.223,2.716.722.464.6.262,1.591-.051,2.828l-3.348,13.194C-5485.246-10666.942-5485.711-10665.729-5489.117-10665.729Zm260.582-1.164h-.7a3.633,3.633,0,0,1-2.878-1.137,1.666,1.666,0,0,1-.387-1.38l2.213-9.342c1.063-1.886,2.365-1.886,4.338-1.886h.91a3.121,3.121,0,0,1,2.582.925,2.367,2.367,0,0,1,.3,2.085l-1.881,7.949a3.418,3.418,0,0,1-1.486,1.919A5.378,5.378,0,0,1-5228.535-10666.893Zm-85.388-3.337h-5.434l2.962-11.7h6.138c1.137,0,1.785.182,2.1.588.35.452.263,1.165.024,2.1l-1.4,5.536a5.4,5.4,0,0,1-1.139,2.677C-5311.271-10670.463-5312.213-10670.229-5313.922-10670.229Zm44.287-4.145h-5.434l2.036-7.735h6.138c1.136,0,1.784.181,2.1.587.35.451.262,1.165.024,2.1l-.474,1.57a5.422,5.422,0,0,1-1.14,2.677C-5266.984-10674.606-5267.926-10674.374-5269.635-10674.374Z" transform="translate(5534 11022)" /> </defs> <clipPath id="clipPath333"> <use xlink:href="#polygonShape333"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath333);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/dynapro/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-5184-10492h-350v-560h350v560Zm-280.264-168.841-1.1,4.327h22.861l.195,0h.009c3.428-.066,6.389-.124,8.69-1.022a7.061,7.061,0,0,0,2.954-2.087,9.9,9.9,0,0,0,1.878-3.987l.286-1.329,5.575-22.022h-13.555l-3.692,14.6-.062.216-.017.06c-.416,1.472-.845,2.992-3.122,2.992h-1.883c-1.436,0-2.249-.222-2.636-.717-.432-.555-.327-1.419,0-2.726l3.659-14.426h-13.6l-3.334,13.178c-.806,3.183-.684,5.3.383,6.674,1.152,1.481,3.421,2.171,7.142,2.171h11.591l-.28,1.118c-.511,2.028-1.04,2.984-3.669,2.984Zm134.893-26-7.741,30.209h14.254l2.255-8.685h12.851a16.9,16.9,0,0,0,7.083-1.157,7.071,7.071,0,0,0,4.017-5l2.319-9.159c.459-1.812.307-3.177-.466-4.169-1.4-1.8-4.75-2.036-7.508-2.036Zm-70.046,4.03h2.474c1.077,0,1.724.186,2.034.583.354.454.265,1.184.024,2.141l-4.871,19.358h13.688l4.685-18.959c.556-2.187.347-3.926-.619-5.168-1.088-1.4-3.09-2.109-5.949-2.109h-26.333l-6.565,26.236h13.594l4.976-19.94C-5401.945-10681.992-5401.349-10682.812-5399.418-10682.812Zm-102.912-8.187-7.669,30.27h28.339a12.082,12.082,0,0,0,7.873-2.446,11.437,11.437,0,0,0,3.7-6.222l3.273-12.937c.694-2.739.464-4.875-.682-6.347-1.2-1.538-3.383-2.318-6.5-2.318Zm134.546,13.69c-4.224,0-7.223,1.889-8.024,5.051l-1.151,5.451c-.482,1.9-.35,3.3.406,4.273.958,1.23,2.946,1.8,6.256,1.8h26.63l5-19.987a4.711,4.711,0,0,0-.66-4.171c-1.036-1.345-2.952-2.1-5.395-2.12l-23.468.042-1.057,4.151h14.762c.977,0,1.963.042,2.354.547a1.074,1.074,0,0,1,.117.971l-1.021,3.988Zm81.774-9.71-6.815,26.238h14.251l2.258-8.683h5.348l3.229,8.684h14.254l-3.478-9.35a7.223,7.223,0,0,0,5.348-5.492l1.393-5.189c.459-1.813.306-3.178-.467-4.171-1.4-1.8-4.75-2.036-7.507-2.036Zm53.931,0a16.748,16.748,0,0,0-6.968,1.7c-2.456,1.2-4.039,2.77-4.457,4.42l-3.04,12.282a5.968,5.968,0,0,0,1.459,4.8,8.457,8.457,0,0,0,6.756,3.031h15.6a14.4,14.4,0,0,0,7.376-2.222,9.427,9.427,0,0,0,4.376-5.239l2.923-11.808a3.987,3.987,0,0,0-1.035-3.3c-1.837-2.22-5.494-3.654-9.316-3.654l-6.9-.006Zm-124.1,22.131h-5.145c-1.173,0-1.888-.216-2.25-.678-.34-.437-.375-1.1-.114-2.138l.868-2.685a3.341,3.341,0,0,1,1.51-2.125,5.767,5.767,0,0,1,3.006-.685h4.244l-2.119,8.309Zm-132.937-.841h-5.146l5.137-20.283h5.148c1.489,0,2.327.223,2.716.722.464.6.262,1.591-.051,2.828l-3.348,13.194C-5485.246-10666.942-5485.711-10665.729-5489.117-10665.729Zm260.582-1.164h-.7a3.633,3.633,0,0,1-2.878-1.137,1.666,1.666,0,0,1-.387-1.38l2.213-9.342c1.063-1.886,2.365-1.886,4.338-1.886h.91a3.121,3.121,0,0,1,2.582.925,2.367,2.367,0,0,1,.3,2.085l-1.881,7.949a3.418,3.418,0,0,1-1.486,1.919A5.378,5.378,0,0,1-5228.535-10666.893Zm-85.388-3.337h-5.434l2.962-11.7h6.138c1.137,0,1.785.182,2.1.588.35.452.263,1.165.024,2.1l-1.4,5.536a5.4,5.4,0,0,1-1.139,2.677C-5311.271-10670.463-5312.213-10670.229-5313.922-10670.229Zm44.287-4.145h-5.434l2.036-7.735h6.138c1.136,0,1.784.181,2.1.587.35.451.262,1.165.024,2.1l-.474,1.57a5.422,5.422,0,0,1-1.14,2.677C-5266.984-10674.606-5267.926-10674.374-5269.635-10674.374Z" transform="translate(5534 11022)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-5184-10492h-350v-560h350v560Zm-280.264-168.841-1.1,4.327h22.861l.195,0h.009c3.428-.066,6.389-.124,8.69-1.022a7.061,7.061,0,0,0,2.954-2.087,9.9,9.9,0,0,0,1.878-3.987l.286-1.329,5.575-22.022h-13.555l-3.692,14.6-.062.216-.017.06c-.416,1.472-.845,2.992-3.122,2.992h-1.883c-1.436,0-2.249-.222-2.636-.717-.432-.555-.327-1.419,0-2.726l3.659-14.426h-13.6l-3.334,13.178c-.806,3.183-.684,5.3.383,6.674,1.152,1.481,3.421,2.171,7.142,2.171h11.591l-.28,1.118c-.511,2.028-1.04,2.984-3.669,2.984Zm134.893-26-7.741,30.209h14.254l2.255-8.685h12.851a16.9,16.9,0,0,0,7.083-1.157,7.071,7.071,0,0,0,4.017-5l2.319-9.159c.459-1.812.307-3.177-.466-4.169-1.4-1.8-4.75-2.036-7.508-2.036Zm-70.046,4.03h2.474c1.077,0,1.724.186,2.034.583.354.454.265,1.184.024,2.141l-4.871,19.358h13.688l4.685-18.959c.556-2.187.347-3.926-.619-5.168-1.088-1.4-3.09-2.109-5.949-2.109h-26.333l-6.565,26.236h13.594l4.976-19.94C-5401.945-10681.992-5401.349-10682.812-5399.418-10682.812Zm-102.912-8.187-7.669,30.27h28.339a12.082,12.082,0,0,0,7.873-2.446,11.437,11.437,0,0,0,3.7-6.222l3.273-12.937c.694-2.739.464-4.875-.682-6.347-1.2-1.538-3.383-2.318-6.5-2.318Zm134.546,13.69c-4.224,0-7.223,1.889-8.024,5.051l-1.151,5.451c-.482,1.9-.35,3.3.406,4.273.958,1.23,2.946,1.8,6.256,1.8h26.63l5-19.987a4.711,4.711,0,0,0-.66-4.171c-1.036-1.345-2.952-2.1-5.395-2.12l-23.468.042-1.057,4.151h14.762c.977,0,1.963.042,2.354.547a1.074,1.074,0,0,1,.117.971l-1.021,3.988Zm81.774-9.71-6.815,26.238h14.251l2.258-8.683h5.348l3.229,8.684h14.254l-3.478-9.35a7.223,7.223,0,0,0,5.348-5.492l1.393-5.189c.459-1.813.306-3.178-.467-4.171-1.4-1.8-4.75-2.036-7.507-2.036Zm53.931,0a16.748,16.748,0,0,0-6.968,1.7c-2.456,1.2-4.039,2.77-4.457,4.42l-3.04,12.282a5.968,5.968,0,0,0,1.459,4.8,8.457,8.457,0,0,0,6.756,3.031h15.6a14.4,14.4,0,0,0,7.376-2.222,9.427,9.427,0,0,0,4.376-5.239l2.923-11.808a3.987,3.987,0,0,0-1.035-3.3c-1.837-2.22-5.494-3.654-9.316-3.654l-6.9-.006Zm-124.1,22.131h-5.145c-1.173,0-1.888-.216-2.25-.678-.34-.437-.375-1.1-.114-2.138l.868-2.685a3.341,3.341,0,0,1,1.51-2.125,5.767,5.767,0,0,1,3.006-.685h4.244l-2.119,8.309Zm-132.937-.841h-5.146l5.137-20.283h5.148c1.489,0,2.327.223,2.716.722.464.6.262,1.591-.051,2.828l-3.348,13.194C-5485.246-10666.942-5485.711-10665.729-5489.117-10665.729Zm260.582-1.164h-.7a3.633,3.633,0,0,1-2.878-1.137,1.666,1.666,0,0,1-.387-1.38l2.213-9.342c1.063-1.886,2.365-1.886,4.338-1.886h.91a3.121,3.121,0,0,1,2.582.925,2.367,2.367,0,0,1,.3,2.085l-1.881,7.949a3.418,3.418,0,0,1-1.486,1.919A5.378,5.378,0,0,1-5228.535-10666.893Zm-85.388-3.337h-5.434l2.962-11.7h6.138c1.137,0,1.785.182,2.1.588.35.452.263,1.165.024,2.1l-1.4,5.536a5.4,5.4,0,0,1-1.139,2.677C-5311.271-10670.463-5312.213-10670.229-5313.922-10670.229Zm44.287-4.145h-5.434l2.036-7.735h6.138c1.136,0,1.784.181,2.1.587.35.451.262,1.165.024,2.1l-.474,1.57a5.422,5.422,0,0,1-1.14,2.677C-5266.984-10674.606-5267.926-10674.374-5269.635-10674.374Z" transform="translate(5534 11022)" /> </svg> <div class="content"> <p class="desc">Journey longer and stronger</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 모바일 --> <div class="svg_wrap m_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape333-m" d="M-5184-10492h-350v-560h350v560Zm-280.264-168.841-1.1,4.327h22.861l.195,0h.009c3.428-.066,6.389-.124,8.69-1.022a7.061,7.061,0,0,0,2.954-2.087,9.9,9.9,0,0,0,1.878-3.987l.286-1.329,5.575-22.022h-13.555l-3.692,14.6-.062.216-.017.06c-.416,1.472-.845,2.992-3.122,2.992h-1.883c-1.436,0-2.249-.222-2.636-.717-.432-.555-.327-1.419,0-2.726l3.659-14.426h-13.6l-3.334,13.178c-.806,3.183-.684,5.3.383,6.674,1.152,1.481,3.421,2.171,7.142,2.171h11.591l-.28,1.118c-.511,2.028-1.04,2.984-3.669,2.984Zm134.893-26-7.741,30.209h14.254l2.255-8.685h12.851a16.9,16.9,0,0,0,7.083-1.157,7.071,7.071,0,0,0,4.017-5l2.319-9.159c.459-1.812.307-3.177-.466-4.169-1.4-1.8-4.75-2.036-7.508-2.036Zm-70.046,4.03h2.474c1.077,0,1.724.186,2.034.583.354.454.265,1.184.024,2.141l-4.871,19.358h13.688l4.685-18.959c.556-2.187.347-3.926-.619-5.168-1.088-1.4-3.09-2.109-5.949-2.109h-26.333l-6.565,26.236h13.594l4.976-19.94C-5401.945-10681.992-5401.349-10682.812-5399.418-10682.812Zm-102.912-8.187-7.669,30.27h28.339a12.082,12.082,0,0,0,7.873-2.446,11.437,11.437,0,0,0,3.7-6.222l3.273-12.937c.694-2.739.464-4.875-.682-6.347-1.2-1.538-3.383-2.318-6.5-2.318Zm134.546,13.69c-4.224,0-7.223,1.889-8.024,5.051l-1.151,5.451c-.482,1.9-.35,3.3.406,4.273.958,1.23,2.946,1.8,6.256,1.8h26.63l5-19.987a4.711,4.711,0,0,0-.66-4.171c-1.036-1.345-2.952-2.1-5.395-2.12l-23.468.042-1.057,4.151h14.762c.977,0,1.963.042,2.354.547a1.074,1.074,0,0,1,.117.971l-1.021,3.988Zm81.774-9.71-6.815,26.238h14.251l2.258-8.683h5.348l3.229,8.684h14.254l-3.478-9.35a7.223,7.223,0,0,0,5.348-5.492l1.393-5.189c.459-1.813.306-3.178-.467-4.171-1.4-1.8-4.75-2.036-7.507-2.036Zm53.931,0a16.748,16.748,0,0,0-6.968,1.7c-2.456,1.2-4.039,2.77-4.457,4.42l-3.04,12.282a5.968,5.968,0,0,0,1.459,4.8,8.457,8.457,0,0,0,6.756,3.031h15.6a14.4,14.4,0,0,0,7.376-2.222,9.427,9.427,0,0,0,4.376-5.239l2.923-11.808a3.987,3.987,0,0,0-1.035-3.3c-1.837-2.22-5.494-3.654-9.316-3.654l-6.9-.006Zm-124.1,22.131h-5.145c-1.173,0-1.888-.216-2.25-.678-.34-.437-.375-1.1-.114-2.138l.868-2.685a3.341,3.341,0,0,1,1.51-2.125,5.767,5.767,0,0,1,3.006-.685h4.244l-2.119,8.309Zm-132.937-.841h-5.146l5.137-20.283h5.148c1.489,0,2.327.223,2.716.722.464.6.262,1.591-.051,2.828l-3.348,13.194C-5485.246-10666.942-5485.711-10665.729-5489.117-10665.729Zm260.582-1.164h-.7a3.633,3.633,0,0,1-2.878-1.137,1.666,1.666,0,0,1-.387-1.38l2.213-9.342c1.063-1.886,2.365-1.886,4.338-1.886h.91a3.121,3.121,0,0,1,2.582.925,2.367,2.367,0,0,1,.3,2.085l-1.881,7.949a3.418,3.418,0,0,1-1.486,1.919A5.378,5.378,0,0,1-5228.535-10666.893Zm-85.388-3.337h-5.434l2.962-11.7h6.138c1.137,0,1.785.182,2.1.588.35.452.263,1.165.024,2.1l-1.4,5.536a5.4,5.4,0,0,1-1.139,2.677C-5311.271-10670.463-5312.213-10670.229-5313.922-10670.229Zm44.287-4.145h-5.434l2.036-7.735h6.138c1.136,0,1.784.181,2.1.587.35.451.262,1.165.024,2.1l-.474,1.57a5.422,5.422,0,0,1-1.14,2.677C-5266.984-10674.606-5267.926-10674.374-5269.635-10674.374Z" transform="translate(5534 11052)" /> </defs> <clipPath id="clipPath333-m"> <use xlink:href="#polygonShape333-m"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath333-m);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/dynapro/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-5184-10492h-350v-560h350v560Zm-280.264-168.841-1.1,4.327h22.861l.195,0h.009c3.428-.066,6.389-.124,8.69-1.022a7.061,7.061,0,0,0,2.954-2.087,9.9,9.9,0,0,0,1.878-3.987l.286-1.329,5.575-22.022h-13.555l-3.692,14.6-.062.216-.017.06c-.416,1.472-.845,2.992-3.122,2.992h-1.883c-1.436,0-2.249-.222-2.636-.717-.432-.555-.327-1.419,0-2.726l3.659-14.426h-13.6l-3.334,13.178c-.806,3.183-.684,5.3.383,6.674,1.152,1.481,3.421,2.171,7.142,2.171h11.591l-.28,1.118c-.511,2.028-1.04,2.984-3.669,2.984Zm134.893-26-7.741,30.209h14.254l2.255-8.685h12.851a16.9,16.9,0,0,0,7.083-1.157,7.071,7.071,0,0,0,4.017-5l2.319-9.159c.459-1.812.307-3.177-.466-4.169-1.4-1.8-4.75-2.036-7.508-2.036Zm-70.046,4.03h2.474c1.077,0,1.724.186,2.034.583.354.454.265,1.184.024,2.141l-4.871,19.358h13.688l4.685-18.959c.556-2.187.347-3.926-.619-5.168-1.088-1.4-3.09-2.109-5.949-2.109h-26.333l-6.565,26.236h13.594l4.976-19.94C-5401.945-10681.992-5401.349-10682.812-5399.418-10682.812Zm-102.912-8.187-7.669,30.27h28.339a12.082,12.082,0,0,0,7.873-2.446,11.437,11.437,0,0,0,3.7-6.222l3.273-12.937c.694-2.739.464-4.875-.682-6.347-1.2-1.538-3.383-2.318-6.5-2.318Zm134.546,13.69c-4.224,0-7.223,1.889-8.024,5.051l-1.151,5.451c-.482,1.9-.35,3.3.406,4.273.958,1.23,2.946,1.8,6.256,1.8h26.63l5-19.987a4.711,4.711,0,0,0-.66-4.171c-1.036-1.345-2.952-2.1-5.395-2.12l-23.468.042-1.057,4.151h14.762c.977,0,1.963.042,2.354.547a1.074,1.074,0,0,1,.117.971l-1.021,3.988Zm81.774-9.71-6.815,26.238h14.251l2.258-8.683h5.348l3.229,8.684h14.254l-3.478-9.35a7.223,7.223,0,0,0,5.348-5.492l1.393-5.189c.459-1.813.306-3.178-.467-4.171-1.4-1.8-4.75-2.036-7.507-2.036Zm53.931,0a16.748,16.748,0,0,0-6.968,1.7c-2.456,1.2-4.039,2.77-4.457,4.42l-3.04,12.282a5.968,5.968,0,0,0,1.459,4.8,8.457,8.457,0,0,0,6.756,3.031h15.6a14.4,14.4,0,0,0,7.376-2.222,9.427,9.427,0,0,0,4.376-5.239l2.923-11.808a3.987,3.987,0,0,0-1.035-3.3c-1.837-2.22-5.494-3.654-9.316-3.654l-6.9-.006Zm-124.1,22.131h-5.145c-1.173,0-1.888-.216-2.25-.678-.34-.437-.375-1.1-.114-2.138l.868-2.685a3.341,3.341,0,0,1,1.51-2.125,5.767,5.767,0,0,1,3.006-.685h4.244l-2.119,8.309Zm-132.937-.841h-5.146l5.137-20.283h5.148c1.489,0,2.327.223,2.716.722.464.6.262,1.591-.051,2.828l-3.348,13.194C-5485.246-10666.942-5485.711-10665.729-5489.117-10665.729Zm260.582-1.164h-.7a3.633,3.633,0,0,1-2.878-1.137,1.666,1.666,0,0,1-.387-1.38l2.213-9.342c1.063-1.886,2.365-1.886,4.338-1.886h.91a3.121,3.121,0,0,1,2.582.925,2.367,2.367,0,0,1,.3,2.085l-1.881,7.949a3.418,3.418,0,0,1-1.486,1.919A5.378,5.378,0,0,1-5228.535-10666.893Zm-85.388-3.337h-5.434l2.962-11.7h6.138c1.137,0,1.785.182,2.1.588.35.452.263,1.165.024,2.1l-1.4,5.536a5.4,5.4,0,0,1-1.139,2.677C-5311.271-10670.463-5312.213-10670.229-5313.922-10670.229Zm44.287-4.145h-5.434l2.036-7.735h6.138c1.136,0,1.784.181,2.1.587.35.451.262,1.165.024,2.1l-.474,1.57a5.422,5.422,0,0,1-1.14,2.677C-5266.984-10674.606-5267.926-10674.374-5269.635-10674.374Z" transform="translate(5534 11052)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-5184-10492h-350v-560h350v560Zm-280.264-168.841-1.1,4.327h22.861l.195,0h.009c3.428-.066,6.389-.124,8.69-1.022a7.061,7.061,0,0,0,2.954-2.087,9.9,9.9,0,0,0,1.878-3.987l.286-1.329,5.575-22.022h-13.555l-3.692,14.6-.062.216-.017.06c-.416,1.472-.845,2.992-3.122,2.992h-1.883c-1.436,0-2.249-.222-2.636-.717-.432-.555-.327-1.419,0-2.726l3.659-14.426h-13.6l-3.334,13.178c-.806,3.183-.684,5.3.383,6.674,1.152,1.481,3.421,2.171,7.142,2.171h11.591l-.28,1.118c-.511,2.028-1.04,2.984-3.669,2.984Zm134.893-26-7.741,30.209h14.254l2.255-8.685h12.851a16.9,16.9,0,0,0,7.083-1.157,7.071,7.071,0,0,0,4.017-5l2.319-9.159c.459-1.812.307-3.177-.466-4.169-1.4-1.8-4.75-2.036-7.508-2.036Zm-70.046,4.03h2.474c1.077,0,1.724.186,2.034.583.354.454.265,1.184.024,2.141l-4.871,19.358h13.688l4.685-18.959c.556-2.187.347-3.926-.619-5.168-1.088-1.4-3.09-2.109-5.949-2.109h-26.333l-6.565,26.236h13.594l4.976-19.94C-5401.945-10681.992-5401.349-10682.812-5399.418-10682.812Zm-102.912-8.187-7.669,30.27h28.339a12.082,12.082,0,0,0,7.873-2.446,11.437,11.437,0,0,0,3.7-6.222l3.273-12.937c.694-2.739.464-4.875-.682-6.347-1.2-1.538-3.383-2.318-6.5-2.318Zm134.546,13.69c-4.224,0-7.223,1.889-8.024,5.051l-1.151,5.451c-.482,1.9-.35,3.3.406,4.273.958,1.23,2.946,1.8,6.256,1.8h26.63l5-19.987a4.711,4.711,0,0,0-.66-4.171c-1.036-1.345-2.952-2.1-5.395-2.12l-23.468.042-1.057,4.151h14.762c.977,0,1.963.042,2.354.547a1.074,1.074,0,0,1,.117.971l-1.021,3.988Zm81.774-9.71-6.815,26.238h14.251l2.258-8.683h5.348l3.229,8.684h14.254l-3.478-9.35a7.223,7.223,0,0,0,5.348-5.492l1.393-5.189c.459-1.813.306-3.178-.467-4.171-1.4-1.8-4.75-2.036-7.507-2.036Zm53.931,0a16.748,16.748,0,0,0-6.968,1.7c-2.456,1.2-4.039,2.77-4.457,4.42l-3.04,12.282a5.968,5.968,0,0,0,1.459,4.8,8.457,8.457,0,0,0,6.756,3.031h15.6a14.4,14.4,0,0,0,7.376-2.222,9.427,9.427,0,0,0,4.376-5.239l2.923-11.808a3.987,3.987,0,0,0-1.035-3.3c-1.837-2.22-5.494-3.654-9.316-3.654l-6.9-.006Zm-124.1,22.131h-5.145c-1.173,0-1.888-.216-2.25-.678-.34-.437-.375-1.1-.114-2.138l.868-2.685a3.341,3.341,0,0,1,1.51-2.125,5.767,5.767,0,0,1,3.006-.685h4.244l-2.119,8.309Zm-132.937-.841h-5.146l5.137-20.283h5.148c1.489,0,2.327.223,2.716.722.464.6.262,1.591-.051,2.828l-3.348,13.194C-5485.246-10666.942-5485.711-10665.729-5489.117-10665.729Zm260.582-1.164h-.7a3.633,3.633,0,0,1-2.878-1.137,1.666,1.666,0,0,1-.387-1.38l2.213-9.342c1.063-1.886,2.365-1.886,4.338-1.886h.91a3.121,3.121,0,0,1,2.582.925,2.367,2.367,0,0,1,.3,2.085l-1.881,7.949a3.418,3.418,0,0,1-1.486,1.919A5.378,5.378,0,0,1-5228.535-10666.893Zm-85.388-3.337h-5.434l2.962-11.7h6.138c1.137,0,1.785.182,2.1.588.35.452.263,1.165.024,2.1l-1.4,5.536a5.4,5.4,0,0,1-1.139,2.677C-5311.271-10670.463-5312.213-10670.229-5313.922-10670.229Zm44.287-4.145h-5.434l2.036-7.735h6.138c1.136,0,1.784.181,2.1.587.35.451.262,1.165.024,2.1l-.474,1.57a5.422,5.422,0,0,1-1.14,2.677C-5266.984-10674.606-5267.926-10674.374-5269.635-10674.374Z" transform="translate(5534 11052)" /> </svg> <div class="content"> <p class="desc">Journey longer and stronger</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <div class="content"> <p class="desc">Journey longer and stronger</p> <span class="btn btn--round">Learn more</span> </div> </a> </div> <div class="display" data-id="weather-flex"> <a href="/global/en/tires/weather-flex.html"> <img class="display__bg t_none" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/weather-flex/bg.jpg" alt="배경이미지"> <img class="display__bg t_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/weather-flex/bg-m.jpg" alt="배경이미지"> <img class="display__bg m_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/weather-flex/bg-m.jpg" alt="배경이미지"> <div class="display__wrap"> <div class="display__lottie"></div> </div> <!-- 웹 --> <div class="svg_wrap t_none"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape7" d="M14443,12913H12683v-720h1760v720Zm-184.357-321.4,0,0h0l17.488,21.72c8.8,10.938,13.519,12.049,29.894,12.049h5.328c11.038,0,16.043-.349,17.648-3.686,1.351-2.836-.67-6.229-4.617-11.132l-35.544-44.149,40.94-34.166c2.974-2.484,5.577-4.383,7.669-5.907l.014-.011.126-.092.019-.015c4.1-2.979,5.965-4.339,5.229-6.594-.78-2.394-3.422-2.508-11.657-2.508h-5.089c-15.7,0-20.278,1.011-33.141,11.732L14272.4,12546l-13.538-16.826c-8.816-10.946-13.537-12.059-29.9-12.059h-5.324c-11.04,0-16.047.35-17.652,3.7-1.352,2.83.669,6.225,4.617,11.13l31.611,39.249-46.795,39.049c-6.761,5.647-9.594,8.67-8.511,11.646,1.149,3.172,5.5,3.487,15.916,3.487h5.082c11.633,0,12.7-.616,17.508-5.44l.15-.15a90.719,90.719,0,0,1,6.686-6.149Zm-121.5-74.563c-56.911,0-73.624,19.789-83.26,53.972-5.022,17.8-4.429,30.042,1.867,38.52,8.013,10.81,25.711,15.844,55.7,15.844a302.252,302.252,0,0,0,47.68-3.82c7.012-1.428,8.518-2.943,10.743-10.812,1.194-4.223,1.6-7.224-.044-9.131a5.009,5.009,0,0,0-4.058-1.543,16.747,16.747,0,0,0-2.5.22c-6.367.941-24.624,3-37.4,3-14.23,0-26.327-.429-30.233-5.705-1.847-2.5-2.019-6.275-.525-11.559,1.048-3.748,2.746-4.038,5.031-4.038h65.4c18.887,0,21.9-1.061,26.438-17.159,3.859-13.941,2.874-24.95-2.929-32.721C14179.156,12518.827,14157.259,12517.037,14137.144,12517.037Zm-106.842-35.809c-7.663,0-12.129.417-15.268,2.693a12.909,12.909,0,0,0-3.918,5.015,55.567,55.567,0,0,0-3.168,8.926l-31.459,109.713c-1.857,6.47-2.554,11.084-.29,14.1a8.309,8.309,0,0,0,5.389,3.14,52.772,52.772,0,0,0,9.683.558h4.871c15.214,0,19.544-1.636,23.854-16.648l31.452-109.705c1.855-6.466,2.551-11.078.29-14.093-2.592-3.439-8.242-3.7-16.565-3.7Zm-370.287,35.809c-56.908,0-73.62,19.789-83.256,53.972-5.025,17.8-4.433,30.045,1.867,38.52,8.009,10.81,25.707,15.844,55.7,15.844a302.3,302.3,0,0,0,47.679-3.82c7.013-1.428,8.519-2.943,10.744-10.812,1.193-4.221,1.6-7.221-.044-9.131a5.009,5.009,0,0,0-4.058-1.543,16.747,16.747,0,0,0-2.5.22c-6.367.941-24.625,3-37.4,3-14.229,0-26.324-.429-30.23-5.705-1.851-2.5-2.022-6.275-.525-11.559,1.048-3.748,2.745-4.038,5.027-4.038h65.4c18.887,0,21.9-1.061,26.438-17.159,3.856-13.945,2.871-24.954-2.929-32.721C13702.031,12518.827,13680.132,12517.037,13660.015,12517.037Zm-438.881,42.876c-34.654,0-61.8,2.21-69.771,30.013-2.456,8.566-4.049,17.395.884,23.941,6.154,8.172,21.276,11.5,52.192,11.5,15.9,0,36.434-1.23,46.741-2.8,22.5-3.428,26.093-8.509,29.429-20.146l14.242-49.687c3-10.446,2.428-17.934-1.81-23.564-6.456-8.563-21.609-12.382-49.133-12.382-26.181,0-51.11,3.176-55.831,4.074-7.134,1.409-8.665,2.923-10.925,10.8-1.229,4.272-1.689,7.532.062,9.552a5.317,5.317,0,0,0,4.265,1.594,15.458,15.458,0,0,0,2.2-.177c.819-.092,2.11-.29,3.746-.541l.749-.115.088-.014c8.155-1.26,23.336-3.6,39.581-3.6,10.688,0,19.131,0,21.868,3.636,1.411,1.877,1.46,5.015.148,9.595l-1.16,4.03c-1.138,3.972-3.025,4.295-5.194,4.295Zm-128.793-42.876c-57.828,0-74.812,19.789-84.608,53.972-5.1,17.8-4.5,30.039,1.893,38.52,8.143,10.81,26.131,15.844,56.61,15.844a312.246,312.246,0,0,0,48.463-3.82c7.125-1.428,8.655-2.943,10.918-10.812,1.208-4.221,1.622-7.22-.048-9.131a5.139,5.139,0,0,0-4.127-1.543,17.356,17.356,0,0,0-2.539.22c-6.472.941-25.026,3-38,3-14.461,0-26.755-.429-30.733-5.705-1.874-2.5-2.048-6.277-.533-11.559,1.073-3.748,2.8-4.038,5.125-4.038h66.452c19.2,0,22.266-1.061,26.874-17.159,3.92-13.941,2.918-24.95-2.979-32.721C13135.046,12518.827,13112.788,12517.037,13092.341,12517.037Zm763.4,7.054c-6.515,0-7.982,3.421-9.479,8.641-1.385,4.855-1.522,7.928-.42,9.392,1.208,1.6,3.37,1.816,5.527,1.816h14.6c2.072,0,2.421.469,2.436.488.14.182.379.9-.4,3.618l-17.42,60.827c-1.72,6-2.363,10.284-.265,13.066,2.4,3.188,7.634,3.426,15.343,3.426h4.524c14.1,0,18.119-1.516,22.117-15.431l17.413-60.834c1.174-4.1,2.365-5.161,5.793-5.161h46.012c2.957,0,5.044-.9,6.567-2.824,1.466-1.854,2.307-4.522,3.107-7.325.945-3.258,1.555-5.9.127-7.808-1.261-1.677-3.566-1.892-5.434-1.892h-46.016c-2.072,0-2.422-.473-2.437-.492-.14-.184-.38-.9.4-3.618l.8-2.443a23.36,23.36,0,0,1,8.412-12.509,24.13,24.13,0,0,1,14.565-4.582c10.5,0,32.952,1.141,39.118,1.856a18.073,18.073,0,0,0,1.836.1,6.658,6.658,0,0,0,5.232-1.933c1.246-1.3,2.236-3.4,3.211-6.793,1-3.489,1.573-5.914.482-7.752-1.055-1.781-3.212-2.266-5.711-2.826l-.007,0-.05-.011c-3.564-.723-30.054-3.085-50.035-3.085a104.575,104.575,0,0,0-20.818,1.907,60.012,60.012,0,0,0-16.911,5.984,41.374,41.374,0,0,0-12.539,10.453,43.775,43.775,0,0,0-7.7,15.314l-1.6,5.267c-1.175,4.1-2.366,5.162-5.792,5.162Zm-28.5-7.312c-15.5,0-38.726,1.127-55.673,3.646-23.487,3.307-27.644,11.729-30.951,23.268l-18.182,63.41c-1.911,6.632-2.627,11.365-.3,14.467,2.658,3.531,8.457,3.795,17,3.795h4.994c15.612,0,20.055-1.678,24.475-17.08l17.438-60.822c.88-3.071,2.455-4.774,5.107-5.521,1.462-.435,15.906-2.247,28.472-2.247h2.726c7.388,0,9.357-4.823,11.165-11.128,1.208-4.211,1.684-7.453.079-9.595C13832.132,12517.04,13829.56,12516.779,13827.234,12516.779Zm-323.956,22.328c7.445,0,11.461,1.115,13.426,3.727,2.273,3.013,2.173,8.68-.308,17.326l-13.582,47.407c-1.855,6.477-2.551,11.095-.29,14.1,2.593,3.44,8.238,3.7,16.555,3.7h4.871c15.214,0,19.544-1.636,23.854-16.648l13.883-48.419c3.346-11.671,2.479-20.964-2.577-27.62-6.714-8.835-20.6-13.129-42.46-13.129-10.047.012-19.771.876-26.211,1.525-.39.036-.756.055-1.088.055-1.171,0-1.771-.223-1.942-.432-.1-.11-.537-.8.247-3.53l5.212-18.159c1.847-6.466,2.537-11.078.279-14.09-2.589-3.439-8.238-3.7-16.562-3.7h-4.871c-15.211,0-19.539,1.634-23.844,16.631l-31.463,109.716c-1.849,6.478-2.54,11.1-.278,14.1,2.592,3.44,8.237,3.7,16.554,3.7h4.872c15.21,0,19.539-1.636,23.854-16.648l17.569-61.283c1.229-4.293,3.153-5.55,6.274-6.368A86.718,86.718,0,0,1,13503.278,12539.107Zm-151.709-51.841c-15.211,0-19.539,1.635-23.843,16.642l-23.5,81.969c-3.716,12.943-3.242,21.9,1.49,28.183,5.891,7.819,18.438,11.306,40.687,11.306,21.7,0,36.469-2.342,40.478-3.06,7.224-1.443,8.643-2.825,10.849-10.559,1.21-4.187,1.632-7.176,0-9.138-1.239-1.508-3.238-1.682-4.635-1.682-.545,0-1.14.029-1.93.094l-3.512.409a213.222,213.222,0,0,1-25.485,1.853c-7.134,0-11.626-.48-13.484-2.936-1.6-2.122-1.516-6.148.247-12.307l12.222-42.623c1.261-4.414,2.541-5.557,6.224-5.557h35.218c6.843,0,8.37-2.841,10.226-9.322,1.017-3.523,1.671-6.382.123-8.438-1.362-1.809-3.848-2.041-5.861-2.041h-35.221c-2.158,0-2.58-.472-2.621-.525-.114-.151-.421-.876.449-3.875l3.03-10.6c1.859-6.461,2.555-11.072.283-14.093-2.593-3.44-8.235-3.7-16.547-3.7Zm-411.971,138.091,1.167.008h.152a25.691,25.691,0,0,0,6.49-.645,12.849,12.849,0,0,0,5.034-2.543c3.265-2.641,6.263-7.293,10.337-14.436l60.779-106.542c5.339-9.364,7.42-14.061,5.644-17.141-1.45-2.535-4.752-2.777-8.3-2.813l-2.831-.018a26.3,26.3,0,0,0-6.507.638,13.008,13.008,0,0,0-5.074,2.522c-3.331,2.654-6.461,7.5-10.432,14.463l-44.91,78.728a2.532,2.532,0,0,1-2.257,1.426,2.6,2.6,0,0,1-.408-.032,2.9,2.9,0,0,1-2.262-2.577l-12.469-76.826a38,38,0,0,0-2.541-9.279,15.609,15.609,0,0,0-3.921-5.594,12.884,12.884,0,0,0-5.295-2.743,25.9,25.9,0,0,0-6.664-.729c-.2,0-.422,0-.674,0h-7.621a25.229,25.229,0,0,0-6.454.651,12.817,12.817,0,0,0-5.011,2.56c-3.243,2.646-6.244,7.311-10.332,14.475l-41.3,78.666a2.5,2.5,0,0,1-2.656,1.394,2.889,2.889,0,0,1-2.27-2.577l-12.469-76.826a37.971,37.971,0,0,0-2.542-9.279,15.607,15.607,0,0,0-3.921-5.594,12.874,12.874,0,0,0-5.294-2.743,25.9,25.9,0,0,0-6.664-.729c-.2,0-.423,0-.674,0l-2.842.018c-9.01.08-15.062,2.1-18.5,6.188-2.726,3.229-3.665,7.616-2.791,13.038l17.294,106.545c1.148,7.068,5.295,12.184,12.325,15.205,4.852,2.086,10.96,3.144,18.155,3.144h.181l1.131-.008,1.164.008h.1a25.73,25.73,0,0,0,6.494-.644,12.913,12.913,0,0,0,5.053-2.554c3.3-2.67,6.324-7.366,10.434-14.575l17.185-36.366,22.711-39.818,12.268,75.608c1.92,11.832,12.576,18.349,30.007,18.349h.658Zm273.094-19.044c-8.074,0-13.436-.474-15.213-2.831-1.352-1.791-1.173-5.307.58-11.4,3.076-10.735,7.681-12.356,21.918-12.356h19.048a2.788,2.788,0,0,1,2.009.532,3.148,3.148,0,0,1-.072,2.342l-4.4,15.387c-1.379,4.789-3.4,5.945-7.688,6.862A83.583,83.583,0,0,1,13212.692,12606.313Zm929.576-44.138h-36.392a4.765,4.765,0,0,1-2.072-.251s-.412-.619.441-3.643c4.388-15.557,12.837-22.194,28.251-22.194,7.663,0,12.521,1.529,14.854,4.676,2.37,3.2,2.453,8.559.254,16.373C14146.169,12562.176,14144.7,12562.176,14142.269,12562.176Zm-477.125,0h-36.4a4.785,4.785,0,0,1-2.073-.251c0-.006-.4-.636.445-3.643,4.389-15.557,12.838-22.194,28.252-22.194,7.659,0,12.518,1.529,14.854,4.676,2.37,3.2,2.453,8.559.254,16.373C13669.04,12562.176,13667.573,12562.176,13665.144,12562.176Zm-567.579,0h-37a4.7,4.7,0,0,1-2.1-.253s-.4-.665.453-3.641c4.469-15.557,13.056-22.194,28.712-22.194,7.786,0,12.725,1.529,15.1,4.676,2.411,3.209,2.494,8.564.254,16.373C13101.525,12562.176,13100.034,12562.176,13097.564,12562.176Z" transform="translate(-12683.002 -12193.002)" /> </defs> <clipPath id="clipPath7"> <use xlink:href="#polygonShape7"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath7);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/weather-flex/bg.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M14443,12913H12683v-720h1760v720Zm-184.357-321.4,0,0h0l17.488,21.72c8.8,10.938,13.519,12.049,29.894,12.049h5.328c11.038,0,16.043-.349,17.648-3.686,1.351-2.836-.67-6.229-4.617-11.132l-35.544-44.149,40.94-34.166c2.974-2.484,5.577-4.383,7.669-5.907l.014-.011.126-.092.019-.015c4.1-2.979,5.965-4.339,5.229-6.594-.78-2.394-3.422-2.508-11.657-2.508h-5.089c-15.7,0-20.278,1.011-33.141,11.732L14272.4,12546l-13.538-16.826c-8.816-10.946-13.537-12.059-29.9-12.059h-5.324c-11.04,0-16.047.35-17.652,3.7-1.352,2.83.669,6.225,4.617,11.13l31.611,39.249-46.795,39.049c-6.761,5.647-9.594,8.67-8.511,11.646,1.149,3.172,5.5,3.487,15.916,3.487h5.082c11.633,0,12.7-.616,17.508-5.44l.15-.15a90.719,90.719,0,0,1,6.686-6.149Zm-121.5-74.563c-56.911,0-73.624,19.789-83.26,53.972-5.022,17.8-4.429,30.042,1.867,38.52,8.013,10.81,25.711,15.844,55.7,15.844a302.252,302.252,0,0,0,47.68-3.82c7.012-1.428,8.518-2.943,10.743-10.812,1.194-4.223,1.6-7.224-.044-9.131a5.009,5.009,0,0,0-4.058-1.543,16.747,16.747,0,0,0-2.5.22c-6.367.941-24.624,3-37.4,3-14.23,0-26.327-.429-30.233-5.705-1.847-2.5-2.019-6.275-.525-11.559,1.048-3.748,2.746-4.038,5.031-4.038h65.4c18.887,0,21.9-1.061,26.438-17.159,3.859-13.941,2.874-24.95-2.929-32.721C14179.156,12518.827,14157.259,12517.037,14137.144,12517.037Zm-106.842-35.809c-7.663,0-12.129.417-15.268,2.693a12.909,12.909,0,0,0-3.918,5.015,55.567,55.567,0,0,0-3.168,8.926l-31.459,109.713c-1.857,6.47-2.554,11.084-.29,14.1a8.309,8.309,0,0,0,5.389,3.14,52.772,52.772,0,0,0,9.683.558h4.871c15.214,0,19.544-1.636,23.854-16.648l31.452-109.705c1.855-6.466,2.551-11.078.29-14.093-2.592-3.439-8.242-3.7-16.565-3.7Zm-370.287,35.809c-56.908,0-73.62,19.789-83.256,53.972-5.025,17.8-4.433,30.045,1.867,38.52,8.009,10.81,25.707,15.844,55.7,15.844a302.3,302.3,0,0,0,47.679-3.82c7.013-1.428,8.519-2.943,10.744-10.812,1.193-4.221,1.6-7.221-.044-9.131a5.009,5.009,0,0,0-4.058-1.543,16.747,16.747,0,0,0-2.5.22c-6.367.941-24.625,3-37.4,3-14.229,0-26.324-.429-30.23-5.705-1.851-2.5-2.022-6.275-.525-11.559,1.048-3.748,2.745-4.038,5.027-4.038h65.4c18.887,0,21.9-1.061,26.438-17.159,3.856-13.945,2.871-24.954-2.929-32.721C13702.031,12518.827,13680.132,12517.037,13660.015,12517.037Zm-438.881,42.876c-34.654,0-61.8,2.21-69.771,30.013-2.456,8.566-4.049,17.395.884,23.941,6.154,8.172,21.276,11.5,52.192,11.5,15.9,0,36.434-1.23,46.741-2.8,22.5-3.428,26.093-8.509,29.429-20.146l14.242-49.687c3-10.446,2.428-17.934-1.81-23.564-6.456-8.563-21.609-12.382-49.133-12.382-26.181,0-51.11,3.176-55.831,4.074-7.134,1.409-8.665,2.923-10.925,10.8-1.229,4.272-1.689,7.532.062,9.552a5.317,5.317,0,0,0,4.265,1.594,15.458,15.458,0,0,0,2.2-.177c.819-.092,2.11-.29,3.746-.541l.749-.115.088-.014c8.155-1.26,23.336-3.6,39.581-3.6,10.688,0,19.131,0,21.868,3.636,1.411,1.877,1.46,5.015.148,9.595l-1.16,4.03c-1.138,3.972-3.025,4.295-5.194,4.295Zm-128.793-42.876c-57.828,0-74.812,19.789-84.608,53.972-5.1,17.8-4.5,30.039,1.893,38.52,8.143,10.81,26.131,15.844,56.61,15.844a312.246,312.246,0,0,0,48.463-3.82c7.125-1.428,8.655-2.943,10.918-10.812,1.208-4.221,1.622-7.22-.048-9.131a5.139,5.139,0,0,0-4.127-1.543,17.356,17.356,0,0,0-2.539.22c-6.472.941-25.026,3-38,3-14.461,0-26.755-.429-30.733-5.705-1.874-2.5-2.048-6.277-.533-11.559,1.073-3.748,2.8-4.038,5.125-4.038h66.452c19.2,0,22.266-1.061,26.874-17.159,3.92-13.941,2.918-24.95-2.979-32.721C13135.046,12518.827,13112.788,12517.037,13092.341,12517.037Zm763.4,7.054c-6.515,0-7.982,3.421-9.479,8.641-1.385,4.855-1.522,7.928-.42,9.392,1.208,1.6,3.37,1.816,5.527,1.816h14.6c2.072,0,2.421.469,2.436.488.14.182.379.9-.4,3.618l-17.42,60.827c-1.72,6-2.363,10.284-.265,13.066,2.4,3.188,7.634,3.426,15.343,3.426h4.524c14.1,0,18.119-1.516,22.117-15.431l17.413-60.834c1.174-4.1,2.365-5.161,5.793-5.161h46.012c2.957,0,5.044-.9,6.567-2.824,1.466-1.854,2.307-4.522,3.107-7.325.945-3.258,1.555-5.9.127-7.808-1.261-1.677-3.566-1.892-5.434-1.892h-46.016c-2.072,0-2.422-.473-2.437-.492-.14-.184-.38-.9.4-3.618l.8-2.443a23.36,23.36,0,0,1,8.412-12.509,24.13,24.13,0,0,1,14.565-4.582c10.5,0,32.952,1.141,39.118,1.856a18.073,18.073,0,0,0,1.836.1,6.658,6.658,0,0,0,5.232-1.933c1.246-1.3,2.236-3.4,3.211-6.793,1-3.489,1.573-5.914.482-7.752-1.055-1.781-3.212-2.266-5.711-2.826l-.007,0-.05-.011c-3.564-.723-30.054-3.085-50.035-3.085a104.575,104.575,0,0,0-20.818,1.907,60.012,60.012,0,0,0-16.911,5.984,41.374,41.374,0,0,0-12.539,10.453,43.775,43.775,0,0,0-7.7,15.314l-1.6,5.267c-1.175,4.1-2.366,5.162-5.792,5.162Zm-28.5-7.312c-15.5,0-38.726,1.127-55.673,3.646-23.487,3.307-27.644,11.729-30.951,23.268l-18.182,63.41c-1.911,6.632-2.627,11.365-.3,14.467,2.658,3.531,8.457,3.795,17,3.795h4.994c15.612,0,20.055-1.678,24.475-17.08l17.438-60.822c.88-3.071,2.455-4.774,5.107-5.521,1.462-.435,15.906-2.247,28.472-2.247h2.726c7.388,0,9.357-4.823,11.165-11.128,1.208-4.211,1.684-7.453.079-9.595C13832.132,12517.04,13829.56,12516.779,13827.234,12516.779Zm-323.956,22.328c7.445,0,11.461,1.115,13.426,3.727,2.273,3.013,2.173,8.68-.308,17.326l-13.582,47.407c-1.855,6.477-2.551,11.095-.29,14.1,2.593,3.44,8.238,3.7,16.555,3.7h4.871c15.214,0,19.544-1.636,23.854-16.648l13.883-48.419c3.346-11.671,2.479-20.964-2.577-27.62-6.714-8.835-20.6-13.129-42.46-13.129-10.047.012-19.771.876-26.211,1.525-.39.036-.756.055-1.088.055-1.171,0-1.771-.223-1.942-.432-.1-.11-.537-.8.247-3.53l5.212-18.159c1.847-6.466,2.537-11.078.279-14.09-2.589-3.439-8.238-3.7-16.562-3.7h-4.871c-15.211,0-19.539,1.634-23.844,16.631l-31.463,109.716c-1.849,6.478-2.54,11.1-.278,14.1,2.592,3.44,8.237,3.7,16.554,3.7h4.872c15.21,0,19.539-1.636,23.854-16.648l17.569-61.283c1.229-4.293,3.153-5.55,6.274-6.368A86.718,86.718,0,0,1,13503.278,12539.107Zm-151.709-51.841c-15.211,0-19.539,1.635-23.843,16.642l-23.5,81.969c-3.716,12.943-3.242,21.9,1.49,28.183,5.891,7.819,18.438,11.306,40.687,11.306,21.7,0,36.469-2.342,40.478-3.06,7.224-1.443,8.643-2.825,10.849-10.559,1.21-4.187,1.632-7.176,0-9.138-1.239-1.508-3.238-1.682-4.635-1.682-.545,0-1.14.029-1.93.094l-3.512.409a213.222,213.222,0,0,1-25.485,1.853c-7.134,0-11.626-.48-13.484-2.936-1.6-2.122-1.516-6.148.247-12.307l12.222-42.623c1.261-4.414,2.541-5.557,6.224-5.557h35.218c6.843,0,8.37-2.841,10.226-9.322,1.017-3.523,1.671-6.382.123-8.438-1.362-1.809-3.848-2.041-5.861-2.041h-35.221c-2.158,0-2.58-.472-2.621-.525-.114-.151-.421-.876.449-3.875l3.03-10.6c1.859-6.461,2.555-11.072.283-14.093-2.593-3.44-8.235-3.7-16.547-3.7Zm-411.971,138.091,1.167.008h.152a25.691,25.691,0,0,0,6.49-.645,12.849,12.849,0,0,0,5.034-2.543c3.265-2.641,6.263-7.293,10.337-14.436l60.779-106.542c5.339-9.364,7.42-14.061,5.644-17.141-1.45-2.535-4.752-2.777-8.3-2.813l-2.831-.018a26.3,26.3,0,0,0-6.507.638,13.008,13.008,0,0,0-5.074,2.522c-3.331,2.654-6.461,7.5-10.432,14.463l-44.91,78.728a2.532,2.532,0,0,1-2.257,1.426,2.6,2.6,0,0,1-.408-.032,2.9,2.9,0,0,1-2.262-2.577l-12.469-76.826a38,38,0,0,0-2.541-9.279,15.609,15.609,0,0,0-3.921-5.594,12.884,12.884,0,0,0-5.295-2.743,25.9,25.9,0,0,0-6.664-.729c-.2,0-.422,0-.674,0h-7.621a25.229,25.229,0,0,0-6.454.651,12.817,12.817,0,0,0-5.011,2.56c-3.243,2.646-6.244,7.311-10.332,14.475l-41.3,78.666a2.5,2.5,0,0,1-2.656,1.394,2.889,2.889,0,0,1-2.27-2.577l-12.469-76.826a37.971,37.971,0,0,0-2.542-9.279,15.607,15.607,0,0,0-3.921-5.594,12.874,12.874,0,0,0-5.294-2.743,25.9,25.9,0,0,0-6.664-.729c-.2,0-.423,0-.674,0l-2.842.018c-9.01.08-15.062,2.1-18.5,6.188-2.726,3.229-3.665,7.616-2.791,13.038l17.294,106.545c1.148,7.068,5.295,12.184,12.325,15.205,4.852,2.086,10.96,3.144,18.155,3.144h.181l1.131-.008,1.164.008h.1a25.73,25.73,0,0,0,6.494-.644,12.913,12.913,0,0,0,5.053-2.554c3.3-2.67,6.324-7.366,10.434-14.575l17.185-36.366,22.711-39.818,12.268,75.608c1.92,11.832,12.576,18.349,30.007,18.349h.658Zm273.094-19.044c-8.074,0-13.436-.474-15.213-2.831-1.352-1.791-1.173-5.307.58-11.4,3.076-10.735,7.681-12.356,21.918-12.356h19.048a2.788,2.788,0,0,1,2.009.532,3.148,3.148,0,0,1-.072,2.342l-4.4,15.387c-1.379,4.789-3.4,5.945-7.688,6.862A83.583,83.583,0,0,1,13212.692,12606.313Zm929.576-44.138h-36.392a4.765,4.765,0,0,1-2.072-.251s-.412-.619.441-3.643c4.388-15.557,12.837-22.194,28.251-22.194,7.663,0,12.521,1.529,14.854,4.676,2.37,3.2,2.453,8.559.254,16.373C14146.169,12562.176,14144.7,12562.176,14142.269,12562.176Zm-477.125,0h-36.4a4.785,4.785,0,0,1-2.073-.251c0-.006-.4-.636.445-3.643,4.389-15.557,12.838-22.194,28.252-22.194,7.659,0,12.518,1.529,14.854,4.676,2.37,3.2,2.453,8.559.254,16.373C13669.04,12562.176,13667.573,12562.176,13665.144,12562.176Zm-567.579,0h-37a4.7,4.7,0,0,1-2.1-.253s-.4-.665.453-3.641c4.469-15.557,13.056-22.194,28.712-22.194,7.786,0,12.725,1.529,15.1,4.676,2.411,3.209,2.494,8.564.254,16.373C13101.525,12562.176,13100.034,12562.176,13097.564,12562.176Z" transform="translate(-12683.002 -12193.002)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M14443,12913H12683v-720h1760v720Zm-184.357-321.4,0,0h0l17.488,21.72c8.8,10.938,13.519,12.049,29.894,12.049h5.328c11.038,0,16.043-.349,17.648-3.686,1.351-2.836-.67-6.229-4.617-11.132l-35.544-44.149,40.94-34.166c2.974-2.484,5.577-4.383,7.669-5.907l.014-.011.126-.092.019-.015c4.1-2.979,5.965-4.339,5.229-6.594-.78-2.394-3.422-2.508-11.657-2.508h-5.089c-15.7,0-20.278,1.011-33.141,11.732L14272.4,12546l-13.538-16.826c-8.816-10.946-13.537-12.059-29.9-12.059h-5.324c-11.04,0-16.047.35-17.652,3.7-1.352,2.83.669,6.225,4.617,11.13l31.611,39.249-46.795,39.049c-6.761,5.647-9.594,8.67-8.511,11.646,1.149,3.172,5.5,3.487,15.916,3.487h5.082c11.633,0,12.7-.616,17.508-5.44l.15-.15a90.719,90.719,0,0,1,6.686-6.149Zm-121.5-74.563c-56.911,0-73.624,19.789-83.26,53.972-5.022,17.8-4.429,30.042,1.867,38.52,8.013,10.81,25.711,15.844,55.7,15.844a302.252,302.252,0,0,0,47.68-3.82c7.012-1.428,8.518-2.943,10.743-10.812,1.194-4.223,1.6-7.224-.044-9.131a5.009,5.009,0,0,0-4.058-1.543,16.747,16.747,0,0,0-2.5.22c-6.367.941-24.624,3-37.4,3-14.23,0-26.327-.429-30.233-5.705-1.847-2.5-2.019-6.275-.525-11.559,1.048-3.748,2.746-4.038,5.031-4.038h65.4c18.887,0,21.9-1.061,26.438-17.159,3.859-13.941,2.874-24.95-2.929-32.721C14179.156,12518.827,14157.259,12517.037,14137.144,12517.037Zm-106.842-35.809c-7.663,0-12.129.417-15.268,2.693a12.909,12.909,0,0,0-3.918,5.015,55.567,55.567,0,0,0-3.168,8.926l-31.459,109.713c-1.857,6.47-2.554,11.084-.29,14.1a8.309,8.309,0,0,0,5.389,3.14,52.772,52.772,0,0,0,9.683.558h4.871c15.214,0,19.544-1.636,23.854-16.648l31.452-109.705c1.855-6.466,2.551-11.078.29-14.093-2.592-3.439-8.242-3.7-16.565-3.7Zm-370.287,35.809c-56.908,0-73.62,19.789-83.256,53.972-5.025,17.8-4.433,30.045,1.867,38.52,8.009,10.81,25.707,15.844,55.7,15.844a302.3,302.3,0,0,0,47.679-3.82c7.013-1.428,8.519-2.943,10.744-10.812,1.193-4.221,1.6-7.221-.044-9.131a5.009,5.009,0,0,0-4.058-1.543,16.747,16.747,0,0,0-2.5.22c-6.367.941-24.625,3-37.4,3-14.229,0-26.324-.429-30.23-5.705-1.851-2.5-2.022-6.275-.525-11.559,1.048-3.748,2.745-4.038,5.027-4.038h65.4c18.887,0,21.9-1.061,26.438-17.159,3.856-13.945,2.871-24.954-2.929-32.721C13702.031,12518.827,13680.132,12517.037,13660.015,12517.037Zm-438.881,42.876c-34.654,0-61.8,2.21-69.771,30.013-2.456,8.566-4.049,17.395.884,23.941,6.154,8.172,21.276,11.5,52.192,11.5,15.9,0,36.434-1.23,46.741-2.8,22.5-3.428,26.093-8.509,29.429-20.146l14.242-49.687c3-10.446,2.428-17.934-1.81-23.564-6.456-8.563-21.609-12.382-49.133-12.382-26.181,0-51.11,3.176-55.831,4.074-7.134,1.409-8.665,2.923-10.925,10.8-1.229,4.272-1.689,7.532.062,9.552a5.317,5.317,0,0,0,4.265,1.594,15.458,15.458,0,0,0,2.2-.177c.819-.092,2.11-.29,3.746-.541l.749-.115.088-.014c8.155-1.26,23.336-3.6,39.581-3.6,10.688,0,19.131,0,21.868,3.636,1.411,1.877,1.46,5.015.148,9.595l-1.16,4.03c-1.138,3.972-3.025,4.295-5.194,4.295Zm-128.793-42.876c-57.828,0-74.812,19.789-84.608,53.972-5.1,17.8-4.5,30.039,1.893,38.52,8.143,10.81,26.131,15.844,56.61,15.844a312.246,312.246,0,0,0,48.463-3.82c7.125-1.428,8.655-2.943,10.918-10.812,1.208-4.221,1.622-7.22-.048-9.131a5.139,5.139,0,0,0-4.127-1.543,17.356,17.356,0,0,0-2.539.22c-6.472.941-25.026,3-38,3-14.461,0-26.755-.429-30.733-5.705-1.874-2.5-2.048-6.277-.533-11.559,1.073-3.748,2.8-4.038,5.125-4.038h66.452c19.2,0,22.266-1.061,26.874-17.159,3.92-13.941,2.918-24.95-2.979-32.721C13135.046,12518.827,13112.788,12517.037,13092.341,12517.037Zm763.4,7.054c-6.515,0-7.982,3.421-9.479,8.641-1.385,4.855-1.522,7.928-.42,9.392,1.208,1.6,3.37,1.816,5.527,1.816h14.6c2.072,0,2.421.469,2.436.488.14.182.379.9-.4,3.618l-17.42,60.827c-1.72,6-2.363,10.284-.265,13.066,2.4,3.188,7.634,3.426,15.343,3.426h4.524c14.1,0,18.119-1.516,22.117-15.431l17.413-60.834c1.174-4.1,2.365-5.161,5.793-5.161h46.012c2.957,0,5.044-.9,6.567-2.824,1.466-1.854,2.307-4.522,3.107-7.325.945-3.258,1.555-5.9.127-7.808-1.261-1.677-3.566-1.892-5.434-1.892h-46.016c-2.072,0-2.422-.473-2.437-.492-.14-.184-.38-.9.4-3.618l.8-2.443a23.36,23.36,0,0,1,8.412-12.509,24.13,24.13,0,0,1,14.565-4.582c10.5,0,32.952,1.141,39.118,1.856a18.073,18.073,0,0,0,1.836.1,6.658,6.658,0,0,0,5.232-1.933c1.246-1.3,2.236-3.4,3.211-6.793,1-3.489,1.573-5.914.482-7.752-1.055-1.781-3.212-2.266-5.711-2.826l-.007,0-.05-.011c-3.564-.723-30.054-3.085-50.035-3.085a104.575,104.575,0,0,0-20.818,1.907,60.012,60.012,0,0,0-16.911,5.984,41.374,41.374,0,0,0-12.539,10.453,43.775,43.775,0,0,0-7.7,15.314l-1.6,5.267c-1.175,4.1-2.366,5.162-5.792,5.162Zm-28.5-7.312c-15.5,0-38.726,1.127-55.673,3.646-23.487,3.307-27.644,11.729-30.951,23.268l-18.182,63.41c-1.911,6.632-2.627,11.365-.3,14.467,2.658,3.531,8.457,3.795,17,3.795h4.994c15.612,0,20.055-1.678,24.475-17.08l17.438-60.822c.88-3.071,2.455-4.774,5.107-5.521,1.462-.435,15.906-2.247,28.472-2.247h2.726c7.388,0,9.357-4.823,11.165-11.128,1.208-4.211,1.684-7.453.079-9.595C13832.132,12517.04,13829.56,12516.779,13827.234,12516.779Zm-323.956,22.328c7.445,0,11.461,1.115,13.426,3.727,2.273,3.013,2.173,8.68-.308,17.326l-13.582,47.407c-1.855,6.477-2.551,11.095-.29,14.1,2.593,3.44,8.238,3.7,16.555,3.7h4.871c15.214,0,19.544-1.636,23.854-16.648l13.883-48.419c3.346-11.671,2.479-20.964-2.577-27.62-6.714-8.835-20.6-13.129-42.46-13.129-10.047.012-19.771.876-26.211,1.525-.39.036-.756.055-1.088.055-1.171,0-1.771-.223-1.942-.432-.1-.11-.537-.8.247-3.53l5.212-18.159c1.847-6.466,2.537-11.078.279-14.09-2.589-3.439-8.238-3.7-16.562-3.7h-4.871c-15.211,0-19.539,1.634-23.844,16.631l-31.463,109.716c-1.849,6.478-2.54,11.1-.278,14.1,2.592,3.44,8.237,3.7,16.554,3.7h4.872c15.21,0,19.539-1.636,23.854-16.648l17.569-61.283c1.229-4.293,3.153-5.55,6.274-6.368A86.718,86.718,0,0,1,13503.278,12539.107Zm-151.709-51.841c-15.211,0-19.539,1.635-23.843,16.642l-23.5,81.969c-3.716,12.943-3.242,21.9,1.49,28.183,5.891,7.819,18.438,11.306,40.687,11.306,21.7,0,36.469-2.342,40.478-3.06,7.224-1.443,8.643-2.825,10.849-10.559,1.21-4.187,1.632-7.176,0-9.138-1.239-1.508-3.238-1.682-4.635-1.682-.545,0-1.14.029-1.93.094l-3.512.409a213.222,213.222,0,0,1-25.485,1.853c-7.134,0-11.626-.48-13.484-2.936-1.6-2.122-1.516-6.148.247-12.307l12.222-42.623c1.261-4.414,2.541-5.557,6.224-5.557h35.218c6.843,0,8.37-2.841,10.226-9.322,1.017-3.523,1.671-6.382.123-8.438-1.362-1.809-3.848-2.041-5.861-2.041h-35.221c-2.158,0-2.58-.472-2.621-.525-.114-.151-.421-.876.449-3.875l3.03-10.6c1.859-6.461,2.555-11.072.283-14.093-2.593-3.44-8.235-3.7-16.547-3.7Zm-411.971,138.091,1.167.008h.152a25.691,25.691,0,0,0,6.49-.645,12.849,12.849,0,0,0,5.034-2.543c3.265-2.641,6.263-7.293,10.337-14.436l60.779-106.542c5.339-9.364,7.42-14.061,5.644-17.141-1.45-2.535-4.752-2.777-8.3-2.813l-2.831-.018a26.3,26.3,0,0,0-6.507.638,13.008,13.008,0,0,0-5.074,2.522c-3.331,2.654-6.461,7.5-10.432,14.463l-44.91,78.728a2.532,2.532,0,0,1-2.257,1.426,2.6,2.6,0,0,1-.408-.032,2.9,2.9,0,0,1-2.262-2.577l-12.469-76.826a38,38,0,0,0-2.541-9.279,15.609,15.609,0,0,0-3.921-5.594,12.884,12.884,0,0,0-5.295-2.743,25.9,25.9,0,0,0-6.664-.729c-.2,0-.422,0-.674,0h-7.621a25.229,25.229,0,0,0-6.454.651,12.817,12.817,0,0,0-5.011,2.56c-3.243,2.646-6.244,7.311-10.332,14.475l-41.3,78.666a2.5,2.5,0,0,1-2.656,1.394,2.889,2.889,0,0,1-2.27-2.577l-12.469-76.826a37.971,37.971,0,0,0-2.542-9.279,15.607,15.607,0,0,0-3.921-5.594,12.874,12.874,0,0,0-5.294-2.743,25.9,25.9,0,0,0-6.664-.729c-.2,0-.423,0-.674,0l-2.842.018c-9.01.08-15.062,2.1-18.5,6.188-2.726,3.229-3.665,7.616-2.791,13.038l17.294,106.545c1.148,7.068,5.295,12.184,12.325,15.205,4.852,2.086,10.96,3.144,18.155,3.144h.181l1.131-.008,1.164.008h.1a25.73,25.73,0,0,0,6.494-.644,12.913,12.913,0,0,0,5.053-2.554c3.3-2.67,6.324-7.366,10.434-14.575l17.185-36.366,22.711-39.818,12.268,75.608c1.92,11.832,12.576,18.349,30.007,18.349h.658Zm273.094-19.044c-8.074,0-13.436-.474-15.213-2.831-1.352-1.791-1.173-5.307.58-11.4,3.076-10.735,7.681-12.356,21.918-12.356h19.048a2.788,2.788,0,0,1,2.009.532,3.148,3.148,0,0,1-.072,2.342l-4.4,15.387c-1.379,4.789-3.4,5.945-7.688,6.862A83.583,83.583,0,0,1,13212.692,12606.313Zm929.576-44.138h-36.392a4.765,4.765,0,0,1-2.072-.251s-.412-.619.441-3.643c4.388-15.557,12.837-22.194,28.251-22.194,7.663,0,12.521,1.529,14.854,4.676,2.37,3.2,2.453,8.559.254,16.373C14146.169,12562.176,14144.7,12562.176,14142.269,12562.176Zm-477.125,0h-36.4a4.785,4.785,0,0,1-2.073-.251c0-.006-.4-.636.445-3.643,4.389-15.557,12.838-22.194,28.252-22.194,7.659,0,12.518,1.529,14.854,4.676,2.37,3.2,2.453,8.559.254,16.373C13669.04,12562.176,13667.573,12562.176,13665.144,12562.176Zm-567.579,0h-37a4.7,4.7,0,0,1-2.1-.253s-.4-.665.453-3.641c4.469-15.557,13.056-22.194,28.712-22.194,7.786,0,12.725,1.529,15.1,4.676,2.411,3.209,2.494,8.564.254,16.373C13101.525,12562.176,13100.034,12562.176,13097.564,12562.176Z" transform="translate(-12683.002 -12193.002)" /> </svg> <div class="content"> <p class="desc">Confident driving in all weather conditions</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 태블릿 --> <div class="svg_wrap t_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape777" d="M13033.5,12753h-350v-560h350v560Zm-33.194-196.838h0l3.564,4.429c1.795,2.229,2.757,2.456,6.091,2.456h1.089c2.249,0,3.269-.071,3.6-.752.275-.579-.136-1.271-.939-2.271l-7.248-9,8.348-6.964c.639-.538,1.213-.952,1.593-1.227.837-.608,1.218-.886,1.069-1.348-.16-.487-.7-.511-2.378-.511h-1.037c-3.2,0-4.134.206-6.754,2.392l-4.19,3.5-2.761-3.429c-1.795-2.233-2.758-2.46-6.094-2.46h-1.086c-2.25,0-3.271.071-3.6.753-.274.575.138,1.268.942,2.27l6.444,8-9.542,7.958c-1.377,1.151-1.954,1.768-1.733,2.379.236.645,1.124.709,3.245.709h1.036c2.369,0,2.586-.126,3.569-1.108l.032-.032a17.762,17.762,0,0,1,1.361-1.253l5.379-4.491Zm-24.768-15.2c-11.6,0-15.011,4.034-16.973,11-1.024,3.628-.9,6.124.379,7.854,1.634,2.2,5.241,3.229,11.354,3.229a61.8,61.8,0,0,0,9.722-.778c1.43-.291,1.736-.6,2.188-2.2.245-.859.329-1.47-.007-1.861a1.026,1.026,0,0,0-.831-.315,3.393,3.393,0,0,0-.507.044,64.8,64.8,0,0,1-7.625.615c-2.9,0-5.363-.088-6.162-1.165a2.694,2.694,0,0,1-.108-2.355c.216-.765.562-.824,1.027-.824h13.333c3.848,0,4.461-.216,5.387-3.5.788-2.84.588-5.084-.595-6.67C12984.1,12541.329,12979.639,12540.964,12975.539,12540.964Zm-21.781-7.3c-1.562,0-2.473.085-3.111.549-.668.483-1.023,1.371-1.445,2.84l-6.411,22.367c-.379,1.318-.521,2.258-.059,2.872.539.722,1.424.755,3.071.755h.994c3.1,0,3.981-.334,4.861-3.395l6.411-22.364c.378-1.317.52-2.257.059-2.872-.527-.7-1.679-.752-3.376-.752Zm-75.481,7.3c-11.6,0-15.007,4.034-16.97,11-1.027,3.628-.906,6.123.38,7.854,1.633,2.2,5.24,3.229,11.354,3.229a61.782,61.782,0,0,0,9.718-.778c1.429-.291,1.736-.6,2.191-2.2.243-.862.326-1.475-.01-1.861a1.025,1.025,0,0,0-.829-.315,3.37,3.37,0,0,0-.5.044,64.854,64.854,0,0,1-7.625.615c-2.9,0-5.367-.088-6.162-1.165a2.689,2.689,0,0,1-.108-2.355c.212-.765.558-.824,1.023-.824h13.333c3.851,0,4.465-.216,5.391-3.5.785-2.845.584-5.089-.6-6.67C12886.844,12541.329,12882.378,12540.964,12878.276,12540.964Zm-89.464,8.74c-7.064,0-12.6.45-14.223,6.119-.5,1.746-.824,3.545.18,4.881,1.257,1.665,4.34,2.345,10.641,2.345a77.771,77.771,0,0,0,9.528-.572c4.581-.7,5.315-1.734,6-4.1l2.9-10.131c.611-2.131.494-3.657-.369-4.8-1.316-1.747-4.405-2.525-10.016-2.525a80.008,80.008,0,0,0-11.38.831c-1.454.288-1.767.6-2.228,2.2-.25.874-.344,1.539.013,1.946a1.089,1.089,0,0,0,.874.325,3.283,3.283,0,0,0,.444-.034c.107-.013.252-.034.431-.062l.089-.014.4-.059.018,0,.017,0a52.859,52.859,0,0,1,8.052-.733c2.18,0,3.9,0,4.458.742a2.274,2.274,0,0,1,.029,1.956l-.235.821c-.232.809-.617.874-1.06.874Zm-26.253-8.74c-11.791,0-15.253,4.034-17.248,11-1.04,3.627-.917,6.122.386,7.854,1.659,2.2,5.326,3.229,11.54,3.229a63.862,63.862,0,0,0,9.879-.778c1.45-.291,1.762-.6,2.224-2.2.248-.858.334-1.469-.007-1.861a1.041,1.041,0,0,0-.845-.315,3.521,3.521,0,0,0-.516.044,66.777,66.777,0,0,1-7.746.615c-2.948,0-5.454-.088-6.267-1.165a2.648,2.648,0,0,1-.108-2.355c.219-.765.57-.824,1.044-.824h13.548c3.913,0,4.537-.216,5.476-3.5.8-2.841.6-5.085-.6-6.67C12771.263,12541.329,12766.727,12540.964,12762.56,12540.964Zm155.616,1.438c-1.33,0-1.629.7-1.933,1.76-.283.99-.311,1.617-.085,1.917a1.332,1.332,0,0,0,1.125.37h2.977c.433,0,.5.1.5.1.028.037.076.184-.082.739l-3.552,12.4c-.351,1.222-.481,2.093-.053,2.663.489.647,1.556.7,3.127.7h.923c2.875,0,3.692-.309,4.507-3.144l3.55-12.4c.241-.834.484-1.05,1.181-1.05h9.381c1.283,0,1.614-.82,1.973-2.07.192-.663.316-1.2.026-1.59a1.333,1.333,0,0,0-1.109-.387h-9.381c-.437,0-.5-.1-.5-.1-.027-.038-.074-.186.081-.736l.167-.5a4.691,4.691,0,0,1,4.685-3.48c2.14,0,6.714.23,7.971.376.139.014.261.021.374.021.92,0,1.338-.432,1.723-1.777.2-.714.319-1.21.1-1.58s-.661-.465-1.175-.578a91.442,91.442,0,0,0-10.2-.632,15.973,15.973,0,0,0-7.689,1.609,8.419,8.419,0,0,0-4.125,5.253l-.327,1.073c-.238.836-.481,1.053-1.181,1.053Zm-5.812-1.491a87.844,87.844,0,0,0-11.347.742c-4.787.674-5.635,2.393-6.31,4.747l-3.71,12.923c-.387,1.355-.531,2.322-.059,2.951.543.718,1.726.771,3.468.771h1.017c3.183,0,4.088-.342,4.988-3.48l3.556-12.4a1.445,1.445,0,0,1,1.04-1.125,39.423,39.423,0,0,1,5.807-.454h.553c1.511,0,1.91-.984,2.276-2.271.248-.857.346-1.519.017-1.956A1.54,1.54,0,0,0,12912.363,12540.911Zm-66.037,4.554c1.521,0,2.339.228,2.737.759.466.615.445,1.771-.062,3.532l-2.771,9.662c-.376,1.322-.517,2.264-.059,2.876.531.7,1.682.752,3.376.752h.994c3.1,0,3.98-.333,4.86-3.392l2.83-9.872c.684-2.38.507-4.273-.527-5.63-1.362-1.8-4.191-2.675-8.651-2.675-2.06,0-4.036.179-5.345.311-.079.008-.153.012-.222.012-.238,0-.361-.047-.4-.091-.02-.022-.108-.163.053-.72l1.063-3.7c.376-1.319.516-2.26.056-2.872-.53-.7-1.681-.755-3.376-.755h-.994c-3.1,0-3.984.333-4.86,3.392l-6.415,22.363c-.373,1.324-.512,2.267-.055,2.876.53.7,1.681.752,3.375.752h.994c3.1,0,3.981-.333,4.861-3.392l3.581-12.492a1.56,1.56,0,0,1,1.279-1.3A17.663,17.663,0,0,1,12846.326,12545.465Zm-30.924-10.569c-3.1,0-3.984.333-4.861,3.393l-4.792,16.711c-.756,2.638-.658,4.463.3,5.744,1.2,1.593,3.758,2.3,8.295,2.3a49.48,49.48,0,0,0,8.249-.621c1.475-.3,1.764-.577,2.212-2.152.248-.854.335-1.465,0-1.865a1.132,1.132,0,0,0-.944-.343c-.114,0-.235.006-.394.02l-.717.085-.048.006a43.779,43.779,0,0,1-5.146.37c-1.453,0-2.369-.1-2.747-.6-.327-.433-.312-1.253.049-2.509l2.492-8.687c.255-.9.516-1.132,1.266-1.132h7.181c1.4,0,1.707-.579,2.087-1.9.206-.72.339-1.3.022-1.721a1.427,1.427,0,0,0-1.194-.415h-7.18c-.437,0-.521-.091-.533-.108s-.09-.161.092-.791l.618-2.159c.377-1.322.518-2.264.056-2.875-.53-.7-1.68-.753-3.372-.753Zm-92.958,9v0l2.5,15.41c.393,2.41,2.562,3.738,6.108,3.738h.64a3.413,3.413,0,0,0,2.348-.649,10.636,10.636,0,0,0,2.107-2.943l12.39-21.717c1.09-1.908,1.515-2.865,1.151-3.493-.3-.519-.971-.567-1.694-.574l-.575,0c-2.072,0-2.743.537-4.488,3.592l-9.151,16.048a.522.522,0,0,1-.463.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.545-15.658a4.915,4.915,0,0,0-1.314-3.031,3.492,3.492,0,0,0-2.437-.708h-1.7a3.367,3.367,0,0,0-2.332.654,10.822,10.822,0,0,0-2.106,2.949l-8.42,16.036a.514.514,0,0,1-.459.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.544-15.658a4.915,4.915,0,0,0-1.315-3.031,3.492,3.492,0,0,0-2.437-.708h-.14l-.579,0c-1.835.017-3.068.429-3.771,1.26a3.176,3.176,0,0,0-.569,2.659l3.526,21.72a3.92,3.92,0,0,0,2.51,3.1,9.448,9.448,0,0,0,3.7.641h.527c2.054,0,2.724-.542,4.48-3.622l3.5-7.414,4.63-8.113Zm64.647,15.269c-1.646,0-2.738-.1-3.1-.579-.274-.363-.238-1.079.118-2.322.628-2.188,1.566-2.519,4.468-2.519h3.883a.576.576,0,0,1,.409.108.638.638,0,0,1-.013.478l-.9,3.137a1.682,1.682,0,0,1-1.566,1.4A17.064,17.064,0,0,1,12787.092,12559.163Zm189.491-9h-7.419c-.37,0-.422-.053-.422-.054s-.084-.126.088-.738c.9-3.173,2.619-4.526,5.761-4.526,1.562,0,2.553.313,3.028.955s.5,1.743.053,3.336C12977.378,12550.165,12977.078,12550.165,12976.583,12550.165Zm-97.26,0h-7.418c-.326,0-.408-.04-.426-.053,0,0-.077-.14.092-.739.9-3.173,2.619-4.526,5.76-4.526,1.563,0,2.554.313,3.026.955s.5,1.74.052,3.336C12880.118,12550.165,12879.819,12550.165,12879.323,12550.165Zm-115.7,0h-7.543c-.328,0-.41-.04-.428-.053,0,0-.08-.143.095-.739.909-3.173,2.659-4.526,5.852-4.526,1.589,0,2.595.313,3.078.955s.507,1.745.052,3.336C12764.431,12550.165,12764.126,12550.165,12763.622,12550.165Z" transform="translate(-12683.5 -12193)" /> </defs> <clipPath id="clipPath777"> <use xlink:href="#polygonShape777"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath777);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/weather-flex/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M13033.5,12753h-350v-560h350v560Zm-33.194-196.838h0l3.564,4.429c1.795,2.229,2.757,2.456,6.091,2.456h1.089c2.249,0,3.269-.071,3.6-.752.275-.579-.136-1.271-.939-2.271l-7.248-9,8.348-6.964c.639-.538,1.213-.952,1.593-1.227.837-.608,1.218-.886,1.069-1.348-.16-.487-.7-.511-2.378-.511h-1.037c-3.2,0-4.134.206-6.754,2.392l-4.19,3.5-2.761-3.429c-1.795-2.233-2.758-2.46-6.094-2.46h-1.086c-2.25,0-3.271.071-3.6.753-.274.575.138,1.268.942,2.27l6.444,8-9.542,7.958c-1.377,1.151-1.954,1.768-1.733,2.379.236.645,1.124.709,3.245.709h1.036c2.369,0,2.586-.126,3.569-1.108l.032-.032a17.762,17.762,0,0,1,1.361-1.253l5.379-4.491Zm-24.768-15.2c-11.6,0-15.011,4.034-16.973,11-1.024,3.628-.9,6.124.379,7.854,1.634,2.2,5.241,3.229,11.354,3.229a61.8,61.8,0,0,0,9.722-.778c1.43-.291,1.736-.6,2.188-2.2.245-.859.329-1.47-.007-1.861a1.026,1.026,0,0,0-.831-.315,3.393,3.393,0,0,0-.507.044,64.8,64.8,0,0,1-7.625.615c-2.9,0-5.363-.088-6.162-1.165a2.694,2.694,0,0,1-.108-2.355c.216-.765.562-.824,1.027-.824h13.333c3.848,0,4.461-.216,5.387-3.5.788-2.84.588-5.084-.595-6.67C12984.1,12541.329,12979.639,12540.964,12975.539,12540.964Zm-21.781-7.3c-1.562,0-2.473.085-3.111.549-.668.483-1.023,1.371-1.445,2.84l-6.411,22.367c-.379,1.318-.521,2.258-.059,2.872.539.722,1.424.755,3.071.755h.994c3.1,0,3.981-.334,4.861-3.395l6.411-22.364c.378-1.317.52-2.257.059-2.872-.527-.7-1.679-.752-3.376-.752Zm-75.481,7.3c-11.6,0-15.007,4.034-16.97,11-1.027,3.628-.906,6.123.38,7.854,1.633,2.2,5.24,3.229,11.354,3.229a61.782,61.782,0,0,0,9.718-.778c1.429-.291,1.736-.6,2.191-2.2.243-.862.326-1.475-.01-1.861a1.025,1.025,0,0,0-.829-.315,3.37,3.37,0,0,0-.5.044,64.854,64.854,0,0,1-7.625.615c-2.9,0-5.367-.088-6.162-1.165a2.689,2.689,0,0,1-.108-2.355c.212-.765.558-.824,1.023-.824h13.333c3.851,0,4.465-.216,5.391-3.5.785-2.845.584-5.089-.6-6.67C12886.844,12541.329,12882.378,12540.964,12878.276,12540.964Zm-89.464,8.74c-7.064,0-12.6.45-14.223,6.119-.5,1.746-.824,3.545.18,4.881,1.257,1.665,4.34,2.345,10.641,2.345a77.771,77.771,0,0,0,9.528-.572c4.581-.7,5.315-1.734,6-4.1l2.9-10.131c.611-2.131.494-3.657-.369-4.8-1.316-1.747-4.405-2.525-10.016-2.525a80.008,80.008,0,0,0-11.38.831c-1.454.288-1.767.6-2.228,2.2-.25.874-.344,1.539.013,1.946a1.089,1.089,0,0,0,.874.325,3.283,3.283,0,0,0,.444-.034c.107-.013.252-.034.431-.062l.089-.014.4-.059.018,0,.017,0a52.859,52.859,0,0,1,8.052-.733c2.18,0,3.9,0,4.458.742a2.274,2.274,0,0,1,.029,1.956l-.235.821c-.232.809-.617.874-1.06.874Zm-26.253-8.74c-11.791,0-15.253,4.034-17.248,11-1.04,3.627-.917,6.122.386,7.854,1.659,2.2,5.326,3.229,11.54,3.229a63.862,63.862,0,0,0,9.879-.778c1.45-.291,1.762-.6,2.224-2.2.248-.858.334-1.469-.007-1.861a1.041,1.041,0,0,0-.845-.315,3.521,3.521,0,0,0-.516.044,66.777,66.777,0,0,1-7.746.615c-2.948,0-5.454-.088-6.267-1.165a2.648,2.648,0,0,1-.108-2.355c.219-.765.57-.824,1.044-.824h13.548c3.913,0,4.537-.216,5.476-3.5.8-2.841.6-5.085-.6-6.67C12771.263,12541.329,12766.727,12540.964,12762.56,12540.964Zm155.616,1.438c-1.33,0-1.629.7-1.933,1.76-.283.99-.311,1.617-.085,1.917a1.332,1.332,0,0,0,1.125.37h2.977c.433,0,.5.1.5.1.028.037.076.184-.082.739l-3.552,12.4c-.351,1.222-.481,2.093-.053,2.663.489.647,1.556.7,3.127.7h.923c2.875,0,3.692-.309,4.507-3.144l3.55-12.4c.241-.834.484-1.05,1.181-1.05h9.381c1.283,0,1.614-.82,1.973-2.07.192-.663.316-1.2.026-1.59a1.333,1.333,0,0,0-1.109-.387h-9.381c-.437,0-.5-.1-.5-.1-.027-.038-.074-.186.081-.736l.167-.5a4.691,4.691,0,0,1,4.685-3.48c2.14,0,6.714.23,7.971.376.139.014.261.021.374.021.92,0,1.338-.432,1.723-1.777.2-.714.319-1.21.1-1.58s-.661-.465-1.175-.578a91.442,91.442,0,0,0-10.2-.632,15.973,15.973,0,0,0-7.689,1.609,8.419,8.419,0,0,0-4.125,5.253l-.327,1.073c-.238.836-.481,1.053-1.181,1.053Zm-5.812-1.491a87.844,87.844,0,0,0-11.347.742c-4.787.674-5.635,2.393-6.31,4.747l-3.71,12.923c-.387,1.355-.531,2.322-.059,2.951.543.718,1.726.771,3.468.771h1.017c3.183,0,4.088-.342,4.988-3.48l3.556-12.4a1.445,1.445,0,0,1,1.04-1.125,39.423,39.423,0,0,1,5.807-.454h.553c1.511,0,1.91-.984,2.276-2.271.248-.857.346-1.519.017-1.956A1.54,1.54,0,0,0,12912.363,12540.911Zm-66.037,4.554c1.521,0,2.339.228,2.737.759.466.615.445,1.771-.062,3.532l-2.771,9.662c-.376,1.322-.517,2.264-.059,2.876.531.7,1.682.752,3.376.752h.994c3.1,0,3.98-.333,4.86-3.392l2.83-9.872c.684-2.38.507-4.273-.527-5.63-1.362-1.8-4.191-2.675-8.651-2.675-2.06,0-4.036.179-5.345.311-.079.008-.153.012-.222.012-.238,0-.361-.047-.4-.091-.02-.022-.108-.163.053-.72l1.063-3.7c.376-1.319.516-2.26.056-2.872-.53-.7-1.681-.755-3.376-.755h-.994c-3.1,0-3.984.333-4.86,3.392l-6.415,22.363c-.373,1.324-.512,2.267-.055,2.876.53.7,1.681.752,3.375.752h.994c3.1,0,3.981-.333,4.861-3.392l3.581-12.492a1.56,1.56,0,0,1,1.279-1.3A17.663,17.663,0,0,1,12846.326,12545.465Zm-30.924-10.569c-3.1,0-3.984.333-4.861,3.393l-4.792,16.711c-.756,2.638-.658,4.463.3,5.744,1.2,1.593,3.758,2.3,8.295,2.3a49.48,49.48,0,0,0,8.249-.621c1.475-.3,1.764-.577,2.212-2.152.248-.854.335-1.465,0-1.865a1.132,1.132,0,0,0-.944-.343c-.114,0-.235.006-.394.02l-.717.085-.048.006a43.779,43.779,0,0,1-5.146.37c-1.453,0-2.369-.1-2.747-.6-.327-.433-.312-1.253.049-2.509l2.492-8.687c.255-.9.516-1.132,1.266-1.132h7.181c1.4,0,1.707-.579,2.087-1.9.206-.72.339-1.3.022-1.721a1.427,1.427,0,0,0-1.194-.415h-7.18c-.437,0-.521-.091-.533-.108s-.09-.161.092-.791l.618-2.159c.377-1.322.518-2.264.056-2.875-.53-.7-1.68-.753-3.372-.753Zm-92.958,9v0l2.5,15.41c.393,2.41,2.562,3.738,6.108,3.738h.64a3.413,3.413,0,0,0,2.348-.649,10.636,10.636,0,0,0,2.107-2.943l12.39-21.717c1.09-1.908,1.515-2.865,1.151-3.493-.3-.519-.971-.567-1.694-.574l-.575,0c-2.072,0-2.743.537-4.488,3.592l-9.151,16.048a.522.522,0,0,1-.463.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.545-15.658a4.915,4.915,0,0,0-1.314-3.031,3.492,3.492,0,0,0-2.437-.708h-1.7a3.367,3.367,0,0,0-2.332.654,10.822,10.822,0,0,0-2.106,2.949l-8.42,16.036a.514.514,0,0,1-.459.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.544-15.658a4.915,4.915,0,0,0-1.315-3.031,3.492,3.492,0,0,0-2.437-.708h-.14l-.579,0c-1.835.017-3.068.429-3.771,1.26a3.176,3.176,0,0,0-.569,2.659l3.526,21.72a3.92,3.92,0,0,0,2.51,3.1,9.448,9.448,0,0,0,3.7.641h.527c2.054,0,2.724-.542,4.48-3.622l3.5-7.414,4.63-8.113Zm64.647,15.269c-1.646,0-2.738-.1-3.1-.579-.274-.363-.238-1.079.118-2.322.628-2.188,1.566-2.519,4.468-2.519h3.883a.576.576,0,0,1,.409.108.638.638,0,0,1-.013.478l-.9,3.137a1.682,1.682,0,0,1-1.566,1.4A17.064,17.064,0,0,1,12787.092,12559.163Zm189.491-9h-7.419c-.37,0-.422-.053-.422-.054s-.084-.126.088-.738c.9-3.173,2.619-4.526,5.761-4.526,1.562,0,2.553.313,3.028.955s.5,1.743.053,3.336C12977.378,12550.165,12977.078,12550.165,12976.583,12550.165Zm-97.26,0h-7.418c-.326,0-.408-.04-.426-.053,0,0-.077-.14.092-.739.9-3.173,2.619-4.526,5.76-4.526,1.563,0,2.554.313,3.026.955s.5,1.74.052,3.336C12880.118,12550.165,12879.819,12550.165,12879.323,12550.165Zm-115.7,0h-7.543c-.328,0-.41-.04-.428-.053,0,0-.08-.143.095-.739.909-3.173,2.659-4.526,5.852-4.526,1.589,0,2.595.313,3.078.955s.507,1.745.052,3.336C12764.431,12550.165,12764.126,12550.165,12763.622,12550.165Z" transform="translate(-12683.5 -12193)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M13033.5,12753h-350v-560h350v560Zm-33.194-196.838h0l3.564,4.429c1.795,2.229,2.757,2.456,6.091,2.456h1.089c2.249,0,3.269-.071,3.6-.752.275-.579-.136-1.271-.939-2.271l-7.248-9,8.348-6.964c.639-.538,1.213-.952,1.593-1.227.837-.608,1.218-.886,1.069-1.348-.16-.487-.7-.511-2.378-.511h-1.037c-3.2,0-4.134.206-6.754,2.392l-4.19,3.5-2.761-3.429c-1.795-2.233-2.758-2.46-6.094-2.46h-1.086c-2.25,0-3.271.071-3.6.753-.274.575.138,1.268.942,2.27l6.444,8-9.542,7.958c-1.377,1.151-1.954,1.768-1.733,2.379.236.645,1.124.709,3.245.709h1.036c2.369,0,2.586-.126,3.569-1.108l.032-.032a17.762,17.762,0,0,1,1.361-1.253l5.379-4.491Zm-24.768-15.2c-11.6,0-15.011,4.034-16.973,11-1.024,3.628-.9,6.124.379,7.854,1.634,2.2,5.241,3.229,11.354,3.229a61.8,61.8,0,0,0,9.722-.778c1.43-.291,1.736-.6,2.188-2.2.245-.859.329-1.47-.007-1.861a1.026,1.026,0,0,0-.831-.315,3.393,3.393,0,0,0-.507.044,64.8,64.8,0,0,1-7.625.615c-2.9,0-5.363-.088-6.162-1.165a2.694,2.694,0,0,1-.108-2.355c.216-.765.562-.824,1.027-.824h13.333c3.848,0,4.461-.216,5.387-3.5.788-2.84.588-5.084-.595-6.67C12984.1,12541.329,12979.639,12540.964,12975.539,12540.964Zm-21.781-7.3c-1.562,0-2.473.085-3.111.549-.668.483-1.023,1.371-1.445,2.84l-6.411,22.367c-.379,1.318-.521,2.258-.059,2.872.539.722,1.424.755,3.071.755h.994c3.1,0,3.981-.334,4.861-3.395l6.411-22.364c.378-1.317.52-2.257.059-2.872-.527-.7-1.679-.752-3.376-.752Zm-75.481,7.3c-11.6,0-15.007,4.034-16.97,11-1.027,3.628-.906,6.123.38,7.854,1.633,2.2,5.24,3.229,11.354,3.229a61.782,61.782,0,0,0,9.718-.778c1.429-.291,1.736-.6,2.191-2.2.243-.862.326-1.475-.01-1.861a1.025,1.025,0,0,0-.829-.315,3.37,3.37,0,0,0-.5.044,64.854,64.854,0,0,1-7.625.615c-2.9,0-5.367-.088-6.162-1.165a2.689,2.689,0,0,1-.108-2.355c.212-.765.558-.824,1.023-.824h13.333c3.851,0,4.465-.216,5.391-3.5.785-2.845.584-5.089-.6-6.67C12886.844,12541.329,12882.378,12540.964,12878.276,12540.964Zm-89.464,8.74c-7.064,0-12.6.45-14.223,6.119-.5,1.746-.824,3.545.18,4.881,1.257,1.665,4.34,2.345,10.641,2.345a77.771,77.771,0,0,0,9.528-.572c4.581-.7,5.315-1.734,6-4.1l2.9-10.131c.611-2.131.494-3.657-.369-4.8-1.316-1.747-4.405-2.525-10.016-2.525a80.008,80.008,0,0,0-11.38.831c-1.454.288-1.767.6-2.228,2.2-.25.874-.344,1.539.013,1.946a1.089,1.089,0,0,0,.874.325,3.283,3.283,0,0,0,.444-.034c.107-.013.252-.034.431-.062l.089-.014.4-.059.018,0,.017,0a52.859,52.859,0,0,1,8.052-.733c2.18,0,3.9,0,4.458.742a2.274,2.274,0,0,1,.029,1.956l-.235.821c-.232.809-.617.874-1.06.874Zm-26.253-8.74c-11.791,0-15.253,4.034-17.248,11-1.04,3.627-.917,6.122.386,7.854,1.659,2.2,5.326,3.229,11.54,3.229a63.862,63.862,0,0,0,9.879-.778c1.45-.291,1.762-.6,2.224-2.2.248-.858.334-1.469-.007-1.861a1.041,1.041,0,0,0-.845-.315,3.521,3.521,0,0,0-.516.044,66.777,66.777,0,0,1-7.746.615c-2.948,0-5.454-.088-6.267-1.165a2.648,2.648,0,0,1-.108-2.355c.219-.765.57-.824,1.044-.824h13.548c3.913,0,4.537-.216,5.476-3.5.8-2.841.6-5.085-.6-6.67C12771.263,12541.329,12766.727,12540.964,12762.56,12540.964Zm155.616,1.438c-1.33,0-1.629.7-1.933,1.76-.283.99-.311,1.617-.085,1.917a1.332,1.332,0,0,0,1.125.37h2.977c.433,0,.5.1.5.1.028.037.076.184-.082.739l-3.552,12.4c-.351,1.222-.481,2.093-.053,2.663.489.647,1.556.7,3.127.7h.923c2.875,0,3.692-.309,4.507-3.144l3.55-12.4c.241-.834.484-1.05,1.181-1.05h9.381c1.283,0,1.614-.82,1.973-2.07.192-.663.316-1.2.026-1.59a1.333,1.333,0,0,0-1.109-.387h-9.381c-.437,0-.5-.1-.5-.1-.027-.038-.074-.186.081-.736l.167-.5a4.691,4.691,0,0,1,4.685-3.48c2.14,0,6.714.23,7.971.376.139.014.261.021.374.021.92,0,1.338-.432,1.723-1.777.2-.714.319-1.21.1-1.58s-.661-.465-1.175-.578a91.442,91.442,0,0,0-10.2-.632,15.973,15.973,0,0,0-7.689,1.609,8.419,8.419,0,0,0-4.125,5.253l-.327,1.073c-.238.836-.481,1.053-1.181,1.053Zm-5.812-1.491a87.844,87.844,0,0,0-11.347.742c-4.787.674-5.635,2.393-6.31,4.747l-3.71,12.923c-.387,1.355-.531,2.322-.059,2.951.543.718,1.726.771,3.468.771h1.017c3.183,0,4.088-.342,4.988-3.48l3.556-12.4a1.445,1.445,0,0,1,1.04-1.125,39.423,39.423,0,0,1,5.807-.454h.553c1.511,0,1.91-.984,2.276-2.271.248-.857.346-1.519.017-1.956A1.54,1.54,0,0,0,12912.363,12540.911Zm-66.037,4.554c1.521,0,2.339.228,2.737.759.466.615.445,1.771-.062,3.532l-2.771,9.662c-.376,1.322-.517,2.264-.059,2.876.531.7,1.682.752,3.376.752h.994c3.1,0,3.98-.333,4.86-3.392l2.83-9.872c.684-2.38.507-4.273-.527-5.63-1.362-1.8-4.191-2.675-8.651-2.675-2.06,0-4.036.179-5.345.311-.079.008-.153.012-.222.012-.238,0-.361-.047-.4-.091-.02-.022-.108-.163.053-.72l1.063-3.7c.376-1.319.516-2.26.056-2.872-.53-.7-1.681-.755-3.376-.755h-.994c-3.1,0-3.984.333-4.86,3.392l-6.415,22.363c-.373,1.324-.512,2.267-.055,2.876.53.7,1.681.752,3.375.752h.994c3.1,0,3.981-.333,4.861-3.392l3.581-12.492a1.56,1.56,0,0,1,1.279-1.3A17.663,17.663,0,0,1,12846.326,12545.465Zm-30.924-10.569c-3.1,0-3.984.333-4.861,3.393l-4.792,16.711c-.756,2.638-.658,4.463.3,5.744,1.2,1.593,3.758,2.3,8.295,2.3a49.48,49.48,0,0,0,8.249-.621c1.475-.3,1.764-.577,2.212-2.152.248-.854.335-1.465,0-1.865a1.132,1.132,0,0,0-.944-.343c-.114,0-.235.006-.394.02l-.717.085-.048.006a43.779,43.779,0,0,1-5.146.37c-1.453,0-2.369-.1-2.747-.6-.327-.433-.312-1.253.049-2.509l2.492-8.687c.255-.9.516-1.132,1.266-1.132h7.181c1.4,0,1.707-.579,2.087-1.9.206-.72.339-1.3.022-1.721a1.427,1.427,0,0,0-1.194-.415h-7.18c-.437,0-.521-.091-.533-.108s-.09-.161.092-.791l.618-2.159c.377-1.322.518-2.264.056-2.875-.53-.7-1.68-.753-3.372-.753Zm-92.958,9v0l2.5,15.41c.393,2.41,2.562,3.738,6.108,3.738h.64a3.413,3.413,0,0,0,2.348-.649,10.636,10.636,0,0,0,2.107-2.943l12.39-21.717c1.09-1.908,1.515-2.865,1.151-3.493-.3-.519-.971-.567-1.694-.574l-.575,0c-2.072,0-2.743.537-4.488,3.592l-9.151,16.048a.522.522,0,0,1-.463.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.545-15.658a4.915,4.915,0,0,0-1.314-3.031,3.492,3.492,0,0,0-2.437-.708h-1.7a3.367,3.367,0,0,0-2.332.654,10.822,10.822,0,0,0-2.106,2.949l-8.42,16.036a.514.514,0,0,1-.459.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.544-15.658a4.915,4.915,0,0,0-1.315-3.031,3.492,3.492,0,0,0-2.437-.708h-.14l-.579,0c-1.835.017-3.068.429-3.771,1.26a3.176,3.176,0,0,0-.569,2.659l3.526,21.72a3.92,3.92,0,0,0,2.51,3.1,9.448,9.448,0,0,0,3.7.641h.527c2.054,0,2.724-.542,4.48-3.622l3.5-7.414,4.63-8.113Zm64.647,15.269c-1.646,0-2.738-.1-3.1-.579-.274-.363-.238-1.079.118-2.322.628-2.188,1.566-2.519,4.468-2.519h3.883a.576.576,0,0,1,.409.108.638.638,0,0,1-.013.478l-.9,3.137a1.682,1.682,0,0,1-1.566,1.4A17.064,17.064,0,0,1,12787.092,12559.163Zm189.491-9h-7.419c-.37,0-.422-.053-.422-.054s-.084-.126.088-.738c.9-3.173,2.619-4.526,5.761-4.526,1.562,0,2.553.313,3.028.955s.5,1.743.053,3.336C12977.378,12550.165,12977.078,12550.165,12976.583,12550.165Zm-97.26,0h-7.418c-.326,0-.408-.04-.426-.053,0,0-.077-.14.092-.739.9-3.173,2.619-4.526,5.76-4.526,1.563,0,2.554.313,3.026.955s.5,1.74.052,3.336C12880.118,12550.165,12879.819,12550.165,12879.323,12550.165Zm-115.7,0h-7.543c-.328,0-.41-.04-.428-.053,0,0-.08-.143.095-.739.909-3.173,2.659-4.526,5.852-4.526,1.589,0,2.595.313,3.078.955s.507,1.745.052,3.336C12764.431,12550.165,12764.126,12550.165,12763.622,12550.165Z" transform="translate(-12683.5 -12193)" /> </svg> <div class="content"> <p class="desc">Confident driving in all weather conditions</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 모바일 --> <div class="svg_wrap m_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape777-m" d="M13033.5,12753h-350v-560h350v560Zm-33.194-196.838h0l3.564,4.429c1.795,2.229,2.757,2.456,6.091,2.456h1.089c2.249,0,3.269-.071,3.6-.752.275-.579-.136-1.271-.939-2.271l-7.248-9,8.348-6.964c.639-.538,1.213-.952,1.593-1.227.837-.608,1.218-.886,1.069-1.348-.16-.487-.7-.511-2.378-.511h-1.037c-3.2,0-4.134.206-6.754,2.392l-4.19,3.5-2.761-3.429c-1.795-2.233-2.758-2.46-6.094-2.46h-1.086c-2.25,0-3.271.071-3.6.753-.274.575.138,1.268.942,2.27l6.444,8-9.542,7.958c-1.377,1.151-1.954,1.768-1.733,2.379.236.645,1.124.709,3.245.709h1.036c2.369,0,2.586-.126,3.569-1.108l.032-.032a17.762,17.762,0,0,1,1.361-1.253l5.379-4.491Zm-24.768-15.2c-11.6,0-15.011,4.034-16.973,11-1.024,3.628-.9,6.124.379,7.854,1.634,2.2,5.241,3.229,11.354,3.229a61.8,61.8,0,0,0,9.722-.778c1.43-.291,1.736-.6,2.188-2.2.245-.859.329-1.47-.007-1.861a1.026,1.026,0,0,0-.831-.315,3.393,3.393,0,0,0-.507.044,64.8,64.8,0,0,1-7.625.615c-2.9,0-5.363-.088-6.162-1.165a2.694,2.694,0,0,1-.108-2.355c.216-.765.562-.824,1.027-.824h13.333c3.848,0,4.461-.216,5.387-3.5.788-2.84.588-5.084-.595-6.67C12984.1,12541.329,12979.639,12540.964,12975.539,12540.964Zm-21.781-7.3c-1.562,0-2.473.085-3.111.549-.668.483-1.023,1.371-1.445,2.84l-6.411,22.367c-.379,1.318-.521,2.258-.059,2.872.539.722,1.424.755,3.071.755h.994c3.1,0,3.981-.334,4.861-3.395l6.411-22.364c.378-1.317.52-2.257.059-2.872-.527-.7-1.679-.752-3.376-.752Zm-75.481,7.3c-11.6,0-15.007,4.034-16.97,11-1.027,3.628-.906,6.123.38,7.854,1.633,2.2,5.24,3.229,11.354,3.229a61.782,61.782,0,0,0,9.718-.778c1.429-.291,1.736-.6,2.191-2.2.243-.862.326-1.475-.01-1.861a1.025,1.025,0,0,0-.829-.315,3.37,3.37,0,0,0-.5.044,64.854,64.854,0,0,1-7.625.615c-2.9,0-5.367-.088-6.162-1.165a2.689,2.689,0,0,1-.108-2.355c.212-.765.558-.824,1.023-.824h13.333c3.851,0,4.465-.216,5.391-3.5.785-2.845.584-5.089-.6-6.67C12886.844,12541.329,12882.378,12540.964,12878.276,12540.964Zm-89.464,8.74c-7.064,0-12.6.45-14.223,6.119-.5,1.746-.824,3.545.18,4.881,1.257,1.665,4.34,2.345,10.641,2.345a77.771,77.771,0,0,0,9.528-.572c4.581-.7,5.315-1.734,6-4.1l2.9-10.131c.611-2.131.494-3.657-.369-4.8-1.316-1.747-4.405-2.525-10.016-2.525a80.008,80.008,0,0,0-11.38.831c-1.454.288-1.767.6-2.228,2.2-.25.874-.344,1.539.013,1.946a1.089,1.089,0,0,0,.874.325,3.283,3.283,0,0,0,.444-.034c.107-.013.252-.034.431-.062l.089-.014.4-.059.018,0,.017,0a52.859,52.859,0,0,1,8.052-.733c2.18,0,3.9,0,4.458.742a2.274,2.274,0,0,1,.029,1.956l-.235.821c-.232.809-.617.874-1.06.874Zm-26.253-8.74c-11.791,0-15.253,4.034-17.248,11-1.04,3.627-.917,6.122.386,7.854,1.659,2.2,5.326,3.229,11.54,3.229a63.862,63.862,0,0,0,9.879-.778c1.45-.291,1.762-.6,2.224-2.2.248-.858.334-1.469-.007-1.861a1.041,1.041,0,0,0-.845-.315,3.521,3.521,0,0,0-.516.044,66.777,66.777,0,0,1-7.746.615c-2.948,0-5.454-.088-6.267-1.165a2.648,2.648,0,0,1-.108-2.355c.219-.765.57-.824,1.044-.824h13.548c3.913,0,4.537-.216,5.476-3.5.8-2.841.6-5.085-.6-6.67C12771.263,12541.329,12766.727,12540.964,12762.56,12540.964Zm155.616,1.438c-1.33,0-1.629.7-1.933,1.76-.283.99-.311,1.617-.085,1.917a1.332,1.332,0,0,0,1.125.37h2.977c.433,0,.5.1.5.1.028.037.076.184-.082.739l-3.552,12.4c-.351,1.222-.481,2.093-.053,2.663.489.647,1.556.7,3.127.7h.923c2.875,0,3.692-.309,4.507-3.144l3.55-12.4c.241-.834.484-1.05,1.181-1.05h9.381c1.283,0,1.614-.82,1.973-2.07.192-.663.316-1.2.026-1.59a1.333,1.333,0,0,0-1.109-.387h-9.381c-.437,0-.5-.1-.5-.1-.027-.038-.074-.186.081-.736l.167-.5a4.691,4.691,0,0,1,4.685-3.48c2.14,0,6.714.23,7.971.376.139.014.261.021.374.021.92,0,1.338-.432,1.723-1.777.2-.714.319-1.21.1-1.58s-.661-.465-1.175-.578a91.442,91.442,0,0,0-10.2-.632,15.973,15.973,0,0,0-7.689,1.609,8.419,8.419,0,0,0-4.125,5.253l-.327,1.073c-.238.836-.481,1.053-1.181,1.053Zm-5.812-1.491a87.844,87.844,0,0,0-11.347.742c-4.787.674-5.635,2.393-6.31,4.747l-3.71,12.923c-.387,1.355-.531,2.322-.059,2.951.543.718,1.726.771,3.468.771h1.017c3.183,0,4.088-.342,4.988-3.48l3.556-12.4a1.445,1.445,0,0,1,1.04-1.125,39.423,39.423,0,0,1,5.807-.454h.553c1.511,0,1.91-.984,2.276-2.271.248-.857.346-1.519.017-1.956A1.54,1.54,0,0,0,12912.363,12540.911Zm-66.037,4.554c1.521,0,2.339.228,2.737.759.466.615.445,1.771-.062,3.532l-2.771,9.662c-.376,1.322-.517,2.264-.059,2.876.531.7,1.682.752,3.376.752h.994c3.1,0,3.98-.333,4.86-3.392l2.83-9.872c.684-2.38.507-4.273-.527-5.63-1.362-1.8-4.191-2.675-8.651-2.675-2.06,0-4.036.179-5.345.311-.079.008-.153.012-.222.012-.238,0-.361-.047-.4-.091-.02-.022-.108-.163.053-.72l1.063-3.7c.376-1.319.516-2.26.056-2.872-.53-.7-1.681-.755-3.376-.755h-.994c-3.1,0-3.984.333-4.86,3.392l-6.415,22.363c-.373,1.324-.512,2.267-.055,2.876.53.7,1.681.752,3.375.752h.994c3.1,0,3.981-.333,4.861-3.392l3.581-12.492a1.56,1.56,0,0,1,1.279-1.3A17.663,17.663,0,0,1,12846.326,12545.465Zm-30.924-10.569c-3.1,0-3.984.333-4.861,3.393l-4.792,16.711c-.756,2.638-.658,4.463.3,5.744,1.2,1.593,3.758,2.3,8.295,2.3a49.48,49.48,0,0,0,8.249-.621c1.475-.3,1.764-.577,2.212-2.152.248-.854.335-1.465,0-1.865a1.132,1.132,0,0,0-.944-.343c-.114,0-.235.006-.394.02l-.717.085-.048.006a43.779,43.779,0,0,1-5.146.37c-1.453,0-2.369-.1-2.747-.6-.327-.433-.312-1.253.049-2.509l2.492-8.687c.255-.9.516-1.132,1.266-1.132h7.181c1.4,0,1.707-.579,2.087-1.9.206-.72.339-1.3.022-1.721a1.427,1.427,0,0,0-1.194-.415h-7.18c-.437,0-.521-.091-.533-.108s-.09-.161.092-.791l.618-2.159c.377-1.322.518-2.264.056-2.875-.53-.7-1.68-.753-3.372-.753Zm-92.958,9v0l2.5,15.41c.393,2.41,2.562,3.738,6.108,3.738h.64a3.413,3.413,0,0,0,2.348-.649,10.636,10.636,0,0,0,2.107-2.943l12.39-21.717c1.09-1.908,1.515-2.865,1.151-3.493-.3-.519-.971-.567-1.694-.574l-.575,0c-2.072,0-2.743.537-4.488,3.592l-9.151,16.048a.522.522,0,0,1-.463.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.545-15.658a4.915,4.915,0,0,0-1.314-3.031,3.492,3.492,0,0,0-2.437-.708h-1.7a3.367,3.367,0,0,0-2.332.654,10.822,10.822,0,0,0-2.106,2.949l-8.42,16.036a.514.514,0,0,1-.459.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.544-15.658a4.915,4.915,0,0,0-1.315-3.031,3.492,3.492,0,0,0-2.437-.708h-.14l-.579,0c-1.835.017-3.068.429-3.771,1.26a3.176,3.176,0,0,0-.569,2.659l3.526,21.72a3.92,3.92,0,0,0,2.51,3.1,9.448,9.448,0,0,0,3.7.641h.527c2.054,0,2.724-.542,4.48-3.622l3.5-7.414,4.63-8.113Zm64.647,15.269c-1.646,0-2.738-.1-3.1-.579-.274-.363-.238-1.079.118-2.322.628-2.188,1.566-2.519,4.468-2.519h3.883a.576.576,0,0,1,.409.108.638.638,0,0,1-.013.478l-.9,3.137a1.682,1.682,0,0,1-1.566,1.4A17.064,17.064,0,0,1,12787.092,12559.163Zm189.491-9h-7.419c-.37,0-.422-.053-.422-.054s-.084-.126.088-.738c.9-3.173,2.619-4.526,5.761-4.526,1.562,0,2.553.313,3.028.955s.5,1.743.053,3.336C12977.378,12550.165,12977.078,12550.165,12976.583,12550.165Zm-97.26,0h-7.418c-.326,0-.408-.04-.426-.053,0,0-.077-.14.092-.739.9-3.173,2.619-4.526,5.76-4.526,1.563,0,2.554.313,3.026.955s.5,1.74.052,3.336C12880.118,12550.165,12879.819,12550.165,12879.323,12550.165Zm-115.7,0h-7.543c-.328,0-.41-.04-.428-.053,0,0-.08-.143.095-.739.909-3.173,2.659-4.526,5.852-4.526,1.589,0,2.595.313,3.078.955s.507,1.745.052,3.336C12764.431,12550.165,12764.126,12550.165,12763.622,12550.165Z" transform="translate(-12683.5 -12193)" /> </defs> <clipPath id="clipPath777-m"> <use xlink:href="#polygonShape777-m"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath777-m);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/weather-flex/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M13033.5,12753h-350v-560h350v560Zm-33.194-196.838h0l3.564,4.429c1.795,2.229,2.757,2.456,6.091,2.456h1.089c2.249,0,3.269-.071,3.6-.752.275-.579-.136-1.271-.939-2.271l-7.248-9,8.348-6.964c.639-.538,1.213-.952,1.593-1.227.837-.608,1.218-.886,1.069-1.348-.16-.487-.7-.511-2.378-.511h-1.037c-3.2,0-4.134.206-6.754,2.392l-4.19,3.5-2.761-3.429c-1.795-2.233-2.758-2.46-6.094-2.46h-1.086c-2.25,0-3.271.071-3.6.753-.274.575.138,1.268.942,2.27l6.444,8-9.542,7.958c-1.377,1.151-1.954,1.768-1.733,2.379.236.645,1.124.709,3.245.709h1.036c2.369,0,2.586-.126,3.569-1.108l.032-.032a17.762,17.762,0,0,1,1.361-1.253l5.379-4.491Zm-24.768-15.2c-11.6,0-15.011,4.034-16.973,11-1.024,3.628-.9,6.124.379,7.854,1.634,2.2,5.241,3.229,11.354,3.229a61.8,61.8,0,0,0,9.722-.778c1.43-.291,1.736-.6,2.188-2.2.245-.859.329-1.47-.007-1.861a1.026,1.026,0,0,0-.831-.315,3.393,3.393,0,0,0-.507.044,64.8,64.8,0,0,1-7.625.615c-2.9,0-5.363-.088-6.162-1.165a2.694,2.694,0,0,1-.108-2.355c.216-.765.562-.824,1.027-.824h13.333c3.848,0,4.461-.216,5.387-3.5.788-2.84.588-5.084-.595-6.67C12984.1,12541.329,12979.639,12540.964,12975.539,12540.964Zm-21.781-7.3c-1.562,0-2.473.085-3.111.549-.668.483-1.023,1.371-1.445,2.84l-6.411,22.367c-.379,1.318-.521,2.258-.059,2.872.539.722,1.424.755,3.071.755h.994c3.1,0,3.981-.334,4.861-3.395l6.411-22.364c.378-1.317.52-2.257.059-2.872-.527-.7-1.679-.752-3.376-.752Zm-75.481,7.3c-11.6,0-15.007,4.034-16.97,11-1.027,3.628-.906,6.123.38,7.854,1.633,2.2,5.24,3.229,11.354,3.229a61.782,61.782,0,0,0,9.718-.778c1.429-.291,1.736-.6,2.191-2.2.243-.862.326-1.475-.01-1.861a1.025,1.025,0,0,0-.829-.315,3.37,3.37,0,0,0-.5.044,64.854,64.854,0,0,1-7.625.615c-2.9,0-5.367-.088-6.162-1.165a2.689,2.689,0,0,1-.108-2.355c.212-.765.558-.824,1.023-.824h13.333c3.851,0,4.465-.216,5.391-3.5.785-2.845.584-5.089-.6-6.67C12886.844,12541.329,12882.378,12540.964,12878.276,12540.964Zm-89.464,8.74c-7.064,0-12.6.45-14.223,6.119-.5,1.746-.824,3.545.18,4.881,1.257,1.665,4.34,2.345,10.641,2.345a77.771,77.771,0,0,0,9.528-.572c4.581-.7,5.315-1.734,6-4.1l2.9-10.131c.611-2.131.494-3.657-.369-4.8-1.316-1.747-4.405-2.525-10.016-2.525a80.008,80.008,0,0,0-11.38.831c-1.454.288-1.767.6-2.228,2.2-.25.874-.344,1.539.013,1.946a1.089,1.089,0,0,0,.874.325,3.283,3.283,0,0,0,.444-.034c.107-.013.252-.034.431-.062l.089-.014.4-.059.018,0,.017,0a52.859,52.859,0,0,1,8.052-.733c2.18,0,3.9,0,4.458.742a2.274,2.274,0,0,1,.029,1.956l-.235.821c-.232.809-.617.874-1.06.874Zm-26.253-8.74c-11.791,0-15.253,4.034-17.248,11-1.04,3.627-.917,6.122.386,7.854,1.659,2.2,5.326,3.229,11.54,3.229a63.862,63.862,0,0,0,9.879-.778c1.45-.291,1.762-.6,2.224-2.2.248-.858.334-1.469-.007-1.861a1.041,1.041,0,0,0-.845-.315,3.521,3.521,0,0,0-.516.044,66.777,66.777,0,0,1-7.746.615c-2.948,0-5.454-.088-6.267-1.165a2.648,2.648,0,0,1-.108-2.355c.219-.765.57-.824,1.044-.824h13.548c3.913,0,4.537-.216,5.476-3.5.8-2.841.6-5.085-.6-6.67C12771.263,12541.329,12766.727,12540.964,12762.56,12540.964Zm155.616,1.438c-1.33,0-1.629.7-1.933,1.76-.283.99-.311,1.617-.085,1.917a1.332,1.332,0,0,0,1.125.37h2.977c.433,0,.5.1.5.1.028.037.076.184-.082.739l-3.552,12.4c-.351,1.222-.481,2.093-.053,2.663.489.647,1.556.7,3.127.7h.923c2.875,0,3.692-.309,4.507-3.144l3.55-12.4c.241-.834.484-1.05,1.181-1.05h9.381c1.283,0,1.614-.82,1.973-2.07.192-.663.316-1.2.026-1.59a1.333,1.333,0,0,0-1.109-.387h-9.381c-.437,0-.5-.1-.5-.1-.027-.038-.074-.186.081-.736l.167-.5a4.691,4.691,0,0,1,4.685-3.48c2.14,0,6.714.23,7.971.376.139.014.261.021.374.021.92,0,1.338-.432,1.723-1.777.2-.714.319-1.21.1-1.58s-.661-.465-1.175-.578a91.442,91.442,0,0,0-10.2-.632,15.973,15.973,0,0,0-7.689,1.609,8.419,8.419,0,0,0-4.125,5.253l-.327,1.073c-.238.836-.481,1.053-1.181,1.053Zm-5.812-1.491a87.844,87.844,0,0,0-11.347.742c-4.787.674-5.635,2.393-6.31,4.747l-3.71,12.923c-.387,1.355-.531,2.322-.059,2.951.543.718,1.726.771,3.468.771h1.017c3.183,0,4.088-.342,4.988-3.48l3.556-12.4a1.445,1.445,0,0,1,1.04-1.125,39.423,39.423,0,0,1,5.807-.454h.553c1.511,0,1.91-.984,2.276-2.271.248-.857.346-1.519.017-1.956A1.54,1.54,0,0,0,12912.363,12540.911Zm-66.037,4.554c1.521,0,2.339.228,2.737.759.466.615.445,1.771-.062,3.532l-2.771,9.662c-.376,1.322-.517,2.264-.059,2.876.531.7,1.682.752,3.376.752h.994c3.1,0,3.98-.333,4.86-3.392l2.83-9.872c.684-2.38.507-4.273-.527-5.63-1.362-1.8-4.191-2.675-8.651-2.675-2.06,0-4.036.179-5.345.311-.079.008-.153.012-.222.012-.238,0-.361-.047-.4-.091-.02-.022-.108-.163.053-.72l1.063-3.7c.376-1.319.516-2.26.056-2.872-.53-.7-1.681-.755-3.376-.755h-.994c-3.1,0-3.984.333-4.86,3.392l-6.415,22.363c-.373,1.324-.512,2.267-.055,2.876.53.7,1.681.752,3.375.752h.994c3.1,0,3.981-.333,4.861-3.392l3.581-12.492a1.56,1.56,0,0,1,1.279-1.3A17.663,17.663,0,0,1,12846.326,12545.465Zm-30.924-10.569c-3.1,0-3.984.333-4.861,3.393l-4.792,16.711c-.756,2.638-.658,4.463.3,5.744,1.2,1.593,3.758,2.3,8.295,2.3a49.48,49.48,0,0,0,8.249-.621c1.475-.3,1.764-.577,2.212-2.152.248-.854.335-1.465,0-1.865a1.132,1.132,0,0,0-.944-.343c-.114,0-.235.006-.394.02l-.717.085-.048.006a43.779,43.779,0,0,1-5.146.37c-1.453,0-2.369-.1-2.747-.6-.327-.433-.312-1.253.049-2.509l2.492-8.687c.255-.9.516-1.132,1.266-1.132h7.181c1.4,0,1.707-.579,2.087-1.9.206-.72.339-1.3.022-1.721a1.427,1.427,0,0,0-1.194-.415h-7.18c-.437,0-.521-.091-.533-.108s-.09-.161.092-.791l.618-2.159c.377-1.322.518-2.264.056-2.875-.53-.7-1.68-.753-3.372-.753Zm-92.958,9v0l2.5,15.41c.393,2.41,2.562,3.738,6.108,3.738h.64a3.413,3.413,0,0,0,2.348-.649,10.636,10.636,0,0,0,2.107-2.943l12.39-21.717c1.09-1.908,1.515-2.865,1.151-3.493-.3-.519-.971-.567-1.694-.574l-.575,0c-2.072,0-2.743.537-4.488,3.592l-9.151,16.048a.522.522,0,0,1-.463.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.545-15.658a4.915,4.915,0,0,0-1.314-3.031,3.492,3.492,0,0,0-2.437-.708h-1.7a3.367,3.367,0,0,0-2.332.654,10.822,10.822,0,0,0-2.106,2.949l-8.42,16.036a.514.514,0,0,1-.459.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.544-15.658a4.915,4.915,0,0,0-1.315-3.031,3.492,3.492,0,0,0-2.437-.708h-.14l-.579,0c-1.835.017-3.068.429-3.771,1.26a3.176,3.176,0,0,0-.569,2.659l3.526,21.72a3.92,3.92,0,0,0,2.51,3.1,9.448,9.448,0,0,0,3.7.641h.527c2.054,0,2.724-.542,4.48-3.622l3.5-7.414,4.63-8.113Zm64.647,15.269c-1.646,0-2.738-.1-3.1-.579-.274-.363-.238-1.079.118-2.322.628-2.188,1.566-2.519,4.468-2.519h3.883a.576.576,0,0,1,.409.108.638.638,0,0,1-.013.478l-.9,3.137a1.682,1.682,0,0,1-1.566,1.4A17.064,17.064,0,0,1,12787.092,12559.163Zm189.491-9h-7.419c-.37,0-.422-.053-.422-.054s-.084-.126.088-.738c.9-3.173,2.619-4.526,5.761-4.526,1.562,0,2.553.313,3.028.955s.5,1.743.053,3.336C12977.378,12550.165,12977.078,12550.165,12976.583,12550.165Zm-97.26,0h-7.418c-.326,0-.408-.04-.426-.053,0,0-.077-.14.092-.739.9-3.173,2.619-4.526,5.76-4.526,1.563,0,2.554.313,3.026.955s.5,1.74.052,3.336C12880.118,12550.165,12879.819,12550.165,12879.323,12550.165Zm-115.7,0h-7.543c-.328,0-.41-.04-.428-.053,0,0-.08-.143.095-.739.909-3.173,2.659-4.526,5.852-4.526,1.589,0,2.595.313,3.078.955s.507,1.745.052,3.336C12764.431,12550.165,12764.126,12550.165,12763.622,12550.165Z" transform="translate(-12683.5 -12193)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M13033.5,12753h-350v-560h350v560Zm-33.194-196.838h0l3.564,4.429c1.795,2.229,2.757,2.456,6.091,2.456h1.089c2.249,0,3.269-.071,3.6-.752.275-.579-.136-1.271-.939-2.271l-7.248-9,8.348-6.964c.639-.538,1.213-.952,1.593-1.227.837-.608,1.218-.886,1.069-1.348-.16-.487-.7-.511-2.378-.511h-1.037c-3.2,0-4.134.206-6.754,2.392l-4.19,3.5-2.761-3.429c-1.795-2.233-2.758-2.46-6.094-2.46h-1.086c-2.25,0-3.271.071-3.6.753-.274.575.138,1.268.942,2.27l6.444,8-9.542,7.958c-1.377,1.151-1.954,1.768-1.733,2.379.236.645,1.124.709,3.245.709h1.036c2.369,0,2.586-.126,3.569-1.108l.032-.032a17.762,17.762,0,0,1,1.361-1.253l5.379-4.491Zm-24.768-15.2c-11.6,0-15.011,4.034-16.973,11-1.024,3.628-.9,6.124.379,7.854,1.634,2.2,5.241,3.229,11.354,3.229a61.8,61.8,0,0,0,9.722-.778c1.43-.291,1.736-.6,2.188-2.2.245-.859.329-1.47-.007-1.861a1.026,1.026,0,0,0-.831-.315,3.393,3.393,0,0,0-.507.044,64.8,64.8,0,0,1-7.625.615c-2.9,0-5.363-.088-6.162-1.165a2.694,2.694,0,0,1-.108-2.355c.216-.765.562-.824,1.027-.824h13.333c3.848,0,4.461-.216,5.387-3.5.788-2.84.588-5.084-.595-6.67C12984.1,12541.329,12979.639,12540.964,12975.539,12540.964Zm-21.781-7.3c-1.562,0-2.473.085-3.111.549-.668.483-1.023,1.371-1.445,2.84l-6.411,22.367c-.379,1.318-.521,2.258-.059,2.872.539.722,1.424.755,3.071.755h.994c3.1,0,3.981-.334,4.861-3.395l6.411-22.364c.378-1.317.52-2.257.059-2.872-.527-.7-1.679-.752-3.376-.752Zm-75.481,7.3c-11.6,0-15.007,4.034-16.97,11-1.027,3.628-.906,6.123.38,7.854,1.633,2.2,5.24,3.229,11.354,3.229a61.782,61.782,0,0,0,9.718-.778c1.429-.291,1.736-.6,2.191-2.2.243-.862.326-1.475-.01-1.861a1.025,1.025,0,0,0-.829-.315,3.37,3.37,0,0,0-.5.044,64.854,64.854,0,0,1-7.625.615c-2.9,0-5.367-.088-6.162-1.165a2.689,2.689,0,0,1-.108-2.355c.212-.765.558-.824,1.023-.824h13.333c3.851,0,4.465-.216,5.391-3.5.785-2.845.584-5.089-.6-6.67C12886.844,12541.329,12882.378,12540.964,12878.276,12540.964Zm-89.464,8.74c-7.064,0-12.6.45-14.223,6.119-.5,1.746-.824,3.545.18,4.881,1.257,1.665,4.34,2.345,10.641,2.345a77.771,77.771,0,0,0,9.528-.572c4.581-.7,5.315-1.734,6-4.1l2.9-10.131c.611-2.131.494-3.657-.369-4.8-1.316-1.747-4.405-2.525-10.016-2.525a80.008,80.008,0,0,0-11.38.831c-1.454.288-1.767.6-2.228,2.2-.25.874-.344,1.539.013,1.946a1.089,1.089,0,0,0,.874.325,3.283,3.283,0,0,0,.444-.034c.107-.013.252-.034.431-.062l.089-.014.4-.059.018,0,.017,0a52.859,52.859,0,0,1,8.052-.733c2.18,0,3.9,0,4.458.742a2.274,2.274,0,0,1,.029,1.956l-.235.821c-.232.809-.617.874-1.06.874Zm-26.253-8.74c-11.791,0-15.253,4.034-17.248,11-1.04,3.627-.917,6.122.386,7.854,1.659,2.2,5.326,3.229,11.54,3.229a63.862,63.862,0,0,0,9.879-.778c1.45-.291,1.762-.6,2.224-2.2.248-.858.334-1.469-.007-1.861a1.041,1.041,0,0,0-.845-.315,3.521,3.521,0,0,0-.516.044,66.777,66.777,0,0,1-7.746.615c-2.948,0-5.454-.088-6.267-1.165a2.648,2.648,0,0,1-.108-2.355c.219-.765.57-.824,1.044-.824h13.548c3.913,0,4.537-.216,5.476-3.5.8-2.841.6-5.085-.6-6.67C12771.263,12541.329,12766.727,12540.964,12762.56,12540.964Zm155.616,1.438c-1.33,0-1.629.7-1.933,1.76-.283.99-.311,1.617-.085,1.917a1.332,1.332,0,0,0,1.125.37h2.977c.433,0,.5.1.5.1.028.037.076.184-.082.739l-3.552,12.4c-.351,1.222-.481,2.093-.053,2.663.489.647,1.556.7,3.127.7h.923c2.875,0,3.692-.309,4.507-3.144l3.55-12.4c.241-.834.484-1.05,1.181-1.05h9.381c1.283,0,1.614-.82,1.973-2.07.192-.663.316-1.2.026-1.59a1.333,1.333,0,0,0-1.109-.387h-9.381c-.437,0-.5-.1-.5-.1-.027-.038-.074-.186.081-.736l.167-.5a4.691,4.691,0,0,1,4.685-3.48c2.14,0,6.714.23,7.971.376.139.014.261.021.374.021.92,0,1.338-.432,1.723-1.777.2-.714.319-1.21.1-1.58s-.661-.465-1.175-.578a91.442,91.442,0,0,0-10.2-.632,15.973,15.973,0,0,0-7.689,1.609,8.419,8.419,0,0,0-4.125,5.253l-.327,1.073c-.238.836-.481,1.053-1.181,1.053Zm-5.812-1.491a87.844,87.844,0,0,0-11.347.742c-4.787.674-5.635,2.393-6.31,4.747l-3.71,12.923c-.387,1.355-.531,2.322-.059,2.951.543.718,1.726.771,3.468.771h1.017c3.183,0,4.088-.342,4.988-3.48l3.556-12.4a1.445,1.445,0,0,1,1.04-1.125,39.423,39.423,0,0,1,5.807-.454h.553c1.511,0,1.91-.984,2.276-2.271.248-.857.346-1.519.017-1.956A1.54,1.54,0,0,0,12912.363,12540.911Zm-66.037,4.554c1.521,0,2.339.228,2.737.759.466.615.445,1.771-.062,3.532l-2.771,9.662c-.376,1.322-.517,2.264-.059,2.876.531.7,1.682.752,3.376.752h.994c3.1,0,3.98-.333,4.86-3.392l2.83-9.872c.684-2.38.507-4.273-.527-5.63-1.362-1.8-4.191-2.675-8.651-2.675-2.06,0-4.036.179-5.345.311-.079.008-.153.012-.222.012-.238,0-.361-.047-.4-.091-.02-.022-.108-.163.053-.72l1.063-3.7c.376-1.319.516-2.26.056-2.872-.53-.7-1.681-.755-3.376-.755h-.994c-3.1,0-3.984.333-4.86,3.392l-6.415,22.363c-.373,1.324-.512,2.267-.055,2.876.53.7,1.681.752,3.375.752h.994c3.1,0,3.981-.333,4.861-3.392l3.581-12.492a1.56,1.56,0,0,1,1.279-1.3A17.663,17.663,0,0,1,12846.326,12545.465Zm-30.924-10.569c-3.1,0-3.984.333-4.861,3.393l-4.792,16.711c-.756,2.638-.658,4.463.3,5.744,1.2,1.593,3.758,2.3,8.295,2.3a49.48,49.48,0,0,0,8.249-.621c1.475-.3,1.764-.577,2.212-2.152.248-.854.335-1.465,0-1.865a1.132,1.132,0,0,0-.944-.343c-.114,0-.235.006-.394.02l-.717.085-.048.006a43.779,43.779,0,0,1-5.146.37c-1.453,0-2.369-.1-2.747-.6-.327-.433-.312-1.253.049-2.509l2.492-8.687c.255-.9.516-1.132,1.266-1.132h7.181c1.4,0,1.707-.579,2.087-1.9.206-.72.339-1.3.022-1.721a1.427,1.427,0,0,0-1.194-.415h-7.18c-.437,0-.521-.091-.533-.108s-.09-.161.092-.791l.618-2.159c.377-1.322.518-2.264.056-2.875-.53-.7-1.68-.753-3.372-.753Zm-92.958,9v0l2.5,15.41c.393,2.41,2.562,3.738,6.108,3.738h.64a3.413,3.413,0,0,0,2.348-.649,10.636,10.636,0,0,0,2.107-2.943l12.39-21.717c1.09-1.908,1.515-2.865,1.151-3.493-.3-.519-.971-.567-1.694-.574l-.575,0c-2.072,0-2.743.537-4.488,3.592l-9.151,16.048a.522.522,0,0,1-.463.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.545-15.658a4.915,4.915,0,0,0-1.314-3.031,3.492,3.492,0,0,0-2.437-.708h-1.7a3.367,3.367,0,0,0-2.332.654,10.822,10.822,0,0,0-2.106,2.949l-8.42,16.036a.514.514,0,0,1-.459.29.542.542,0,0,1-.08-.006.588.588,0,0,1-.462-.527l-2.544-15.658a4.915,4.915,0,0,0-1.315-3.031,3.492,3.492,0,0,0-2.437-.708h-.14l-.579,0c-1.835.017-3.068.429-3.771,1.26a3.176,3.176,0,0,0-.569,2.659l3.526,21.72a3.92,3.92,0,0,0,2.51,3.1,9.448,9.448,0,0,0,3.7.641h.527c2.054,0,2.724-.542,4.48-3.622l3.5-7.414,4.63-8.113Zm64.647,15.269c-1.646,0-2.738-.1-3.1-.579-.274-.363-.238-1.079.118-2.322.628-2.188,1.566-2.519,4.468-2.519h3.883a.576.576,0,0,1,.409.108.638.638,0,0,1-.013.478l-.9,3.137a1.682,1.682,0,0,1-1.566,1.4A17.064,17.064,0,0,1,12787.092,12559.163Zm189.491-9h-7.419c-.37,0-.422-.053-.422-.054s-.084-.126.088-.738c.9-3.173,2.619-4.526,5.761-4.526,1.562,0,2.553.313,3.028.955s.5,1.743.053,3.336C12977.378,12550.165,12977.078,12550.165,12976.583,12550.165Zm-97.26,0h-7.418c-.326,0-.408-.04-.426-.053,0,0-.077-.14.092-.739.9-3.173,2.619-4.526,5.76-4.526,1.563,0,2.554.313,3.026.955s.5,1.74.052,3.336C12880.118,12550.165,12879.819,12550.165,12879.323,12550.165Zm-115.7,0h-7.543c-.328,0-.41-.04-.428-.053,0,0-.08-.143.095-.739.909-3.173,2.659-4.526,5.852-4.526,1.589,0,2.595.313,3.078.955s.507,1.745.052,3.336C12764.431,12550.165,12764.126,12550.165,12763.622,12550.165Z" transform="translate(-12683.5 -12193)" /> </svg> <div class="content"> <p class="desc">Confident driving in all weather conditions</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <div class="content"> <p class="desc">Confident driving in all weather conditions</p> <span class="btn btn--round">Learn more</span> </div> </a> </div> <div class="display" data-id="kinergy"> <a href="/global/en/tires/kinergy.html"> <img class="display__bg t_none" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/kinergy/bg.jpg" alt="배경이미지"> <img class="display__bg t_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/kinergy/bg-m.jpg" alt="배경이미지"> <img class="display__bg m_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/kinergy/bg-m.jpg" alt="배경이미지"> <div class="display__wrap"> <div class="display__lottie"></div> </div> <!-- 웹 --> <div class="svg_wrap t_none"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape4" d="M-1246-8314H-3006v-720h1760v720Zm-427.526-443.4c.542,1.528,27.41,77.837,37.526,106.566,2.406,6.834,3.919,11.131,4,11.35l-1.27,1.521c-18.3,21.885-49.212,58.86-50.677,60.6,2.656.021,51.053.218,51.534.22l18.555-22.214c39.055-46.757,130.516-156.253,132.022-158.045h-51.543c-.287.337-37.38,44.682-55.206,65.992l-8.347,9.979c-.072-.2-1.921-5.424-4.719-13.332-7.667-21.668-21.939-62-22.157-62.639h-49.713Zm-394.937,0c-.053.223-2.176,9.025-5.39,22.351l-1.542,6.393-1.082,4.486c-12.268,50.871-35.1,145.561-35.391,146.81h52.087c.131-.586,12.408-51.531,35.5-147.328l1.283-5.322h23.416l6.6-.019.243,0c2.065-.014,4.2-.028,6.246-.028,7.473,0,15.257.18,21.557,1.486a29.542,29.542,0,0,1,8.115,2.786,16.049,16.049,0,0,1,5.722,4.972c3.222,4.661,3.754,11.212,1.628,20.024a41.339,41.339,0,0,1-3.03,8.554,31.208,31.208,0,0,1-4.335,6.605,30.643,30.643,0,0,1-11.883,8.357,55.634,55.634,0,0,1-15,3.552,153.118,153.118,0,0,1-16.71.741c-2.413,0-4.923-.025-6.939-.045l-6.852-.043h-17.054c1.007,1.983,47.352,95.008,47.682,95.708H-1926c-.877-1.669-26.962-51.785-35.533-68.254l-2.64-5.073h1.1c33.763,0,57.579-18.5,65.342-50.766a70,70,0,0,0,2.161-16.317,39.812,39.812,0,0,0-1.388-10.785,30.054,30.054,0,0,0-4.162-8.931c-9.5-13.771-31.037-19.913-69.84-19.913Zm-139.53,0a80.543,80.543,0,0,0-24.448,3.593,63.458,63.458,0,0,0-19.978,10.463,63.031,63.031,0,0,0-14.9,16.859,79.183,79.183,0,0,0-9.213,22.784l-.853,3.542c-18.845,78.2-29.359,121.807-29.6,122.8H-2136.5c.238-.939,6.912-28.583,7.323-30.391h-118.4l10.341-42.937h103.32c.05-.2,7.644-31.641,8.046-33.41h-103.311l3.326-13.848c4.632-19.287,16.376-29.066,34.906-29.066h90.526c.151-.6,2.855-11.834,4.83-20.036l.156-.649c1.4-5.816,2.208-9.171,2.337-9.7Zm-224.683,37.953h44.4c11.2,0,18.633,2.863,22.713,8.754a19.264,19.264,0,0,1,2.794,6.454,31.934,31.934,0,0,1,.806,7.463,79.377,79.377,0,0,1-2.582,17.884c-.239.992-24.083,99.813-24.479,101.531h52.047c.135-.575,8.683-36.015,25.407-105.334l1.428-5.919a144.566,144.566,0,0,0,2.749-14.274,93.049,93.049,0,0,0,.913-12.5,55.97,55.97,0,0,0-1.688-14.265,35.94,35.94,0,0,0-5.064-11.251c-7.545-10.946-21.8-16.5-42.381-16.5h-119.946c-.313,1.207-42.925,177.882-43.422,180.039h52.087l34.224-142.085Zm-129.179-37.953c-.206.955-43,178.4-43.4,180.039h52.069c.214-.834,29.626-122.905,39.292-163.019l4.1-17.021h-52.062Zm-148.681,0h-52.087l-7.53,31.258-1.236,5.127-3.951,16.4c-12.825,53.237-30.391,126.148-30.66,127.254h52.064c.129-.586,5.429-22.605,14.921-62l.405-1.683v0h0l.79.944.027.033c2.062,2.548,50.5,62.387,50.5,62.708h67.75c-1.774-2.18-76.079-93.733-76.716-94.519.151-.12,2.414-1.9,6.19-4.87,66.29-52.14,100.807-79.273,102.592-80.65-3.115,0-43.6-.094-56.908-.124l-4.135-.01-76.66,60.8c.063-.267,3.034-12.573,6.18-25.6C-2715.139-8738.343-2710.76-8756.483-2710.536-8757.4Zm941.052,0c-56.078,0-107.7,38.709-120.071,90.041a87.079,87.079,0,0,0-2.5,20.4,72.862,72.862,0,0,0,2.916,20.7,63.968,63.968,0,0,0,8.64,18.184c13.7,19.81,37.6,30.719,67.287,30.719h87.021c.208-.812,25.219-104.558,25.731-106.737h-83.072c-.247,1.088-7.713,32-8.069,33.41h31.05l-10.363,42.937H-1791.2c-20.792,0-34.318-4.97-41.35-15.192a30.747,30.747,0,0,1-4.352-9.632,47.622,47.622,0,0,1-1.446-12.179,98.807,98.807,0,0,1,3.068-22.647c5.04-20.812,13.193-35.62,24.925-45.27s27.28-14.341,47.538-14.341h65.163c.142-.509,2.048-8.4,3.892-16.035l.071-.293.064-.267c1.619-6.705,3.149-13.038,3.344-13.793Zm-215.331-56-5.9,24.443h257.658l5.9-24.443h-257.662Zm-265.28,0-5.9,24.443h257.66l5.9-24.443h-257.657Zm791.445-45.6h0a252.648,252.648,0,0,1-29.548,19.1,227.972,227.972,0,0,1-31.291,14.3,190.136,190.136,0,0,1-65.487,12.068l-135.032.045-5.924,24.522,137.714-.021a215.049,215.049,0,0,0,74.047-13.528,250.063,250.063,0,0,0,35.131-16.105A274.4,274.4,0,0,0-1446-8840.235L-1458.648-8859Z" transform="translate(3006 9034)" /> </defs> <clipPath id="clipPath4"> <use xlink:href="#polygonShape4"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath4);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/kinergy/bg.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M-1246-8314H-3006v-720h1760v720Zm-427.526-443.4c.542,1.528,27.41,77.837,37.526,106.566,2.406,6.834,3.919,11.131,4,11.35l-1.27,1.521c-18.3,21.885-49.212,58.86-50.677,60.6,2.656.021,51.053.218,51.534.22l18.555-22.214c39.055-46.757,130.516-156.253,132.022-158.045h-51.543c-.287.337-37.38,44.682-55.206,65.992l-8.347,9.979c-.072-.2-1.921-5.424-4.719-13.332-7.667-21.668-21.939-62-22.157-62.639h-49.713Zm-394.937,0c-.053.223-2.176,9.025-5.39,22.351l-1.542,6.393-1.082,4.486c-12.268,50.871-35.1,145.561-35.391,146.81h52.087c.131-.586,12.408-51.531,35.5-147.328l1.283-5.322h23.416l6.6-.019.243,0c2.065-.014,4.2-.028,6.246-.028,7.473,0,15.257.18,21.557,1.486a29.542,29.542,0,0,1,8.115,2.786,16.049,16.049,0,0,1,5.722,4.972c3.222,4.661,3.754,11.212,1.628,20.024a41.339,41.339,0,0,1-3.03,8.554,31.208,31.208,0,0,1-4.335,6.605,30.643,30.643,0,0,1-11.883,8.357,55.634,55.634,0,0,1-15,3.552,153.118,153.118,0,0,1-16.71.741c-2.413,0-4.923-.025-6.939-.045l-6.852-.043h-17.054c1.007,1.983,47.352,95.008,47.682,95.708H-1926c-.877-1.669-26.962-51.785-35.533-68.254l-2.64-5.073h1.1c33.763,0,57.579-18.5,65.342-50.766a70,70,0,0,0,2.161-16.317,39.812,39.812,0,0,0-1.388-10.785,30.054,30.054,0,0,0-4.162-8.931c-9.5-13.771-31.037-19.913-69.84-19.913Zm-139.53,0a80.543,80.543,0,0,0-24.448,3.593,63.458,63.458,0,0,0-19.978,10.463,63.031,63.031,0,0,0-14.9,16.859,79.183,79.183,0,0,0-9.213,22.784l-.853,3.542c-18.845,78.2-29.359,121.807-29.6,122.8H-2136.5c.238-.939,6.912-28.583,7.323-30.391h-118.4l10.341-42.937h103.32c.05-.2,7.644-31.641,8.046-33.41h-103.311l3.326-13.848c4.632-19.287,16.376-29.066,34.906-29.066h90.526c.151-.6,2.855-11.834,4.83-20.036l.156-.649c1.4-5.816,2.208-9.171,2.337-9.7Zm-224.683,37.953h44.4c11.2,0,18.633,2.863,22.713,8.754a19.264,19.264,0,0,1,2.794,6.454,31.934,31.934,0,0,1,.806,7.463,79.377,79.377,0,0,1-2.582,17.884c-.239.992-24.083,99.813-24.479,101.531h52.047c.135-.575,8.683-36.015,25.407-105.334l1.428-5.919a144.566,144.566,0,0,0,2.749-14.274,93.049,93.049,0,0,0,.913-12.5,55.97,55.97,0,0,0-1.688-14.265,35.94,35.94,0,0,0-5.064-11.251c-7.545-10.946-21.8-16.5-42.381-16.5h-119.946c-.313,1.207-42.925,177.882-43.422,180.039h52.087l34.224-142.085Zm-129.179-37.953c-.206.955-43,178.4-43.4,180.039h52.069c.214-.834,29.626-122.905,39.292-163.019l4.1-17.021h-52.062Zm-148.681,0h-52.087l-7.53,31.258-1.236,5.127-3.951,16.4c-12.825,53.237-30.391,126.148-30.66,127.254h52.064c.129-.586,5.429-22.605,14.921-62l.405-1.683v0h0l.79.944.027.033c2.062,2.548,50.5,62.387,50.5,62.708h67.75c-1.774-2.18-76.079-93.733-76.716-94.519.151-.12,2.414-1.9,6.19-4.87,66.29-52.14,100.807-79.273,102.592-80.65-3.115,0-43.6-.094-56.908-.124l-4.135-.01-76.66,60.8c.063-.267,3.034-12.573,6.18-25.6C-2715.139-8738.343-2710.76-8756.483-2710.536-8757.4Zm941.052,0c-56.078,0-107.7,38.709-120.071,90.041a87.079,87.079,0,0,0-2.5,20.4,72.862,72.862,0,0,0,2.916,20.7,63.968,63.968,0,0,0,8.64,18.184c13.7,19.81,37.6,30.719,67.287,30.719h87.021c.208-.812,25.219-104.558,25.731-106.737h-83.072c-.247,1.088-7.713,32-8.069,33.41h31.05l-10.363,42.937H-1791.2c-20.792,0-34.318-4.97-41.35-15.192a30.747,30.747,0,0,1-4.352-9.632,47.622,47.622,0,0,1-1.446-12.179,98.807,98.807,0,0,1,3.068-22.647c5.04-20.812,13.193-35.62,24.925-45.27s27.28-14.341,47.538-14.341h65.163c.142-.509,2.048-8.4,3.892-16.035l.071-.293.064-.267c1.619-6.705,3.149-13.038,3.344-13.793Zm-215.331-56-5.9,24.443h257.658l5.9-24.443h-257.662Zm-265.28,0-5.9,24.443h257.66l5.9-24.443h-257.657Zm791.445-45.6h0a252.648,252.648,0,0,1-29.548,19.1,227.972,227.972,0,0,1-31.291,14.3,190.136,190.136,0,0,1-65.487,12.068l-135.032.045-5.924,24.522,137.714-.021a215.049,215.049,0,0,0,74.047-13.528,250.063,250.063,0,0,0,35.131-16.105A274.4,274.4,0,0,0-1446-8840.235L-1458.648-8859Z" transform="translate(3006 9034)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M-1246-8314H-3006v-720h1760v720Zm-427.526-443.4c.542,1.528,27.41,77.837,37.526,106.566,2.406,6.834,3.919,11.131,4,11.35l-1.27,1.521c-18.3,21.885-49.212,58.86-50.677,60.6,2.656.021,51.053.218,51.534.22l18.555-22.214c39.055-46.757,130.516-156.253,132.022-158.045h-51.543c-.287.337-37.38,44.682-55.206,65.992l-8.347,9.979c-.072-.2-1.921-5.424-4.719-13.332-7.667-21.668-21.939-62-22.157-62.639h-49.713Zm-394.937,0c-.053.223-2.176,9.025-5.39,22.351l-1.542,6.393-1.082,4.486c-12.268,50.871-35.1,145.561-35.391,146.81h52.087c.131-.586,12.408-51.531,35.5-147.328l1.283-5.322h23.416l6.6-.019.243,0c2.065-.014,4.2-.028,6.246-.028,7.473,0,15.257.18,21.557,1.486a29.542,29.542,0,0,1,8.115,2.786,16.049,16.049,0,0,1,5.722,4.972c3.222,4.661,3.754,11.212,1.628,20.024a41.339,41.339,0,0,1-3.03,8.554,31.208,31.208,0,0,1-4.335,6.605,30.643,30.643,0,0,1-11.883,8.357,55.634,55.634,0,0,1-15,3.552,153.118,153.118,0,0,1-16.71.741c-2.413,0-4.923-.025-6.939-.045l-6.852-.043h-17.054c1.007,1.983,47.352,95.008,47.682,95.708H-1926c-.877-1.669-26.962-51.785-35.533-68.254l-2.64-5.073h1.1c33.763,0,57.579-18.5,65.342-50.766a70,70,0,0,0,2.161-16.317,39.812,39.812,0,0,0-1.388-10.785,30.054,30.054,0,0,0-4.162-8.931c-9.5-13.771-31.037-19.913-69.84-19.913Zm-139.53,0a80.543,80.543,0,0,0-24.448,3.593,63.458,63.458,0,0,0-19.978,10.463,63.031,63.031,0,0,0-14.9,16.859,79.183,79.183,0,0,0-9.213,22.784l-.853,3.542c-18.845,78.2-29.359,121.807-29.6,122.8H-2136.5c.238-.939,6.912-28.583,7.323-30.391h-118.4l10.341-42.937h103.32c.05-.2,7.644-31.641,8.046-33.41h-103.311l3.326-13.848c4.632-19.287,16.376-29.066,34.906-29.066h90.526c.151-.6,2.855-11.834,4.83-20.036l.156-.649c1.4-5.816,2.208-9.171,2.337-9.7Zm-224.683,37.953h44.4c11.2,0,18.633,2.863,22.713,8.754a19.264,19.264,0,0,1,2.794,6.454,31.934,31.934,0,0,1,.806,7.463,79.377,79.377,0,0,1-2.582,17.884c-.239.992-24.083,99.813-24.479,101.531h52.047c.135-.575,8.683-36.015,25.407-105.334l1.428-5.919a144.566,144.566,0,0,0,2.749-14.274,93.049,93.049,0,0,0,.913-12.5,55.97,55.97,0,0,0-1.688-14.265,35.94,35.94,0,0,0-5.064-11.251c-7.545-10.946-21.8-16.5-42.381-16.5h-119.946c-.313,1.207-42.925,177.882-43.422,180.039h52.087l34.224-142.085Zm-129.179-37.953c-.206.955-43,178.4-43.4,180.039h52.069c.214-.834,29.626-122.905,39.292-163.019l4.1-17.021h-52.062Zm-148.681,0h-52.087l-7.53,31.258-1.236,5.127-3.951,16.4c-12.825,53.237-30.391,126.148-30.66,127.254h52.064c.129-.586,5.429-22.605,14.921-62l.405-1.683v0h0l.79.944.027.033c2.062,2.548,50.5,62.387,50.5,62.708h67.75c-1.774-2.18-76.079-93.733-76.716-94.519.151-.12,2.414-1.9,6.19-4.87,66.29-52.14,100.807-79.273,102.592-80.65-3.115,0-43.6-.094-56.908-.124l-4.135-.01-76.66,60.8c.063-.267,3.034-12.573,6.18-25.6C-2715.139-8738.343-2710.76-8756.483-2710.536-8757.4Zm941.052,0c-56.078,0-107.7,38.709-120.071,90.041a87.079,87.079,0,0,0-2.5,20.4,72.862,72.862,0,0,0,2.916,20.7,63.968,63.968,0,0,0,8.64,18.184c13.7,19.81,37.6,30.719,67.287,30.719h87.021c.208-.812,25.219-104.558,25.731-106.737h-83.072c-.247,1.088-7.713,32-8.069,33.41h31.05l-10.363,42.937H-1791.2c-20.792,0-34.318-4.97-41.35-15.192a30.747,30.747,0,0,1-4.352-9.632,47.622,47.622,0,0,1-1.446-12.179,98.807,98.807,0,0,1,3.068-22.647c5.04-20.812,13.193-35.62,24.925-45.27s27.28-14.341,47.538-14.341h65.163c.142-.509,2.048-8.4,3.892-16.035l.071-.293.064-.267c1.619-6.705,3.149-13.038,3.344-13.793Zm-215.331-56-5.9,24.443h257.658l5.9-24.443h-257.662Zm-265.28,0-5.9,24.443h257.66l5.9-24.443h-257.657Zm791.445-45.6h0a252.648,252.648,0,0,1-29.548,19.1,227.972,227.972,0,0,1-31.291,14.3,190.136,190.136,0,0,1-65.487,12.068l-135.032.045-5.924,24.522,137.714-.021a215.049,215.049,0,0,0,74.047-13.528,250.063,250.063,0,0,0,35.131-16.105A274.4,274.4,0,0,0-1446-8840.235L-1458.648-8859Z" transform="translate(3006 9034)" /> </svg> <div class="content"> <p class="desc">Drive your way with balanced technology</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 태블릿 --> <div class="svg_wrap t_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape444" d="M-6944-10492h-350v-560h350v560Zm-81.177-198.933c.144.4,8.53,24.224,8.609,24.45-.085.1-10.383,12.42-10.77,12.881l10.687.044,10.294-12.324,20.926-25.051h-10.687c-.054.063-6.563,7.844-10.453,12.493l-2.725,3.259c-.025-.069-1.086-3.067-2.314-6.539-1.511-4.271-3.224-9.113-3.258-9.213Zm-81.891,0c-.013.057-.691,2.866-1.686,6.991-1.793,7.436-7.25,30.064-7.314,30.34h10.8c.038-.167,4.8-19.913,6.83-28.345.479-1.986.782-3.247.8-3.309h4.857l1.368,0h.084c.437,0,.849,0,1.263,0,3.163,0,6.1.146,7.337,1.917.667.962.778,2.32.338,4.152a6.526,6.526,0,0,1-3.994,4.876,17.915,17.915,0,0,1-6.58.889c-.519,0-1.037,0-1.43-.009l-1.42-.009h-3.537c.222.438,9.822,19.712,9.885,19.846h11.941c-.131-.248-2.94-5.646-5.2-9.982l-2.718-5.223h.227c7,0,11.941-3.837,13.55-10.526a14.541,14.541,0,0,0,.449-3.384,6.976,6.976,0,0,0-1.151-4.089c-1.971-2.854-6.437-4.127-14.481-4.127Zm-28.932,0c-7.326,0-12.506,4.059-14.212,11.134-.057.238-6.225,25.832-6.315,26.2h35.353c.067-.268,1.458-6.04,1.518-6.3h-24.55l2.144-8.9h21.424c.007-.029,1.587-6.578,1.667-6.929H-7140.4l.691-2.871c.958-4,3.393-6.027,7.236-6.027h18.772c.02-.08.264-1.091.7-2.923l.021-.089c.368-1.532.75-3.116.792-3.287Zm-46.589,7.869h9.206c2.323,0,3.864.594,4.71,1.813a5.025,5.025,0,0,1,.746,2.888,16.535,16.535,0,0,1-.536,3.706l-.247,1.022c-3.157,13.089-4.782,19.828-4.829,20.032h10.792c.04-.169,5.5-22.808,5.564-23.068a24.053,24.053,0,0,0,.76-5.554,9.042,9.042,0,0,0-1.4-5.289c-1.563-2.27-4.52-3.42-8.787-3.42h-24.872c-.046.172-8.882,36.807-9,37.331h10.8c.057-.241,7.021-29.157,7.1-29.461Zm-26.786-7.869c-.033.153-4.506,18.706-7.18,29.791l-1.031,4.274-.448,1.857c-.206.853-.33,1.368-.339,1.408h10.8c.045-.174,6.041-25.057,8.01-33.233l.987-4.1Zm-30.83,0h-10.8l-5.6,23.245c-1.755,7.286-3.356,13.934-3.393,14.086h10.795c.037-.163,1.969-8.186,2.794-11.611.226-.935.373-1.545.384-1.592v0h0l.162.2c.1.129,10.459,12.918,10.477,13.009h14.048c-.34-.416-15.654-19.284-15.91-19.6l3.2-2.517c6.122-4.814,18.862-14.832,19.36-15.216-.709,0-12.544-.027-12.659-.027l-15.9,12.606c.015-.066.855-3.547,1.668-6.912C-7240.891-10688.1-7240.245-10690.773-7240.206-10690.933Zm195.131,0c-11.63,0-22.333,8.026-24.9,18.67a17.937,17.937,0,0,0-.519,4.229,14.088,14.088,0,0,0,2.4,8.061c2.841,4.108,7.8,6.371,13.952,6.371h18.043c.05-.192,5.3-21.959,5.336-22.134h-17.225c0,.007-.034.144-.09.376-1,4.136-1.53,6.341-1.585,6.553h6.44l-2.149,8.9h-4.208c-4.312,0-7.116-1.031-8.573-3.151a7.711,7.711,0,0,1-1.2-4.521,20.454,20.454,0,0,1,.638-4.7c2.069-8.55,6.7-12.362,15.025-12.362h13.511c.028-.1.4-1.62.751-3.09l.129-.535c.314-1.3.61-2.525.648-2.674Zm-44.65-11.613-1.221,5.07h53.424l1.223-5.07Zm-55.005,0-1.226,5.07h53.427l1.223-5.07Zm164.107-9.454h0a49.545,49.545,0,0,1-12.614,6.926,39.439,39.439,0,0,1-13.58,2.5l-28,.009-1.229,5.084,28.555,0a44.59,44.59,0,0,0,15.353-2.806,54.073,54.073,0,0,0,14.134-7.823l-2.622-3.889Z" transform="translate(7293.999 11022)" /> </defs> <clipPath id="clipPath444"> <use xlink:href="#polygonShape444"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath444);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/kinergy/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-6944-10492h-350v-560h350v560Zm-81.177-198.933c.144.4,8.53,24.224,8.609,24.45-.085.1-10.383,12.42-10.77,12.881l10.687.044,10.294-12.324,20.926-25.051h-10.687c-.054.063-6.563,7.844-10.453,12.493l-2.725,3.259c-.025-.069-1.086-3.067-2.314-6.539-1.511-4.271-3.224-9.113-3.258-9.213Zm-81.891,0c-.013.057-.691,2.866-1.686,6.991-1.793,7.436-7.25,30.064-7.314,30.34h10.8c.038-.167,4.8-19.913,6.83-28.345.479-1.986.782-3.247.8-3.309h4.857l1.368,0h.084c.437,0,.849,0,1.263,0,3.163,0,6.1.146,7.337,1.917.667.962.778,2.32.338,4.152a6.526,6.526,0,0,1-3.994,4.876,17.915,17.915,0,0,1-6.58.889c-.519,0-1.037,0-1.43-.009l-1.42-.009h-3.537c.222.438,9.822,19.712,9.885,19.846h11.941c-.131-.248-2.94-5.646-5.2-9.982l-2.718-5.223h.227c7,0,11.941-3.837,13.55-10.526a14.541,14.541,0,0,0,.449-3.384,6.976,6.976,0,0,0-1.151-4.089c-1.971-2.854-6.437-4.127-14.481-4.127Zm-28.932,0c-7.326,0-12.506,4.059-14.212,11.134-.057.238-6.225,25.832-6.315,26.2h35.353c.067-.268,1.458-6.04,1.518-6.3h-24.55l2.144-8.9h21.424c.007-.029,1.587-6.578,1.667-6.929H-7140.4l.691-2.871c.958-4,3.393-6.027,7.236-6.027h18.772c.02-.08.264-1.091.7-2.923l.021-.089c.368-1.532.75-3.116.792-3.287Zm-46.589,7.869h9.206c2.323,0,3.864.594,4.71,1.813a5.025,5.025,0,0,1,.746,2.888,16.535,16.535,0,0,1-.536,3.706l-.247,1.022c-3.157,13.089-4.782,19.828-4.829,20.032h10.792c.04-.169,5.5-22.808,5.564-23.068a24.053,24.053,0,0,0,.76-5.554,9.042,9.042,0,0,0-1.4-5.289c-1.563-2.27-4.52-3.42-8.787-3.42h-24.872c-.046.172-8.882,36.807-9,37.331h10.8c.057-.241,7.021-29.157,7.1-29.461Zm-26.786-7.869c-.033.153-4.506,18.706-7.18,29.791l-1.031,4.274-.448,1.857c-.206.853-.33,1.368-.339,1.408h10.8c.045-.174,6.041-25.057,8.01-33.233l.987-4.1Zm-30.83,0h-10.8l-5.6,23.245c-1.755,7.286-3.356,13.934-3.393,14.086h10.795c.037-.163,1.969-8.186,2.794-11.611.226-.935.373-1.545.384-1.592v0h0l.162.2c.1.129,10.459,12.918,10.477,13.009h14.048c-.34-.416-15.654-19.284-15.91-19.6l3.2-2.517c6.122-4.814,18.862-14.832,19.36-15.216-.709,0-12.544-.027-12.659-.027l-15.9,12.606c.015-.066.855-3.547,1.668-6.912C-7240.891-10688.1-7240.245-10690.773-7240.206-10690.933Zm195.131,0c-11.63,0-22.333,8.026-24.9,18.67a17.937,17.937,0,0,0-.519,4.229,14.088,14.088,0,0,0,2.4,8.061c2.841,4.108,7.8,6.371,13.952,6.371h18.043c.05-.192,5.3-21.959,5.336-22.134h-17.225c0,.007-.034.144-.09.376-1,4.136-1.53,6.341-1.585,6.553h6.44l-2.149,8.9h-4.208c-4.312,0-7.116-1.031-8.573-3.151a7.711,7.711,0,0,1-1.2-4.521,20.454,20.454,0,0,1,.638-4.7c2.069-8.55,6.7-12.362,15.025-12.362h13.511c.028-.1.4-1.62.751-3.09l.129-.535c.314-1.3.61-2.525.648-2.674Zm-44.65-11.613-1.221,5.07h53.424l1.223-5.07Zm-55.005,0-1.226,5.07h53.427l1.223-5.07Zm164.107-9.454h0a49.545,49.545,0,0,1-12.614,6.926,39.439,39.439,0,0,1-13.58,2.5l-28,.009-1.229,5.084,28.555,0a44.59,44.59,0,0,0,15.353-2.806,54.073,54.073,0,0,0,14.134-7.823l-2.622-3.889Z" transform="translate(7293.999 11022)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-6944-10492h-350v-560h350v560Zm-81.177-198.933c.144.4,8.53,24.224,8.609,24.45-.085.1-10.383,12.42-10.77,12.881l10.687.044,10.294-12.324,20.926-25.051h-10.687c-.054.063-6.563,7.844-10.453,12.493l-2.725,3.259c-.025-.069-1.086-3.067-2.314-6.539-1.511-4.271-3.224-9.113-3.258-9.213Zm-81.891,0c-.013.057-.691,2.866-1.686,6.991-1.793,7.436-7.25,30.064-7.314,30.34h10.8c.038-.167,4.8-19.913,6.83-28.345.479-1.986.782-3.247.8-3.309h4.857l1.368,0h.084c.437,0,.849,0,1.263,0,3.163,0,6.1.146,7.337,1.917.667.962.778,2.32.338,4.152a6.526,6.526,0,0,1-3.994,4.876,17.915,17.915,0,0,1-6.58.889c-.519,0-1.037,0-1.43-.009l-1.42-.009h-3.537c.222.438,9.822,19.712,9.885,19.846h11.941c-.131-.248-2.94-5.646-5.2-9.982l-2.718-5.223h.227c7,0,11.941-3.837,13.55-10.526a14.541,14.541,0,0,0,.449-3.384,6.976,6.976,0,0,0-1.151-4.089c-1.971-2.854-6.437-4.127-14.481-4.127Zm-28.932,0c-7.326,0-12.506,4.059-14.212,11.134-.057.238-6.225,25.832-6.315,26.2h35.353c.067-.268,1.458-6.04,1.518-6.3h-24.55l2.144-8.9h21.424c.007-.029,1.587-6.578,1.667-6.929H-7140.4l.691-2.871c.958-4,3.393-6.027,7.236-6.027h18.772c.02-.08.264-1.091.7-2.923l.021-.089c.368-1.532.75-3.116.792-3.287Zm-46.589,7.869h9.206c2.323,0,3.864.594,4.71,1.813a5.025,5.025,0,0,1,.746,2.888,16.535,16.535,0,0,1-.536,3.706l-.247,1.022c-3.157,13.089-4.782,19.828-4.829,20.032h10.792c.04-.169,5.5-22.808,5.564-23.068a24.053,24.053,0,0,0,.76-5.554,9.042,9.042,0,0,0-1.4-5.289c-1.563-2.27-4.52-3.42-8.787-3.42h-24.872c-.046.172-8.882,36.807-9,37.331h10.8c.057-.241,7.021-29.157,7.1-29.461Zm-26.786-7.869c-.033.153-4.506,18.706-7.18,29.791l-1.031,4.274-.448,1.857c-.206.853-.33,1.368-.339,1.408h10.8c.045-.174,6.041-25.057,8.01-33.233l.987-4.1Zm-30.83,0h-10.8l-5.6,23.245c-1.755,7.286-3.356,13.934-3.393,14.086h10.795c.037-.163,1.969-8.186,2.794-11.611.226-.935.373-1.545.384-1.592v0h0l.162.2c.1.129,10.459,12.918,10.477,13.009h14.048c-.34-.416-15.654-19.284-15.91-19.6l3.2-2.517c6.122-4.814,18.862-14.832,19.36-15.216-.709,0-12.544-.027-12.659-.027l-15.9,12.606c.015-.066.855-3.547,1.668-6.912C-7240.891-10688.1-7240.245-10690.773-7240.206-10690.933Zm195.131,0c-11.63,0-22.333,8.026-24.9,18.67a17.937,17.937,0,0,0-.519,4.229,14.088,14.088,0,0,0,2.4,8.061c2.841,4.108,7.8,6.371,13.952,6.371h18.043c.05-.192,5.3-21.959,5.336-22.134h-17.225c0,.007-.034.144-.09.376-1,4.136-1.53,6.341-1.585,6.553h6.44l-2.149,8.9h-4.208c-4.312,0-7.116-1.031-8.573-3.151a7.711,7.711,0,0,1-1.2-4.521,20.454,20.454,0,0,1,.638-4.7c2.069-8.55,6.7-12.362,15.025-12.362h13.511c.028-.1.4-1.62.751-3.09l.129-.535c.314-1.3.61-2.525.648-2.674Zm-44.65-11.613-1.221,5.07h53.424l1.223-5.07Zm-55.005,0-1.226,5.07h53.427l1.223-5.07Zm164.107-9.454h0a49.545,49.545,0,0,1-12.614,6.926,39.439,39.439,0,0,1-13.58,2.5l-28,.009-1.229,5.084,28.555,0a44.59,44.59,0,0,0,15.353-2.806,54.073,54.073,0,0,0,14.134-7.823l-2.622-3.889Z" transform="translate(7293.999 11022)" /> </svg> <div class="content"> <p class="desc">Drive your way with balanced technology</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 모바일 --> <div class="svg_wrap m_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape444-m" d="M-6944-10492h-350v-560h350v560Zm-81.177-198.933c.144.4,8.53,24.224,8.609,24.45-.085.1-10.383,12.42-10.77,12.881l10.687.044,10.294-12.324,20.926-25.051h-10.687c-.054.063-6.563,7.844-10.453,12.493l-2.725,3.259c-.025-.069-1.086-3.067-2.314-6.539-1.511-4.271-3.224-9.113-3.258-9.213Zm-81.891,0c-.013.057-.691,2.866-1.686,6.991-1.793,7.436-7.25,30.064-7.314,30.34h10.8c.038-.167,4.8-19.913,6.83-28.345.479-1.986.782-3.247.8-3.309h4.857l1.368,0h.084c.437,0,.849,0,1.263,0,3.163,0,6.1.146,7.337,1.917.667.962.778,2.32.338,4.152a6.526,6.526,0,0,1-3.994,4.876,17.915,17.915,0,0,1-6.58.889c-.519,0-1.037,0-1.43-.009l-1.42-.009h-3.537c.222.438,9.822,19.712,9.885,19.846h11.941c-.131-.248-2.94-5.646-5.2-9.982l-2.718-5.223h.227c7,0,11.941-3.837,13.55-10.526a14.541,14.541,0,0,0,.449-3.384,6.976,6.976,0,0,0-1.151-4.089c-1.971-2.854-6.437-4.127-14.481-4.127Zm-28.932,0c-7.326,0-12.506,4.059-14.212,11.134-.057.238-6.225,25.832-6.315,26.2h35.353c.067-.268,1.458-6.04,1.518-6.3h-24.55l2.144-8.9h21.424c.007-.029,1.587-6.578,1.667-6.929H-7140.4l.691-2.871c.958-4,3.393-6.027,7.236-6.027h18.772c.02-.08.264-1.091.7-2.923l.021-.089c.368-1.532.75-3.116.792-3.287Zm-46.589,7.869h9.206c2.323,0,3.864.594,4.71,1.813a5.025,5.025,0,0,1,.746,2.888,16.535,16.535,0,0,1-.536,3.706l-.247,1.022c-3.157,13.089-4.782,19.828-4.829,20.032h10.792c.04-.169,5.5-22.808,5.564-23.068a24.053,24.053,0,0,0,.76-5.554,9.042,9.042,0,0,0-1.4-5.289c-1.563-2.27-4.52-3.42-8.787-3.42h-24.872c-.046.172-8.882,36.807-9,37.331h10.8c.057-.241,7.021-29.157,7.1-29.461Zm-26.786-7.869c-.033.153-4.506,18.706-7.18,29.791l-1.031,4.274-.448,1.857c-.206.853-.33,1.368-.339,1.408h10.8c.045-.174,6.041-25.057,8.01-33.233l.987-4.1Zm-30.83,0h-10.8l-5.6,23.245c-1.755,7.286-3.356,13.934-3.393,14.086h10.795c.037-.163,1.969-8.186,2.794-11.611.226-.935.373-1.545.384-1.592v0h0l.162.2c.1.129,10.459,12.918,10.477,13.009h14.048c-.34-.416-15.654-19.284-15.91-19.6l3.2-2.517c6.122-4.814,18.862-14.832,19.36-15.216-.709,0-12.544-.027-12.659-.027l-15.9,12.606c.015-.066.855-3.547,1.668-6.912C-7240.891-10688.1-7240.245-10690.773-7240.206-10690.933Zm195.131,0c-11.63,0-22.333,8.026-24.9,18.67a17.937,17.937,0,0,0-.519,4.229,14.088,14.088,0,0,0,2.4,8.061c2.841,4.108,7.8,6.371,13.952,6.371h18.043c.05-.192,5.3-21.959,5.336-22.134h-17.225c0,.007-.034.144-.09.376-1,4.136-1.53,6.341-1.585,6.553h6.44l-2.149,8.9h-4.208c-4.312,0-7.116-1.031-8.573-3.151a7.711,7.711,0,0,1-1.2-4.521,20.454,20.454,0,0,1,.638-4.7c2.069-8.55,6.7-12.362,15.025-12.362h13.511c.028-.1.4-1.62.751-3.09l.129-.535c.314-1.3.61-2.525.648-2.674Zm-44.65-11.613-1.221,5.07h53.424l1.223-5.07Zm-55.005,0-1.226,5.07h53.427l1.223-5.07Zm164.107-9.454h0a49.545,49.545,0,0,1-12.614,6.926,39.439,39.439,0,0,1-13.58,2.5l-28,.009-1.229,5.084,28.555,0a44.59,44.59,0,0,0,15.353-2.806,54.073,54.073,0,0,0,14.134-7.823l-2.622-3.889Z" transform="translate(7293.999 11052)" /> </defs> <clipPath id="clipPath444-m"> <use xlink:href="#polygonShape444-m"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath444-m);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/kinergy/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-6944-10492h-350v-560h350v560Zm-81.177-198.933c.144.4,8.53,24.224,8.609,24.45-.085.1-10.383,12.42-10.77,12.881l10.687.044,10.294-12.324,20.926-25.051h-10.687c-.054.063-6.563,7.844-10.453,12.493l-2.725,3.259c-.025-.069-1.086-3.067-2.314-6.539-1.511-4.271-3.224-9.113-3.258-9.213Zm-81.891,0c-.013.057-.691,2.866-1.686,6.991-1.793,7.436-7.25,30.064-7.314,30.34h10.8c.038-.167,4.8-19.913,6.83-28.345.479-1.986.782-3.247.8-3.309h4.857l1.368,0h.084c.437,0,.849,0,1.263,0,3.163,0,6.1.146,7.337,1.917.667.962.778,2.32.338,4.152a6.526,6.526,0,0,1-3.994,4.876,17.915,17.915,0,0,1-6.58.889c-.519,0-1.037,0-1.43-.009l-1.42-.009h-3.537c.222.438,9.822,19.712,9.885,19.846h11.941c-.131-.248-2.94-5.646-5.2-9.982l-2.718-5.223h.227c7,0,11.941-3.837,13.55-10.526a14.541,14.541,0,0,0,.449-3.384,6.976,6.976,0,0,0-1.151-4.089c-1.971-2.854-6.437-4.127-14.481-4.127Zm-28.932,0c-7.326,0-12.506,4.059-14.212,11.134-.057.238-6.225,25.832-6.315,26.2h35.353c.067-.268,1.458-6.04,1.518-6.3h-24.55l2.144-8.9h21.424c.007-.029,1.587-6.578,1.667-6.929H-7140.4l.691-2.871c.958-4,3.393-6.027,7.236-6.027h18.772c.02-.08.264-1.091.7-2.923l.021-.089c.368-1.532.75-3.116.792-3.287Zm-46.589,7.869h9.206c2.323,0,3.864.594,4.71,1.813a5.025,5.025,0,0,1,.746,2.888,16.535,16.535,0,0,1-.536,3.706l-.247,1.022c-3.157,13.089-4.782,19.828-4.829,20.032h10.792c.04-.169,5.5-22.808,5.564-23.068a24.053,24.053,0,0,0,.76-5.554,9.042,9.042,0,0,0-1.4-5.289c-1.563-2.27-4.52-3.42-8.787-3.42h-24.872c-.046.172-8.882,36.807-9,37.331h10.8c.057-.241,7.021-29.157,7.1-29.461Zm-26.786-7.869c-.033.153-4.506,18.706-7.18,29.791l-1.031,4.274-.448,1.857c-.206.853-.33,1.368-.339,1.408h10.8c.045-.174,6.041-25.057,8.01-33.233l.987-4.1Zm-30.83,0h-10.8l-5.6,23.245c-1.755,7.286-3.356,13.934-3.393,14.086h10.795c.037-.163,1.969-8.186,2.794-11.611.226-.935.373-1.545.384-1.592v0h0l.162.2c.1.129,10.459,12.918,10.477,13.009h14.048c-.34-.416-15.654-19.284-15.91-19.6l3.2-2.517c6.122-4.814,18.862-14.832,19.36-15.216-.709,0-12.544-.027-12.659-.027l-15.9,12.606c.015-.066.855-3.547,1.668-6.912C-7240.891-10688.1-7240.245-10690.773-7240.206-10690.933Zm195.131,0c-11.63,0-22.333,8.026-24.9,18.67a17.937,17.937,0,0,0-.519,4.229,14.088,14.088,0,0,0,2.4,8.061c2.841,4.108,7.8,6.371,13.952,6.371h18.043c.05-.192,5.3-21.959,5.336-22.134h-17.225c0,.007-.034.144-.09.376-1,4.136-1.53,6.341-1.585,6.553h6.44l-2.149,8.9h-4.208c-4.312,0-7.116-1.031-8.573-3.151a7.711,7.711,0,0,1-1.2-4.521,20.454,20.454,0,0,1,.638-4.7c2.069-8.55,6.7-12.362,15.025-12.362h13.511c.028-.1.4-1.62.751-3.09l.129-.535c.314-1.3.61-2.525.648-2.674Zm-44.65-11.613-1.221,5.07h53.424l1.223-5.07Zm-55.005,0-1.226,5.07h53.427l1.223-5.07Zm164.107-9.454h0a49.545,49.545,0,0,1-12.614,6.926,39.439,39.439,0,0,1-13.58,2.5l-28,.009-1.229,5.084,28.555,0a44.59,44.59,0,0,0,15.353-2.806,54.073,54.073,0,0,0,14.134-7.823l-2.622-3.889Z" transform="translate(7293.999 11052)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-6944-10492h-350v-560h350v560Zm-81.177-198.933c.144.4,8.53,24.224,8.609,24.45-.085.1-10.383,12.42-10.77,12.881l10.687.044,10.294-12.324,20.926-25.051h-10.687c-.054.063-6.563,7.844-10.453,12.493l-2.725,3.259c-.025-.069-1.086-3.067-2.314-6.539-1.511-4.271-3.224-9.113-3.258-9.213Zm-81.891,0c-.013.057-.691,2.866-1.686,6.991-1.793,7.436-7.25,30.064-7.314,30.34h10.8c.038-.167,4.8-19.913,6.83-28.345.479-1.986.782-3.247.8-3.309h4.857l1.368,0h.084c.437,0,.849,0,1.263,0,3.163,0,6.1.146,7.337,1.917.667.962.778,2.32.338,4.152a6.526,6.526,0,0,1-3.994,4.876,17.915,17.915,0,0,1-6.58.889c-.519,0-1.037,0-1.43-.009l-1.42-.009h-3.537c.222.438,9.822,19.712,9.885,19.846h11.941c-.131-.248-2.94-5.646-5.2-9.982l-2.718-5.223h.227c7,0,11.941-3.837,13.55-10.526a14.541,14.541,0,0,0,.449-3.384,6.976,6.976,0,0,0-1.151-4.089c-1.971-2.854-6.437-4.127-14.481-4.127Zm-28.932,0c-7.326,0-12.506,4.059-14.212,11.134-.057.238-6.225,25.832-6.315,26.2h35.353c.067-.268,1.458-6.04,1.518-6.3h-24.55l2.144-8.9h21.424c.007-.029,1.587-6.578,1.667-6.929H-7140.4l.691-2.871c.958-4,3.393-6.027,7.236-6.027h18.772c.02-.08.264-1.091.7-2.923l.021-.089c.368-1.532.75-3.116.792-3.287Zm-46.589,7.869h9.206c2.323,0,3.864.594,4.71,1.813a5.025,5.025,0,0,1,.746,2.888,16.535,16.535,0,0,1-.536,3.706l-.247,1.022c-3.157,13.089-4.782,19.828-4.829,20.032h10.792c.04-.169,5.5-22.808,5.564-23.068a24.053,24.053,0,0,0,.76-5.554,9.042,9.042,0,0,0-1.4-5.289c-1.563-2.27-4.52-3.42-8.787-3.42h-24.872c-.046.172-8.882,36.807-9,37.331h10.8c.057-.241,7.021-29.157,7.1-29.461Zm-26.786-7.869c-.033.153-4.506,18.706-7.18,29.791l-1.031,4.274-.448,1.857c-.206.853-.33,1.368-.339,1.408h10.8c.045-.174,6.041-25.057,8.01-33.233l.987-4.1Zm-30.83,0h-10.8l-5.6,23.245c-1.755,7.286-3.356,13.934-3.393,14.086h10.795c.037-.163,1.969-8.186,2.794-11.611.226-.935.373-1.545.384-1.592v0h0l.162.2c.1.129,10.459,12.918,10.477,13.009h14.048c-.34-.416-15.654-19.284-15.91-19.6l3.2-2.517c6.122-4.814,18.862-14.832,19.36-15.216-.709,0-12.544-.027-12.659-.027l-15.9,12.606c.015-.066.855-3.547,1.668-6.912C-7240.891-10688.1-7240.245-10690.773-7240.206-10690.933Zm195.131,0c-11.63,0-22.333,8.026-24.9,18.67a17.937,17.937,0,0,0-.519,4.229,14.088,14.088,0,0,0,2.4,8.061c2.841,4.108,7.8,6.371,13.952,6.371h18.043c.05-.192,5.3-21.959,5.336-22.134h-17.225c0,.007-.034.144-.09.376-1,4.136-1.53,6.341-1.585,6.553h6.44l-2.149,8.9h-4.208c-4.312,0-7.116-1.031-8.573-3.151a7.711,7.711,0,0,1-1.2-4.521,20.454,20.454,0,0,1,.638-4.7c2.069-8.55,6.7-12.362,15.025-12.362h13.511c.028-.1.4-1.62.751-3.09l.129-.535c.314-1.3.61-2.525.648-2.674Zm-44.65-11.613-1.221,5.07h53.424l1.223-5.07Zm-55.005,0-1.226,5.07h53.427l1.223-5.07Zm164.107-9.454h0a49.545,49.545,0,0,1-12.614,6.926,39.439,39.439,0,0,1-13.58,2.5l-28,.009-1.229,5.084,28.555,0a44.59,44.59,0,0,0,15.353-2.806,54.073,54.073,0,0,0,14.134-7.823l-2.622-3.889Z" transform="translate(7293.999 11052)" /> </svg> <div class="content"> <p class="desc">Drive your way with balanced technology</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <div class="content"> <p class="desc">Drive your way with balanced technology</p> <span class="btn btn--round">Learn more</span> </div> </a> </div> <div class="display" data-id="winter-icept"> <a href="/global/en/tires/winter-i-cept-winter-i-pike.html"> <img class="display__bg t_none" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/winter-icept/bg.jpg" alt="배경이미지"> <img class="display__bg t_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/winter-icept/bg-m.jpg" alt="배경이미지"> <img class="display__bg m_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/winter-icept/bg-m.jpg" alt="배경이미지"> <div class="display__wrap"> <div class="display__lottie"></div> </div> <!-- 웹 --> <div class="svg_wrap t_none"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape5" d="M-1246-8314H-3006v-720h1760v720Zm-477.14-316.8-67.078,36.466-28.676,93.532h55.788l8.792-28.36,17.953-10.687h0v0l12.628,39.047h60.208l-23.316-65.449L-1636-8594.4h-63.825l-13.381,8c-9,5.522-25.311,15.924-30.762,20.321,2.363-6.086,7.33-20.577,9.173-26.551Zm-140.079,0-11.508,36.4-28.658,93.6h56.03l28.477-93.6h-55.8l63.249-36.4Zm-173.52,28.8-30.778,101.193h50.081l11.261-34.757h38.028a110.007,110.007,0,0,0,24.788-2.587,68.13,68.13,0,0,0,20.473-8.207,56.261,56.261,0,0,0,8.478-6.419,56.766,56.766,0,0,0,7.231-8.076,64.233,64.233,0,0,0,5.928-9.814,79.748,79.748,0,0,0,4.569-11.638h.1a40.061,40.061,0,0,0,1.991-15.586,22.4,22.4,0,0,0-4.213-11.257,26.575,26.575,0,0,0-8.557-7.284,48.951,48.951,0,0,0-11.84-4.513,93.024,93.024,0,0,0-13.988-2.3c-4.54-.427-9.587-.643-15-.643h-50.442l12.037-6.919h-51.788l-11.51,36.4,13.15-7.595Zm-148.642-28.8-11.509,36.4-28.674,93.6h56.048l28.474-93.6h-55.783l63.233-36.4h-51.79Zm654.655,36.44c-.394,0-.64,0-.706.007l-.052.017h-50.081c-12,0-22.685,1.643-31.75,4.881a55.5,55.5,0,0,0-18.552,10.738,41.84,41.84,0,0,0-8.687,10.737,25.044,25.044,0,0,0-2.155,4.881l-7.645,24.285a30.2,30.2,0,0,0-1.359,12.718,21.209,21.209,0,0,0,3.691,9.523,29.173,29.173,0,0,0,9.966,8.555,54.6,54.6,0,0,0,12.062,4.744,77.478,77.478,0,0,0,14.437,2.472h102.037l6.117-20.174h-79.872c-6.871,0-11.441-1.664-13.584-4.944a9.38,9.38,0,0,1-1.24-6.539,13.745,13.745,0,0,1,.867-3.312l1.349-4.276h98.645l4.784-15.849c3.186-10.254,2.424-18.683-2.266-25.05C-1504.123-8593.71-1526.363-8594.356-1530.726-8594.356Zm-937.148,12.522-7.267,24c-1.656,5.42-1.449,9.42.63,12.229,1.375,1.857,3.543,3.191,6.628,4.078a43.049,43.049,0,0,0,11.667,1.283h19.729l8.976-16.128h-12.658c-3.333,0-5.2-.5-6.051-1.606-.647-.845-.733-2.1-.264-3.852l6.115-20.008h20.076l4.586-14.8h-20.074l6.691-21.489-30,7.5-4.194,13.994h-13.957l-4.768,14.8Zm88.667-14.5a53.16,53.16,0,0,0-18.235,2.875,31.839,31.839,0,0,0-10.672,6.323,24.68,24.68,0,0,0-5.01,6.324,14.79,14.79,0,0,0-1.248,2.874l-4.392,14.272c-1.571,5.2-1.1,9.641,1.413,13.209a17.074,17.074,0,0,0,5.757,4.968,31.282,31.282,0,0,0,6.924,2.758,43.379,43.379,0,0,0,8.265,1.44h53.5l3.635-11.853h-43.375c-4.075,0-6.946-1.023-8.535-3.041a7.225,7.225,0,0,1-1.212-5.656l.758-2.517h55.8l2.877-9.339c1.841-6.113,1.358-11.12-1.438-14.881-5.466-7.355-18.052-7.728-20.52-7.728-.223,0-.362,0-.4,0l0-.034Zm64.023-.294L-2332-8541.323h31.535l9.173-30.122a11.3,11.3,0,0,1,5.56-7.028c2.442-1.311,5.619-1.948,9.715-1.948.218-.008.44-.012.66-.012a19.034,19.034,0,0,1,12.49,4.648l13.549-19.7a35.282,35.282,0,0,0-12.616-2.325c-.471,0-.961.01-1.457.03a46.81,46.81,0,0,0-10.988,1.312,47.264,47.264,0,0,0-10.385,3.852l1.149-4.011h-31.566Zm-301.005.016h0l-16.819,55.291h31.551l17-55.291Zm-83.684,8.729v0l-.2,46.559h31.535l51.788-73.722h-34.525l-24.45,44.39.2-44.39h-31.156l-26.946,44.39,2.861-44.39H-2766l6.888,73.722h30.959l28.277-46.559Zm149.27,11.655v0l20.073,34.888h28.1l16.819-55.291h-28.13l-10.7,34.87-20.058-34.87h-28.1l-16.82,55.291h28.116l10.7-34.886Zm437.318-2.972-14.517,16.521,10.7,7.6,14.795-16.441,4.39,16.441,15.488-7.6-4.389-16.521h19.088l4.586-15.192h-19.2l14.533-16.442-10.7-7.613-14.714,16.442-4.389-16.442-15.472,7.613,4.389,16.442h-19.1l-4.59,15.192Zm-480.527-39.183c-9.542,0-18.548,3.873-20.076,8.634a4.319,4.319,0,0,0,.684,4c2.085,2.858,7.393,4.634,13.852,4.634,9.534,0,18.532-3.872,20.058-8.632a4.325,4.325,0,0,0-.683-4C-2582.059-8616.613-2587.36-8618.387-2593.812-8618.387Zm844.9-191.475h0l-38.2,125.149v.009l58.164-12.54,5.963-19.172h35.725c17.746,0,32.655-3.93,44.313-11.681,12.1-8.053,20.711-20.254,25.595-36.265,4.413-14.234,3.829-25.284-1.734-32.843-6.189-8.4-18.593-12.658-36.867-12.658h-92.954Zm-70.559-1.928c-.39,0-.633.006-.7.008h-41.292c-11.913,0-22.526,1.675-31.544,4.978a55.177,55.177,0,0,0-18.475,10.951,42.844,42.844,0,0,0-8.683,10.95,25.858,25.858,0,0,0-2.166,4.978l-7.5,24.733a31.4,31.4,0,0,0-1.368,13.16,21.861,21.861,0,0,0,3.809,9.8,29.472,29.472,0,0,0,9.9,8.563,53.719,53.719,0,0,0,11.89,4.755,74.365,74.365,0,0,0,14.182,2.484l11.715-.048h81.244l6.328-20.539h-75.279c-7.071,0-12.052-1.774-14.8-5.273a11.329,11.329,0,0,1-2.33-6.526,12.615,12.615,0,0,1,.233-3.268l1.338-4.362h96.807l4.795-16.143c3.2-10.595,2.364-19.273-2.479-25.794C-1793.327-8811.143-1815.183-8811.789-1819.468-8811.789Zm-174.307.008c-11.958,0-22.609,1.675-31.658,4.978a55.335,55.335,0,0,0-18.534,10.95,42.819,42.819,0,0,0-8.7,10.949,25.622,25.622,0,0,0-2.169,4.978l-7.5,24.735a31.364,31.364,0,0,0-1.3,13.146,21.989,21.989,0,0,0,3.85,9.793,29.7,29.7,0,0,0,9.943,8.574,54.01,54.01,0,0,0,11.918,4.76,74.423,74.423,0,0,0,14.2,2.487l11.715-.048h60.685l6.149-20.539h-54.541c-7.083,0-12.092-1.779-14.888-5.289a11.488,11.488,0,0,1-2.4-6.518,12.684,12.684,0,0,1,.19-3.261l1.34-4.362,6.144-19.911a21.009,21.009,0,0,1,5.54-9.185,23.255,23.255,0,0,1,7.5-4.755,28.884,28.884,0,0,1,9.433-2.056h58.769l5.949-19.428Zm385.242,1.85,10.18,24.586h18.818l-12.1,39.735c-2.73,8.961-2.383,15.576,1.06,20.225a15.677,15.677,0,0,0,4.454,3.988,26.5,26.5,0,0,0,6.517,2.761c4.972,1.428,11.278,2.122,19.279,2.122h39.937l14.986-26.666h-21.133c-5.457,0-8.509-.834-9.9-2.7-1.051-1.418-1.143-3.489-.281-6.334l10.178-33.129h33.045l7.484-24.586h-33.027l10.937-35.591-56.84,12.393-7.1,23.2h-36.5Zm-590.153-1.784h0l-28.81,93.319h55.883l28.427-93.319h-55.5Zm-270.215,12.59-7.305,23.939c-1.654,5.395-1.449,9.38.625,12.184,1.37,1.854,3.53,3.185,6.6,4.069a42.648,42.648,0,0,0,11.594,1.28h19.6l9.021-16.061c-.073,0-8.427-.017-12.674-.017-3.236,0-5.055-.493-5.9-1.6-.645-.848-.727-2.1-.249-3.835l6.146-19.961h19.779l4.807-14.8h-19.977l6.527-21.43-29.755,7.468-4.428,13.962h-13.83l-4.612,14.8Zm112.551-14.527c-.217,0-.353,0-.389,0h-23.813a53.227,53.227,0,0,0-18.213,2.866,31.882,31.882,0,0,0-10.667,6.3,24.673,24.673,0,0,0-5.014,6.3,15.065,15.065,0,0,0-1.251,2.866l-4.228,14.24c-1.585,5.2-1.121,9.647,1.379,13.211a16.9,16.9,0,0,0,5.695,4.924A30.915,30.915,0,0,0-2406-8760.2a42.993,42.993,0,0,0,8.17,1.423l6.908-.016h46.66l3.65-11.83h-43.4c-4.021,0-6.874-1.016-8.479-3.018a7.317,7.317,0,0,1-1.3-5.64l.76-2.512h55.9l2.677-9.3c1.85-6.1,1.376-11.091-1.407-14.843C-2341.32-8813.281-2353.886-8813.653-2356.35-8813.653Zm39.56-.275-16.723,55.135H-2302l9.019-30.039a11.814,11.814,0,0,1,5.666-7c2.436-1.307,5.61-1.942,9.7-1.942a20.981,20.981,0,0,1,7.627,1.327,21.027,21.027,0,0,1,5.622,3.282l13.252-19.609c-3.76-1.577-8.218-2.312-14.03-2.312a45.474,45.474,0,0,0-11.3,1.392,50.016,50.016,0,0,0-10.014,3.746l1.159-3.981h-31.492Zm-256.588-.007-16.7,55.137h27.841l10.758-34.772v0l19.973,34.771h28.039l16.9-55.137h-28.041l-10.561,34.777-20.163-34.776Zm-43.4,0h0l-16.71,55.137h31.5l16.707-55.137h-31.5Zm-83.348,8.709v0l-.388,46.424h31.5l51.659-73.5h-34.571l-24.2,44.181.2-44.181h-31.111l-26.889,44.181,2.879-44.181H-2766l6.718,73.5h30.923l28.232-46.424Zm601.1,19.731v0l3.271,12.422a5.69,5.69,0,0,0,5.8,4.081,10.114,10.114,0,0,0,4.373-1.09c4.64-2.262,7.479-7.257,6.328-11.135l-3.256-12.411h14.211a11.117,11.117,0,0,0,6.6-2.389,11.53,11.53,0,0,0,4.152-5.773,6.518,6.518,0,0,0-.742-5.882,6.044,6.044,0,0,0-5.026-2.264h-14.209l10.955-12.409a9.548,9.548,0,0,0,2.661-7.268,5.343,5.343,0,0,0-2.28-3.866,6.645,6.645,0,0,0-3.783-1.095,10.152,10.152,0,0,0-4.348,1.054,12.674,12.674,0,0,0-3.962,3.013l-10.958,12.427-3.256-12.427a5.677,5.677,0,0,0-5.8-4.066,10.168,10.168,0,0,0-4.395,1.095,12.725,12.725,0,0,0-5.344,4.94,8.441,8.441,0,0,0-1.181,6.193l3.453,12.409h-14.39a10.779,10.779,0,0,0-6.438,2.388,11.624,11.624,0,0,0-4.123,5.758,6.586,6.586,0,0,0,.741,5.947,5.812,5.812,0,0,0,4.829,2.215h14.39l-10.937,12.411a11.245,11.245,0,0,0-2.2,3.646,7.965,7.965,0,0,0-.463,3.623,5.328,5.328,0,0,0,2.287,3.866,6.086,6.086,0,0,0,3.626,1.09,11.609,11.609,0,0,0,8.27-4.081l11.135-12.423ZM-2187.36-8848l-11.325,36.285L-2135.7-8848Zm-407.146,12.375a33.494,33.494,0,0,0-12.937,2.526c-3.8,1.633-6.3,3.793-7.038,6.082a4.314,4.314,0,0,0,.687,3.989,10.5,10.5,0,0,0,5.154,3.34,26.809,26.809,0,0,0,8.566,1.279,33.533,33.533,0,0,0,13.012-2.52c3.746-1.62,6.22-3.782,6.965-6.089a4.337,4.337,0,0,0-.671-4.025C-2582.823-8833.87-2588.087-8835.626-2594.506-8835.626Zm613.443,276.865h0c-.861,0-1.72-.03-2.552-.091-8.531,0-16.364-.473-16.442-.478l13.365-43.075h18.562a44.825,44.825,0,0,1,11.009,1.121,19.126,19.126,0,0,1,4.765,1.861,11.648,11.648,0,0,1,3.613,3.14,11.518,11.518,0,0,1,2.131,6.051,24.733,24.733,0,0,1-1.262,9,35.576,35.576,0,0,1-13.189,16.348A35.634,35.634,0,0,1-1981.063-8558.761Zm434.829-.8h-43.617a21.611,21.611,0,0,1,19.729-15.7h12.987c6.921,0,11.259,1.584,12.895,4.707a6.927,6.927,0,0,1,.71,3.669,12.482,12.482,0,0,1-.8,3.562,18.906,18.906,0,0,1-1.9,3.763Zm-813.473-16.326H-2388.2a14.1,14.1,0,0,1,5.078-6.637,14.04,14.04,0,0,1,7.927-2.6h7.661c4.061,0,6.731.986,7.938,2.933a5.668,5.668,0,0,1,.574,4.169,9.366,9.366,0,0,1-.684,2.138h0Zm664.55-166.4h-19.968l13.442-43.736h19.8c5.724,0,9.1,1.1,10.955,3.577,2.495,3.33,2.316,9.215-.58,19.081C-1675.571-8750.011-1680.741-8742.282-1695.157-8742.282Zm-132.5-34.076h-49.153a20.988,20.988,0,0,1,5.529-9.185,23.2,23.2,0,0,1,7.493-4.754,28.86,28.86,0,0,1,9.43-2.055h13.068c7.121,0,11.791,1.719,13.88,5.109a8.379,8.379,0,0,1,1.177,3.676,12.458,12.458,0,0,1-.22,3.521,16.2,16.2,0,0,1-1.2,3.686h0Zm-533.317-16.884h-28.42a11.955,11.955,0,0,1,3.148-5.286,13.235,13.235,0,0,1,4.3-2.736,16.586,16.586,0,0,1,5.426-1.183h7.489c4.119,0,6.836,1,8.074,2.969a5.7,5.7,0,0,1,.627,4.127,8.922,8.922,0,0,1-.641,2.108Z" transform="translate(3006 9034)" /> </defs> <clipPath id="clipPath5"> <use xlink:href="#polygonShape5"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath5);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/winter-icept/bg.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M-1246-8314H-3006v-720h1760v720Zm-477.14-316.8-67.078,36.466-28.676,93.532h55.788l8.792-28.36,17.953-10.687h0v0l12.628,39.047h60.208l-23.316-65.449L-1636-8594.4h-63.825l-13.381,8c-9,5.522-25.311,15.924-30.762,20.321,2.363-6.086,7.33-20.577,9.173-26.551Zm-140.079,0-11.508,36.4-28.658,93.6h56.03l28.477-93.6h-55.8l63.249-36.4Zm-173.52,28.8-30.778,101.193h50.081l11.261-34.757h38.028a110.007,110.007,0,0,0,24.788-2.587,68.13,68.13,0,0,0,20.473-8.207,56.261,56.261,0,0,0,8.478-6.419,56.766,56.766,0,0,0,7.231-8.076,64.233,64.233,0,0,0,5.928-9.814,79.748,79.748,0,0,0,4.569-11.638h.1a40.061,40.061,0,0,0,1.991-15.586,22.4,22.4,0,0,0-4.213-11.257,26.575,26.575,0,0,0-8.557-7.284,48.951,48.951,0,0,0-11.84-4.513,93.024,93.024,0,0,0-13.988-2.3c-4.54-.427-9.587-.643-15-.643h-50.442l12.037-6.919h-51.788l-11.51,36.4,13.15-7.595Zm-148.642-28.8-11.509,36.4-28.674,93.6h56.048l28.474-93.6h-55.783l63.233-36.4h-51.79Zm654.655,36.44c-.394,0-.64,0-.706.007l-.052.017h-50.081c-12,0-22.685,1.643-31.75,4.881a55.5,55.5,0,0,0-18.552,10.738,41.84,41.84,0,0,0-8.687,10.737,25.044,25.044,0,0,0-2.155,4.881l-7.645,24.285a30.2,30.2,0,0,0-1.359,12.718,21.209,21.209,0,0,0,3.691,9.523,29.173,29.173,0,0,0,9.966,8.555,54.6,54.6,0,0,0,12.062,4.744,77.478,77.478,0,0,0,14.437,2.472h102.037l6.117-20.174h-79.872c-6.871,0-11.441-1.664-13.584-4.944a9.38,9.38,0,0,1-1.24-6.539,13.745,13.745,0,0,1,.867-3.312l1.349-4.276h98.645l4.784-15.849c3.186-10.254,2.424-18.683-2.266-25.05C-1504.123-8593.71-1526.363-8594.356-1530.726-8594.356Zm-937.148,12.522-7.267,24c-1.656,5.42-1.449,9.42.63,12.229,1.375,1.857,3.543,3.191,6.628,4.078a43.049,43.049,0,0,0,11.667,1.283h19.729l8.976-16.128h-12.658c-3.333,0-5.2-.5-6.051-1.606-.647-.845-.733-2.1-.264-3.852l6.115-20.008h20.076l4.586-14.8h-20.074l6.691-21.489-30,7.5-4.194,13.994h-13.957l-4.768,14.8Zm88.667-14.5a53.16,53.16,0,0,0-18.235,2.875,31.839,31.839,0,0,0-10.672,6.323,24.68,24.68,0,0,0-5.01,6.324,14.79,14.79,0,0,0-1.248,2.874l-4.392,14.272c-1.571,5.2-1.1,9.641,1.413,13.209a17.074,17.074,0,0,0,5.757,4.968,31.282,31.282,0,0,0,6.924,2.758,43.379,43.379,0,0,0,8.265,1.44h53.5l3.635-11.853h-43.375c-4.075,0-6.946-1.023-8.535-3.041a7.225,7.225,0,0,1-1.212-5.656l.758-2.517h55.8l2.877-9.339c1.841-6.113,1.358-11.12-1.438-14.881-5.466-7.355-18.052-7.728-20.52-7.728-.223,0-.362,0-.4,0l0-.034Zm64.023-.294L-2332-8541.323h31.535l9.173-30.122a11.3,11.3,0,0,1,5.56-7.028c2.442-1.311,5.619-1.948,9.715-1.948.218-.008.44-.012.66-.012a19.034,19.034,0,0,1,12.49,4.648l13.549-19.7a35.282,35.282,0,0,0-12.616-2.325c-.471,0-.961.01-1.457.03a46.81,46.81,0,0,0-10.988,1.312,47.264,47.264,0,0,0-10.385,3.852l1.149-4.011h-31.566Zm-301.005.016h0l-16.819,55.291h31.551l17-55.291Zm-83.684,8.729v0l-.2,46.559h31.535l51.788-73.722h-34.525l-24.45,44.39.2-44.39h-31.156l-26.946,44.39,2.861-44.39H-2766l6.888,73.722h30.959l28.277-46.559Zm149.27,11.655v0l20.073,34.888h28.1l16.819-55.291h-28.13l-10.7,34.87-20.058-34.87h-28.1l-16.82,55.291h28.116l10.7-34.886Zm437.318-2.972-14.517,16.521,10.7,7.6,14.795-16.441,4.39,16.441,15.488-7.6-4.389-16.521h19.088l4.586-15.192h-19.2l14.533-16.442-10.7-7.613-14.714,16.442-4.389-16.442-15.472,7.613,4.389,16.442h-19.1l-4.59,15.192Zm-480.527-39.183c-9.542,0-18.548,3.873-20.076,8.634a4.319,4.319,0,0,0,.684,4c2.085,2.858,7.393,4.634,13.852,4.634,9.534,0,18.532-3.872,20.058-8.632a4.325,4.325,0,0,0-.683-4C-2582.059-8616.613-2587.36-8618.387-2593.812-8618.387Zm844.9-191.475h0l-38.2,125.149v.009l58.164-12.54,5.963-19.172h35.725c17.746,0,32.655-3.93,44.313-11.681,12.1-8.053,20.711-20.254,25.595-36.265,4.413-14.234,3.829-25.284-1.734-32.843-6.189-8.4-18.593-12.658-36.867-12.658h-92.954Zm-70.559-1.928c-.39,0-.633.006-.7.008h-41.292c-11.913,0-22.526,1.675-31.544,4.978a55.177,55.177,0,0,0-18.475,10.951,42.844,42.844,0,0,0-8.683,10.95,25.858,25.858,0,0,0-2.166,4.978l-7.5,24.733a31.4,31.4,0,0,0-1.368,13.16,21.861,21.861,0,0,0,3.809,9.8,29.472,29.472,0,0,0,9.9,8.563,53.719,53.719,0,0,0,11.89,4.755,74.365,74.365,0,0,0,14.182,2.484l11.715-.048h81.244l6.328-20.539h-75.279c-7.071,0-12.052-1.774-14.8-5.273a11.329,11.329,0,0,1-2.33-6.526,12.615,12.615,0,0,1,.233-3.268l1.338-4.362h96.807l4.795-16.143c3.2-10.595,2.364-19.273-2.479-25.794C-1793.327-8811.143-1815.183-8811.789-1819.468-8811.789Zm-174.307.008c-11.958,0-22.609,1.675-31.658,4.978a55.335,55.335,0,0,0-18.534,10.95,42.819,42.819,0,0,0-8.7,10.949,25.622,25.622,0,0,0-2.169,4.978l-7.5,24.735a31.364,31.364,0,0,0-1.3,13.146,21.989,21.989,0,0,0,3.85,9.793,29.7,29.7,0,0,0,9.943,8.574,54.01,54.01,0,0,0,11.918,4.76,74.423,74.423,0,0,0,14.2,2.487l11.715-.048h60.685l6.149-20.539h-54.541c-7.083,0-12.092-1.779-14.888-5.289a11.488,11.488,0,0,1-2.4-6.518,12.684,12.684,0,0,1,.19-3.261l1.34-4.362,6.144-19.911a21.009,21.009,0,0,1,5.54-9.185,23.255,23.255,0,0,1,7.5-4.755,28.884,28.884,0,0,1,9.433-2.056h58.769l5.949-19.428Zm385.242,1.85,10.18,24.586h18.818l-12.1,39.735c-2.73,8.961-2.383,15.576,1.06,20.225a15.677,15.677,0,0,0,4.454,3.988,26.5,26.5,0,0,0,6.517,2.761c4.972,1.428,11.278,2.122,19.279,2.122h39.937l14.986-26.666h-21.133c-5.457,0-8.509-.834-9.9-2.7-1.051-1.418-1.143-3.489-.281-6.334l10.178-33.129h33.045l7.484-24.586h-33.027l10.937-35.591-56.84,12.393-7.1,23.2h-36.5Zm-590.153-1.784h0l-28.81,93.319h55.883l28.427-93.319h-55.5Zm-270.215,12.59-7.305,23.939c-1.654,5.395-1.449,9.38.625,12.184,1.37,1.854,3.53,3.185,6.6,4.069a42.648,42.648,0,0,0,11.594,1.28h19.6l9.021-16.061c-.073,0-8.427-.017-12.674-.017-3.236,0-5.055-.493-5.9-1.6-.645-.848-.727-2.1-.249-3.835l6.146-19.961h19.779l4.807-14.8h-19.977l6.527-21.43-29.755,7.468-4.428,13.962h-13.83l-4.612,14.8Zm112.551-14.527c-.217,0-.353,0-.389,0h-23.813a53.227,53.227,0,0,0-18.213,2.866,31.882,31.882,0,0,0-10.667,6.3,24.673,24.673,0,0,0-5.014,6.3,15.065,15.065,0,0,0-1.251,2.866l-4.228,14.24c-1.585,5.2-1.121,9.647,1.379,13.211a16.9,16.9,0,0,0,5.695,4.924A30.915,30.915,0,0,0-2406-8760.2a42.993,42.993,0,0,0,8.17,1.423l6.908-.016h46.66l3.65-11.83h-43.4c-4.021,0-6.874-1.016-8.479-3.018a7.317,7.317,0,0,1-1.3-5.64l.76-2.512h55.9l2.677-9.3c1.85-6.1,1.376-11.091-1.407-14.843C-2341.32-8813.281-2353.886-8813.653-2356.35-8813.653Zm39.56-.275-16.723,55.135H-2302l9.019-30.039a11.814,11.814,0,0,1,5.666-7c2.436-1.307,5.61-1.942,9.7-1.942a20.981,20.981,0,0,1,7.627,1.327,21.027,21.027,0,0,1,5.622,3.282l13.252-19.609c-3.76-1.577-8.218-2.312-14.03-2.312a45.474,45.474,0,0,0-11.3,1.392,50.016,50.016,0,0,0-10.014,3.746l1.159-3.981h-31.492Zm-256.588-.007-16.7,55.137h27.841l10.758-34.772v0l19.973,34.771h28.039l16.9-55.137h-28.041l-10.561,34.777-20.163-34.776Zm-43.4,0h0l-16.71,55.137h31.5l16.707-55.137h-31.5Zm-83.348,8.709v0l-.388,46.424h31.5l51.659-73.5h-34.571l-24.2,44.181.2-44.181h-31.111l-26.889,44.181,2.879-44.181H-2766l6.718,73.5h30.923l28.232-46.424Zm601.1,19.731v0l3.271,12.422a5.69,5.69,0,0,0,5.8,4.081,10.114,10.114,0,0,0,4.373-1.09c4.64-2.262,7.479-7.257,6.328-11.135l-3.256-12.411h14.211a11.117,11.117,0,0,0,6.6-2.389,11.53,11.53,0,0,0,4.152-5.773,6.518,6.518,0,0,0-.742-5.882,6.044,6.044,0,0,0-5.026-2.264h-14.209l10.955-12.409a9.548,9.548,0,0,0,2.661-7.268,5.343,5.343,0,0,0-2.28-3.866,6.645,6.645,0,0,0-3.783-1.095,10.152,10.152,0,0,0-4.348,1.054,12.674,12.674,0,0,0-3.962,3.013l-10.958,12.427-3.256-12.427a5.677,5.677,0,0,0-5.8-4.066,10.168,10.168,0,0,0-4.395,1.095,12.725,12.725,0,0,0-5.344,4.94,8.441,8.441,0,0,0-1.181,6.193l3.453,12.409h-14.39a10.779,10.779,0,0,0-6.438,2.388,11.624,11.624,0,0,0-4.123,5.758,6.586,6.586,0,0,0,.741,5.947,5.812,5.812,0,0,0,4.829,2.215h14.39l-10.937,12.411a11.245,11.245,0,0,0-2.2,3.646,7.965,7.965,0,0,0-.463,3.623,5.328,5.328,0,0,0,2.287,3.866,6.086,6.086,0,0,0,3.626,1.09,11.609,11.609,0,0,0,8.27-4.081l11.135-12.423ZM-2187.36-8848l-11.325,36.285L-2135.7-8848Zm-407.146,12.375a33.494,33.494,0,0,0-12.937,2.526c-3.8,1.633-6.3,3.793-7.038,6.082a4.314,4.314,0,0,0,.687,3.989,10.5,10.5,0,0,0,5.154,3.34,26.809,26.809,0,0,0,8.566,1.279,33.533,33.533,0,0,0,13.012-2.52c3.746-1.62,6.22-3.782,6.965-6.089a4.337,4.337,0,0,0-.671-4.025C-2582.823-8833.87-2588.087-8835.626-2594.506-8835.626Zm613.443,276.865h0c-.861,0-1.72-.03-2.552-.091-8.531,0-16.364-.473-16.442-.478l13.365-43.075h18.562a44.825,44.825,0,0,1,11.009,1.121,19.126,19.126,0,0,1,4.765,1.861,11.648,11.648,0,0,1,3.613,3.14,11.518,11.518,0,0,1,2.131,6.051,24.733,24.733,0,0,1-1.262,9,35.576,35.576,0,0,1-13.189,16.348A35.634,35.634,0,0,1-1981.063-8558.761Zm434.829-.8h-43.617a21.611,21.611,0,0,1,19.729-15.7h12.987c6.921,0,11.259,1.584,12.895,4.707a6.927,6.927,0,0,1,.71,3.669,12.482,12.482,0,0,1-.8,3.562,18.906,18.906,0,0,1-1.9,3.763Zm-813.473-16.326H-2388.2a14.1,14.1,0,0,1,5.078-6.637,14.04,14.04,0,0,1,7.927-2.6h7.661c4.061,0,6.731.986,7.938,2.933a5.668,5.668,0,0,1,.574,4.169,9.366,9.366,0,0,1-.684,2.138h0Zm664.55-166.4h-19.968l13.442-43.736h19.8c5.724,0,9.1,1.1,10.955,3.577,2.495,3.33,2.316,9.215-.58,19.081C-1675.571-8750.011-1680.741-8742.282-1695.157-8742.282Zm-132.5-34.076h-49.153a20.988,20.988,0,0,1,5.529-9.185,23.2,23.2,0,0,1,7.493-4.754,28.86,28.86,0,0,1,9.43-2.055h13.068c7.121,0,11.791,1.719,13.88,5.109a8.379,8.379,0,0,1,1.177,3.676,12.458,12.458,0,0,1-.22,3.521,16.2,16.2,0,0,1-1.2,3.686h0Zm-533.317-16.884h-28.42a11.955,11.955,0,0,1,3.148-5.286,13.235,13.235,0,0,1,4.3-2.736,16.586,16.586,0,0,1,5.426-1.183h7.489c4.119,0,6.836,1,8.074,2.969a5.7,5.7,0,0,1,.627,4.127,8.922,8.922,0,0,1-.641,2.108Z" transform="translate(3006 9034)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M-1246-8314H-3006v-720h1760v720Zm-477.14-316.8-67.078,36.466-28.676,93.532h55.788l8.792-28.36,17.953-10.687h0v0l12.628,39.047h60.208l-23.316-65.449L-1636-8594.4h-63.825l-13.381,8c-9,5.522-25.311,15.924-30.762,20.321,2.363-6.086,7.33-20.577,9.173-26.551Zm-140.079,0-11.508,36.4-28.658,93.6h56.03l28.477-93.6h-55.8l63.249-36.4Zm-173.52,28.8-30.778,101.193h50.081l11.261-34.757h38.028a110.007,110.007,0,0,0,24.788-2.587,68.13,68.13,0,0,0,20.473-8.207,56.261,56.261,0,0,0,8.478-6.419,56.766,56.766,0,0,0,7.231-8.076,64.233,64.233,0,0,0,5.928-9.814,79.748,79.748,0,0,0,4.569-11.638h.1a40.061,40.061,0,0,0,1.991-15.586,22.4,22.4,0,0,0-4.213-11.257,26.575,26.575,0,0,0-8.557-7.284,48.951,48.951,0,0,0-11.84-4.513,93.024,93.024,0,0,0-13.988-2.3c-4.54-.427-9.587-.643-15-.643h-50.442l12.037-6.919h-51.788l-11.51,36.4,13.15-7.595Zm-148.642-28.8-11.509,36.4-28.674,93.6h56.048l28.474-93.6h-55.783l63.233-36.4h-51.79Zm654.655,36.44c-.394,0-.64,0-.706.007l-.052.017h-50.081c-12,0-22.685,1.643-31.75,4.881a55.5,55.5,0,0,0-18.552,10.738,41.84,41.84,0,0,0-8.687,10.737,25.044,25.044,0,0,0-2.155,4.881l-7.645,24.285a30.2,30.2,0,0,0-1.359,12.718,21.209,21.209,0,0,0,3.691,9.523,29.173,29.173,0,0,0,9.966,8.555,54.6,54.6,0,0,0,12.062,4.744,77.478,77.478,0,0,0,14.437,2.472h102.037l6.117-20.174h-79.872c-6.871,0-11.441-1.664-13.584-4.944a9.38,9.38,0,0,1-1.24-6.539,13.745,13.745,0,0,1,.867-3.312l1.349-4.276h98.645l4.784-15.849c3.186-10.254,2.424-18.683-2.266-25.05C-1504.123-8593.71-1526.363-8594.356-1530.726-8594.356Zm-937.148,12.522-7.267,24c-1.656,5.42-1.449,9.42.63,12.229,1.375,1.857,3.543,3.191,6.628,4.078a43.049,43.049,0,0,0,11.667,1.283h19.729l8.976-16.128h-12.658c-3.333,0-5.2-.5-6.051-1.606-.647-.845-.733-2.1-.264-3.852l6.115-20.008h20.076l4.586-14.8h-20.074l6.691-21.489-30,7.5-4.194,13.994h-13.957l-4.768,14.8Zm88.667-14.5a53.16,53.16,0,0,0-18.235,2.875,31.839,31.839,0,0,0-10.672,6.323,24.68,24.68,0,0,0-5.01,6.324,14.79,14.79,0,0,0-1.248,2.874l-4.392,14.272c-1.571,5.2-1.1,9.641,1.413,13.209a17.074,17.074,0,0,0,5.757,4.968,31.282,31.282,0,0,0,6.924,2.758,43.379,43.379,0,0,0,8.265,1.44h53.5l3.635-11.853h-43.375c-4.075,0-6.946-1.023-8.535-3.041a7.225,7.225,0,0,1-1.212-5.656l.758-2.517h55.8l2.877-9.339c1.841-6.113,1.358-11.12-1.438-14.881-5.466-7.355-18.052-7.728-20.52-7.728-.223,0-.362,0-.4,0l0-.034Zm64.023-.294L-2332-8541.323h31.535l9.173-30.122a11.3,11.3,0,0,1,5.56-7.028c2.442-1.311,5.619-1.948,9.715-1.948.218-.008.44-.012.66-.012a19.034,19.034,0,0,1,12.49,4.648l13.549-19.7a35.282,35.282,0,0,0-12.616-2.325c-.471,0-.961.01-1.457.03a46.81,46.81,0,0,0-10.988,1.312,47.264,47.264,0,0,0-10.385,3.852l1.149-4.011h-31.566Zm-301.005.016h0l-16.819,55.291h31.551l17-55.291Zm-83.684,8.729v0l-.2,46.559h31.535l51.788-73.722h-34.525l-24.45,44.39.2-44.39h-31.156l-26.946,44.39,2.861-44.39H-2766l6.888,73.722h30.959l28.277-46.559Zm149.27,11.655v0l20.073,34.888h28.1l16.819-55.291h-28.13l-10.7,34.87-20.058-34.87h-28.1l-16.82,55.291h28.116l10.7-34.886Zm437.318-2.972-14.517,16.521,10.7,7.6,14.795-16.441,4.39,16.441,15.488-7.6-4.389-16.521h19.088l4.586-15.192h-19.2l14.533-16.442-10.7-7.613-14.714,16.442-4.389-16.442-15.472,7.613,4.389,16.442h-19.1l-4.59,15.192Zm-480.527-39.183c-9.542,0-18.548,3.873-20.076,8.634a4.319,4.319,0,0,0,.684,4c2.085,2.858,7.393,4.634,13.852,4.634,9.534,0,18.532-3.872,20.058-8.632a4.325,4.325,0,0,0-.683-4C-2582.059-8616.613-2587.36-8618.387-2593.812-8618.387Zm844.9-191.475h0l-38.2,125.149v.009l58.164-12.54,5.963-19.172h35.725c17.746,0,32.655-3.93,44.313-11.681,12.1-8.053,20.711-20.254,25.595-36.265,4.413-14.234,3.829-25.284-1.734-32.843-6.189-8.4-18.593-12.658-36.867-12.658h-92.954Zm-70.559-1.928c-.39,0-.633.006-.7.008h-41.292c-11.913,0-22.526,1.675-31.544,4.978a55.177,55.177,0,0,0-18.475,10.951,42.844,42.844,0,0,0-8.683,10.95,25.858,25.858,0,0,0-2.166,4.978l-7.5,24.733a31.4,31.4,0,0,0-1.368,13.16,21.861,21.861,0,0,0,3.809,9.8,29.472,29.472,0,0,0,9.9,8.563,53.719,53.719,0,0,0,11.89,4.755,74.365,74.365,0,0,0,14.182,2.484l11.715-.048h81.244l6.328-20.539h-75.279c-7.071,0-12.052-1.774-14.8-5.273a11.329,11.329,0,0,1-2.33-6.526,12.615,12.615,0,0,1,.233-3.268l1.338-4.362h96.807l4.795-16.143c3.2-10.595,2.364-19.273-2.479-25.794C-1793.327-8811.143-1815.183-8811.789-1819.468-8811.789Zm-174.307.008c-11.958,0-22.609,1.675-31.658,4.978a55.335,55.335,0,0,0-18.534,10.95,42.819,42.819,0,0,0-8.7,10.949,25.622,25.622,0,0,0-2.169,4.978l-7.5,24.735a31.364,31.364,0,0,0-1.3,13.146,21.989,21.989,0,0,0,3.85,9.793,29.7,29.7,0,0,0,9.943,8.574,54.01,54.01,0,0,0,11.918,4.76,74.423,74.423,0,0,0,14.2,2.487l11.715-.048h60.685l6.149-20.539h-54.541c-7.083,0-12.092-1.779-14.888-5.289a11.488,11.488,0,0,1-2.4-6.518,12.684,12.684,0,0,1,.19-3.261l1.34-4.362,6.144-19.911a21.009,21.009,0,0,1,5.54-9.185,23.255,23.255,0,0,1,7.5-4.755,28.884,28.884,0,0,1,9.433-2.056h58.769l5.949-19.428Zm385.242,1.85,10.18,24.586h18.818l-12.1,39.735c-2.73,8.961-2.383,15.576,1.06,20.225a15.677,15.677,0,0,0,4.454,3.988,26.5,26.5,0,0,0,6.517,2.761c4.972,1.428,11.278,2.122,19.279,2.122h39.937l14.986-26.666h-21.133c-5.457,0-8.509-.834-9.9-2.7-1.051-1.418-1.143-3.489-.281-6.334l10.178-33.129h33.045l7.484-24.586h-33.027l10.937-35.591-56.84,12.393-7.1,23.2h-36.5Zm-590.153-1.784h0l-28.81,93.319h55.883l28.427-93.319h-55.5Zm-270.215,12.59-7.305,23.939c-1.654,5.395-1.449,9.38.625,12.184,1.37,1.854,3.53,3.185,6.6,4.069a42.648,42.648,0,0,0,11.594,1.28h19.6l9.021-16.061c-.073,0-8.427-.017-12.674-.017-3.236,0-5.055-.493-5.9-1.6-.645-.848-.727-2.1-.249-3.835l6.146-19.961h19.779l4.807-14.8h-19.977l6.527-21.43-29.755,7.468-4.428,13.962h-13.83l-4.612,14.8Zm112.551-14.527c-.217,0-.353,0-.389,0h-23.813a53.227,53.227,0,0,0-18.213,2.866,31.882,31.882,0,0,0-10.667,6.3,24.673,24.673,0,0,0-5.014,6.3,15.065,15.065,0,0,0-1.251,2.866l-4.228,14.24c-1.585,5.2-1.121,9.647,1.379,13.211a16.9,16.9,0,0,0,5.695,4.924A30.915,30.915,0,0,0-2406-8760.2a42.993,42.993,0,0,0,8.17,1.423l6.908-.016h46.66l3.65-11.83h-43.4c-4.021,0-6.874-1.016-8.479-3.018a7.317,7.317,0,0,1-1.3-5.64l.76-2.512h55.9l2.677-9.3c1.85-6.1,1.376-11.091-1.407-14.843C-2341.32-8813.281-2353.886-8813.653-2356.35-8813.653Zm39.56-.275-16.723,55.135H-2302l9.019-30.039a11.814,11.814,0,0,1,5.666-7c2.436-1.307,5.61-1.942,9.7-1.942a20.981,20.981,0,0,1,7.627,1.327,21.027,21.027,0,0,1,5.622,3.282l13.252-19.609c-3.76-1.577-8.218-2.312-14.03-2.312a45.474,45.474,0,0,0-11.3,1.392,50.016,50.016,0,0,0-10.014,3.746l1.159-3.981h-31.492Zm-256.588-.007-16.7,55.137h27.841l10.758-34.772v0l19.973,34.771h28.039l16.9-55.137h-28.041l-10.561,34.777-20.163-34.776Zm-43.4,0h0l-16.71,55.137h31.5l16.707-55.137h-31.5Zm-83.348,8.709v0l-.388,46.424h31.5l51.659-73.5h-34.571l-24.2,44.181.2-44.181h-31.111l-26.889,44.181,2.879-44.181H-2766l6.718,73.5h30.923l28.232-46.424Zm601.1,19.731v0l3.271,12.422a5.69,5.69,0,0,0,5.8,4.081,10.114,10.114,0,0,0,4.373-1.09c4.64-2.262,7.479-7.257,6.328-11.135l-3.256-12.411h14.211a11.117,11.117,0,0,0,6.6-2.389,11.53,11.53,0,0,0,4.152-5.773,6.518,6.518,0,0,0-.742-5.882,6.044,6.044,0,0,0-5.026-2.264h-14.209l10.955-12.409a9.548,9.548,0,0,0,2.661-7.268,5.343,5.343,0,0,0-2.28-3.866,6.645,6.645,0,0,0-3.783-1.095,10.152,10.152,0,0,0-4.348,1.054,12.674,12.674,0,0,0-3.962,3.013l-10.958,12.427-3.256-12.427a5.677,5.677,0,0,0-5.8-4.066,10.168,10.168,0,0,0-4.395,1.095,12.725,12.725,0,0,0-5.344,4.94,8.441,8.441,0,0,0-1.181,6.193l3.453,12.409h-14.39a10.779,10.779,0,0,0-6.438,2.388,11.624,11.624,0,0,0-4.123,5.758,6.586,6.586,0,0,0,.741,5.947,5.812,5.812,0,0,0,4.829,2.215h14.39l-10.937,12.411a11.245,11.245,0,0,0-2.2,3.646,7.965,7.965,0,0,0-.463,3.623,5.328,5.328,0,0,0,2.287,3.866,6.086,6.086,0,0,0,3.626,1.09,11.609,11.609,0,0,0,8.27-4.081l11.135-12.423ZM-2187.36-8848l-11.325,36.285L-2135.7-8848Zm-407.146,12.375a33.494,33.494,0,0,0-12.937,2.526c-3.8,1.633-6.3,3.793-7.038,6.082a4.314,4.314,0,0,0,.687,3.989,10.5,10.5,0,0,0,5.154,3.34,26.809,26.809,0,0,0,8.566,1.279,33.533,33.533,0,0,0,13.012-2.52c3.746-1.62,6.22-3.782,6.965-6.089a4.337,4.337,0,0,0-.671-4.025C-2582.823-8833.87-2588.087-8835.626-2594.506-8835.626Zm613.443,276.865h0c-.861,0-1.72-.03-2.552-.091-8.531,0-16.364-.473-16.442-.478l13.365-43.075h18.562a44.825,44.825,0,0,1,11.009,1.121,19.126,19.126,0,0,1,4.765,1.861,11.648,11.648,0,0,1,3.613,3.14,11.518,11.518,0,0,1,2.131,6.051,24.733,24.733,0,0,1-1.262,9,35.576,35.576,0,0,1-13.189,16.348A35.634,35.634,0,0,1-1981.063-8558.761Zm434.829-.8h-43.617a21.611,21.611,0,0,1,19.729-15.7h12.987c6.921,0,11.259,1.584,12.895,4.707a6.927,6.927,0,0,1,.71,3.669,12.482,12.482,0,0,1-.8,3.562,18.906,18.906,0,0,1-1.9,3.763Zm-813.473-16.326H-2388.2a14.1,14.1,0,0,1,5.078-6.637,14.04,14.04,0,0,1,7.927-2.6h7.661c4.061,0,6.731.986,7.938,2.933a5.668,5.668,0,0,1,.574,4.169,9.366,9.366,0,0,1-.684,2.138h0Zm664.55-166.4h-19.968l13.442-43.736h19.8c5.724,0,9.1,1.1,10.955,3.577,2.495,3.33,2.316,9.215-.58,19.081C-1675.571-8750.011-1680.741-8742.282-1695.157-8742.282Zm-132.5-34.076h-49.153a20.988,20.988,0,0,1,5.529-9.185,23.2,23.2,0,0,1,7.493-4.754,28.86,28.86,0,0,1,9.43-2.055h13.068c7.121,0,11.791,1.719,13.88,5.109a8.379,8.379,0,0,1,1.177,3.676,12.458,12.458,0,0,1-.22,3.521,16.2,16.2,0,0,1-1.2,3.686h0Zm-533.317-16.884h-28.42a11.955,11.955,0,0,1,3.148-5.286,13.235,13.235,0,0,1,4.3-2.736,16.586,16.586,0,0,1,5.426-1.183h7.489c4.119,0,6.836,1,8.074,2.969a5.7,5.7,0,0,1,.627,4.127,8.922,8.922,0,0,1-.641,2.108Z" transform="translate(3006 9034)" /> </svg> <div class="content"> <p class="desc">Excellent control in snow</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 태블릿 --> <div class="svg_wrap t_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape555" d="M-8704-10492h-350v-560h350v560Zm-86.874-175.237-14.672,8.186-6.275,21h12.2l1.923-6.368,3.928-2.4h0v0l2.76,8.766h13.173l-5.1-14.694,11.119-6.321h-13.959l-2.93,1.8c-1.983,1.252-5.564,3.6-6.729,4.563.477-1.26,1.564-4.49,2.006-5.96Zm-30.644,0-2.516,8.172-6.269,21.016h12.257l6.229-21.016h-12.207l13.836-8.172Zm-37.955,6.469v0l-6.734,22.717h10.956l2.464-7.8h8.318c8.4,0,13.517-3.433,15.635-10.493h.022c.763-2.541.583-4.591-.533-6.091a7.746,7.746,0,0,0-4.462-2.6,25.618,25.618,0,0,0-6.3-.648h-11.033l2.633-1.554h-11.329l-2.519,8.172,2.877-1.7Zm-32.517-6.469-2.519,8.172-6.271,21.016h12.259l6.23-21.016h-12.2l13.833-8.172Zm132.083,8.186a20.258,20.258,0,0,0-6.945,1.1,12.076,12.076,0,0,0-4.057,2.412,8.237,8.237,0,0,0-2.372,3.507l-1.673,5.453a5.615,5.615,0,0,0,.555,5.056,8.284,8.284,0,0,0,4.808,2.933,16.262,16.262,0,0,0,3.124.546h22.323l1.337-4.529h-17.474c-1.484,0-2.478-.365-2.953-1.085a2.623,2.623,0,0,1-.1-2.237l.294-.96h21.579l1.046-3.559c.707-2.338.524-4.251-.542-5.687-2.083-2.807-6.887-2.949-7.829-2.949-.1,0-.155,0-.155,0l-.012,0Zm-193.878,2.807-1.589,5.39a3.049,3.049,0,0,0,.153,2.769c.6.806,1.866,1.181,3.984,1.181h4.316l1.964-3.622h-2.769c-.724,0-1.131-.108-1.319-.353a.979.979,0,0,1-.062-.871l1.337-4.493h4.391l1-3.322h-4.391l1.462-4.824-6.562,1.684-.918,3.141h-3.052l-1.043,3.322Zm19.4-3.256c-3.412,0-5.323,1.123-6.324,2.065a4.892,4.892,0,0,0-1.37,2.064l-.959,3.206a3.346,3.346,0,0,0,.334,3c1.275,1.8,4.423,2.013,4.556,2.021h11.7l.8-2.663h-9.488a2.249,2.249,0,0,1-1.853-.666,1.662,1.662,0,0,1-.278-1.286l.164-.563h12.207l.63-2.1a3.691,3.691,0,0,0-.343-3.379c-1.211-1.616-3.928-1.7-4.46-1.7h-.088v-.008Zm14-.066-3.681,12.417h6.9l2.009-6.762c.413-1.374,1.475-2.014,3.339-2.014l.151,0a4.082,4.082,0,0,1,2.726,1.043l2.965-4.424a7.532,7.532,0,0,0-2.748-.521c-.1,0-.215,0-.331.008a10.114,10.114,0,0,0-4.675,1.157l.251-.9Zm-65.845,0-3.681,12.412h6.9l3.717-12.412Zm-18.307,1.959v0l-.044,10.449h6.9l11.328-16.55h-7.55l-5.351,9.967.044-9.967h-6.814l-5.895,9.967.624-9.967H-9019l1.506,16.55h6.773l6.184-10.449Zm27.84-1.964-3.678,12.415h6.148l2.341-7.83v0l4.39,7.83h6.146l3.681-12.415h-6.155l-2.341,7.83-4.388-7.829Zm100.477,3.913-3.176,3.709,2.341,1.705,3.235-3.687.961,3.688,3.387-1.705-.959-3.709h4.177l1-3.411h-4.2l3.179-3.689-2.341-1.711-3.218,3.691-.962-3.691-3.384,1.711.959,3.689h-4.176l-1,3.411Zm-105.117-8.795c-2.085,0-4.055.87-4.391,1.938a.992.992,0,0,0,.162.913,3.85,3.85,0,0,0,3.017,1.023c2.087,0,4.055-.869,4.388-1.937a.991.991,0,0,0-.161-.916A3.841,3.841,0,0,0-8981.335-10664.449Zm184.824-42.989-8.356,28.1,12.723-2.812,1.3-4.3h7.816a16.907,16.907,0,0,0,9.693-2.621,14.486,14.486,0,0,0,5.6-8.144c.965-3.2.837-5.676-.38-7.372-1.354-1.887-4.066-2.843-8.063-2.843Zm-24.622-.431a19.661,19.661,0,0,0-6.9,1.117,12.013,12.013,0,0,0-4.04,2.459,8.555,8.555,0,0,0-2.373,3.575l-1.642,5.553a5.819,5.819,0,0,0,.578,5.219,8.29,8.29,0,0,0,4.756,2.937,16.019,16.019,0,0,0,3.068.549l2.564-.012h17.771l1.384-4.612h-16.468a3.9,3.9,0,0,1-3.217-1.155,2.884,2.884,0,0,1-.48-2.226l.294-.979h21.175l1.051-3.625c.71-2.413.512-4.383-.589-5.854-2.1-2.8-6.82-2.947-7.745-2.947-.1,0-.153,0-.153,0Zm-28.943,0a19.8,19.8,0,0,0-6.926,1.117,12.039,12.039,0,0,0-4.054,2.459,8.481,8.481,0,0,0-2.378,3.575l-1.643,5.553a5.833,5.833,0,0,0,.6,5.215,8.342,8.342,0,0,0,4.771,2.94,16.059,16.059,0,0,0,3.072.549l2.564-.012h13.272l1.348-4.612h-11.933a3.946,3.946,0,0,1-3.234-1.158,2.906,2.906,0,0,1-.507-2.223l.294-.979,1.345-4.472a4.757,4.757,0,0,1,2.853-3.128,6.182,6.182,0,0,1,2.063-.461h12.856l1.3-4.363Zm84.273.414,2.225,5.522h4.116l-2.644,8.92c-.605,2.037-.521,3.534.259,4.579.993,1.333,3.087,1.953,6.589,1.953h8.737l3.276-5.985h-4.621c-1.184,0-1.85-.184-2.158-.6a1.594,1.594,0,0,1-.069-1.435l2.228-7.436h7.228l1.637-5.522h-7.223l2.392-7.988-12.435,2.781-1.554,5.207Zm-126.619-8.546-2.479,8.146-6.3,20.953h12.227l6.216-20.952H-8894.9l13.78-8.146Zm-61.587,10.973-1.6,5.375a3.032,3.032,0,0,0,.153,2.759c.6.8,1.857,1.178,3.963,1.178h4.285l1.976-3.606-2.774,0c-.7,0-1.1-.108-1.285-.352a.983.983,0,0,1-.06-.868l1.345-4.482h4.327l1.052-3.323h-4.369l1.426-4.81-6.507,1.676-.971,3.134h-3.023l-1.01,3.323Zm19.327-3.259c-3.41,0-5.318,1.119-6.318,2.059a4.886,4.886,0,0,0-1.37,2.058l-.927,3.2a3.343,3.343,0,0,0,.328,3c1.258,1.783,4.371,1.994,4.5,2l1.512,0h10.207l.8-2.657h-9.494a2.253,2.253,0,0,1-1.843-.661,1.676,1.676,0,0,1-.3-1.28l.164-.565h12.229l.586-2.089a3.672,3.672,0,0,0-.335-3.367c-1.206-1.613-3.92-1.7-4.452-1.7h-5.293Zm-37.392,4.507v0l4.367,7.807h6.133l3.7-12.379h-6.133l-2.311,7.806-4.41-7.807h-6.136l-3.655,12.379h6.091l2.354-7.8Zm51.338-4.571-3.658,12.379h6.893l1.975-6.742c.46-1.39,1.5-2.009,3.361-2.009a4.355,4.355,0,0,1,2.9,1.035l2.9-4.4a7.634,7.634,0,0,0-3.07-.521,10.109,10.109,0,0,0-4.662,1.154l.255-.894Zm-65.623,0-3.652,12.379h6.89l3.655-12.379h-6.893Zm-18.231,1.953v0l-.083,10.422h6.89l11.3-16.5h-7.561l-5.295,9.918.044-9.918h-6.807l-5.883,9.918.63-9.918H-9019l1.471,16.5h6.762l6.175-10.422Zm131.492,4.433v0l.716,2.785a1.246,1.246,0,0,0,1.268.918,2.17,2.17,0,0,0,.957-.244,2.352,2.352,0,0,0,1.384-2.5l-.71-2.787h3.106a2.625,2.625,0,0,0,2.353-1.831,1.491,1.491,0,0,0-.173-1.337,1.311,1.311,0,0,0-1.087-.493h-3.109l2.4-2.785a2.172,2.172,0,0,0,.582-1.637,1.2,1.2,0,0,0-.5-.862,1.419,1.419,0,0,0-.827-.246,2.529,2.529,0,0,0-1.819.912l-2.4,2.79-.713-2.79a1.24,1.24,0,0,0-1.267-.912,2.167,2.167,0,0,0-.961.246,2.455,2.455,0,0,0-1.428,2.5l.754,2.785h-3.148a2.6,2.6,0,0,0-2.308,1.83,1.515,1.515,0,0,0,.172,1.349,1.26,1.26,0,0,0,1.046.482h3.148l-2.394,2.787a2.18,2.18,0,0,0-.583,1.64,1.208,1.208,0,0,0,.5.862,1.3,1.3,0,0,0,.791.243,2.519,2.519,0,0,0,1.811-.917l2.436-2.786Zm-108.387-11.256c-2.074,0-4.035.867-4.372,1.933a.989.989,0,0,0,.165.913,3.8,3.8,0,0,0,2.986,1.021c2.075,0,4.036-.867,4.371-1.934a.994.994,0,0,0-.159-.92A3.811,3.811,0,0,0-8981.484-10713.222Zm134.183,62.158c-.188,0-.374-.007-.553-.02-1.713,0-3.291-.09-3.59-.108h-.007l2.926-9.672h4.056c1.382,0,3.322.14,4.222,1.345a3.791,3.791,0,0,1,.213,3.412,7.951,7.951,0,0,1-2.888,3.671A7.676,7.676,0,0,1-8847.3-10651.063Zm95.125-.181h-9.54a4.759,4.759,0,0,1,4.315-3.525h2.84c1.5,0,2.445.349,2.811,1.038.546,1.026-.415,2.473-.425,2.487Zm-177.947-3.664h-6.232a3.078,3.078,0,0,1,2.846-2.074h1.675a1.913,1.913,0,0,1,1.728.645,1.672,1.672,0,0,1-.016,1.429Zm145.371-37.358h-4.368l2.939-9.819h4.33c1.254,0,1.993.248,2.4.8.547.748.508,2.068-.125,4.282C-8780.467-10694-8781.6-10692.267-8784.753-10692.267Zm-28.982-7.65h-10.753a4.75,4.75,0,0,1,2.85-3.128,6.182,6.182,0,0,1,2.063-.461h2.856c1.541,0,2.558.378,3.022,1.123a2.894,2.894,0,0,1-.038,2.465Zm-116.666-3.791h-6.216a3.064,3.064,0,0,1,2.814-2.066h1.64a1.957,1.957,0,0,1,1.757.651,1.642,1.642,0,0,1,0,1.414Z" transform="translate(9054 11012)" /> </defs> <clipPath id="clipPath555"> <use xlink:href="#polygonShape555"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath555);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/winter-icept/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-8704-10492h-350v-560h350v560Zm-86.874-175.237-14.672,8.186-6.275,21h12.2l1.923-6.368,3.928-2.4h0v0l2.76,8.766h13.173l-5.1-14.694,11.119-6.321h-13.959l-2.93,1.8c-1.983,1.252-5.564,3.6-6.729,4.563.477-1.26,1.564-4.49,2.006-5.96Zm-30.644,0-2.516,8.172-6.269,21.016h12.257l6.229-21.016h-12.207l13.836-8.172Zm-37.955,6.469v0l-6.734,22.717h10.956l2.464-7.8h8.318c8.4,0,13.517-3.433,15.635-10.493h.022c.763-2.541.583-4.591-.533-6.091a7.746,7.746,0,0,0-4.462-2.6,25.618,25.618,0,0,0-6.3-.648h-11.033l2.633-1.554h-11.329l-2.519,8.172,2.877-1.7Zm-32.517-6.469-2.519,8.172-6.271,21.016h12.259l6.23-21.016h-12.2l13.833-8.172Zm132.083,8.186a20.258,20.258,0,0,0-6.945,1.1,12.076,12.076,0,0,0-4.057,2.412,8.237,8.237,0,0,0-2.372,3.507l-1.673,5.453a5.615,5.615,0,0,0,.555,5.056,8.284,8.284,0,0,0,4.808,2.933,16.262,16.262,0,0,0,3.124.546h22.323l1.337-4.529h-17.474c-1.484,0-2.478-.365-2.953-1.085a2.623,2.623,0,0,1-.1-2.237l.294-.96h21.579l1.046-3.559c.707-2.338.524-4.251-.542-5.687-2.083-2.807-6.887-2.949-7.829-2.949-.1,0-.155,0-.155,0l-.012,0Zm-193.878,2.807-1.589,5.39a3.049,3.049,0,0,0,.153,2.769c.6.806,1.866,1.181,3.984,1.181h4.316l1.964-3.622h-2.769c-.724,0-1.131-.108-1.319-.353a.979.979,0,0,1-.062-.871l1.337-4.493h4.391l1-3.322h-4.391l1.462-4.824-6.562,1.684-.918,3.141h-3.052l-1.043,3.322Zm19.4-3.256c-3.412,0-5.323,1.123-6.324,2.065a4.892,4.892,0,0,0-1.37,2.064l-.959,3.206a3.346,3.346,0,0,0,.334,3c1.275,1.8,4.423,2.013,4.556,2.021h11.7l.8-2.663h-9.488a2.249,2.249,0,0,1-1.853-.666,1.662,1.662,0,0,1-.278-1.286l.164-.563h12.207l.63-2.1a3.691,3.691,0,0,0-.343-3.379c-1.211-1.616-3.928-1.7-4.46-1.7h-.088v-.008Zm14-.066-3.681,12.417h6.9l2.009-6.762c.413-1.374,1.475-2.014,3.339-2.014l.151,0a4.082,4.082,0,0,1,2.726,1.043l2.965-4.424a7.532,7.532,0,0,0-2.748-.521c-.1,0-.215,0-.331.008a10.114,10.114,0,0,0-4.675,1.157l.251-.9Zm-65.845,0-3.681,12.412h6.9l3.717-12.412Zm-18.307,1.959v0l-.044,10.449h6.9l11.328-16.55h-7.55l-5.351,9.967.044-9.967h-6.814l-5.895,9.967.624-9.967H-9019l1.506,16.55h6.773l6.184-10.449Zm27.84-1.964-3.678,12.415h6.148l2.341-7.83v0l4.39,7.83h6.146l3.681-12.415h-6.155l-2.341,7.83-4.388-7.829Zm100.477,3.913-3.176,3.709,2.341,1.705,3.235-3.687.961,3.688,3.387-1.705-.959-3.709h4.177l1-3.411h-4.2l3.179-3.689-2.341-1.711-3.218,3.691-.962-3.691-3.384,1.711.959,3.689h-4.176l-1,3.411Zm-105.117-8.795c-2.085,0-4.055.87-4.391,1.938a.992.992,0,0,0,.162.913,3.85,3.85,0,0,0,3.017,1.023c2.087,0,4.055-.869,4.388-1.937a.991.991,0,0,0-.161-.916A3.841,3.841,0,0,0-8981.335-10664.449Zm184.824-42.989-8.356,28.1,12.723-2.812,1.3-4.3h7.816a16.907,16.907,0,0,0,9.693-2.621,14.486,14.486,0,0,0,5.6-8.144c.965-3.2.837-5.676-.38-7.372-1.354-1.887-4.066-2.843-8.063-2.843Zm-24.622-.431a19.661,19.661,0,0,0-6.9,1.117,12.013,12.013,0,0,0-4.04,2.459,8.555,8.555,0,0,0-2.373,3.575l-1.642,5.553a5.819,5.819,0,0,0,.578,5.219,8.29,8.29,0,0,0,4.756,2.937,16.019,16.019,0,0,0,3.068.549l2.564-.012h17.771l1.384-4.612h-16.468a3.9,3.9,0,0,1-3.217-1.155,2.884,2.884,0,0,1-.48-2.226l.294-.979h21.175l1.051-3.625c.71-2.413.512-4.383-.589-5.854-2.1-2.8-6.82-2.947-7.745-2.947-.1,0-.153,0-.153,0Zm-28.943,0a19.8,19.8,0,0,0-6.926,1.117,12.039,12.039,0,0,0-4.054,2.459,8.481,8.481,0,0,0-2.378,3.575l-1.643,5.553a5.833,5.833,0,0,0,.6,5.215,8.342,8.342,0,0,0,4.771,2.94,16.059,16.059,0,0,0,3.072.549l2.564-.012h13.272l1.348-4.612h-11.933a3.946,3.946,0,0,1-3.234-1.158,2.906,2.906,0,0,1-.507-2.223l.294-.979,1.345-4.472a4.757,4.757,0,0,1,2.853-3.128,6.182,6.182,0,0,1,2.063-.461h12.856l1.3-4.363Zm84.273.414,2.225,5.522h4.116l-2.644,8.92c-.605,2.037-.521,3.534.259,4.579.993,1.333,3.087,1.953,6.589,1.953h8.737l3.276-5.985h-4.621c-1.184,0-1.85-.184-2.158-.6a1.594,1.594,0,0,1-.069-1.435l2.228-7.436h7.228l1.637-5.522h-7.223l2.392-7.988-12.435,2.781-1.554,5.207Zm-126.619-8.546-2.479,8.146-6.3,20.953h12.227l6.216-20.952H-8894.9l13.78-8.146Zm-61.587,10.973-1.6,5.375a3.032,3.032,0,0,0,.153,2.759c.6.8,1.857,1.178,3.963,1.178h4.285l1.976-3.606-2.774,0c-.7,0-1.1-.108-1.285-.352a.983.983,0,0,1-.06-.868l1.345-4.482h4.327l1.052-3.323h-4.369l1.426-4.81-6.507,1.676-.971,3.134h-3.023l-1.01,3.323Zm19.327-3.259c-3.41,0-5.318,1.119-6.318,2.059a4.886,4.886,0,0,0-1.37,2.058l-.927,3.2a3.343,3.343,0,0,0,.328,3c1.258,1.783,4.371,1.994,4.5,2l1.512,0h10.207l.8-2.657h-9.494a2.253,2.253,0,0,1-1.843-.661,1.676,1.676,0,0,1-.3-1.28l.164-.565h12.229l.586-2.089a3.672,3.672,0,0,0-.335-3.367c-1.206-1.613-3.92-1.7-4.452-1.7h-5.293Zm-37.392,4.507v0l4.367,7.807h6.133l3.7-12.379h-6.133l-2.311,7.806-4.41-7.807h-6.136l-3.655,12.379h6.091l2.354-7.8Zm51.338-4.571-3.658,12.379h6.893l1.975-6.742c.46-1.39,1.5-2.009,3.361-2.009a4.355,4.355,0,0,1,2.9,1.035l2.9-4.4a7.634,7.634,0,0,0-3.07-.521,10.109,10.109,0,0,0-4.662,1.154l.255-.894Zm-65.623,0-3.652,12.379h6.89l3.655-12.379h-6.893Zm-18.231,1.953v0l-.083,10.422h6.89l11.3-16.5h-7.561l-5.295,9.918.044-9.918h-6.807l-5.883,9.918.63-9.918H-9019l1.471,16.5h6.762l6.175-10.422Zm131.492,4.433v0l.716,2.785a1.246,1.246,0,0,0,1.268.918,2.17,2.17,0,0,0,.957-.244,2.352,2.352,0,0,0,1.384-2.5l-.71-2.787h3.106a2.625,2.625,0,0,0,2.353-1.831,1.491,1.491,0,0,0-.173-1.337,1.311,1.311,0,0,0-1.087-.493h-3.109l2.4-2.785a2.172,2.172,0,0,0,.582-1.637,1.2,1.2,0,0,0-.5-.862,1.419,1.419,0,0,0-.827-.246,2.529,2.529,0,0,0-1.819.912l-2.4,2.79-.713-2.79a1.24,1.24,0,0,0-1.267-.912,2.167,2.167,0,0,0-.961.246,2.455,2.455,0,0,0-1.428,2.5l.754,2.785h-3.148a2.6,2.6,0,0,0-2.308,1.83,1.515,1.515,0,0,0,.172,1.349,1.26,1.26,0,0,0,1.046.482h3.148l-2.394,2.787a2.18,2.18,0,0,0-.583,1.64,1.208,1.208,0,0,0,.5.862,1.3,1.3,0,0,0,.791.243,2.519,2.519,0,0,0,1.811-.917l2.436-2.786Zm-108.387-11.256c-2.074,0-4.035.867-4.372,1.933a.989.989,0,0,0,.165.913,3.8,3.8,0,0,0,2.986,1.021c2.075,0,4.036-.867,4.371-1.934a.994.994,0,0,0-.159-.92A3.811,3.811,0,0,0-8981.484-10713.222Zm134.183,62.158c-.188,0-.374-.007-.553-.02-1.713,0-3.291-.09-3.59-.108h-.007l2.926-9.672h4.056c1.382,0,3.322.14,4.222,1.345a3.791,3.791,0,0,1,.213,3.412,7.951,7.951,0,0,1-2.888,3.671A7.676,7.676,0,0,1-8847.3-10651.063Zm95.125-.181h-9.54a4.759,4.759,0,0,1,4.315-3.525h2.84c1.5,0,2.445.349,2.811,1.038.546,1.026-.415,2.473-.425,2.487Zm-177.947-3.664h-6.232a3.078,3.078,0,0,1,2.846-2.074h1.675a1.913,1.913,0,0,1,1.728.645,1.672,1.672,0,0,1-.016,1.429Zm145.371-37.358h-4.368l2.939-9.819h4.33c1.254,0,1.993.248,2.4.8.547.748.508,2.068-.125,4.282C-8780.467-10694-8781.6-10692.267-8784.753-10692.267Zm-28.982-7.65h-10.753a4.75,4.75,0,0,1,2.85-3.128,6.182,6.182,0,0,1,2.063-.461h2.856c1.541,0,2.558.378,3.022,1.123a2.894,2.894,0,0,1-.038,2.465Zm-116.666-3.791h-6.216a3.064,3.064,0,0,1,2.814-2.066h1.64a1.957,1.957,0,0,1,1.757.651,1.642,1.642,0,0,1,0,1.414Z" transform="translate(9054 11012)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-8704-10492h-350v-560h350v560Zm-86.874-175.237-14.672,8.186-6.275,21h12.2l1.923-6.368,3.928-2.4h0v0l2.76,8.766h13.173l-5.1-14.694,11.119-6.321h-13.959l-2.93,1.8c-1.983,1.252-5.564,3.6-6.729,4.563.477-1.26,1.564-4.49,2.006-5.96Zm-30.644,0-2.516,8.172-6.269,21.016h12.257l6.229-21.016h-12.207l13.836-8.172Zm-37.955,6.469v0l-6.734,22.717h10.956l2.464-7.8h8.318c8.4,0,13.517-3.433,15.635-10.493h.022c.763-2.541.583-4.591-.533-6.091a7.746,7.746,0,0,0-4.462-2.6,25.618,25.618,0,0,0-6.3-.648h-11.033l2.633-1.554h-11.329l-2.519,8.172,2.877-1.7Zm-32.517-6.469-2.519,8.172-6.271,21.016h12.259l6.23-21.016h-12.2l13.833-8.172Zm132.083,8.186a20.258,20.258,0,0,0-6.945,1.1,12.076,12.076,0,0,0-4.057,2.412,8.237,8.237,0,0,0-2.372,3.507l-1.673,5.453a5.615,5.615,0,0,0,.555,5.056,8.284,8.284,0,0,0,4.808,2.933,16.262,16.262,0,0,0,3.124.546h22.323l1.337-4.529h-17.474c-1.484,0-2.478-.365-2.953-1.085a2.623,2.623,0,0,1-.1-2.237l.294-.96h21.579l1.046-3.559c.707-2.338.524-4.251-.542-5.687-2.083-2.807-6.887-2.949-7.829-2.949-.1,0-.155,0-.155,0l-.012,0Zm-193.878,2.807-1.589,5.39a3.049,3.049,0,0,0,.153,2.769c.6.806,1.866,1.181,3.984,1.181h4.316l1.964-3.622h-2.769c-.724,0-1.131-.108-1.319-.353a.979.979,0,0,1-.062-.871l1.337-4.493h4.391l1-3.322h-4.391l1.462-4.824-6.562,1.684-.918,3.141h-3.052l-1.043,3.322Zm19.4-3.256c-3.412,0-5.323,1.123-6.324,2.065a4.892,4.892,0,0,0-1.37,2.064l-.959,3.206a3.346,3.346,0,0,0,.334,3c1.275,1.8,4.423,2.013,4.556,2.021h11.7l.8-2.663h-9.488a2.249,2.249,0,0,1-1.853-.666,1.662,1.662,0,0,1-.278-1.286l.164-.563h12.207l.63-2.1a3.691,3.691,0,0,0-.343-3.379c-1.211-1.616-3.928-1.7-4.46-1.7h-.088v-.008Zm14-.066-3.681,12.417h6.9l2.009-6.762c.413-1.374,1.475-2.014,3.339-2.014l.151,0a4.082,4.082,0,0,1,2.726,1.043l2.965-4.424a7.532,7.532,0,0,0-2.748-.521c-.1,0-.215,0-.331.008a10.114,10.114,0,0,0-4.675,1.157l.251-.9Zm-65.845,0-3.681,12.412h6.9l3.717-12.412Zm-18.307,1.959v0l-.044,10.449h6.9l11.328-16.55h-7.55l-5.351,9.967.044-9.967h-6.814l-5.895,9.967.624-9.967H-9019l1.506,16.55h6.773l6.184-10.449Zm27.84-1.964-3.678,12.415h6.148l2.341-7.83v0l4.39,7.83h6.146l3.681-12.415h-6.155l-2.341,7.83-4.388-7.829Zm100.477,3.913-3.176,3.709,2.341,1.705,3.235-3.687.961,3.688,3.387-1.705-.959-3.709h4.177l1-3.411h-4.2l3.179-3.689-2.341-1.711-3.218,3.691-.962-3.691-3.384,1.711.959,3.689h-4.176l-1,3.411Zm-105.117-8.795c-2.085,0-4.055.87-4.391,1.938a.992.992,0,0,0,.162.913,3.85,3.85,0,0,0,3.017,1.023c2.087,0,4.055-.869,4.388-1.937a.991.991,0,0,0-.161-.916A3.841,3.841,0,0,0-8981.335-10664.449Zm184.824-42.989-8.356,28.1,12.723-2.812,1.3-4.3h7.816a16.907,16.907,0,0,0,9.693-2.621,14.486,14.486,0,0,0,5.6-8.144c.965-3.2.837-5.676-.38-7.372-1.354-1.887-4.066-2.843-8.063-2.843Zm-24.622-.431a19.661,19.661,0,0,0-6.9,1.117,12.013,12.013,0,0,0-4.04,2.459,8.555,8.555,0,0,0-2.373,3.575l-1.642,5.553a5.819,5.819,0,0,0,.578,5.219,8.29,8.29,0,0,0,4.756,2.937,16.019,16.019,0,0,0,3.068.549l2.564-.012h17.771l1.384-4.612h-16.468a3.9,3.9,0,0,1-3.217-1.155,2.884,2.884,0,0,1-.48-2.226l.294-.979h21.175l1.051-3.625c.71-2.413.512-4.383-.589-5.854-2.1-2.8-6.82-2.947-7.745-2.947-.1,0-.153,0-.153,0Zm-28.943,0a19.8,19.8,0,0,0-6.926,1.117,12.039,12.039,0,0,0-4.054,2.459,8.481,8.481,0,0,0-2.378,3.575l-1.643,5.553a5.833,5.833,0,0,0,.6,5.215,8.342,8.342,0,0,0,4.771,2.94,16.059,16.059,0,0,0,3.072.549l2.564-.012h13.272l1.348-4.612h-11.933a3.946,3.946,0,0,1-3.234-1.158,2.906,2.906,0,0,1-.507-2.223l.294-.979,1.345-4.472a4.757,4.757,0,0,1,2.853-3.128,6.182,6.182,0,0,1,2.063-.461h12.856l1.3-4.363Zm84.273.414,2.225,5.522h4.116l-2.644,8.92c-.605,2.037-.521,3.534.259,4.579.993,1.333,3.087,1.953,6.589,1.953h8.737l3.276-5.985h-4.621c-1.184,0-1.85-.184-2.158-.6a1.594,1.594,0,0,1-.069-1.435l2.228-7.436h7.228l1.637-5.522h-7.223l2.392-7.988-12.435,2.781-1.554,5.207Zm-126.619-8.546-2.479,8.146-6.3,20.953h12.227l6.216-20.952H-8894.9l13.78-8.146Zm-61.587,10.973-1.6,5.375a3.032,3.032,0,0,0,.153,2.759c.6.8,1.857,1.178,3.963,1.178h4.285l1.976-3.606-2.774,0c-.7,0-1.1-.108-1.285-.352a.983.983,0,0,1-.06-.868l1.345-4.482h4.327l1.052-3.323h-4.369l1.426-4.81-6.507,1.676-.971,3.134h-3.023l-1.01,3.323Zm19.327-3.259c-3.41,0-5.318,1.119-6.318,2.059a4.886,4.886,0,0,0-1.37,2.058l-.927,3.2a3.343,3.343,0,0,0,.328,3c1.258,1.783,4.371,1.994,4.5,2l1.512,0h10.207l.8-2.657h-9.494a2.253,2.253,0,0,1-1.843-.661,1.676,1.676,0,0,1-.3-1.28l.164-.565h12.229l.586-2.089a3.672,3.672,0,0,0-.335-3.367c-1.206-1.613-3.92-1.7-4.452-1.7h-5.293Zm-37.392,4.507v0l4.367,7.807h6.133l3.7-12.379h-6.133l-2.311,7.806-4.41-7.807h-6.136l-3.655,12.379h6.091l2.354-7.8Zm51.338-4.571-3.658,12.379h6.893l1.975-6.742c.46-1.39,1.5-2.009,3.361-2.009a4.355,4.355,0,0,1,2.9,1.035l2.9-4.4a7.634,7.634,0,0,0-3.07-.521,10.109,10.109,0,0,0-4.662,1.154l.255-.894Zm-65.623,0-3.652,12.379h6.89l3.655-12.379h-6.893Zm-18.231,1.953v0l-.083,10.422h6.89l11.3-16.5h-7.561l-5.295,9.918.044-9.918h-6.807l-5.883,9.918.63-9.918H-9019l1.471,16.5h6.762l6.175-10.422Zm131.492,4.433v0l.716,2.785a1.246,1.246,0,0,0,1.268.918,2.17,2.17,0,0,0,.957-.244,2.352,2.352,0,0,0,1.384-2.5l-.71-2.787h3.106a2.625,2.625,0,0,0,2.353-1.831,1.491,1.491,0,0,0-.173-1.337,1.311,1.311,0,0,0-1.087-.493h-3.109l2.4-2.785a2.172,2.172,0,0,0,.582-1.637,1.2,1.2,0,0,0-.5-.862,1.419,1.419,0,0,0-.827-.246,2.529,2.529,0,0,0-1.819.912l-2.4,2.79-.713-2.79a1.24,1.24,0,0,0-1.267-.912,2.167,2.167,0,0,0-.961.246,2.455,2.455,0,0,0-1.428,2.5l.754,2.785h-3.148a2.6,2.6,0,0,0-2.308,1.83,1.515,1.515,0,0,0,.172,1.349,1.26,1.26,0,0,0,1.046.482h3.148l-2.394,2.787a2.18,2.18,0,0,0-.583,1.64,1.208,1.208,0,0,0,.5.862,1.3,1.3,0,0,0,.791.243,2.519,2.519,0,0,0,1.811-.917l2.436-2.786Zm-108.387-11.256c-2.074,0-4.035.867-4.372,1.933a.989.989,0,0,0,.165.913,3.8,3.8,0,0,0,2.986,1.021c2.075,0,4.036-.867,4.371-1.934a.994.994,0,0,0-.159-.92A3.811,3.811,0,0,0-8981.484-10713.222Zm134.183,62.158c-.188,0-.374-.007-.553-.02-1.713,0-3.291-.09-3.59-.108h-.007l2.926-9.672h4.056c1.382,0,3.322.14,4.222,1.345a3.791,3.791,0,0,1,.213,3.412,7.951,7.951,0,0,1-2.888,3.671A7.676,7.676,0,0,1-8847.3-10651.063Zm95.125-.181h-9.54a4.759,4.759,0,0,1,4.315-3.525h2.84c1.5,0,2.445.349,2.811,1.038.546,1.026-.415,2.473-.425,2.487Zm-177.947-3.664h-6.232a3.078,3.078,0,0,1,2.846-2.074h1.675a1.913,1.913,0,0,1,1.728.645,1.672,1.672,0,0,1-.016,1.429Zm145.371-37.358h-4.368l2.939-9.819h4.33c1.254,0,1.993.248,2.4.8.547.748.508,2.068-.125,4.282C-8780.467-10694-8781.6-10692.267-8784.753-10692.267Zm-28.982-7.65h-10.753a4.75,4.75,0,0,1,2.85-3.128,6.182,6.182,0,0,1,2.063-.461h2.856c1.541,0,2.558.378,3.022,1.123a2.894,2.894,0,0,1-.038,2.465Zm-116.666-3.791h-6.216a3.064,3.064,0,0,1,2.814-2.066h1.64a1.957,1.957,0,0,1,1.757.651,1.642,1.642,0,0,1,0,1.414Z" transform="translate(9054 11012)" /> </svg> <div class="content"> <p class="desc">Excellent control in snow</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 모바일 --> <div class="svg_wrap m_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape555-m" d="M-8704-10492h-350v-560h350v560Zm-86.874-175.237-14.672,8.186-6.275,21h12.2l1.923-6.368,3.928-2.4h0v0l2.76,8.766h13.173l-5.1-14.694,11.119-6.321h-13.959l-2.93,1.8c-1.983,1.252-5.564,3.6-6.729,4.563.477-1.26,1.564-4.49,2.006-5.96Zm-30.644,0-2.516,8.172-6.269,21.016h12.257l6.229-21.016h-12.207l13.836-8.172Zm-37.955,6.469v0l-6.734,22.717h10.956l2.464-7.8h8.318c8.4,0,13.517-3.433,15.635-10.493h.022c.763-2.541.583-4.591-.533-6.091a7.746,7.746,0,0,0-4.462-2.6,25.618,25.618,0,0,0-6.3-.648h-11.033l2.633-1.554h-11.329l-2.519,8.172,2.877-1.7Zm-32.517-6.469-2.519,8.172-6.271,21.016h12.259l6.23-21.016h-12.2l13.833-8.172Zm132.083,8.186a20.258,20.258,0,0,0-6.945,1.1,12.076,12.076,0,0,0-4.057,2.412,8.237,8.237,0,0,0-2.372,3.507l-1.673,5.453a5.615,5.615,0,0,0,.555,5.056,8.284,8.284,0,0,0,4.808,2.933,16.262,16.262,0,0,0,3.124.546h22.323l1.337-4.529h-17.474c-1.484,0-2.478-.365-2.953-1.085a2.623,2.623,0,0,1-.1-2.237l.294-.96h21.579l1.046-3.559c.707-2.338.524-4.251-.542-5.687-2.083-2.807-6.887-2.949-7.829-2.949-.1,0-.155,0-.155,0l-.012,0Zm-193.878,2.807-1.589,5.39a3.049,3.049,0,0,0,.153,2.769c.6.806,1.866,1.181,3.984,1.181h4.316l1.964-3.622h-2.769c-.724,0-1.131-.108-1.319-.353a.979.979,0,0,1-.062-.871l1.337-4.493h4.391l1-3.322h-4.391l1.462-4.824-6.562,1.684-.918,3.141h-3.052l-1.043,3.322Zm19.4-3.256c-3.412,0-5.323,1.123-6.324,2.065a4.892,4.892,0,0,0-1.37,2.064l-.959,3.206a3.346,3.346,0,0,0,.334,3c1.275,1.8,4.423,2.013,4.556,2.021h11.7l.8-2.663h-9.488a2.249,2.249,0,0,1-1.853-.666,1.662,1.662,0,0,1-.278-1.286l.164-.563h12.207l.63-2.1a3.691,3.691,0,0,0-.343-3.379c-1.211-1.616-3.928-1.7-4.46-1.7h-.088v-.008Zm14-.066-3.681,12.417h6.9l2.009-6.762c.413-1.374,1.475-2.014,3.339-2.014l.151,0a4.082,4.082,0,0,1,2.726,1.043l2.965-4.424a7.532,7.532,0,0,0-2.748-.521c-.1,0-.215,0-.331.008a10.114,10.114,0,0,0-4.675,1.157l.251-.9Zm-65.845,0-3.681,12.412h6.9l3.717-12.412Zm-18.307,1.959v0l-.044,10.449h6.9l11.328-16.55h-7.55l-5.351,9.967.044-9.967h-6.814l-5.895,9.967.624-9.967H-9019l1.506,16.55h6.773l6.184-10.449Zm27.84-1.964-3.678,12.415h6.148l2.341-7.83v0l4.39,7.83h6.146l3.681-12.415h-6.155l-2.341,7.83-4.388-7.829Zm100.477,3.913-3.176,3.709,2.341,1.705,3.235-3.687.961,3.688,3.387-1.705-.959-3.709h4.177l1-3.411h-4.2l3.179-3.689-2.341-1.711-3.218,3.691-.962-3.691-3.384,1.711.959,3.689h-4.176l-1,3.411Zm-105.117-8.795c-2.085,0-4.055.87-4.391,1.938a.992.992,0,0,0,.162.913,3.85,3.85,0,0,0,3.017,1.023c2.087,0,4.055-.869,4.388-1.937a.991.991,0,0,0-.161-.916A3.841,3.841,0,0,0-8981.335-10664.449Zm184.824-42.989-8.356,28.1,12.723-2.812,1.3-4.3h7.816a16.907,16.907,0,0,0,9.693-2.621,14.486,14.486,0,0,0,5.6-8.144c.965-3.2.837-5.676-.38-7.372-1.354-1.887-4.066-2.843-8.063-2.843Zm-24.622-.431a19.661,19.661,0,0,0-6.9,1.117,12.013,12.013,0,0,0-4.04,2.459,8.555,8.555,0,0,0-2.373,3.575l-1.642,5.553a5.819,5.819,0,0,0,.578,5.219,8.29,8.29,0,0,0,4.756,2.937,16.019,16.019,0,0,0,3.068.549l2.564-.012h17.771l1.384-4.612h-16.468a3.9,3.9,0,0,1-3.217-1.155,2.884,2.884,0,0,1-.48-2.226l.294-.979h21.175l1.051-3.625c.71-2.413.512-4.383-.589-5.854-2.1-2.8-6.82-2.947-7.745-2.947-.1,0-.153,0-.153,0Zm-28.943,0a19.8,19.8,0,0,0-6.926,1.117,12.039,12.039,0,0,0-4.054,2.459,8.481,8.481,0,0,0-2.378,3.575l-1.643,5.553a5.833,5.833,0,0,0,.6,5.215,8.342,8.342,0,0,0,4.771,2.94,16.059,16.059,0,0,0,3.072.549l2.564-.012h13.272l1.348-4.612h-11.933a3.946,3.946,0,0,1-3.234-1.158,2.906,2.906,0,0,1-.507-2.223l.294-.979,1.345-4.472a4.757,4.757,0,0,1,2.853-3.128,6.182,6.182,0,0,1,2.063-.461h12.856l1.3-4.363Zm84.273.414,2.225,5.522h4.116l-2.644,8.92c-.605,2.037-.521,3.534.259,4.579.993,1.333,3.087,1.953,6.589,1.953h8.737l3.276-5.985h-4.621c-1.184,0-1.85-.184-2.158-.6a1.594,1.594,0,0,1-.069-1.435l2.228-7.436h7.228l1.637-5.522h-7.223l2.392-7.988-12.435,2.781-1.554,5.207Zm-126.619-8.546-2.479,8.146-6.3,20.953h12.227l6.216-20.952H-8894.9l13.78-8.146Zm-61.587,10.973-1.6,5.375a3.032,3.032,0,0,0,.153,2.759c.6.8,1.857,1.178,3.963,1.178h4.285l1.976-3.606-2.774,0c-.7,0-1.1-.108-1.285-.352a.983.983,0,0,1-.06-.868l1.345-4.482h4.327l1.052-3.323h-4.369l1.426-4.81-6.507,1.676-.971,3.134h-3.023l-1.01,3.323Zm19.327-3.259c-3.41,0-5.318,1.119-6.318,2.059a4.886,4.886,0,0,0-1.37,2.058l-.927,3.2a3.343,3.343,0,0,0,.328,3c1.258,1.783,4.371,1.994,4.5,2l1.512,0h10.207l.8-2.657h-9.494a2.253,2.253,0,0,1-1.843-.661,1.676,1.676,0,0,1-.3-1.28l.164-.565h12.229l.586-2.089a3.672,3.672,0,0,0-.335-3.367c-1.206-1.613-3.92-1.7-4.452-1.7h-5.293Zm-37.392,4.507v0l4.367,7.807h6.133l3.7-12.379h-6.133l-2.311,7.806-4.41-7.807h-6.136l-3.655,12.379h6.091l2.354-7.8Zm51.338-4.571-3.658,12.379h6.893l1.975-6.742c.46-1.39,1.5-2.009,3.361-2.009a4.355,4.355,0,0,1,2.9,1.035l2.9-4.4a7.634,7.634,0,0,0-3.07-.521,10.109,10.109,0,0,0-4.662,1.154l.255-.894Zm-65.623,0-3.652,12.379h6.89l3.655-12.379h-6.893Zm-18.231,1.953v0l-.083,10.422h6.89l11.3-16.5h-7.561l-5.295,9.918.044-9.918h-6.807l-5.883,9.918.63-9.918H-9019l1.471,16.5h6.762l6.175-10.422Zm131.492,4.433v0l.716,2.785a1.246,1.246,0,0,0,1.268.918,2.17,2.17,0,0,0,.957-.244,2.352,2.352,0,0,0,1.384-2.5l-.71-2.787h3.106a2.625,2.625,0,0,0,2.353-1.831,1.491,1.491,0,0,0-.173-1.337,1.311,1.311,0,0,0-1.087-.493h-3.109l2.4-2.785a2.172,2.172,0,0,0,.582-1.637,1.2,1.2,0,0,0-.5-.862,1.419,1.419,0,0,0-.827-.246,2.529,2.529,0,0,0-1.819.912l-2.4,2.79-.713-2.79a1.24,1.24,0,0,0-1.267-.912,2.167,2.167,0,0,0-.961.246,2.455,2.455,0,0,0-1.428,2.5l.754,2.785h-3.148a2.6,2.6,0,0,0-2.308,1.83,1.515,1.515,0,0,0,.172,1.349,1.26,1.26,0,0,0,1.046.482h3.148l-2.394,2.787a2.18,2.18,0,0,0-.583,1.64,1.208,1.208,0,0,0,.5.862,1.3,1.3,0,0,0,.791.243,2.519,2.519,0,0,0,1.811-.917l2.436-2.786Zm-108.387-11.256c-2.074,0-4.035.867-4.372,1.933a.989.989,0,0,0,.165.913,3.8,3.8,0,0,0,2.986,1.021c2.075,0,4.036-.867,4.371-1.934a.994.994,0,0,0-.159-.92A3.811,3.811,0,0,0-8981.484-10713.222Zm134.183,62.158c-.188,0-.374-.007-.553-.02-1.713,0-3.291-.09-3.59-.108h-.007l2.926-9.672h4.056c1.382,0,3.322.14,4.222,1.345a3.791,3.791,0,0,1,.213,3.412,7.951,7.951,0,0,1-2.888,3.671A7.676,7.676,0,0,1-8847.3-10651.063Zm95.125-.181h-9.54a4.759,4.759,0,0,1,4.315-3.525h2.84c1.5,0,2.445.349,2.811,1.038.546,1.026-.415,2.473-.425,2.487Zm-177.947-3.664h-6.232a3.078,3.078,0,0,1,2.846-2.074h1.675a1.913,1.913,0,0,1,1.728.645,1.672,1.672,0,0,1-.016,1.429Zm145.371-37.358h-4.368l2.939-9.819h4.33c1.254,0,1.993.248,2.4.8.547.748.508,2.068-.125,4.282C-8780.467-10694-8781.6-10692.267-8784.753-10692.267Zm-28.982-7.65h-10.753a4.75,4.75,0,0,1,2.85-3.128,6.182,6.182,0,0,1,2.063-.461h2.856c1.541,0,2.558.378,3.022,1.123a2.894,2.894,0,0,1-.038,2.465Zm-116.666-3.791h-6.216a3.064,3.064,0,0,1,2.814-2.066h1.64a1.957,1.957,0,0,1,1.757.651,1.642,1.642,0,0,1,0,1.414Z" transform="translate(9054 11052)" /> </defs> <clipPath id="clipPath555-m"> <use xlink:href="#polygonShape555-m"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath555-m);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/winter-icept/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-8704-10492h-350v-560h350v560Zm-86.874-175.237-14.672,8.186-6.275,21h12.2l1.923-6.368,3.928-2.4h0v0l2.76,8.766h13.173l-5.1-14.694,11.119-6.321h-13.959l-2.93,1.8c-1.983,1.252-5.564,3.6-6.729,4.563.477-1.26,1.564-4.49,2.006-5.96Zm-30.644,0-2.516,8.172-6.269,21.016h12.257l6.229-21.016h-12.207l13.836-8.172Zm-37.955,6.469v0l-6.734,22.717h10.956l2.464-7.8h8.318c8.4,0,13.517-3.433,15.635-10.493h.022c.763-2.541.583-4.591-.533-6.091a7.746,7.746,0,0,0-4.462-2.6,25.618,25.618,0,0,0-6.3-.648h-11.033l2.633-1.554h-11.329l-2.519,8.172,2.877-1.7Zm-32.517-6.469-2.519,8.172-6.271,21.016h12.259l6.23-21.016h-12.2l13.833-8.172Zm132.083,8.186a20.258,20.258,0,0,0-6.945,1.1,12.076,12.076,0,0,0-4.057,2.412,8.237,8.237,0,0,0-2.372,3.507l-1.673,5.453a5.615,5.615,0,0,0,.555,5.056,8.284,8.284,0,0,0,4.808,2.933,16.262,16.262,0,0,0,3.124.546h22.323l1.337-4.529h-17.474c-1.484,0-2.478-.365-2.953-1.085a2.623,2.623,0,0,1-.1-2.237l.294-.96h21.579l1.046-3.559c.707-2.338.524-4.251-.542-5.687-2.083-2.807-6.887-2.949-7.829-2.949-.1,0-.155,0-.155,0l-.012,0Zm-193.878,2.807-1.589,5.39a3.049,3.049,0,0,0,.153,2.769c.6.806,1.866,1.181,3.984,1.181h4.316l1.964-3.622h-2.769c-.724,0-1.131-.108-1.319-.353a.979.979,0,0,1-.062-.871l1.337-4.493h4.391l1-3.322h-4.391l1.462-4.824-6.562,1.684-.918,3.141h-3.052l-1.043,3.322Zm19.4-3.256c-3.412,0-5.323,1.123-6.324,2.065a4.892,4.892,0,0,0-1.37,2.064l-.959,3.206a3.346,3.346,0,0,0,.334,3c1.275,1.8,4.423,2.013,4.556,2.021h11.7l.8-2.663h-9.488a2.249,2.249,0,0,1-1.853-.666,1.662,1.662,0,0,1-.278-1.286l.164-.563h12.207l.63-2.1a3.691,3.691,0,0,0-.343-3.379c-1.211-1.616-3.928-1.7-4.46-1.7h-.088v-.008Zm14-.066-3.681,12.417h6.9l2.009-6.762c.413-1.374,1.475-2.014,3.339-2.014l.151,0a4.082,4.082,0,0,1,2.726,1.043l2.965-4.424a7.532,7.532,0,0,0-2.748-.521c-.1,0-.215,0-.331.008a10.114,10.114,0,0,0-4.675,1.157l.251-.9Zm-65.845,0-3.681,12.412h6.9l3.717-12.412Zm-18.307,1.959v0l-.044,10.449h6.9l11.328-16.55h-7.55l-5.351,9.967.044-9.967h-6.814l-5.895,9.967.624-9.967H-9019l1.506,16.55h6.773l6.184-10.449Zm27.84-1.964-3.678,12.415h6.148l2.341-7.83v0l4.39,7.83h6.146l3.681-12.415h-6.155l-2.341,7.83-4.388-7.829Zm100.477,3.913-3.176,3.709,2.341,1.705,3.235-3.687.961,3.688,3.387-1.705-.959-3.709h4.177l1-3.411h-4.2l3.179-3.689-2.341-1.711-3.218,3.691-.962-3.691-3.384,1.711.959,3.689h-4.176l-1,3.411Zm-105.117-8.795c-2.085,0-4.055.87-4.391,1.938a.992.992,0,0,0,.162.913,3.85,3.85,0,0,0,3.017,1.023c2.087,0,4.055-.869,4.388-1.937a.991.991,0,0,0-.161-.916A3.841,3.841,0,0,0-8981.335-10664.449Zm184.824-42.989-8.356,28.1,12.723-2.812,1.3-4.3h7.816a16.907,16.907,0,0,0,9.693-2.621,14.486,14.486,0,0,0,5.6-8.144c.965-3.2.837-5.676-.38-7.372-1.354-1.887-4.066-2.843-8.063-2.843Zm-24.622-.431a19.661,19.661,0,0,0-6.9,1.117,12.013,12.013,0,0,0-4.04,2.459,8.555,8.555,0,0,0-2.373,3.575l-1.642,5.553a5.819,5.819,0,0,0,.578,5.219,8.29,8.29,0,0,0,4.756,2.937,16.019,16.019,0,0,0,3.068.549l2.564-.012h17.771l1.384-4.612h-16.468a3.9,3.9,0,0,1-3.217-1.155,2.884,2.884,0,0,1-.48-2.226l.294-.979h21.175l1.051-3.625c.71-2.413.512-4.383-.589-5.854-2.1-2.8-6.82-2.947-7.745-2.947-.1,0-.153,0-.153,0Zm-28.943,0a19.8,19.8,0,0,0-6.926,1.117,12.039,12.039,0,0,0-4.054,2.459,8.481,8.481,0,0,0-2.378,3.575l-1.643,5.553a5.833,5.833,0,0,0,.6,5.215,8.342,8.342,0,0,0,4.771,2.94,16.059,16.059,0,0,0,3.072.549l2.564-.012h13.272l1.348-4.612h-11.933a3.946,3.946,0,0,1-3.234-1.158,2.906,2.906,0,0,1-.507-2.223l.294-.979,1.345-4.472a4.757,4.757,0,0,1,2.853-3.128,6.182,6.182,0,0,1,2.063-.461h12.856l1.3-4.363Zm84.273.414,2.225,5.522h4.116l-2.644,8.92c-.605,2.037-.521,3.534.259,4.579.993,1.333,3.087,1.953,6.589,1.953h8.737l3.276-5.985h-4.621c-1.184,0-1.85-.184-2.158-.6a1.594,1.594,0,0,1-.069-1.435l2.228-7.436h7.228l1.637-5.522h-7.223l2.392-7.988-12.435,2.781-1.554,5.207Zm-126.619-8.546-2.479,8.146-6.3,20.953h12.227l6.216-20.952H-8894.9l13.78-8.146Zm-61.587,10.973-1.6,5.375a3.032,3.032,0,0,0,.153,2.759c.6.8,1.857,1.178,3.963,1.178h4.285l1.976-3.606-2.774,0c-.7,0-1.1-.108-1.285-.352a.983.983,0,0,1-.06-.868l1.345-4.482h4.327l1.052-3.323h-4.369l1.426-4.81-6.507,1.676-.971,3.134h-3.023l-1.01,3.323Zm19.327-3.259c-3.41,0-5.318,1.119-6.318,2.059a4.886,4.886,0,0,0-1.37,2.058l-.927,3.2a3.343,3.343,0,0,0,.328,3c1.258,1.783,4.371,1.994,4.5,2l1.512,0h10.207l.8-2.657h-9.494a2.253,2.253,0,0,1-1.843-.661,1.676,1.676,0,0,1-.3-1.28l.164-.565h12.229l.586-2.089a3.672,3.672,0,0,0-.335-3.367c-1.206-1.613-3.92-1.7-4.452-1.7h-5.293Zm-37.392,4.507v0l4.367,7.807h6.133l3.7-12.379h-6.133l-2.311,7.806-4.41-7.807h-6.136l-3.655,12.379h6.091l2.354-7.8Zm51.338-4.571-3.658,12.379h6.893l1.975-6.742c.46-1.39,1.5-2.009,3.361-2.009a4.355,4.355,0,0,1,2.9,1.035l2.9-4.4a7.634,7.634,0,0,0-3.07-.521,10.109,10.109,0,0,0-4.662,1.154l.255-.894Zm-65.623,0-3.652,12.379h6.89l3.655-12.379h-6.893Zm-18.231,1.953v0l-.083,10.422h6.89l11.3-16.5h-7.561l-5.295,9.918.044-9.918h-6.807l-5.883,9.918.63-9.918H-9019l1.471,16.5h6.762l6.175-10.422Zm131.492,4.433v0l.716,2.785a1.246,1.246,0,0,0,1.268.918,2.17,2.17,0,0,0,.957-.244,2.352,2.352,0,0,0,1.384-2.5l-.71-2.787h3.106a2.625,2.625,0,0,0,2.353-1.831,1.491,1.491,0,0,0-.173-1.337,1.311,1.311,0,0,0-1.087-.493h-3.109l2.4-2.785a2.172,2.172,0,0,0,.582-1.637,1.2,1.2,0,0,0-.5-.862,1.419,1.419,0,0,0-.827-.246,2.529,2.529,0,0,0-1.819.912l-2.4,2.79-.713-2.79a1.24,1.24,0,0,0-1.267-.912,2.167,2.167,0,0,0-.961.246,2.455,2.455,0,0,0-1.428,2.5l.754,2.785h-3.148a2.6,2.6,0,0,0-2.308,1.83,1.515,1.515,0,0,0,.172,1.349,1.26,1.26,0,0,0,1.046.482h3.148l-2.394,2.787a2.18,2.18,0,0,0-.583,1.64,1.208,1.208,0,0,0,.5.862,1.3,1.3,0,0,0,.791.243,2.519,2.519,0,0,0,1.811-.917l2.436-2.786Zm-108.387-11.256c-2.074,0-4.035.867-4.372,1.933a.989.989,0,0,0,.165.913,3.8,3.8,0,0,0,2.986,1.021c2.075,0,4.036-.867,4.371-1.934a.994.994,0,0,0-.159-.92A3.811,3.811,0,0,0-8981.484-10713.222Zm134.183,62.158c-.188,0-.374-.007-.553-.02-1.713,0-3.291-.09-3.59-.108h-.007l2.926-9.672h4.056c1.382,0,3.322.14,4.222,1.345a3.791,3.791,0,0,1,.213,3.412,7.951,7.951,0,0,1-2.888,3.671A7.676,7.676,0,0,1-8847.3-10651.063Zm95.125-.181h-9.54a4.759,4.759,0,0,1,4.315-3.525h2.84c1.5,0,2.445.349,2.811,1.038.546,1.026-.415,2.473-.425,2.487Zm-177.947-3.664h-6.232a3.078,3.078,0,0,1,2.846-2.074h1.675a1.913,1.913,0,0,1,1.728.645,1.672,1.672,0,0,1-.016,1.429Zm145.371-37.358h-4.368l2.939-9.819h4.33c1.254,0,1.993.248,2.4.8.547.748.508,2.068-.125,4.282C-8780.467-10694-8781.6-10692.267-8784.753-10692.267Zm-28.982-7.65h-10.753a4.75,4.75,0,0,1,2.85-3.128,6.182,6.182,0,0,1,2.063-.461h2.856c1.541,0,2.558.378,3.022,1.123a2.894,2.894,0,0,1-.038,2.465Zm-116.666-3.791h-6.216a3.064,3.064,0,0,1,2.814-2.066h1.64a1.957,1.957,0,0,1,1.757.651,1.642,1.642,0,0,1,0,1.414Z" transform="translate(9054 11052)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-8704-10492h-350v-560h350v560Zm-86.874-175.237-14.672,8.186-6.275,21h12.2l1.923-6.368,3.928-2.4h0v0l2.76,8.766h13.173l-5.1-14.694,11.119-6.321h-13.959l-2.93,1.8c-1.983,1.252-5.564,3.6-6.729,4.563.477-1.26,1.564-4.49,2.006-5.96Zm-30.644,0-2.516,8.172-6.269,21.016h12.257l6.229-21.016h-12.207l13.836-8.172Zm-37.955,6.469v0l-6.734,22.717h10.956l2.464-7.8h8.318c8.4,0,13.517-3.433,15.635-10.493h.022c.763-2.541.583-4.591-.533-6.091a7.746,7.746,0,0,0-4.462-2.6,25.618,25.618,0,0,0-6.3-.648h-11.033l2.633-1.554h-11.329l-2.519,8.172,2.877-1.7Zm-32.517-6.469-2.519,8.172-6.271,21.016h12.259l6.23-21.016h-12.2l13.833-8.172Zm132.083,8.186a20.258,20.258,0,0,0-6.945,1.1,12.076,12.076,0,0,0-4.057,2.412,8.237,8.237,0,0,0-2.372,3.507l-1.673,5.453a5.615,5.615,0,0,0,.555,5.056,8.284,8.284,0,0,0,4.808,2.933,16.262,16.262,0,0,0,3.124.546h22.323l1.337-4.529h-17.474c-1.484,0-2.478-.365-2.953-1.085a2.623,2.623,0,0,1-.1-2.237l.294-.96h21.579l1.046-3.559c.707-2.338.524-4.251-.542-5.687-2.083-2.807-6.887-2.949-7.829-2.949-.1,0-.155,0-.155,0l-.012,0Zm-193.878,2.807-1.589,5.39a3.049,3.049,0,0,0,.153,2.769c.6.806,1.866,1.181,3.984,1.181h4.316l1.964-3.622h-2.769c-.724,0-1.131-.108-1.319-.353a.979.979,0,0,1-.062-.871l1.337-4.493h4.391l1-3.322h-4.391l1.462-4.824-6.562,1.684-.918,3.141h-3.052l-1.043,3.322Zm19.4-3.256c-3.412,0-5.323,1.123-6.324,2.065a4.892,4.892,0,0,0-1.37,2.064l-.959,3.206a3.346,3.346,0,0,0,.334,3c1.275,1.8,4.423,2.013,4.556,2.021h11.7l.8-2.663h-9.488a2.249,2.249,0,0,1-1.853-.666,1.662,1.662,0,0,1-.278-1.286l.164-.563h12.207l.63-2.1a3.691,3.691,0,0,0-.343-3.379c-1.211-1.616-3.928-1.7-4.46-1.7h-.088v-.008Zm14-.066-3.681,12.417h6.9l2.009-6.762c.413-1.374,1.475-2.014,3.339-2.014l.151,0a4.082,4.082,0,0,1,2.726,1.043l2.965-4.424a7.532,7.532,0,0,0-2.748-.521c-.1,0-.215,0-.331.008a10.114,10.114,0,0,0-4.675,1.157l.251-.9Zm-65.845,0-3.681,12.412h6.9l3.717-12.412Zm-18.307,1.959v0l-.044,10.449h6.9l11.328-16.55h-7.55l-5.351,9.967.044-9.967h-6.814l-5.895,9.967.624-9.967H-9019l1.506,16.55h6.773l6.184-10.449Zm27.84-1.964-3.678,12.415h6.148l2.341-7.83v0l4.39,7.83h6.146l3.681-12.415h-6.155l-2.341,7.83-4.388-7.829Zm100.477,3.913-3.176,3.709,2.341,1.705,3.235-3.687.961,3.688,3.387-1.705-.959-3.709h4.177l1-3.411h-4.2l3.179-3.689-2.341-1.711-3.218,3.691-.962-3.691-3.384,1.711.959,3.689h-4.176l-1,3.411Zm-105.117-8.795c-2.085,0-4.055.87-4.391,1.938a.992.992,0,0,0,.162.913,3.85,3.85,0,0,0,3.017,1.023c2.087,0,4.055-.869,4.388-1.937a.991.991,0,0,0-.161-.916A3.841,3.841,0,0,0-8981.335-10664.449Zm184.824-42.989-8.356,28.1,12.723-2.812,1.3-4.3h7.816a16.907,16.907,0,0,0,9.693-2.621,14.486,14.486,0,0,0,5.6-8.144c.965-3.2.837-5.676-.38-7.372-1.354-1.887-4.066-2.843-8.063-2.843Zm-24.622-.431a19.661,19.661,0,0,0-6.9,1.117,12.013,12.013,0,0,0-4.04,2.459,8.555,8.555,0,0,0-2.373,3.575l-1.642,5.553a5.819,5.819,0,0,0,.578,5.219,8.29,8.29,0,0,0,4.756,2.937,16.019,16.019,0,0,0,3.068.549l2.564-.012h17.771l1.384-4.612h-16.468a3.9,3.9,0,0,1-3.217-1.155,2.884,2.884,0,0,1-.48-2.226l.294-.979h21.175l1.051-3.625c.71-2.413.512-4.383-.589-5.854-2.1-2.8-6.82-2.947-7.745-2.947-.1,0-.153,0-.153,0Zm-28.943,0a19.8,19.8,0,0,0-6.926,1.117,12.039,12.039,0,0,0-4.054,2.459,8.481,8.481,0,0,0-2.378,3.575l-1.643,5.553a5.833,5.833,0,0,0,.6,5.215,8.342,8.342,0,0,0,4.771,2.94,16.059,16.059,0,0,0,3.072.549l2.564-.012h13.272l1.348-4.612h-11.933a3.946,3.946,0,0,1-3.234-1.158,2.906,2.906,0,0,1-.507-2.223l.294-.979,1.345-4.472a4.757,4.757,0,0,1,2.853-3.128,6.182,6.182,0,0,1,2.063-.461h12.856l1.3-4.363Zm84.273.414,2.225,5.522h4.116l-2.644,8.92c-.605,2.037-.521,3.534.259,4.579.993,1.333,3.087,1.953,6.589,1.953h8.737l3.276-5.985h-4.621c-1.184,0-1.85-.184-2.158-.6a1.594,1.594,0,0,1-.069-1.435l2.228-7.436h7.228l1.637-5.522h-7.223l2.392-7.988-12.435,2.781-1.554,5.207Zm-126.619-8.546-2.479,8.146-6.3,20.953h12.227l6.216-20.952H-8894.9l13.78-8.146Zm-61.587,10.973-1.6,5.375a3.032,3.032,0,0,0,.153,2.759c.6.8,1.857,1.178,3.963,1.178h4.285l1.976-3.606-2.774,0c-.7,0-1.1-.108-1.285-.352a.983.983,0,0,1-.06-.868l1.345-4.482h4.327l1.052-3.323h-4.369l1.426-4.81-6.507,1.676-.971,3.134h-3.023l-1.01,3.323Zm19.327-3.259c-3.41,0-5.318,1.119-6.318,2.059a4.886,4.886,0,0,0-1.37,2.058l-.927,3.2a3.343,3.343,0,0,0,.328,3c1.258,1.783,4.371,1.994,4.5,2l1.512,0h10.207l.8-2.657h-9.494a2.253,2.253,0,0,1-1.843-.661,1.676,1.676,0,0,1-.3-1.28l.164-.565h12.229l.586-2.089a3.672,3.672,0,0,0-.335-3.367c-1.206-1.613-3.92-1.7-4.452-1.7h-5.293Zm-37.392,4.507v0l4.367,7.807h6.133l3.7-12.379h-6.133l-2.311,7.806-4.41-7.807h-6.136l-3.655,12.379h6.091l2.354-7.8Zm51.338-4.571-3.658,12.379h6.893l1.975-6.742c.46-1.39,1.5-2.009,3.361-2.009a4.355,4.355,0,0,1,2.9,1.035l2.9-4.4a7.634,7.634,0,0,0-3.07-.521,10.109,10.109,0,0,0-4.662,1.154l.255-.894Zm-65.623,0-3.652,12.379h6.89l3.655-12.379h-6.893Zm-18.231,1.953v0l-.083,10.422h6.89l11.3-16.5h-7.561l-5.295,9.918.044-9.918h-6.807l-5.883,9.918.63-9.918H-9019l1.471,16.5h6.762l6.175-10.422Zm131.492,4.433v0l.716,2.785a1.246,1.246,0,0,0,1.268.918,2.17,2.17,0,0,0,.957-.244,2.352,2.352,0,0,0,1.384-2.5l-.71-2.787h3.106a2.625,2.625,0,0,0,2.353-1.831,1.491,1.491,0,0,0-.173-1.337,1.311,1.311,0,0,0-1.087-.493h-3.109l2.4-2.785a2.172,2.172,0,0,0,.582-1.637,1.2,1.2,0,0,0-.5-.862,1.419,1.419,0,0,0-.827-.246,2.529,2.529,0,0,0-1.819.912l-2.4,2.79-.713-2.79a1.24,1.24,0,0,0-1.267-.912,2.167,2.167,0,0,0-.961.246,2.455,2.455,0,0,0-1.428,2.5l.754,2.785h-3.148a2.6,2.6,0,0,0-2.308,1.83,1.515,1.515,0,0,0,.172,1.349,1.26,1.26,0,0,0,1.046.482h3.148l-2.394,2.787a2.18,2.18,0,0,0-.583,1.64,1.208,1.208,0,0,0,.5.862,1.3,1.3,0,0,0,.791.243,2.519,2.519,0,0,0,1.811-.917l2.436-2.786Zm-108.387-11.256c-2.074,0-4.035.867-4.372,1.933a.989.989,0,0,0,.165.913,3.8,3.8,0,0,0,2.986,1.021c2.075,0,4.036-.867,4.371-1.934a.994.994,0,0,0-.159-.92A3.811,3.811,0,0,0-8981.484-10713.222Zm134.183,62.158c-.188,0-.374-.007-.553-.02-1.713,0-3.291-.09-3.59-.108h-.007l2.926-9.672h4.056c1.382,0,3.322.14,4.222,1.345a3.791,3.791,0,0,1,.213,3.412,7.951,7.951,0,0,1-2.888,3.671A7.676,7.676,0,0,1-8847.3-10651.063Zm95.125-.181h-9.54a4.759,4.759,0,0,1,4.315-3.525h2.84c1.5,0,2.445.349,2.811,1.038.546,1.026-.415,2.473-.425,2.487Zm-177.947-3.664h-6.232a3.078,3.078,0,0,1,2.846-2.074h1.675a1.913,1.913,0,0,1,1.728.645,1.672,1.672,0,0,1-.016,1.429Zm145.371-37.358h-4.368l2.939-9.819h4.33c1.254,0,1.993.248,2.4.8.547.748.508,2.068-.125,4.282C-8780.467-10694-8781.6-10692.267-8784.753-10692.267Zm-28.982-7.65h-10.753a4.75,4.75,0,0,1,2.85-3.128,6.182,6.182,0,0,1,2.063-.461h2.856c1.541,0,2.558.378,3.022,1.123a2.894,2.894,0,0,1-.038,2.465Zm-116.666-3.791h-6.216a3.064,3.064,0,0,1,2.814-2.066h1.64a1.957,1.957,0,0,1,1.757.651,1.642,1.642,0,0,1,0,1.414Z" transform="translate(9054 11052)" /> </svg> <div class="content"> <p class="desc">Excellent control in snow</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <div class="content"> <p class="desc">Excellent control in snow</p> <span class="btn btn--round">Learn more</span> </div> </a> </div> <div class="display" data-id="smart"> <a href="/global/en/tires/smart.html"> <img class="display__bg t_none" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/smart/bg.jpg" alt="배경이미지"> <img class="display__bg t_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/smart/bg-m.jpg" alt="배경이미지"> <img class="display__bg m_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/smart/bg-m.jpg" alt="배경이미지"> <div class="display__wrap"> <div class="display__lottie"></div> </div> <!-- 웹 --> <div class="svg_wrap t_none"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape6" d="M-3006-8314H-4766v-720h1760v720Zm-1445.225-339.392h0L-4510-8622.442l1.981,3c16.358,24.843,56.644,39.675,107.764,39.675,106.271,0,135.767-44.6,143.89-71.189a53.163,53.163,0,0,0,2.565-19.648,35.66,35.66,0,0,0-1.606-8.163,33.521,33.521,0,0,0-3.316-7.169c-5.659-9.213-16.087-16.515-31.881-22.323-14.836-5.456-32.854-8.978-48.521-11.7-17.966-3.121-28.878-5.416-36.486-7.675-7.994-2.372-12.364-4.739-14.169-7.677-1.147-1.865-1.289-4.021-.445-6.785,2.331-7.6,15.216-15.714,44.39-15.714,25.261,0,44.326,6.732,60,21.187l1.607,1.48,59.952-33.891-2.983-2.827c-24.5-23.287-56.806-34.133-101.679-34.133-65.56,0-119.61,27.027-131.441,65.725a67.234,67.234,0,0,0-2.39,10.645,46.164,46.164,0,0,0-.347,9.371,35.4,35.4,0,0,0,1.538,8.2,32.218,32.218,0,0,0,3.266,7.129,35.651,35.651,0,0,0,5.163,6.489,46.572,46.572,0,0,0,6.735,5.522,79.334,79.334,0,0,0,17.444,8.622,177.974,177.974,0,0,0,21.5,6.186c6.736,1.547,14.158,3,24.063,4.706,19.277,3.248,32.391,6.07,41.271,8.881,8.244,2.609,12.98,5.279,14.906,8.4a7.274,7.274,0,0,1,1.091,3.882,14.373,14.373,0,0,1-.759,4.313c-2.788,9.166-11.568,19.687-55.087,19.687-30.677,0-53.465-7.909-67.731-23.507l-1.505-1.642Zm600.462-42a240.46,240.46,0,0,0-41.106,3.415,167.616,167.616,0,0,0-36.13,10.247c-11.13,4.685-20.421,10.432-27.614,17.082-7.63,7.054-12.865,15.1-15.558,23.919a41.494,41.494,0,0,0-1.7,18.371,33.1,33.1,0,0,0,6.232,14.854,45.966,45.966,0,0,0,12.461,11.266,77.565,77.565,0,0,0,17.295,7.971c12.5,4.123,27.5,6.3,43.366,6.3a141.445,141.445,0,0,0,33.589-4.154,108.218,108.218,0,0,0,26.912-10.284l-3.362,11h68.053L-3733-8700.95a35.6,35.6,0,0,0,1.516-15.369,27.362,27.362,0,0,0-5.2-12.566c-6.157-8.317-17.4-14.693-33.4-18.95a170.5,170.5,0,0,0-25.561-4.531,284.387,284.387,0,0,0-29.854-1.471,332.81,332.81,0,0,0-54.843,4.2c-8.308,1.376-16.371,3.08-24.649,5.209-7.891,2.028-15.8,4.4-24.166,7.246l3.685,33.87a280.427,280.427,0,0,1,42.586-9.8,308.71,308.71,0,0,1,46.072-3.677,87.414,87.414,0,0,1,11.422.708,56.869,56.869,0,0,1,9.472,2.025,32.368,32.368,0,0,1,7.263,3.2,16.893,16.893,0,0,1,4.793,4.223,10.575,10.575,0,0,1,1.983,4.533,11.117,11.117,0,0,1-.395,5.134l-2.512,8.176a96.65,96.65,0,0,0-17.961-4.595A176.443,176.443,0,0,0-3850.763-8695.389Zm-314.71,21.856v0l31.466,91.3,86.915-91.3-28.384,88.127h64.873l50.441-164.943h-60.263l-90.85,93.777-33.172-93.778h-60.975l-50.426,164.943h64.873l25.5-88.124Zm676.046-76.817,15.68,39.812h60.571l-38.262,125.138h69.141l38.276-125.138h69.854l12.166-39.811h-227.426Zm-165.306,109.335h27.828l42.189,55.608h77.317l-49.213-62.936c15.533-4.27,28.395-10.31,38.229-17.957a65.4,65.4,0,0,0,13.134-13.515,57.866,57.866,0,0,0,8.291-16.83,45.613,45.613,0,0,0,2.169-18.075,28.335,28.335,0,0,0-5.393-14.018,36.751,36.751,0,0,0-11.53-9.851,71.964,71.964,0,0,0-17.172-6.713,145.293,145.293,0,0,0-22.228-3.836c-8.011-.81-16.992-1.221-26.694-1.221h-111.541l-50.46,164.95h68.1l16.977-55.608Zm-216.709,21.057c-15.852,0-26.045-2.906-30.3-8.637-2.388-3.221-2.856-7.3-1.391-12.131,3.955-12.944,18.752-19.507,43.979-19.507,10.914,0,19.354.735,26.564,2.313a73.825,73.825,0,0,1,16.552,5.844l-5.176,17.033c-4.941,4.072-12.281,7.8-20.67,10.489A98.008,98.008,0,0,1-3871.442-8619.958Zm268.4-57.1h-40.649l11.025-36.067h41.706c12.333,0,20.327,2.349,23.758,6.979,2.065,2.787,2.447,6.388,1.134,10.7a22.549,22.549,0,0,1-4.141,7.842,23.4,23.4,0,0,1-7.283,5.769,39.311,39.311,0,0,1-10.814,3.561A80.029,80.029,0,0,1-3603.045-8677.056Z" transform="translate(4766 9034)" /> </defs> <clipPath id="clipPath6"> <use xlink:href="#polygonShape6"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath6);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/smart/bg.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M-3006-8314H-4766v-720h1760v720Zm-1445.225-339.392h0L-4510-8622.442l1.981,3c16.358,24.843,56.644,39.675,107.764,39.675,106.271,0,135.767-44.6,143.89-71.189a53.163,53.163,0,0,0,2.565-19.648,35.66,35.66,0,0,0-1.606-8.163,33.521,33.521,0,0,0-3.316-7.169c-5.659-9.213-16.087-16.515-31.881-22.323-14.836-5.456-32.854-8.978-48.521-11.7-17.966-3.121-28.878-5.416-36.486-7.675-7.994-2.372-12.364-4.739-14.169-7.677-1.147-1.865-1.289-4.021-.445-6.785,2.331-7.6,15.216-15.714,44.39-15.714,25.261,0,44.326,6.732,60,21.187l1.607,1.48,59.952-33.891-2.983-2.827c-24.5-23.287-56.806-34.133-101.679-34.133-65.56,0-119.61,27.027-131.441,65.725a67.234,67.234,0,0,0-2.39,10.645,46.164,46.164,0,0,0-.347,9.371,35.4,35.4,0,0,0,1.538,8.2,32.218,32.218,0,0,0,3.266,7.129,35.651,35.651,0,0,0,5.163,6.489,46.572,46.572,0,0,0,6.735,5.522,79.334,79.334,0,0,0,17.444,8.622,177.974,177.974,0,0,0,21.5,6.186c6.736,1.547,14.158,3,24.063,4.706,19.277,3.248,32.391,6.07,41.271,8.881,8.244,2.609,12.98,5.279,14.906,8.4a7.274,7.274,0,0,1,1.091,3.882,14.373,14.373,0,0,1-.759,4.313c-2.788,9.166-11.568,19.687-55.087,19.687-30.677,0-53.465-7.909-67.731-23.507l-1.505-1.642Zm600.462-42a240.46,240.46,0,0,0-41.106,3.415,167.616,167.616,0,0,0-36.13,10.247c-11.13,4.685-20.421,10.432-27.614,17.082-7.63,7.054-12.865,15.1-15.558,23.919a41.494,41.494,0,0,0-1.7,18.371,33.1,33.1,0,0,0,6.232,14.854,45.966,45.966,0,0,0,12.461,11.266,77.565,77.565,0,0,0,17.295,7.971c12.5,4.123,27.5,6.3,43.366,6.3a141.445,141.445,0,0,0,33.589-4.154,108.218,108.218,0,0,0,26.912-10.284l-3.362,11h68.053L-3733-8700.95a35.6,35.6,0,0,0,1.516-15.369,27.362,27.362,0,0,0-5.2-12.566c-6.157-8.317-17.4-14.693-33.4-18.95a170.5,170.5,0,0,0-25.561-4.531,284.387,284.387,0,0,0-29.854-1.471,332.81,332.81,0,0,0-54.843,4.2c-8.308,1.376-16.371,3.08-24.649,5.209-7.891,2.028-15.8,4.4-24.166,7.246l3.685,33.87a280.427,280.427,0,0,1,42.586-9.8,308.71,308.71,0,0,1,46.072-3.677,87.414,87.414,0,0,1,11.422.708,56.869,56.869,0,0,1,9.472,2.025,32.368,32.368,0,0,1,7.263,3.2,16.893,16.893,0,0,1,4.793,4.223,10.575,10.575,0,0,1,1.983,4.533,11.117,11.117,0,0,1-.395,5.134l-2.512,8.176a96.65,96.65,0,0,0-17.961-4.595A176.443,176.443,0,0,0-3850.763-8695.389Zm-314.71,21.856v0l31.466,91.3,86.915-91.3-28.384,88.127h64.873l50.441-164.943h-60.263l-90.85,93.777-33.172-93.778h-60.975l-50.426,164.943h64.873l25.5-88.124Zm676.046-76.817,15.68,39.812h60.571l-38.262,125.138h69.141l38.276-125.138h69.854l12.166-39.811h-227.426Zm-165.306,109.335h27.828l42.189,55.608h77.317l-49.213-62.936c15.533-4.27,28.395-10.31,38.229-17.957a65.4,65.4,0,0,0,13.134-13.515,57.866,57.866,0,0,0,8.291-16.83,45.613,45.613,0,0,0,2.169-18.075,28.335,28.335,0,0,0-5.393-14.018,36.751,36.751,0,0,0-11.53-9.851,71.964,71.964,0,0,0-17.172-6.713,145.293,145.293,0,0,0-22.228-3.836c-8.011-.81-16.992-1.221-26.694-1.221h-111.541l-50.46,164.95h68.1l16.977-55.608Zm-216.709,21.057c-15.852,0-26.045-2.906-30.3-8.637-2.388-3.221-2.856-7.3-1.391-12.131,3.955-12.944,18.752-19.507,43.979-19.507,10.914,0,19.354.735,26.564,2.313a73.825,73.825,0,0,1,16.552,5.844l-5.176,17.033c-4.941,4.072-12.281,7.8-20.67,10.489A98.008,98.008,0,0,1-3871.442-8619.958Zm268.4-57.1h-40.649l11.025-36.067h41.706c12.333,0,20.327,2.349,23.758,6.979,2.065,2.787,2.447,6.388,1.134,10.7a22.549,22.549,0,0,1-4.141,7.842,23.4,23.4,0,0,1-7.283,5.769,39.311,39.311,0,0,1-10.814,3.561A80.029,80.029,0,0,1-3603.045-8677.056Z" transform="translate(4766 9034)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M-3006-8314H-4766v-720h1760v720Zm-1445.225-339.392h0L-4510-8622.442l1.981,3c16.358,24.843,56.644,39.675,107.764,39.675,106.271,0,135.767-44.6,143.89-71.189a53.163,53.163,0,0,0,2.565-19.648,35.66,35.66,0,0,0-1.606-8.163,33.521,33.521,0,0,0-3.316-7.169c-5.659-9.213-16.087-16.515-31.881-22.323-14.836-5.456-32.854-8.978-48.521-11.7-17.966-3.121-28.878-5.416-36.486-7.675-7.994-2.372-12.364-4.739-14.169-7.677-1.147-1.865-1.289-4.021-.445-6.785,2.331-7.6,15.216-15.714,44.39-15.714,25.261,0,44.326,6.732,60,21.187l1.607,1.48,59.952-33.891-2.983-2.827c-24.5-23.287-56.806-34.133-101.679-34.133-65.56,0-119.61,27.027-131.441,65.725a67.234,67.234,0,0,0-2.39,10.645,46.164,46.164,0,0,0-.347,9.371,35.4,35.4,0,0,0,1.538,8.2,32.218,32.218,0,0,0,3.266,7.129,35.651,35.651,0,0,0,5.163,6.489,46.572,46.572,0,0,0,6.735,5.522,79.334,79.334,0,0,0,17.444,8.622,177.974,177.974,0,0,0,21.5,6.186c6.736,1.547,14.158,3,24.063,4.706,19.277,3.248,32.391,6.07,41.271,8.881,8.244,2.609,12.98,5.279,14.906,8.4a7.274,7.274,0,0,1,1.091,3.882,14.373,14.373,0,0,1-.759,4.313c-2.788,9.166-11.568,19.687-55.087,19.687-30.677,0-53.465-7.909-67.731-23.507l-1.505-1.642Zm600.462-42a240.46,240.46,0,0,0-41.106,3.415,167.616,167.616,0,0,0-36.13,10.247c-11.13,4.685-20.421,10.432-27.614,17.082-7.63,7.054-12.865,15.1-15.558,23.919a41.494,41.494,0,0,0-1.7,18.371,33.1,33.1,0,0,0,6.232,14.854,45.966,45.966,0,0,0,12.461,11.266,77.565,77.565,0,0,0,17.295,7.971c12.5,4.123,27.5,6.3,43.366,6.3a141.445,141.445,0,0,0,33.589-4.154,108.218,108.218,0,0,0,26.912-10.284l-3.362,11h68.053L-3733-8700.95a35.6,35.6,0,0,0,1.516-15.369,27.362,27.362,0,0,0-5.2-12.566c-6.157-8.317-17.4-14.693-33.4-18.95a170.5,170.5,0,0,0-25.561-4.531,284.387,284.387,0,0,0-29.854-1.471,332.81,332.81,0,0,0-54.843,4.2c-8.308,1.376-16.371,3.08-24.649,5.209-7.891,2.028-15.8,4.4-24.166,7.246l3.685,33.87a280.427,280.427,0,0,1,42.586-9.8,308.71,308.71,0,0,1,46.072-3.677,87.414,87.414,0,0,1,11.422.708,56.869,56.869,0,0,1,9.472,2.025,32.368,32.368,0,0,1,7.263,3.2,16.893,16.893,0,0,1,4.793,4.223,10.575,10.575,0,0,1,1.983,4.533,11.117,11.117,0,0,1-.395,5.134l-2.512,8.176a96.65,96.65,0,0,0-17.961-4.595A176.443,176.443,0,0,0-3850.763-8695.389Zm-314.71,21.856v0l31.466,91.3,86.915-91.3-28.384,88.127h64.873l50.441-164.943h-60.263l-90.85,93.777-33.172-93.778h-60.975l-50.426,164.943h64.873l25.5-88.124Zm676.046-76.817,15.68,39.812h60.571l-38.262,125.138h69.141l38.276-125.138h69.854l12.166-39.811h-227.426Zm-165.306,109.335h27.828l42.189,55.608h77.317l-49.213-62.936c15.533-4.27,28.395-10.31,38.229-17.957a65.4,65.4,0,0,0,13.134-13.515,57.866,57.866,0,0,0,8.291-16.83,45.613,45.613,0,0,0,2.169-18.075,28.335,28.335,0,0,0-5.393-14.018,36.751,36.751,0,0,0-11.53-9.851,71.964,71.964,0,0,0-17.172-6.713,145.293,145.293,0,0,0-22.228-3.836c-8.011-.81-16.992-1.221-26.694-1.221h-111.541l-50.46,164.95h68.1l16.977-55.608Zm-216.709,21.057c-15.852,0-26.045-2.906-30.3-8.637-2.388-3.221-2.856-7.3-1.391-12.131,3.955-12.944,18.752-19.507,43.979-19.507,10.914,0,19.354.735,26.564,2.313a73.825,73.825,0,0,1,16.552,5.844l-5.176,17.033c-4.941,4.072-12.281,7.8-20.67,10.489A98.008,98.008,0,0,1-3871.442-8619.958Zm268.4-57.1h-40.649l11.025-36.067h41.706c12.333,0,20.327,2.349,23.758,6.979,2.065,2.787,2.447,6.388,1.134,10.7a22.549,22.549,0,0,1-4.141,7.842,23.4,23.4,0,0,1-7.283,5.769,39.311,39.311,0,0,1-10.814,3.561A80.029,80.029,0,0,1-3603.045-8677.056Z" transform="translate(4766 9034)" /> </svg> <div class="content"> <p class="desc">Safe driving with longer life</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 태블릿 --> <div class="svg_wrap t_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape666" d="M-10464-10492h-350v-560h350v560Zm-294.53-178.622h0l-12.471,6.568.423.635c3.471,5.271,12.018,8.419,22.863,8.419,22.551,0,28.808-9.464,30.53-15.105a11.273,11.273,0,0,0,.544-4.169,7.254,7.254,0,0,0-1.044-3.252c-1.2-1.956-3.414-3.506-6.764-4.737a61.86,61.86,0,0,0-10.294-2.484c-7.41-1.285-10.022-2.076-10.748-3.255a1.676,1.676,0,0,1-.094-1.441c.493-1.612,3.226-3.334,9.416-3.334,5.357,0,9.4,1.429,12.731,4.5l.341.313,12.722-7.189-.634-.6c-5.2-4.941-12.058-7.242-21.573-7.242-13.91,0-25.379,5.735-27.89,13.946-.934,3.049-.79,5.5.438,7.5,1.118,1.817,3.154,3.25,6.226,4.378a58.067,58.067,0,0,0,9.667,2.311c7.756,1.308,11.1,2.336,11.921,3.667a2.049,2.049,0,0,1,.07,1.738c-.593,1.945-2.457,4.178-11.688,4.178-6.509,0-11.345-1.678-14.373-4.987l-.319-.35Zm127.405-8.908a51.071,51.071,0,0,0-8.722.725,35.642,35.642,0,0,0-7.667,2.174c-4.881,2.055-8.049,5.063-9.16,8.7a7.565,7.565,0,0,0,.963,7.051,12.618,12.618,0,0,0,6.313,4.08,29.854,29.854,0,0,0,9.2,1.337,27.566,27.566,0,0,0,12.836-3.062l-.712,2.332h14.439l7.5-24.517a6.362,6.362,0,0,0-.781-5.927c-1.307-1.766-3.691-3.118-7.087-4.021a46.668,46.668,0,0,0-11.756-1.273,64.5,64.5,0,0,0-22,3.536l.782,7.184a64.829,64.829,0,0,1,18.811-2.859,15.207,15.207,0,0,1,4.433.58,4.988,4.988,0,0,1,2.558,1.575,2.2,2.2,0,0,1,.338,2.053l-.532,1.733A28.465,28.465,0,0,0-10631.126-10679.53Zm-66.774,4.638v0l6.676,19.369,18.442-19.372-6.024,18.7h13.766l10.7-35h-12.786l-19.277,19.9-7.037-19.9h-12.938l-10.7,35h13.763l5.41-18.694Zm108.365,6.9h5.905l8.951,11.8h16.406l-10.443-13.353a23.164,23.164,0,0,0,8.112-3.811,12.808,12.808,0,0,0,4.547-6.437c.845-2.763.614-5.055-.686-6.811-1.163-1.571-3.212-2.754-6.09-3.515a41.849,41.849,0,0,0-10.38-1.072h-23.665l-10.706,35h14.448l3.6-11.8Zm35.076-23.2,3.326,8.448h12.853l-8.118,26.55h14.67l8.121-26.55h14.82l2.582-8.448Zm-81.056,27.668c-3.362,0-5.524-.616-6.427-1.832a2.782,2.782,0,0,1-.3-2.576c.84-2.746,3.979-4.138,9.33-4.138,5.08,0,7.149.784,9.15,1.73l-1.1,3.614C-10626.791-10665.133-10630.837-10663.525-10635.515-10663.525Zm56.947-12.116h-8.624l2.339-7.652h8.851c2.615,0,4.311.5,5.039,1.479a2.459,2.459,0,0,1,.242,2.271,4.666,4.666,0,0,1-2.425,2.889A11.78,11.78,0,0,1-10578.567-10675.642Z" transform="translate(10814.001 11022)" /> </defs> <clipPath id="clipPath666"> <use xlink:href="#polygonShape666"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath666);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/smart/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-10464-10492h-350v-560h350v560Zm-294.53-178.622h0l-12.471,6.568.423.635c3.471,5.271,12.018,8.419,22.863,8.419,22.551,0,28.808-9.464,30.53-15.105a11.273,11.273,0,0,0,.544-4.169,7.254,7.254,0,0,0-1.044-3.252c-1.2-1.956-3.414-3.506-6.764-4.737a61.86,61.86,0,0,0-10.294-2.484c-7.41-1.285-10.022-2.076-10.748-3.255a1.676,1.676,0,0,1-.094-1.441c.493-1.612,3.226-3.334,9.416-3.334,5.357,0,9.4,1.429,12.731,4.5l.341.313,12.722-7.189-.634-.6c-5.2-4.941-12.058-7.242-21.573-7.242-13.91,0-25.379,5.735-27.89,13.946-.934,3.049-.79,5.5.438,7.5,1.118,1.817,3.154,3.25,6.226,4.378a58.067,58.067,0,0,0,9.667,2.311c7.756,1.308,11.1,2.336,11.921,3.667a2.049,2.049,0,0,1,.07,1.738c-.593,1.945-2.457,4.178-11.688,4.178-6.509,0-11.345-1.678-14.373-4.987l-.319-.35Zm127.405-8.908a51.071,51.071,0,0,0-8.722.725,35.642,35.642,0,0,0-7.667,2.174c-4.881,2.055-8.049,5.063-9.16,8.7a7.565,7.565,0,0,0,.963,7.051,12.618,12.618,0,0,0,6.313,4.08,29.854,29.854,0,0,0,9.2,1.337,27.566,27.566,0,0,0,12.836-3.062l-.712,2.332h14.439l7.5-24.517a6.362,6.362,0,0,0-.781-5.927c-1.307-1.766-3.691-3.118-7.087-4.021a46.668,46.668,0,0,0-11.756-1.273,64.5,64.5,0,0,0-22,3.536l.782,7.184a64.829,64.829,0,0,1,18.811-2.859,15.207,15.207,0,0,1,4.433.58,4.988,4.988,0,0,1,2.558,1.575,2.2,2.2,0,0,1,.338,2.053l-.532,1.733A28.465,28.465,0,0,0-10631.126-10679.53Zm-66.774,4.638v0l6.676,19.369,18.442-19.372-6.024,18.7h13.766l10.7-35h-12.786l-19.277,19.9-7.037-19.9h-12.938l-10.7,35h13.763l5.41-18.694Zm108.365,6.9h5.905l8.951,11.8h16.406l-10.443-13.353a23.164,23.164,0,0,0,8.112-3.811,12.808,12.808,0,0,0,4.547-6.437c.845-2.763.614-5.055-.686-6.811-1.163-1.571-3.212-2.754-6.09-3.515a41.849,41.849,0,0,0-10.38-1.072h-23.665l-10.706,35h14.448l3.6-11.8Zm35.076-23.2,3.326,8.448h12.853l-8.118,26.55h14.67l8.121-26.55h14.82l2.582-8.448Zm-81.056,27.668c-3.362,0-5.524-.616-6.427-1.832a2.782,2.782,0,0,1-.3-2.576c.84-2.746,3.979-4.138,9.33-4.138,5.08,0,7.149.784,9.15,1.73l-1.1,3.614C-10626.791-10665.133-10630.837-10663.525-10635.515-10663.525Zm56.947-12.116h-8.624l2.339-7.652h8.851c2.615,0,4.311.5,5.039,1.479a2.459,2.459,0,0,1,.242,2.271,4.666,4.666,0,0,1-2.425,2.889A11.78,11.78,0,0,1-10578.567-10675.642Z" transform="translate(10814.001 11022)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-10464-10492h-350v-560h350v560Zm-294.53-178.622h0l-12.471,6.568.423.635c3.471,5.271,12.018,8.419,22.863,8.419,22.551,0,28.808-9.464,30.53-15.105a11.273,11.273,0,0,0,.544-4.169,7.254,7.254,0,0,0-1.044-3.252c-1.2-1.956-3.414-3.506-6.764-4.737a61.86,61.86,0,0,0-10.294-2.484c-7.41-1.285-10.022-2.076-10.748-3.255a1.676,1.676,0,0,1-.094-1.441c.493-1.612,3.226-3.334,9.416-3.334,5.357,0,9.4,1.429,12.731,4.5l.341.313,12.722-7.189-.634-.6c-5.2-4.941-12.058-7.242-21.573-7.242-13.91,0-25.379,5.735-27.89,13.946-.934,3.049-.79,5.5.438,7.5,1.118,1.817,3.154,3.25,6.226,4.378a58.067,58.067,0,0,0,9.667,2.311c7.756,1.308,11.1,2.336,11.921,3.667a2.049,2.049,0,0,1,.07,1.738c-.593,1.945-2.457,4.178-11.688,4.178-6.509,0-11.345-1.678-14.373-4.987l-.319-.35Zm127.405-8.908a51.071,51.071,0,0,0-8.722.725,35.642,35.642,0,0,0-7.667,2.174c-4.881,2.055-8.049,5.063-9.16,8.7a7.565,7.565,0,0,0,.963,7.051,12.618,12.618,0,0,0,6.313,4.08,29.854,29.854,0,0,0,9.2,1.337,27.566,27.566,0,0,0,12.836-3.062l-.712,2.332h14.439l7.5-24.517a6.362,6.362,0,0,0-.781-5.927c-1.307-1.766-3.691-3.118-7.087-4.021a46.668,46.668,0,0,0-11.756-1.273,64.5,64.5,0,0,0-22,3.536l.782,7.184a64.829,64.829,0,0,1,18.811-2.859,15.207,15.207,0,0,1,4.433.58,4.988,4.988,0,0,1,2.558,1.575,2.2,2.2,0,0,1,.338,2.053l-.532,1.733A28.465,28.465,0,0,0-10631.126-10679.53Zm-66.774,4.638v0l6.676,19.369,18.442-19.372-6.024,18.7h13.766l10.7-35h-12.786l-19.277,19.9-7.037-19.9h-12.938l-10.7,35h13.763l5.41-18.694Zm108.365,6.9h5.905l8.951,11.8h16.406l-10.443-13.353a23.164,23.164,0,0,0,8.112-3.811,12.808,12.808,0,0,0,4.547-6.437c.845-2.763.614-5.055-.686-6.811-1.163-1.571-3.212-2.754-6.09-3.515a41.849,41.849,0,0,0-10.38-1.072h-23.665l-10.706,35h14.448l3.6-11.8Zm35.076-23.2,3.326,8.448h12.853l-8.118,26.55h14.67l8.121-26.55h14.82l2.582-8.448Zm-81.056,27.668c-3.362,0-5.524-.616-6.427-1.832a2.782,2.782,0,0,1-.3-2.576c.84-2.746,3.979-4.138,9.33-4.138,5.08,0,7.149.784,9.15,1.73l-1.1,3.614C-10626.791-10665.133-10630.837-10663.525-10635.515-10663.525Zm56.947-12.116h-8.624l2.339-7.652h8.851c2.615,0,4.311.5,5.039,1.479a2.459,2.459,0,0,1,.242,2.271,4.666,4.666,0,0,1-2.425,2.889A11.78,11.78,0,0,1-10578.567-10675.642Z" transform="translate(10814.001 11022)" /> </svg> <div class="content"> <p class="desc">Safe driving with longer life</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 모바일 --> <div class="svg_wrap m_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape666-m" d="M-10464-10492h-350v-560h350v560Zm-294.53-178.622h0l-12.471,6.568.423.635c3.471,5.271,12.018,8.419,22.863,8.419,22.551,0,28.808-9.464,30.53-15.105a11.273,11.273,0,0,0,.544-4.169,7.254,7.254,0,0,0-1.044-3.252c-1.2-1.956-3.414-3.506-6.764-4.737a61.86,61.86,0,0,0-10.294-2.484c-7.41-1.285-10.022-2.076-10.748-3.255a1.676,1.676,0,0,1-.094-1.441c.493-1.612,3.226-3.334,9.416-3.334,5.357,0,9.4,1.429,12.731,4.5l.341.313,12.722-7.189-.634-.6c-5.2-4.941-12.058-7.242-21.573-7.242-13.91,0-25.379,5.735-27.89,13.946-.934,3.049-.79,5.5.438,7.5,1.118,1.817,3.154,3.25,6.226,4.378a58.067,58.067,0,0,0,9.667,2.311c7.756,1.308,11.1,2.336,11.921,3.667a2.049,2.049,0,0,1,.07,1.738c-.593,1.945-2.457,4.178-11.688,4.178-6.509,0-11.345-1.678-14.373-4.987l-.319-.35Zm127.405-8.908a51.071,51.071,0,0,0-8.722.725,35.642,35.642,0,0,0-7.667,2.174c-4.881,2.055-8.049,5.063-9.16,8.7a7.565,7.565,0,0,0,.963,7.051,12.618,12.618,0,0,0,6.313,4.08,29.854,29.854,0,0,0,9.2,1.337,27.566,27.566,0,0,0,12.836-3.062l-.712,2.332h14.439l7.5-24.517a6.362,6.362,0,0,0-.781-5.927c-1.307-1.766-3.691-3.118-7.087-4.021a46.668,46.668,0,0,0-11.756-1.273,64.5,64.5,0,0,0-22,3.536l.782,7.184a64.829,64.829,0,0,1,18.811-2.859,15.207,15.207,0,0,1,4.433.58,4.988,4.988,0,0,1,2.558,1.575,2.2,2.2,0,0,1,.338,2.053l-.532,1.733A28.465,28.465,0,0,0-10631.126-10679.53Zm-66.774,4.638v0l6.676,19.369,18.442-19.372-6.024,18.7h13.766l10.7-35h-12.786l-19.277,19.9-7.037-19.9h-12.938l-10.7,35h13.763l5.41-18.694Zm108.365,6.9h5.905l8.951,11.8h16.406l-10.443-13.353a23.164,23.164,0,0,0,8.112-3.811,12.808,12.808,0,0,0,4.547-6.437c.845-2.763.614-5.055-.686-6.811-1.163-1.571-3.212-2.754-6.09-3.515a41.849,41.849,0,0,0-10.38-1.072h-23.665l-10.706,35h14.448l3.6-11.8Zm35.076-23.2,3.326,8.448h12.853l-8.118,26.55h14.67l8.121-26.55h14.82l2.582-8.448Zm-81.056,27.668c-3.362,0-5.524-.616-6.427-1.832a2.782,2.782,0,0,1-.3-2.576c.84-2.746,3.979-4.138,9.33-4.138,5.08,0,7.149.784,9.15,1.73l-1.1,3.614C-10626.791-10665.133-10630.837-10663.525-10635.515-10663.525Zm56.947-12.116h-8.624l2.339-7.652h8.851c2.615,0,4.311.5,5.039,1.479a2.459,2.459,0,0,1,.242,2.271,4.666,4.666,0,0,1-2.425,2.889A11.78,11.78,0,0,1-10578.567-10675.642Z" transform="translate(10814.001 11052)" /> </defs> <clipPath id="clipPath666-m"> <use xlink:href="#polygonShape666-m"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath666-m);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/smart/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-10464-10492h-350v-560h350v560Zm-294.53-178.622h0l-12.471,6.568.423.635c3.471,5.271,12.018,8.419,22.863,8.419,22.551,0,28.808-9.464,30.53-15.105a11.273,11.273,0,0,0,.544-4.169,7.254,7.254,0,0,0-1.044-3.252c-1.2-1.956-3.414-3.506-6.764-4.737a61.86,61.86,0,0,0-10.294-2.484c-7.41-1.285-10.022-2.076-10.748-3.255a1.676,1.676,0,0,1-.094-1.441c.493-1.612,3.226-3.334,9.416-3.334,5.357,0,9.4,1.429,12.731,4.5l.341.313,12.722-7.189-.634-.6c-5.2-4.941-12.058-7.242-21.573-7.242-13.91,0-25.379,5.735-27.89,13.946-.934,3.049-.79,5.5.438,7.5,1.118,1.817,3.154,3.25,6.226,4.378a58.067,58.067,0,0,0,9.667,2.311c7.756,1.308,11.1,2.336,11.921,3.667a2.049,2.049,0,0,1,.07,1.738c-.593,1.945-2.457,4.178-11.688,4.178-6.509,0-11.345-1.678-14.373-4.987l-.319-.35Zm127.405-8.908a51.071,51.071,0,0,0-8.722.725,35.642,35.642,0,0,0-7.667,2.174c-4.881,2.055-8.049,5.063-9.16,8.7a7.565,7.565,0,0,0,.963,7.051,12.618,12.618,0,0,0,6.313,4.08,29.854,29.854,0,0,0,9.2,1.337,27.566,27.566,0,0,0,12.836-3.062l-.712,2.332h14.439l7.5-24.517a6.362,6.362,0,0,0-.781-5.927c-1.307-1.766-3.691-3.118-7.087-4.021a46.668,46.668,0,0,0-11.756-1.273,64.5,64.5,0,0,0-22,3.536l.782,7.184a64.829,64.829,0,0,1,18.811-2.859,15.207,15.207,0,0,1,4.433.58,4.988,4.988,0,0,1,2.558,1.575,2.2,2.2,0,0,1,.338,2.053l-.532,1.733A28.465,28.465,0,0,0-10631.126-10679.53Zm-66.774,4.638v0l6.676,19.369,18.442-19.372-6.024,18.7h13.766l10.7-35h-12.786l-19.277,19.9-7.037-19.9h-12.938l-10.7,35h13.763l5.41-18.694Zm108.365,6.9h5.905l8.951,11.8h16.406l-10.443-13.353a23.164,23.164,0,0,0,8.112-3.811,12.808,12.808,0,0,0,4.547-6.437c.845-2.763.614-5.055-.686-6.811-1.163-1.571-3.212-2.754-6.09-3.515a41.849,41.849,0,0,0-10.38-1.072h-23.665l-10.706,35h14.448l3.6-11.8Zm35.076-23.2,3.326,8.448h12.853l-8.118,26.55h14.67l8.121-26.55h14.82l2.582-8.448Zm-81.056,27.668c-3.362,0-5.524-.616-6.427-1.832a2.782,2.782,0,0,1-.3-2.576c.84-2.746,3.979-4.138,9.33-4.138,5.08,0,7.149.784,9.15,1.73l-1.1,3.614C-10626.791-10665.133-10630.837-10663.525-10635.515-10663.525Zm56.947-12.116h-8.624l2.339-7.652h8.851c2.615,0,4.311.5,5.039,1.479a2.459,2.459,0,0,1,.242,2.271,4.666,4.666,0,0,1-2.425,2.889A11.78,11.78,0,0,1-10578.567-10675.642Z" transform="translate(10814.001 11052)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M-10464-10492h-350v-560h350v560Zm-294.53-178.622h0l-12.471,6.568.423.635c3.471,5.271,12.018,8.419,22.863,8.419,22.551,0,28.808-9.464,30.53-15.105a11.273,11.273,0,0,0,.544-4.169,7.254,7.254,0,0,0-1.044-3.252c-1.2-1.956-3.414-3.506-6.764-4.737a61.86,61.86,0,0,0-10.294-2.484c-7.41-1.285-10.022-2.076-10.748-3.255a1.676,1.676,0,0,1-.094-1.441c.493-1.612,3.226-3.334,9.416-3.334,5.357,0,9.4,1.429,12.731,4.5l.341.313,12.722-7.189-.634-.6c-5.2-4.941-12.058-7.242-21.573-7.242-13.91,0-25.379,5.735-27.89,13.946-.934,3.049-.79,5.5.438,7.5,1.118,1.817,3.154,3.25,6.226,4.378a58.067,58.067,0,0,0,9.667,2.311c7.756,1.308,11.1,2.336,11.921,3.667a2.049,2.049,0,0,1,.07,1.738c-.593,1.945-2.457,4.178-11.688,4.178-6.509,0-11.345-1.678-14.373-4.987l-.319-.35Zm127.405-8.908a51.071,51.071,0,0,0-8.722.725,35.642,35.642,0,0,0-7.667,2.174c-4.881,2.055-8.049,5.063-9.16,8.7a7.565,7.565,0,0,0,.963,7.051,12.618,12.618,0,0,0,6.313,4.08,29.854,29.854,0,0,0,9.2,1.337,27.566,27.566,0,0,0,12.836-3.062l-.712,2.332h14.439l7.5-24.517a6.362,6.362,0,0,0-.781-5.927c-1.307-1.766-3.691-3.118-7.087-4.021a46.668,46.668,0,0,0-11.756-1.273,64.5,64.5,0,0,0-22,3.536l.782,7.184a64.829,64.829,0,0,1,18.811-2.859,15.207,15.207,0,0,1,4.433.58,4.988,4.988,0,0,1,2.558,1.575,2.2,2.2,0,0,1,.338,2.053l-.532,1.733A28.465,28.465,0,0,0-10631.126-10679.53Zm-66.774,4.638v0l6.676,19.369,18.442-19.372-6.024,18.7h13.766l10.7-35h-12.786l-19.277,19.9-7.037-19.9h-12.938l-10.7,35h13.763l5.41-18.694Zm108.365,6.9h5.905l8.951,11.8h16.406l-10.443-13.353a23.164,23.164,0,0,0,8.112-3.811,12.808,12.808,0,0,0,4.547-6.437c.845-2.763.614-5.055-.686-6.811-1.163-1.571-3.212-2.754-6.09-3.515a41.849,41.849,0,0,0-10.38-1.072h-23.665l-10.706,35h14.448l3.6-11.8Zm35.076-23.2,3.326,8.448h12.853l-8.118,26.55h14.67l8.121-26.55h14.82l2.582-8.448Zm-81.056,27.668c-3.362,0-5.524-.616-6.427-1.832a2.782,2.782,0,0,1-.3-2.576c.84-2.746,3.979-4.138,9.33-4.138,5.08,0,7.149.784,9.15,1.73l-1.1,3.614C-10626.791-10665.133-10630.837-10663.525-10635.515-10663.525Zm56.947-12.116h-8.624l2.339-7.652h8.851c2.615,0,4.311.5,5.039,1.479a2.459,2.459,0,0,1,.242,2.271,4.666,4.666,0,0,1-2.425,2.889A11.78,11.78,0,0,1-10578.567-10675.642Z" transform="translate(10814.001 11052)" /> </svg> <div class="content"> <p class="desc">Safe driving with longer life</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <div class="content"> <p class="desc">Safe driving with longer life</p> <span class="btn btn--round">Learn more</span> </div> </a> </div> <div class="display" data-id="vantra"> <a href="/global/en/tires/vantra.html"> <img class="display__bg t_none" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/vantra/bg.jpg" alt="배경이미지"> <img class="display__bg t_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/vantra/bg-t.jpg" alt="배경이미지"> <img class="display__bg m_show" src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/vantra/bg-m.jpg" alt="배경이미지"> <div class="display__wrap"> <div class="display__lottie"></div> </div> <!-- 웹 --> <div class="svg_wrap t_none"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape8" d="M1760,720H0V0H1760V720ZM1376.743,338.64a27.977,27.977,0,0,0-26.908,20.277l-17.742,61.872a22.732,22.732,0,0,0-.472,10.777,23.143,23.143,0,0,0,12.074,16.022,22.72,22.72,0,0,0,10.485,2.515h171.476l41.183-143.621a28.364,28.364,0,0,0,.591-13.448,28.874,28.874,0,0,0-15.068-20,28.37,28.37,0,0,0-13.091-3.139H1394.836l-12.551,43.778h119.448a6.3,6.3,0,0,1,6.057,8.034l-4.854,16.929Zm-213.683,53.784H1227.7l16.762,57.679h54.884L1282.344,391.6A53.535,53.535,0,0,0,1324.5,353.69l12.524-43.54a31.19,31.19,0,0,0,.66-14.793,31.755,31.755,0,0,0-16.568-22,31.2,31.2,0,0,0-14.4-3.455H1145.5l-51.644,180.2h52.543l16.664-57.679ZM448.64,338.64a27.979,27.979,0,0,0-26.908,20.277L403.99,420.79a22.733,22.733,0,0,0-.472,10.777,23.142,23.142,0,0,0,12.074,16.022,22.72,22.72,0,0,0,10.485,2.515H597.554l41.183-143.621a28.37,28.37,0,0,0,.59-13.448,28.875,28.875,0,0,0-15.069-20,28.369,28.369,0,0,0-13.091-3.139H466.735l-12.552,43.778H573.63a6.3,6.3,0,0,1,6.057,8.034l-4.854,16.929ZM912.3,269.9l-12.552,43.783h79.506L940.147,450.1h60.664l39.108-136.421h68.168l12.551-43.783ZM715.983,335.913h0L780.8,450.1h55.967l51.688-180.2H832.451L799.963,383.257,735.073,269.9h-56l-51.65,180.2H683.23l32.753-114.188h0v0h0ZM192.035,269.9l66.883,180.2H319.09L444.974,269.9H384.954l-85.79,121.339L252.05,269.9Zm1291.49,136.427h-96.381l4.751-16.566a10.131,10.131,0,0,1,9.735-7.34h88.747l-6.852,23.906Zm-928.1,0H459.041l4.751-16.566a10.131,10.131,0,0,1,9.735-7.34h88.748l-6.853,23.906Zm707.246-57.712H1175.72l9.827-34.9h89.582a6.3,6.3,0,0,1,6.056,8.034l-4.724,16.479a14.35,14.35,0,0,1-13.793,10.39Z" transform="translate(0 0)" /> </defs> <clipPath id="clipPath8"> <use xlink:href="#polygonShape8"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath8);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/vantra/bg.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M1760,720H0V0H1760V720ZM1376.743,338.64a27.977,27.977,0,0,0-26.908,20.277l-17.742,61.872a22.732,22.732,0,0,0-.472,10.777,23.143,23.143,0,0,0,12.074,16.022,22.72,22.72,0,0,0,10.485,2.515h171.476l41.183-143.621a28.364,28.364,0,0,0,.591-13.448,28.874,28.874,0,0,0-15.068-20,28.37,28.37,0,0,0-13.091-3.139H1394.836l-12.551,43.778h119.448a6.3,6.3,0,0,1,6.057,8.034l-4.854,16.929Zm-213.683,53.784H1227.7l16.762,57.679h54.884L1282.344,391.6A53.535,53.535,0,0,0,1324.5,353.69l12.524-43.54a31.19,31.19,0,0,0,.66-14.793,31.755,31.755,0,0,0-16.568-22,31.2,31.2,0,0,0-14.4-3.455H1145.5l-51.644,180.2h52.543l16.664-57.679ZM448.64,338.64a27.979,27.979,0,0,0-26.908,20.277L403.99,420.79a22.733,22.733,0,0,0-.472,10.777,23.142,23.142,0,0,0,12.074,16.022,22.72,22.72,0,0,0,10.485,2.515H597.554l41.183-143.621a28.37,28.37,0,0,0,.59-13.448,28.875,28.875,0,0,0-15.069-20,28.369,28.369,0,0,0-13.091-3.139H466.735l-12.552,43.778H573.63a6.3,6.3,0,0,1,6.057,8.034l-4.854,16.929ZM912.3,269.9l-12.552,43.783h79.506L940.147,450.1h60.664l39.108-136.421h68.168l12.551-43.783ZM715.983,335.913h0L780.8,450.1h55.967l51.688-180.2H832.451L799.963,383.257,735.073,269.9h-56l-51.65,180.2H683.23l32.753-114.188h0v0h0ZM192.035,269.9l66.883,180.2H319.09L444.974,269.9H384.954l-85.79,121.339L252.05,269.9Zm1291.49,136.427h-96.381l4.751-16.566a10.131,10.131,0,0,1,9.735-7.34h88.747l-6.852,23.906Zm-928.1,0H459.041l4.751-16.566a10.131,10.131,0,0,1,9.735-7.34h88.748l-6.853,23.906Zm707.246-57.712H1175.72l9.827-34.9h89.582a6.3,6.3,0,0,1,6.056,8.034l-4.724,16.479a14.35,14.35,0,0,1-13.793,10.39Z" transform="translate(0 0)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="1760" height="720" viewBox="0 0 1760 720" preserveAspectRatio="xMidYMid slice"> <path d="M1760,720H0V0H1760V720ZM1376.743,338.64a27.977,27.977,0,0,0-26.908,20.277l-17.742,61.872a22.732,22.732,0,0,0-.472,10.777,23.143,23.143,0,0,0,12.074,16.022,22.72,22.72,0,0,0,10.485,2.515h171.476l41.183-143.621a28.364,28.364,0,0,0,.591-13.448,28.874,28.874,0,0,0-15.068-20,28.37,28.37,0,0,0-13.091-3.139H1394.836l-12.551,43.778h119.448a6.3,6.3,0,0,1,6.057,8.034l-4.854,16.929Zm-213.683,53.784H1227.7l16.762,57.679h54.884L1282.344,391.6A53.535,53.535,0,0,0,1324.5,353.69l12.524-43.54a31.19,31.19,0,0,0,.66-14.793,31.755,31.755,0,0,0-16.568-22,31.2,31.2,0,0,0-14.4-3.455H1145.5l-51.644,180.2h52.543l16.664-57.679ZM448.64,338.64a27.979,27.979,0,0,0-26.908,20.277L403.99,420.79a22.733,22.733,0,0,0-.472,10.777,23.142,23.142,0,0,0,12.074,16.022,22.72,22.72,0,0,0,10.485,2.515H597.554l41.183-143.621a28.37,28.37,0,0,0,.59-13.448,28.875,28.875,0,0,0-15.069-20,28.369,28.369,0,0,0-13.091-3.139H466.735l-12.552,43.778H573.63a6.3,6.3,0,0,1,6.057,8.034l-4.854,16.929ZM912.3,269.9l-12.552,43.783h79.506L940.147,450.1h60.664l39.108-136.421h68.168l12.551-43.783ZM715.983,335.913h0L780.8,450.1h55.967l51.688-180.2H832.451L799.963,383.257,735.073,269.9h-56l-51.65,180.2H683.23l32.753-114.188h0v0h0ZM192.035,269.9l66.883,180.2H319.09L444.974,269.9H384.954l-85.79,121.339L252.05,269.9Zm1291.49,136.427h-96.381l4.751-16.566a10.131,10.131,0,0,1,9.735-7.34h88.747l-6.852,23.906Zm-928.1,0H459.041l4.751-16.566a10.131,10.131,0,0,1,9.735-7.34h88.748l-6.853,23.906Zm707.246-57.712H1175.72l9.827-34.9h89.582a6.3,6.3,0,0,1,6.056,8.034l-4.724,16.479a14.35,14.35,0,0,1-13.793,10.39Z" transform="translate(0 0)" /> </svg> <div class="content"> <p class="desc">Reliable Partner of Commercial Van & Light Truck</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 태블릿 --> <div class="svg_wrap t_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape888" d="M350,560H0V0H350V560ZM285.448,371.218a6.222,6.222,0,0,0-5.982,4.508l-3.946,13.757A5.11,5.11,0,0,0,280.431,396h38.127l9.157-31.934a6.376,6.376,0,0,0-6.129-8.134H289.471l-2.791,9.734h26.559a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765Zm-47.511,11.958H252.31L256.036,396h12.2l-3.781-13.01a11.9,11.9,0,0,0,9.373-8.428l2.785-9.681a7.012,7.012,0,0,0-6.739-8.95H234.031L222.548,396h11.683l3.705-12.824Zm-55.755-27.243-2.791,9.735h17.678L188.373,396h13.488l8.7-30.333h15.157l2.791-9.735H182.182ZM79.089,371.218a6.223,6.223,0,0,0-5.983,4.508l-3.945,13.757A5.11,5.11,0,0,0,74.073,396H112.2l9.157-31.934a6.377,6.377,0,0,0-6.13-8.134H83.112l-2.791,9.734H106.88a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765ZM22.035,355.933,36.905,396H50.284l27.99-40.068H64.929L45.854,382.912,35.378,355.933Zm116.5,14.678v0L152.943,396h12.444l11.492-40.067H164.427l-7.223,25.2-14.428-25.2H130.324L118.84,396h12.409l7.282-25.387Zm170.659,15.655h-21.43l1.057-3.683a2.261,2.261,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm-206.358,0H81.4l1.056-3.683a2.263,2.263,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm157.251-12.831H240.752l2.184-7.761h19.919a1.4,1.4,0,0,1,1.346,1.786l-1.05,3.665A3.207,3.207,0,0,1,260.084,373.435Z" transform="translate(0 0)" /> </defs> <clipPath id="clipPath888"> <use xlink:href="#polygonShape888"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath888);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/vantra/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M350,560H0V0H350V560ZM285.448,371.218a6.222,6.222,0,0,0-5.982,4.508l-3.946,13.757A5.11,5.11,0,0,0,280.431,396h38.127l9.157-31.934a6.376,6.376,0,0,0-6.129-8.134H289.471l-2.791,9.734h26.559a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765Zm-47.511,11.958H252.31L256.036,396h12.2l-3.781-13.01a11.9,11.9,0,0,0,9.373-8.428l2.785-9.681a7.012,7.012,0,0,0-6.739-8.95H234.031L222.548,396h11.683l3.705-12.824Zm-55.755-27.243-2.791,9.735h17.678L188.373,396h13.488l8.7-30.333h15.157l2.791-9.735H182.182ZM79.089,371.218a6.223,6.223,0,0,0-5.983,4.508l-3.945,13.757A5.11,5.11,0,0,0,74.073,396H112.2l9.157-31.934a6.377,6.377,0,0,0-6.13-8.134H83.112l-2.791,9.734H106.88a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765ZM22.035,355.933,36.905,396H50.284l27.99-40.068H64.929L45.854,382.912,35.378,355.933Zm116.5,14.678v0L152.943,396h12.444l11.492-40.067H164.427l-7.223,25.2-14.428-25.2H130.324L118.84,396h12.409l7.282-25.387Zm170.659,15.655h-21.43l1.057-3.683a2.261,2.261,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm-206.358,0H81.4l1.056-3.683a2.263,2.263,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm157.251-12.831H240.752l2.184-7.761h19.919a1.4,1.4,0,0,1,1.346,1.786l-1.05,3.665A3.207,3.207,0,0,1,260.084,373.435Z" transform="translate(0 0)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M350,560H0V0H350V560ZM285.448,371.218a6.222,6.222,0,0,0-5.982,4.508l-3.946,13.757A5.11,5.11,0,0,0,280.431,396h38.127l9.157-31.934a6.376,6.376,0,0,0-6.129-8.134H289.471l-2.791,9.734h26.559a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765Zm-47.511,11.958H252.31L256.036,396h12.2l-3.781-13.01a11.9,11.9,0,0,0,9.373-8.428l2.785-9.681a7.012,7.012,0,0,0-6.739-8.95H234.031L222.548,396h11.683l3.705-12.824Zm-55.755-27.243-2.791,9.735h17.678L188.373,396h13.488l8.7-30.333h15.157l2.791-9.735H182.182ZM79.089,371.218a6.223,6.223,0,0,0-5.983,4.508l-3.945,13.757A5.11,5.11,0,0,0,74.073,396H112.2l9.157-31.934a6.377,6.377,0,0,0-6.13-8.134H83.112l-2.791,9.734H106.88a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765ZM22.035,355.933,36.905,396H50.284l27.99-40.068H64.929L45.854,382.912,35.378,355.933Zm116.5,14.678v0L152.943,396h12.444l11.492-40.067H164.427l-7.223,25.2-14.428-25.2H130.324L118.84,396h12.409l7.282-25.387Zm170.659,15.655h-21.43l1.057-3.683a2.261,2.261,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm-206.358,0H81.4l1.056-3.683a2.263,2.263,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm157.251-12.831H240.752l2.184-7.761h19.919a1.4,1.4,0,0,1,1.346,1.786l-1.05,3.665A3.207,3.207,0,0,1,260.084,373.435Z" transform="translate(0 0)" /> </svg> <div class="content"> <p class="desc">Reliable Partner of Commercial Van & Light Truck</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <!-- 모바일 --> <div class="svg_wrap m_show"> <svg class="display__logo_blur" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <g> <defs> <path id="polygonShape888-m" d="M350,560H0V0H350V560ZM285.448,371.218a6.222,6.222,0,0,0-5.982,4.508l-3.946,13.757A5.11,5.11,0,0,0,280.431,396h38.127l9.157-31.934a6.376,6.376,0,0,0-6.129-8.134H289.471l-2.791,9.734h26.559a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765Zm-47.511,11.958H252.31L256.036,396h12.2l-3.781-13.01a11.9,11.9,0,0,0,9.373-8.428l2.785-9.681a7.012,7.012,0,0,0-6.739-8.95H234.031L222.548,396h11.683l3.705-12.824Zm-55.755-27.243-2.791,9.735h17.678L188.373,396h13.488l8.7-30.333h15.157l2.791-9.735H182.182ZM79.089,371.218a6.223,6.223,0,0,0-5.983,4.508l-3.945,13.757A5.11,5.11,0,0,0,74.073,396H112.2l9.157-31.934a6.377,6.377,0,0,0-6.13-8.134H83.112l-2.791,9.734H106.88a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765ZM22.035,355.933,36.905,396H50.284l27.99-40.068H64.929L45.854,382.912,35.378,355.933Zm116.5,14.678v0L152.943,396h12.444l11.492-40.067H164.427l-7.223,25.2-14.428-25.2H130.324L118.84,396h12.409l7.282-25.387Zm170.659,15.655h-21.43l1.057-3.683a2.261,2.261,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm-206.358,0H81.4l1.056-3.683a2.263,2.263,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm157.251-12.831H240.752l2.184-7.761h19.919a1.4,1.4,0,0,1,1.346,1.786l-1.05,3.665A3.207,3.207,0,0,1,260.084,373.435Z" transform="translate(0 0)" /> </defs> <clipPath id="clipPath888-m"> <use xlink:href="#polygonShape888-m"/> </clipPath> <g id="clipMask" style="clip-path: url(#clipPath888-m);"> <image class="mask_img" xlink:href="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/vantra/bg-m.jpg"></image> </g> </g> </svg> <svg class="display__logo_stroke" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M350,560H0V0H350V560ZM285.448,371.218a6.222,6.222,0,0,0-5.982,4.508l-3.946,13.757A5.11,5.11,0,0,0,280.431,396h38.127l9.157-31.934a6.376,6.376,0,0,0-6.129-8.134H289.471l-2.791,9.734h26.559a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765Zm-47.511,11.958H252.31L256.036,396h12.2l-3.781-13.01a11.9,11.9,0,0,0,9.373-8.428l2.785-9.681a7.012,7.012,0,0,0-6.739-8.95H234.031L222.548,396h11.683l3.705-12.824Zm-55.755-27.243-2.791,9.735h17.678L188.373,396h13.488l8.7-30.333h15.157l2.791-9.735H182.182ZM79.089,371.218a6.223,6.223,0,0,0-5.983,4.508l-3.945,13.757A5.11,5.11,0,0,0,74.073,396H112.2l9.157-31.934a6.377,6.377,0,0,0-6.13-8.134H83.112l-2.791,9.734H106.88a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765ZM22.035,355.933,36.905,396H50.284l27.99-40.068H64.929L45.854,382.912,35.378,355.933Zm116.5,14.678v0L152.943,396h12.444l11.492-40.067H164.427l-7.223,25.2-14.428-25.2H130.324L118.84,396h12.409l7.282-25.387Zm170.659,15.655h-21.43l1.057-3.683a2.261,2.261,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm-206.358,0H81.4l1.056-3.683a2.263,2.263,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm157.251-12.831H240.752l2.184-7.761h19.919a1.4,1.4,0,0,1,1.346,1.786l-1.05,3.665A3.207,3.207,0,0,1,260.084,373.435Z" transform="translate(0 0)" /> </svg> <div class="display__logo_frame_wrap"> <svg class="display__logo_frame" xmlns="http://www.w3.org/2000/svg" width="350" height="560" viewBox="0 0 350 560" preserveAspectRatio="xMidYMid slice"> <path d="M350,560H0V0H350V560ZM285.448,371.218a6.222,6.222,0,0,0-5.982,4.508l-3.946,13.757A5.11,5.11,0,0,0,280.431,396h38.127l9.157-31.934a6.376,6.376,0,0,0-6.129-8.134H289.471l-2.791,9.734h26.559a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765Zm-47.511,11.958H252.31L256.036,396h12.2l-3.781-13.01a11.9,11.9,0,0,0,9.373-8.428l2.785-9.681a7.012,7.012,0,0,0-6.739-8.95H234.031L222.548,396h11.683l3.705-12.824Zm-55.755-27.243-2.791,9.735h17.678L188.373,396h13.488l8.7-30.333h15.157l2.791-9.735H182.182ZM79.089,371.218a6.223,6.223,0,0,0-5.983,4.508l-3.945,13.757A5.11,5.11,0,0,0,74.073,396H112.2l9.157-31.934a6.377,6.377,0,0,0-6.13-8.134H83.112l-2.791,9.734H106.88a1.4,1.4,0,0,1,1.346,1.786l-1.079,3.765ZM22.035,355.933,36.905,396H50.284l27.99-40.068H64.929L45.854,382.912,35.378,355.933Zm116.5,14.678v0L152.943,396h12.444l11.492-40.067H164.427l-7.223,25.2-14.428-25.2H130.324L118.84,396h12.409l7.282-25.387Zm170.659,15.655h-21.43l1.057-3.683a2.261,2.261,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm-206.358,0H81.4l1.056-3.683a2.263,2.263,0,0,1,2.164-1.633h19.733l-1.523,5.315Zm157.251-12.831H240.752l2.184-7.761h19.919a1.4,1.4,0,0,1,1.346,1.786l-1.05,3.665A3.207,3.207,0,0,1,260.084,373.435Z" transform="translate(0 0)" /> </svg> <div class="content"> <p class="desc">Reliable Partner of Commercial Van & Light Truck</p> <span class="btn btn--round">Learn more</span> </div> </div> </div> <div class="content"> <p class="desc">Reliable Partner of Commercial Van & Light Truck</p> <span class="btn btn--round">Learn more</span> </div> </a> </div> </div> <div class="ghbs__container swiper-container"> <ul class="ghbs__list swiper-wrapper"> <li class="ghbs__item ghbs__item-ion swiper-slide is-active"> <a href="#ion"> <span class="a11y">ion</span> </a> </li> <li class="ghbs__item ghbs__item-ventus swiper-slide"> <a href="#ventus"> <span class="a11y">ventus</span> </a> </li> <li class="ghbs__item ghbs__item-dynapro swiper-slide"> <a href="#dynapro"> <span class="a11y">dynapro</span> </a> </li> <li class="ghbs__item ghbs__item-weather-flex swiper-slide"> <a href="#weather-flex"> <span class="a11y">weather-flex</span> </a> </li> <li class="ghbs__item ghbs__item-kinergy swiper-slide"> <a href="#kinergy"> <span class="a11y">kinergy</span> </a> </li> <li class="ghbs__item ghbs__item-winter-icept swiper-slide"> <a href="#winter-icept"> <span class="a11y">winter-icept</span> </a> </li> <li class="ghbs__item ghbs__item-smart swiper-slide"> <a href="#smart"> <span class="a11y">smart</span> </a> </li> <li class="ghbs__item ghbs__item-vantra swiper-slide"> <a href="#vantra"> <span class="a11y">vantra</span> </a> </li> </ul> </div> <hr class="divider"> </div> </section> <script> /******/ (() => { // webpackBootstrap /******/ var __webpack_modules__ = ({ /***/ 1248: /***/ ((module, exports, __webpack_require__) => { var __WEBPACK_AMD_DEFINE_RESULT__;(typeof navigator !== "undefined") && (function(root, factory) { if (true) { !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { return factory(root); }).call(exports, __webpack_require__, exports, module), __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); } else {} }((window || {}), function(window) { /* global locationHref:writable, animationManager, subframeEnabled:writable, defaultCurveSegments:writable, roundValues, expressionsPlugin:writable, PropertyFactory, ShapePropertyFactory, Matrix, idPrefix:writable, _useWebWorker:writable */ /* exported locationHref, subframeEnabled, expressionsPlugin, idPrefix, _useWebWorker */ 'use strict'; /* exported svgNS, locationHref, initialDefaultFrame, _useWebWorker */ var svgNS = 'http://www.w3.org/2000/svg'; var locationHref = ''; var initialDefaultFrame = -999999; var _useWebWorker = false; /* global createSizedArray */ /* exported subframeEnabled, expressionsPlugin, isSafari, cachedColors, bmPow, bmSqrt, bmFloor, bmMax, bmMin, ProjectInterface, defaultCurveSegments, degToRads, roundCorner, bmRnd, styleDiv, BMEnterFrameEvent, BMCompleteEvent, BMCompleteLoopEvent, BMSegmentStartEvent, BMDestroyEvent, BMRenderFrameErrorEvent, BMConfigErrorEvent, BMAnimationConfigErrorEvent, createElementID, addSaturationToRGB, addBrightnessToRGB, addHueToRGB, rgbToHex */ var subframeEnabled = true; var idPrefix = ''; var expressionsPlugin; var isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent); var cachedColors = {}; var bmRnd; var bmPow = Math.pow; var bmSqrt = Math.sqrt; var bmFloor = Math.floor; var bmMax = Math.max; var bmMin = Math.min; var BMMath = {}; (function () { var propertyNames = ['abs', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atanh', 'atan2', 'ceil', 'cbrt', 'expm1', 'clz32', 'cos', 'cosh', 'exp', 'floor', 'fround', 'hypot', 'imul', 'log', 'log1p', 'log2', 'log10', 'max', 'min', 'pow', 'random', 'round', 'sign', 'sin', 'sinh', 'sqrt', 'tan', 'tanh', 'trunc', 'E', 'LN10', 'LN2', 'LOG10E', 'LOG2E', 'PI', 'SQRT1_2', 'SQRT2']; var i; var len = propertyNames.length; for (i = 0; i < len; i += 1) { BMMath[propertyNames[i]] = Math[propertyNames[i]]; } }()); function ProjectInterface() { return {}; } BMMath.random = Math.random; BMMath.abs = function (val) { var tOfVal = typeof val; if (tOfVal === 'object' && val.length) { var absArr = createSizedArray(val.length); var i; var len = val.length; for (i = 0; i < len; i += 1) { absArr[i] = Math.abs(val[i]); } return absArr; } return Math.abs(val); }; var defaultCurveSegments = 150; var degToRads = Math.PI / 180; var roundCorner = 0.5519; function roundValues(flag) { if (flag) { bmRnd = Math.round; } else { bmRnd = function (val) { return val; }; } } roundValues(false); function styleDiv(element) { element.style.position = 'absolute'; element.style.top = 0; element.style.left = 0; element.style.display = 'block'; element.style.transformOrigin = '0 0'; element.style.webkitTransformOrigin = '0 0'; element.style.backfaceVisibility = 'visible'; element.style.webkitBackfaceVisibility = 'visible'; element.style.transformStyle = 'preserve-3d'; element.style.webkitTransformStyle = 'preserve-3d'; element.style.mozTransformStyle = 'preserve-3d'; } function BMEnterFrameEvent(type, currentTime, totalTime, frameMultiplier) { this.type = type; this.currentTime = currentTime; this.totalTime = totalTime; this.direction = frameMultiplier < 0 ? -1 : 1; } function BMCompleteEvent(type, frameMultiplier) { this.type = type; this.direction = frameMultiplier < 0 ? -1 : 1; } function BMCompleteLoopEvent(type, totalLoops, currentLoop, frameMultiplier) { this.type = type; this.currentLoop = currentLoop; this.totalLoops = totalLoops; this.direction = frameMultiplier < 0 ? -1 : 1; } function BMSegmentStartEvent(type, firstFrame, totalFrames) { this.type = type; this.firstFrame = firstFrame; this.totalFrames = totalFrames; } function BMDestroyEvent(type, target) { this.type = type; this.target = target; } function BMRenderFrameErrorEvent(nativeError, currentTime) { this.type = 'renderFrameError'; this.nativeError = nativeError; this.currentTime = currentTime; } function BMConfigErrorEvent(nativeError) { this.type = 'configError'; this.nativeError = nativeError; } function BMAnimationConfigErrorEvent(type, nativeError) { this.type = type; this.nativeError = nativeError; } var createElementID = (function () { var _count = 0; return function createID() { _count += 1; return idPrefix + '__lottie_element_' + _count; }; }()); function HSVtoRGB(h, s, v) { var r; var g; var b; var i; var f; var p; var q; var t; i = Math.floor(h * 6); f = h * 6 - i; p = v * (1 - s); q = v * (1 - f * s); t = v * (1 - (1 - f) * s); switch (i % 6) { case 0: r = v; g = t; b = p; break; case 1: r = q; g = v; b = p; break; case 2: r = p; g = v; b = t; break; case 3: r = p; g = q; b = v; break; case 4: r = t; g = p; b = v; break; case 5: r = v; g = p; b = q; break; default: break; } return [r, g, b]; } function RGBtoHSV(r, g, b) { var max = Math.max(r, g, b); var min = Math.min(r, g, b); var d = max - min; var h; var s = (max === 0 ? 0 : d / max); var v = max / 255; switch (max) { case min: h = 0; break; case r: h = (g - b) + d * (g < b ? 6 : 0); h /= 6 * d; break; case g: h = (b - r) + d * 2; h /= 6 * d; break; case b: h = (r - g) + d * 4; h /= 6 * d; break; default: break; } return [ h, s, v, ]; } function addSaturationToRGB(color, offset) { var hsv = RGBtoHSV(color[0] * 255, color[1] * 255, color[2] * 255); hsv[1] += offset; if (hsv[1] > 1) { hsv[1] = 1; } else if (hsv[1] <= 0) { hsv[1] = 0; } return HSVtoRGB(hsv[0], hsv[1], hsv[2]); } function addBrightnessToRGB(color, offset) { var hsv = RGBtoHSV(color[0] * 255, color[1] * 255, color[2] * 255); hsv[2] += offset; if (hsv[2] > 1) { hsv[2] = 1; } else if (hsv[2] < 0) { hsv[2] = 0; } return HSVtoRGB(hsv[0], hsv[1], hsv[2]); } function addHueToRGB(color, offset) { var hsv = RGBtoHSV(color[0] * 255, color[1] * 255, color[2] * 255); hsv[0] += offset / 360; if (hsv[0] > 1) { hsv[0] -= 1; } else if (hsv[0] < 0) { hsv[0] += 1; } return HSVtoRGB(hsv[0], hsv[1], hsv[2]); } var rgbToHex = (function () { var colorMap = []; var i; var hex; for (i = 0; i < 256; i += 1) { hex = i.toString(16); colorMap[i] = hex.length === 1 ? '0' + hex : hex; } return function (r, g, b) { if (r < 0) { r = 0; } if (g < 0) { g = 0; } if (b < 0) { b = 0; } return '#' + colorMap[r] + colorMap[g] + colorMap[b]; }; }()); function BaseEvent() {} BaseEvent.prototype = { triggerEvent: function (eventName, args) { if (this._cbs[eventName]) { var callbacks = this._cbs[eventName]; for (var i = 0; i < callbacks.length; i += 1) { callbacks[i](args); } } }, addEventListener: function (eventName, callback) { if (!this._cbs[eventName]) { this._cbs[eventName] = []; } this._cbs[eventName].push(callback); return function () { this.removeEventListener(eventName, callback); }.bind(this); }, removeEventListener: function (eventName, callback) { if (!callback) { this._cbs[eventName] = null; } else if (this._cbs[eventName]) { var i = 0; var len = this._cbs[eventName].length; while (i < len) { if (this._cbs[eventName][i] === callback) { this._cbs[eventName].splice(i, 1); i -= 1; len -= 1; } i += 1; } if (!this._cbs[eventName].length) { this._cbs[eventName] = null; } } }, }; /* exported createTypedArray, createSizedArray */ var createTypedArray = (function () { function createRegularArray(type, len) { var i = 0; var arr = []; var value; switch (type) { case 'int16': case 'uint8c': value = 1; break; default: value = 1.1; break; } for (i = 0; i < len; i += 1) { arr.push(value); } return arr; } function createTypedArrayFactory(type, len) { if (type === 'float32') { return new Float32Array(len); } if (type === 'int16') { return new Int16Array(len); } if (type === 'uint8c') { return new Uint8ClampedArray(len); } return createRegularArray(type, len); } if (typeof Uint8ClampedArray === 'function' && typeof Float32Array === 'function') { return createTypedArrayFactory; } return createRegularArray; }()); function createSizedArray(len) { return Array.apply(null, { length: len }); } /* global svgNS */ /* exported createNS */ function createNS(type) { // return {appendChild:function(){},setAttribute:function(){},style:{}} return document.createElementNS(svgNS, type); } /* exported createTag */ function createTag(type) { // return {appendChild:function(){},setAttribute:function(){},style:{}} return document.createElement(type); } function DynamicPropertyContainer() {} DynamicPropertyContainer.prototype = { addDynamicProperty: function (prop) { if (this.dynamicProperties.indexOf(prop) === -1) { this.dynamicProperties.push(prop); this.container.addDynamicProperty(this); this._isAnimated = true; } }, iterateDynamicProperties: function () { this._mdf = false; var i; var len = this.dynamicProperties.length; for (i = 0; i < len; i += 1) { this.dynamicProperties[i].getValue(); if (this.dynamicProperties[i]._mdf) { this._mdf = true; } } }, initDynamicPropertyContainer: function (container) { this.container = container; this.dynamicProperties = []; this._mdf = false; this._isAnimated = false; }, }; /* exported getBlendMode */ var getBlendMode = (function () { var blendModeEnums = { 0: 'source-over', 1: 'multiply', 2: 'screen', 3: 'overlay', 4: 'darken', 5: 'lighten', 6: 'color-dodge', 7: 'color-burn', 8: 'hard-light', 9: 'soft-light', 10: 'difference', 11: 'exclusion', 12: 'hue', 13: 'saturation', 14: 'color', 15: 'luminosity', }; return function (mode) { return blendModeEnums[mode] || ''; }; }()); /* exported lineCapEnum, lineJoinEnum */ var lineCapEnum = { 1: 'butt', 2: 'round', 3: 'square', }; var lineJoinEnum = { 1: 'miter', 2: 'round', 3: 'bevel', }; /* global createTypedArray */ /*! Transformation Matrix v2.0 (c) Epistemex 2014-2015 www.epistemex.com By Ken Fyrstenberg Contributions by leeoniya. License: MIT, header required. */ /** * 2D transformation matrix object initialized with identity matrix. * * The matrix can synchronize a canvas context by supplying the context * as an argument, or later apply current absolute transform to an * existing context. * * All values are handled as floating point values. * * @param {CanvasRenderingContext2D} [context] - Optional context to sync with Matrix * @prop {number} a - scale x * @prop {number} b - shear y * @prop {number} c - shear x * @prop {number} d - scale y * @prop {number} e - translate x * @prop {number} f - translate y * @prop {CanvasRenderingContext2D|null} [context=null] - set or get current canvas context * @constructor */ var Matrix = (function () { var _cos = Math.cos; var _sin = Math.sin; var _tan = Math.tan; var _rnd = Math.round; function reset() { this.props[0] = 1; this.props[1] = 0; this.props[2] = 0; this.props[3] = 0; this.props[4] = 0; this.props[5] = 1; this.props[6] = 0; this.props[7] = 0; this.props[8] = 0; this.props[9] = 0; this.props[10] = 1; this.props[11] = 0; this.props[12] = 0; this.props[13] = 0; this.props[14] = 0; this.props[15] = 1; return this; } function rotate(angle) { if (angle === 0) { return this; } var mCos = _cos(angle); var mSin = _sin(angle); return this._t(mCos, -mSin, 0, 0, mSin, mCos, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); } function rotateX(angle) { if (angle === 0) { return this; } var mCos = _cos(angle); var mSin = _sin(angle); return this._t(1, 0, 0, 0, 0, mCos, -mSin, 0, 0, mSin, mCos, 0, 0, 0, 0, 1); } function rotateY(angle) { if (angle === 0) { return this; } var mCos = _cos(angle); var mSin = _sin(angle); return this._t(mCos, 0, mSin, 0, 0, 1, 0, 0, -mSin, 0, mCos, 0, 0, 0, 0, 1); } function rotateZ(angle) { if (angle === 0) { return this; } var mCos = _cos(angle); var mSin = _sin(angle); return this._t(mCos, -mSin, 0, 0, mSin, mCos, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); } function shear(sx, sy) { return this._t(1, sy, sx, 1, 0, 0); } function skew(ax, ay) { return this.shear(_tan(ax), _tan(ay)); } function skewFromAxis(ax, angle) { var mCos = _cos(angle); var mSin = _sin(angle); return this._t(mCos, mSin, 0, 0, -mSin, mCos, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1) ._t(1, 0, 0, 0, _tan(ax), 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1) ._t(mCos, -mSin, 0, 0, mSin, mCos, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); // return this._t(mCos, mSin, -mSin, mCos, 0, 0)._t(1, 0, _tan(ax), 1, 0, 0)._t(mCos, -mSin, mSin, mCos, 0, 0); } function scale(sx, sy, sz) { if (!sz && sz !== 0) { sz = 1; } if (sx === 1 && sy === 1 && sz === 1) { return this; } return this._t(sx, 0, 0, 0, 0, sy, 0, 0, 0, 0, sz, 0, 0, 0, 0, 1); } function setTransform(a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p) { this.props[0] = a; this.props[1] = b; this.props[2] = c; this.props[3] = d; this.props[4] = e; this.props[5] = f; this.props[6] = g; this.props[7] = h; this.props[8] = i; this.props[9] = j; this.props[10] = k; this.props[11] = l; this.props[12] = m; this.props[13] = n; this.props[14] = o; this.props[15] = p; return this; } function translate(tx, ty, tz) { tz = tz || 0; if (tx !== 0 || ty !== 0 || tz !== 0) { return this._t(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, tx, ty, tz, 1); } return this; } function transform(a2, b2, c2, d2, e2, f2, g2, h2, i2, j2, k2, l2, m2, n2, o2, p2) { var _p = this.props; if (a2 === 1 && b2 === 0 && c2 === 0 && d2 === 0 && e2 === 0 && f2 === 1 && g2 === 0 && h2 === 0 && i2 === 0 && j2 === 0 && k2 === 1 && l2 === 0) { // NOTE: commenting this condition because TurboFan deoptimizes code when present // if(m2 !== 0 || n2 !== 0 || o2 !== 0){ _p[12] = _p[12] * a2 + _p[15] * m2; _p[13] = _p[13] * f2 + _p[15] * n2; _p[14] = _p[14] * k2 + _p[15] * o2; _p[15] *= p2; // } this._identityCalculated = false; return this; } var a1 = _p[0]; var b1 = _p[1]; var c1 = _p[2]; var d1 = _p[3]; var e1 = _p[4]; var f1 = _p[5]; var g1 = _p[6]; var h1 = _p[7]; var i1 = _p[8]; var j1 = _p[9]; var k1 = _p[10]; var l1 = _p[11]; var m1 = _p[12]; var n1 = _p[13]; var o1 = _p[14]; var p1 = _p[15]; /* matrix order (canvas compatible): * ace * bdf * 001 */ _p[0] = a1 * a2 + b1 * e2 + c1 * i2 + d1 * m2; _p[1] = a1 * b2 + b1 * f2 + c1 * j2 + d1 * n2; _p[2] = a1 * c2 + b1 * g2 + c1 * k2 + d1 * o2; _p[3] = a1 * d2 + b1 * h2 + c1 * l2 + d1 * p2; _p[4] = e1 * a2 + f1 * e2 + g1 * i2 + h1 * m2; _p[5] = e1 * b2 + f1 * f2 + g1 * j2 + h1 * n2; _p[6] = e1 * c2 + f1 * g2 + g1 * k2 + h1 * o2; _p[7] = e1 * d2 + f1 * h2 + g1 * l2 + h1 * p2; _p[8] = i1 * a2 + j1 * e2 + k1 * i2 + l1 * m2; _p[9] = i1 * b2 + j1 * f2 + k1 * j2 + l1 * n2; _p[10] = i1 * c2 + j1 * g2 + k1 * k2 + l1 * o2; _p[11] = i1 * d2 + j1 * h2 + k1 * l2 + l1 * p2; _p[12] = m1 * a2 + n1 * e2 + o1 * i2 + p1 * m2; _p[13] = m1 * b2 + n1 * f2 + o1 * j2 + p1 * n2; _p[14] = m1 * c2 + n1 * g2 + o1 * k2 + p1 * o2; _p[15] = m1 * d2 + n1 * h2 + o1 * l2 + p1 * p2; this._identityCalculated = false; return this; } function isIdentity() { if (!this._identityCalculated) { this._identity = !(this.props[0] !== 1 || this.props[1] !== 0 || this.props[2] !== 0 || this.props[3] !== 0 || this.props[4] !== 0 || this.props[5] !== 1 || this.props[6] !== 0 || this.props[7] !== 0 || this.props[8] !== 0 || this.props[9] !== 0 || this.props[10] !== 1 || this.props[11] !== 0 || this.props[12] !== 0 || this.props[13] !== 0 || this.props[14] !== 0 || this.props[15] !== 1); this._identityCalculated = true; } return this._identity; } function equals(matr) { var i = 0; while (i < 16) { if (matr.props[i] !== this.props[i]) { return false; } i += 1; } return true; } function clone(matr) { var i; for (i = 0; i < 16; i += 1) { matr.props[i] = this.props[i]; } return matr; } function cloneFromProps(props) { var i; for (i = 0; i < 16; i += 1) { this.props[i] = props[i]; } } function applyToPoint(x, y, z) { return { x: x * this.props[0] + y * this.props[4] + z * this.props[8] + this.props[12], y: x * this.props[1] + y * this.props[5] + z * this.props[9] + this.props[13], z: x * this.props[2] + y * this.props[6] + z * this.props[10] + this.props[14], }; /* return { x: x * me.a + y * me.c + me.e, y: x * me.b + y * me.d + me.f }; */ } function applyToX(x, y, z) { return x * this.props[0] + y * this.props[4] + z * this.props[8] + this.props[12]; } function applyToY(x, y, z) { return x * this.props[1] + y * this.props[5] + z * this.props[9] + this.props[13]; } function applyToZ(x, y, z) { return x * this.props[2] + y * this.props[6] + z * this.props[10] + this.props[14]; } function getInverseMatrix() { var determinant = this.props[0] * this.props[5] - this.props[1] * this.props[4]; var a = this.props[5] / determinant; var b = -this.props[1] / determinant; var c = -this.props[4] / determinant; var d = this.props[0] / determinant; var e = (this.props[4] * this.props[13] - this.props[5] * this.props[12]) / determinant; var f = -(this.props[0] * this.props[13] - this.props[1] * this.props[12]) / determinant; var inverseMatrix = new Matrix(); inverseMatrix.props[0] = a; inverseMatrix.props[1] = b; inverseMatrix.props[4] = c; inverseMatrix.props[5] = d; inverseMatrix.props[12] = e; inverseMatrix.props[13] = f; return inverseMatrix; } function inversePoint(pt) { var inverseMatrix = this.getInverseMatrix(); return inverseMatrix.applyToPointArray(pt[0], pt[1], pt[2] || 0); } function inversePoints(pts) { var i; var len = pts.length; var retPts = []; for (i = 0; i < len; i += 1) { retPts[i] = inversePoint(pts[i]); } return retPts; } function applyToTriplePoints(pt1, pt2, pt3) { var arr = createTypedArray('float32', 6); if (this.isIdentity()) { arr[0] = pt1[0]; arr[1] = pt1[1]; arr[2] = pt2[0]; arr[3] = pt2[1]; arr[4] = pt3[0]; arr[5] = pt3[1]; } else { var p0 = this.props[0]; var p1 = this.props[1]; var p4 = this.props[4]; var p5 = this.props[5]; var p12 = this.props[12]; var p13 = this.props[13]; arr[0] = pt1[0] * p0 + pt1[1] * p4 + p12; arr[1] = pt1[0] * p1 + pt1[1] * p5 + p13; arr[2] = pt2[0] * p0 + pt2[1] * p4 + p12; arr[3] = pt2[0] * p1 + pt2[1] * p5 + p13; arr[4] = pt3[0] * p0 + pt3[1] * p4 + p12; arr[5] = pt3[0] * p1 + pt3[1] * p5 + p13; } return arr; } function applyToPointArray(x, y, z) { var arr; if (this.isIdentity()) { arr = [x, y, z]; } else { arr = [ x * this.props[0] + y * this.props[4] + z * this.props[8] + this.props[12], x * this.props[1] + y * this.props[5] + z * this.props[9] + this.props[13], x * this.props[2] + y * this.props[6] + z * this.props[10] + this.props[14], ]; } return arr; } function applyToPointStringified(x, y) { if (this.isIdentity()) { return x + ',' + y; } var _p = this.props; return Math.round((x * _p[0] + y * _p[4] + _p[12]) * 100) / 100 + ',' + Math.round((x * _p[1] + y * _p[5] + _p[13]) * 100) / 100; } function toCSS() { // Doesn't make much sense to add this optimization. If it is an identity matrix, it's very likely this will get called only once since it won't be keyframed. /* if(this.isIdentity()) { return ''; } */ var i = 0; var props = this.props; var cssValue = 'matrix3d('; var v = 10000; while (i < 16) { cssValue += _rnd(props[i] * v) / v; cssValue += i === 15 ? ')' : ','; i += 1; } return cssValue; } function roundMatrixProperty(val) { var v = 10000; if ((val < 0.000001 && val > 0) || (val > -0.000001 && val < 0)) { return _rnd(val * v) / v; } return val; } function to2dCSS() { // Doesn't make much sense to add this optimization. If it is an identity matrix, it's very likely this will get called only once since it won't be keyframed. /* if(this.isIdentity()) { return ''; } */ var props = this.props; var _a = roundMatrixProperty(props[0]); var _b = roundMatrixProperty(props[1]); var _c = roundMatrixProperty(props[4]); var _d = roundMatrixProperty(props[5]); var _e = roundMatrixProperty(props[12]); var _f = roundMatrixProperty(props[13]); return 'matrix(' + _a + ',' + _b + ',' + _c + ',' + _d + ',' + _e + ',' + _f + ')'; } return function () { this.reset = reset; this.rotate = rotate; this.rotateX = rotateX; this.rotateY = rotateY; this.rotateZ = rotateZ; this.skew = skew; this.skewFromAxis = skewFromAxis; this.shear = shear; this.scale = scale; this.setTransform = setTransform; this.translate = translate; this.transform = transform; this.applyToPoint = applyToPoint; this.applyToX = applyToX; this.applyToY = applyToY; this.applyToZ = applyToZ; this.applyToPointArray = applyToPointArray; this.applyToTriplePoints = applyToTriplePoints; this.applyToPointStringified = applyToPointStringified; this.toCSS = toCSS; this.to2dCSS = to2dCSS; this.clone = clone; this.cloneFromProps = cloneFromProps; this.equals = equals; this.inversePoints = inversePoints; this.inversePoint = inversePoint; this.getInverseMatrix = getInverseMatrix; this._t = this.transform; this.isIdentity = isIdentity; this._identity = true; this._identityCalculated = false; this.props = createTypedArray('float32', 16); this.reset(); }; }()); /* eslint-disable */ /* Copyright 2014 David Bau. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ (function (pool, math) { // // The following constants are related to IEEE 754 limits. // var global = this, width = 256, // each RC4 output is 0 <= x < 256 chunks = 6, // at least six RC4 outputs for each double digits = 52, // there are 52 significant digits in a double rngname = 'random', // rngname: name for Math.random and Math.seedrandom startdenom = math.pow(width, chunks), significance = math.pow(2, digits), overflow = significance * 2, mask = width - 1, nodecrypto; // node.js crypto module, initialized at the bottom. // // seedrandom() // This is the seedrandom function described above. // function seedrandom(seed, options, callback) { var key = []; options = (options === true) ? { entropy: true } : (options || {}); // Flatten the seed string or build one from local entropy if needed. var shortseed = mixkey(flatten( options.entropy ? [seed, tostring(pool)] : (seed === null) ? autoseed() : seed, 3), key); // Use the seed to initialize an ARC4 generator. var arc4 = new ARC4(key); // This function returns a random double in [0, 1) that contains // randomness in every bit of the mantissa of the IEEE 754 value. var prng = function() { var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48 d = startdenom, // and denominator d = 2 ^ 48. x = 0; // and no 'extra last byte'. while (n < significance) { // Fill up all significant digits by n = (n + x) * width; // shifting numerator and d *= width; // denominator and generating a x = arc4.g(1); // new least-significant-byte. } while (n >= overflow) { // To avoid rounding up, before adding n /= 2; // last byte, shift everything d /= 2; // right using integer math until x >>>= 1; // we have exactly the desired bits. } return (n + x) / d; // Form the number within [0, 1). }; prng.int32 = function() { return arc4.g(4) | 0; }; prng.quick = function() { return arc4.g(4) / 0x100000000; }; prng.double = prng; // Mix the randomness into accumulated entropy. mixkey(tostring(arc4.S), pool); // Calling convention: what to return as a function of prng, seed, is_math. return (options.pass || callback || function(prng, seed, is_math_call, state) { if (state) { // Load the arc4 state from the given state if it has an S array. if (state.S) { copy(state, arc4); } // Only provide the .state method if requested via options.state. prng.state = function() { return copy(arc4, {}); }; } // If called as a method of Math (Math.seedrandom()), mutate // Math.random because that is how seedrandom.js has worked since v1.0. if (is_math_call) { math[rngname] = prng; return seed; } // Otherwise, it is a newer calling convention, so return the // prng directly. else return prng; })( prng, shortseed, 'global' in options ? options.global : (this == math), options.state); } math['seed' + rngname] = seedrandom; // // ARC4 // // An ARC4 implementation. The constructor takes a key in the form of // an array of at most (width) integers that should be 0 <= x < (width). // // The g(count) method returns a pseudorandom integer that concatenates // the next (count) outputs from ARC4. Its return value is a number x // that is in the range 0 <= x < (width ^ count). // function ARC4(key) { var t, keylen = key.length, me = this, i = 0, j = me.i = me.j = 0, s = me.S = []; // The empty key [] is treated as [0]. if (!keylen) { key = [keylen++]; } // Set up S using the standard key scheduling algorithm. while (i < width) { s[i] = i++; } for (i = 0; i < width; i++) { s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))]; s[j] = t; } // The "g" method returns the next (count) outputs as one number. me.g = function(count) { // Using instance members instead of closure state nearly doubles speed. var t, r = 0, i = me.i, j = me.j, s = me.S; while (count--) { t = s[i = mask & (i + 1)]; r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))]; } me.i = i; me.j = j; return r; // For robust unpredictability, the function call below automatically // discards an initial batch of values. This is called RC4-drop[256]. // See http://google.com/search?q=rsa+fluhrer+response&btnI }; } // // copy() // Copies internal state of ARC4 to or from a plain object. // function copy(f, t) { t.i = f.i; t.j = f.j; t.S = f.S.slice(); return t; } // // flatten() // Converts an object tree to nested arrays of strings. // function flatten(obj, depth) { var result = [], typ = (typeof obj), prop; if (depth && typ == 'object') { for (prop in obj) { try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {} } } return (result.length ? result : typ == 'string' ? obj : obj + '\0'); } // // mixkey() // Mixes a string seed into a key that is an array of integers, and // returns a shortened string seed that is equivalent to the result key. // function mixkey(seed, key) { var stringseed = seed + '', smear, j = 0; while (j < stringseed.length) { key[mask & j] = mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++)); } return tostring(key); } // // autoseed() // Returns an object for autoseeding, using window.crypto and Node crypto // module if available. // function autoseed() { try { if (nodecrypto) { return tostring(nodecrypto.randomBytes(width)); } var out = new Uint8Array(width); (global.crypto || global.msCrypto).getRandomValues(out); return tostring(out); } catch (e) { var browser = global.navigator, plugins = browser && browser.plugins; return [+new Date(), global, plugins, global.screen, tostring(pool)]; } } // // tostring() // Converts an array of charcodes to a string // function tostring(a) { return String.fromCharCode.apply(0, a); } // // When seedrandom.js is loaded, we immediately mix a few bits // from the built-in RNG into the entropy pool. Because we do // not want to interfere with deterministic PRNG state later, // seedrandom will not call math.random on its own again after // initialization. // mixkey(math.random(), pool); // // Nodejs and AMD support: export the implementation as a module using // either convention. // // End anonymous scope, and pass initial values. })( [], // pool: entropy pool starts empty BMMath // math: package containing random, pow, and seedrandom ); /* eslint-disable */ var BezierFactory = (function () { /** * BezierEasing - use bezier curve for transition easing function * by Gaëtan Renaudeau 2014 - 2015 – MIT License * * Credits: is based on Firefox's nsSMILKeySpline.cpp * Usage: * var spline = BezierEasing([ 0.25, 0.1, 0.25, 1.0 ]) * spline.get(x) => returns the easing value | x must be in [0, 1] range * */ var ob = {}; ob.getBezierEasing = getBezierEasing; var beziers = {}; function getBezierEasing(a, b, c, d, nm) { var str = nm || ('bez_' + a + '_' + b + '_' + c + '_' + d).replace(/\./g, 'p'); if (beziers[str]) { return beziers[str]; } var bezEasing = new BezierEasing([a, b, c, d]); beziers[str] = bezEasing; return bezEasing; } // These values are established by empiricism with tests (tradeoff: performance VS precision) var NEWTON_ITERATIONS = 4; var NEWTON_MIN_SLOPE = 0.001; var SUBDIVISION_PRECISION = 0.0000001; var SUBDIVISION_MAX_ITERATIONS = 10; var kSplineTableSize = 11; var kSampleStepSize = 1.0 / (kSplineTableSize - 1.0); var float32ArraySupported = typeof Float32Array === 'function'; function A(aA1, aA2) { return 1.0 - 3.0 * aA2 + 3.0 * aA1; } function B(aA1, aA2) { return 3.0 * aA2 - 6.0 * aA1; } function C(aA1) { return 3.0 * aA1; } // Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2. function calcBezier(aT, aA1, aA2) { return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT; } // Returns dx/dt given t, x1, and x2, or dy/dt given t, y1, and y2. function getSlope(aT, aA1, aA2) { return 3.0 * A(aA1, aA2) * aT * aT + 2.0 * B(aA1, aA2) * aT + C(aA1); } function binarySubdivide(aX, aA, aB, mX1, mX2) { var currentX, currentT, i = 0; do { currentT = aA + (aB - aA) / 2.0; currentX = calcBezier(currentT, mX1, mX2) - aX; if (currentX > 0.0) { aB = currentT; } else { aA = currentT; } } while (Math.abs(currentX) > SUBDIVISION_PRECISION && ++i < SUBDIVISION_MAX_ITERATIONS); return currentT; } function newtonRaphsonIterate(aX, aGuessT, mX1, mX2) { for (var i = 0; i < NEWTON_ITERATIONS; ++i) { var currentSlope = getSlope(aGuessT, mX1, mX2); if (currentSlope === 0.0) return aGuessT; var currentX = calcBezier(aGuessT, mX1, mX2) - aX; aGuessT -= currentX / currentSlope; } return aGuessT; } /** * points is an array of [ mX1, mY1, mX2, mY2 ] */ function BezierEasing(points) { this._p = points; this._mSampleValues = float32ArraySupported ? new Float32Array(kSplineTableSize) : new Array(kSplineTableSize); this._precomputed = false; this.get = this.get.bind(this); } BezierEasing.prototype = { get: function (x) { var mX1 = this._p[0], mY1 = this._p[1], mX2 = this._p[2], mY2 = this._p[3]; if (!this._precomputed) this._precompute(); if (mX1 === mY1 && mX2 === mY2) return x; // linear // Because JavaScript number are imprecise, we should guarantee the extremes are right. if (x === 0) return 0; if (x === 1) return 1; return calcBezier(this._getTForX(x), mY1, mY2); }, // Private part _precompute: function () { var mX1 = this._p[0], mY1 = this._p[1], mX2 = this._p[2], mY2 = this._p[3]; this._precomputed = true; if (mX1 !== mY1 || mX2 !== mY2) { this._calcSampleValues(); } }, _calcSampleValues: function () { var mX1 = this._p[0], mX2 = this._p[2]; for (var i = 0; i < kSplineTableSize; ++i) { this._mSampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2); } }, /** * getTForX chose the fastest heuristic to determine the percentage value precisely from a given X projection. */ _getTForX: function (aX) { var mX1 = this._p[0], mX2 = this._p[2], mSampleValues = this._mSampleValues; var intervalStart = 0.0; var currentSample = 1; var lastSample = kSplineTableSize - 1; for (; currentSample !== lastSample && mSampleValues[currentSample] <= aX; ++currentSample) { intervalStart += kSampleStepSize; } --currentSample; // Interpolate to provide an initial guess for t var dist = (aX - mSampleValues[currentSample]) / (mSampleValues[currentSample + 1] - mSampleValues[currentSample]); var guessForT = intervalStart + dist * kSampleStepSize; var initialSlope = getSlope(guessForT, mX1, mX2); if (initialSlope >= NEWTON_MIN_SLOPE) { return newtonRaphsonIterate(aX, guessForT, mX1, mX2); } if (initialSlope === 0.0) { return guessForT; } return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2); }, }; return ob; }()); (function () { var lastTime = 0; var vendors = ['ms', 'moz', 'webkit', 'o']; for (var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) { // eslint-disable-line no-plusplus window.requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame']; window.cancelAnimationFrame = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame']; } if (!window.requestAnimationFrame) { window.requestAnimationFrame = function (callback) { var currTime = new Date().getTime(); var timeToCall = Math.max(0, 16 - (currTime - lastTime)); var id = setTimeout(function () { callback(currTime + timeToCall); }, timeToCall); lastTime = currTime + timeToCall; return id; }; } if (!window.cancelAnimationFrame) { window.cancelAnimationFrame = function (id) { clearTimeout(id); }; } }()); /* exported extendPrototype, getDescriptor, createProxyFunction */ function extendPrototype(sources, destination) { var i; var len = sources.length; var sourcePrototype; for (i = 0; i < len; i += 1) { sourcePrototype = sources[i].prototype; for (var attr in sourcePrototype) { if (Object.prototype.hasOwnProperty.call(sourcePrototype, attr)) destination.prototype[attr] = sourcePrototype[attr]; } } } function getDescriptor(object, prop) { return Object.getOwnPropertyDescriptor(object, prop); } function createProxyFunction(prototype) { function ProxyFunction() {} ProxyFunction.prototype = prototype; return ProxyFunction; } /* global segmentsLengthPool, defaultCurveSegments, createSizedArray, bmPow, bmSqrt, bmFloor, createTypedArray, bezierLengthPool */ /* exported bez */ function bezFunction() { var math = Math; function pointOnLine2D(x1, y1, x2, y2, x3, y3) { var det1 = (x1 * y2) + (y1 * x3) + (x2 * y3) - (x3 * y2) - (y3 * x1) - (x2 * y1); return det1 > -0.001 && det1 < 0.001; } function pointOnLine3D(x1, y1, z1, x2, y2, z2, x3, y3, z3) { if (z1 === 0 && z2 === 0 && z3 === 0) { return pointOnLine2D(x1, y1, x2, y2, x3, y3); } var dist1 = math.sqrt(math.pow(x2 - x1, 2) + math.pow(y2 - y1, 2) + math.pow(z2 - z1, 2)); var dist2 = math.sqrt(math.pow(x3 - x1, 2) + math.pow(y3 - y1, 2) + math.pow(z3 - z1, 2)); var dist3 = math.sqrt(math.pow(x3 - x2, 2) + math.pow(y3 - y2, 2) + math.pow(z3 - z2, 2)); var diffDist; if (dist1 > dist2) { if (dist1 > dist3) { diffDist = dist1 - dist2 - dist3; } else { diffDist = dist3 - dist2 - dist1; } } else if (dist3 > dist2) { diffDist = dist3 - dist2 - dist1; } else { diffDist = dist2 - dist1 - dist3; } return diffDist > -0.0001 && diffDist < 0.0001; } var getBezierLength = (function () { return function (pt1, pt2, pt3, pt4) { var curveSegments = defaultCurveSegments; var k; var i; var len; var ptCoord; var perc; var addedLength = 0; var ptDistance; var point = []; var lastPoint = []; var lengthData = bezierLengthPool.newElement(); len = pt3.length; for (k = 0; k < curveSegments; k += 1) { perc = k / (curveSegments - 1); ptDistance = 0; for (i = 0; i < len; i += 1) { ptCoord = bmPow(1 - perc, 3) * pt1[i] + 3 * bmPow(1 - perc, 2) * perc * pt3[i] + 3 * (1 - perc) * bmPow(perc, 2) * pt4[i] + bmPow(perc, 3) * pt2[i]; point[i] = ptCoord; if (lastPoint[i] !== null) { ptDistance += bmPow(point[i] - lastPoint[i], 2); } lastPoint[i] = point[i]; } if (ptDistance) { ptDistance = bmSqrt(ptDistance); addedLength += ptDistance; } lengthData.percents[k] = perc; lengthData.lengths[k] = addedLength; } lengthData.addedLength = addedLength; return lengthData; }; }()); function getSegmentsLength(shapeData) { var segmentsLength = segmentsLengthPool.newElement(); var closed = shapeData.c; var pathV = shapeData.v; var pathO = shapeData.o; var pathI = shapeData.i; var i; var len = shapeData._length; var lengths = segmentsLength.lengths; var totalLength = 0; for (i = 0; i < len - 1; i += 1) { lengths[i] = getBezierLength(pathV[i], pathV[i + 1], pathO[i], pathI[i + 1]); totalLength += lengths[i].addedLength; } if (closed && len) { lengths[i] = getBezierLength(pathV[i], pathV[0], pathO[i], pathI[0]); totalLength += lengths[i].addedLength; } segmentsLength.totalLength = totalLength; return segmentsLength; } function BezierData(length) { this.segmentLength = 0; this.points = new Array(length); } function PointData(partial, point) { this.partialLength = partial; this.point = point; } var buildBezierData = (function () { var storedData = {}; return function (pt1, pt2, pt3, pt4) { var bezierName = (pt1[0] + '_' + pt1[1] + '_' + pt2[0] + '_' + pt2[1] + '_' + pt3[0] + '_' + pt3[1] + '_' + pt4[0] + '_' + pt4[1]).replace(/\./g, 'p'); if (!storedData[bezierName]) { var curveSegments = defaultCurveSegments; var k; var i; var len; var ptCoord; var perc; var addedLength = 0; var ptDistance; var point; var lastPoint = null; if (pt1.length === 2 && (pt1[0] !== pt2[0] || pt1[1] !== pt2[1]) && pointOnLine2D(pt1[0], pt1[1], pt2[0], pt2[1], pt1[0] + pt3[0], pt1[1] + pt3[1]) && pointOnLine2D(pt1[0], pt1[1], pt2[0], pt2[1], pt2[0] + pt4[0], pt2[1] + pt4[1])) { curveSegments = 2; } var bezierData = new BezierData(curveSegments); len = pt3.length; for (k = 0; k < curveSegments; k += 1) { point = createSizedArray(len); perc = k / (curveSegments - 1); ptDistance = 0; for (i = 0; i < len; i += 1) { ptCoord = bmPow(1 - perc, 3) * pt1[i] + 3 * bmPow(1 - perc, 2) * perc * (pt1[i] + pt3[i]) + 3 * (1 - perc) * bmPow(perc, 2) * (pt2[i] + pt4[i]) + bmPow(perc, 3) * pt2[i]; point[i] = ptCoord; if (lastPoint !== null) { ptDistance += bmPow(point[i] - lastPoint[i], 2); } } ptDistance = bmSqrt(ptDistance); addedLength += ptDistance; bezierData.points[k] = new PointData(ptDistance, point); lastPoint = point; } bezierData.segmentLength = addedLength; storedData[bezierName] = bezierData; } return storedData[bezierName]; }; }()); function getDistancePerc(perc, bezierData) { var percents = bezierData.percents; var lengths = bezierData.lengths; var len = percents.length; var initPos = bmFloor((len - 1) * perc); var lengthPos = perc * bezierData.addedLength; var lPerc = 0; if (initPos === len - 1 || initPos === 0 || lengthPos === lengths[initPos]) { return percents[initPos]; } var dir = lengths[initPos] > lengthPos ? -1 : 1; var flag = true; while (flag) { if (lengths[initPos] <= lengthPos && lengths[initPos + 1] > lengthPos) { lPerc = (lengthPos - lengths[initPos]) / (lengths[initPos + 1] - lengths[initPos]); flag = false; } else { initPos += dir; } if (initPos < 0 || initPos >= len - 1) { // FIX for TypedArrays that don't store floating point values with enough accuracy if (initPos === len - 1) { return percents[initPos]; } flag = false; } } return percents[initPos] + (percents[initPos + 1] - percents[initPos]) * lPerc; } function getPointInSegment(pt1, pt2, pt3, pt4, percent, bezierData) { var t1 = getDistancePerc(percent, bezierData); var u1 = 1 - t1; var ptX = math.round((u1 * u1 * u1 * pt1[0] + (t1 * u1 * u1 + u1 * t1 * u1 + u1 * u1 * t1) * pt3[0] + (t1 * t1 * u1 + u1 * t1 * t1 + t1 * u1 * t1) * pt4[0] + t1 * t1 * t1 * pt2[0]) * 1000) / 1000; var ptY = math.round((u1 * u1 * u1 * pt1[1] + (t1 * u1 * u1 + u1 * t1 * u1 + u1 * u1 * t1) * pt3[1] + (t1 * t1 * u1 + u1 * t1 * t1 + t1 * u1 * t1) * pt4[1] + t1 * t1 * t1 * pt2[1]) * 1000) / 1000; return [ptX, ptY]; } var bezierSegmentPoints = createTypedArray('float32', 8); function getNewSegment(pt1, pt2, pt3, pt4, startPerc, endPerc, bezierData) { if (startPerc < 0) { startPerc = 0; } else if (startPerc > 1) { startPerc = 1; } var t0 = getDistancePerc(startPerc, bezierData); endPerc = endPerc > 1 ? 1 : endPerc; var t1 = getDistancePerc(endPerc, bezierData); var i; var len = pt1.length; var u0 = 1 - t0; var u1 = 1 - t1; var u0u0u0 = u0 * u0 * u0; var t0u0u0_3 = t0 * u0 * u0 * 3; // eslint-disable-line camelcase var t0t0u0_3 = t0 * t0 * u0 * 3; // eslint-disable-line camelcase var t0t0t0 = t0 * t0 * t0; // var u0u0u1 = u0 * u0 * u1; var t0u0u1_3 = t0 * u0 * u1 + u0 * t0 * u1 + u0 * u0 * t1; // eslint-disable-line camelcase var t0t0u1_3 = t0 * t0 * u1 + u0 * t0 * t1 + t0 * u0 * t1; // eslint-disable-line camelcase var t0t0t1 = t0 * t0 * t1; // var u0u1u1 = u0 * u1 * u1; var t0u1u1_3 = t0 * u1 * u1 + u0 * t1 * u1 + u0 * u1 * t1; // eslint-disable-line camelcase var t0t1u1_3 = t0 * t1 * u1 + u0 * t1 * t1 + t0 * u1 * t1; // eslint-disable-line camelcase var t0t1t1 = t0 * t1 * t1; // var u1u1u1 = u1 * u1 * u1; var t1u1u1_3 = t1 * u1 * u1 + u1 * t1 * u1 + u1 * u1 * t1; // eslint-disable-line camelcase var t1t1u1_3 = t1 * t1 * u1 + u1 * t1 * t1 + t1 * u1 * t1; // eslint-disable-line camelcase var t1t1t1 = t1 * t1 * t1; for (i = 0; i < len; i += 1) { bezierSegmentPoints[i * 4] = math.round((u0u0u0 * pt1[i] + t0u0u0_3 * pt3[i] + t0t0u0_3 * pt4[i] + t0t0t0 * pt2[i]) * 1000) / 1000; // eslint-disable-line camelcase bezierSegmentPoints[i * 4 + 1] = math.round((u0u0u1 * pt1[i] + t0u0u1_3 * pt3[i] + t0t0u1_3 * pt4[i] + t0t0t1 * pt2[i]) * 1000) / 1000; // eslint-disable-line camelcase bezierSegmentPoints[i * 4 + 2] = math.round((u0u1u1 * pt1[i] + t0u1u1_3 * pt3[i] + t0t1u1_3 * pt4[i] + t0t1t1 * pt2[i]) * 1000) / 1000; // eslint-disable-line camelcase bezierSegmentPoints[i * 4 + 3] = math.round((u1u1u1 * pt1[i] + t1u1u1_3 * pt3[i] + t1t1u1_3 * pt4[i] + t1t1t1 * pt2[i]) * 1000) / 1000; // eslint-disable-line camelcase } return bezierSegmentPoints; } return { getSegmentsLength: getSegmentsLength, getNewSegment: getNewSegment, getPointInSegment: getPointInSegment, buildBezierData: buildBezierData, pointOnLine2D: pointOnLine2D, pointOnLine3D: pointOnLine3D, }; } var bez = bezFunction(); /* global _useWebWorker */ var dataManager = (function () { var _counterId = 1; var processes = []; var workerFn; var workerInstance; var workerProxy = { onmessage: function () { }, postMessage: function (path) { workerFn({ data: path, }); }, }; var _workerSelf = { postMessage: function (data) { workerProxy.onmessage({ data: data, }); }, }; function createWorker(fn) { if (window.Worker && window.Blob && _useWebWorker) { var blob = new Blob(['var _workerSelf = self; self.onmessage = ', fn.toString()], { type: 'text/javascript' }); // var blob = new Blob(['self.onmessage = ', fn.toString()], { type: 'text/javascript' }); var url = URL.createObjectURL(blob); return new Worker(url); } workerFn = fn; return workerProxy; } function setupWorker() { if (!workerInstance) { workerInstance = createWorker(function workerStart(e) { /* exported dataManager */ function dataFunctionManager() { // var tCanvasHelper = createTag('canvas').getContext('2d'); function completeLayers(layers, comps) { var layerData; var i; var len = layers.length; var j; var jLen; var k; var kLen; for (i = 0; i < len; i += 1) { layerData = layers[i]; if (('ks' in layerData) && !layerData.completed) { layerData.completed = true; if (layerData.tt) { layers[i - 1].td = layerData.tt; } if (layerData.hasMask) { var maskProps = layerData.masksProperties; jLen = maskProps.length; for (j = 0; j < jLen; j += 1) { if (maskProps[j].pt.k.i) { convertPathsToAbsoluteValues(maskProps[j].pt.k); } else { kLen = maskProps[j].pt.k.length; for (k = 0; k < kLen; k += 1) { if (maskProps[j].pt.k[k].s) { convertPathsToAbsoluteValues(maskProps[j].pt.k[k].s[0]); } if (maskProps[j].pt.k[k].e) { convertPathsToAbsoluteValues(maskProps[j].pt.k[k].e[0]); } } } } } if (layerData.ty === 0) { layerData.layers = findCompLayers(layerData.refId, comps); completeLayers(layerData.layers, comps); } else if (layerData.ty === 4) { completeShapes(layerData.shapes); } else if (layerData.ty === 5) { completeText(layerData); } } } } function findCompLayers(id, comps) { var i = 0; var len = comps.length; while (i < len) { if (comps[i].id === id) { if (!comps[i].layers.__used) { comps[i].layers.__used = true; return comps[i].layers; } return JSON.parse(JSON.stringify(comps[i].layers)); } i += 1; } return null; } function completeShapes(arr) { var i; var len = arr.length; var j; var jLen; for (i = len - 1; i >= 0; i -= 1) { if (arr[i].ty === 'sh') { if (arr[i].ks.k.i) { convertPathsToAbsoluteValues(arr[i].ks.k); } else { jLen = arr[i].ks.k.length; for (j = 0; j < jLen; j += 1) { if (arr[i].ks.k[j].s) { convertPathsToAbsoluteValues(arr[i].ks.k[j].s[0]); } if (arr[i].ks.k[j].e) { convertPathsToAbsoluteValues(arr[i].ks.k[j].e[0]); } } } } else if (arr[i].ty === 'gr') { completeShapes(arr[i].it); } } } function convertPathsToAbsoluteValues(path) { var i; var len = path.i.length; for (i = 0; i < len; i += 1) { path.i[i][0] += path.v[i][0]; path.i[i][1] += path.v[i][1]; path.o[i][0] += path.v[i][0]; path.o[i][1] += path.v[i][1]; } } function checkVersion(minimum, animVersionString) { var animVersion = animVersionString ? animVersionString.split('.') : [100, 100, 100]; if (minimum[0] > animVersion[0]) { return true; } if (animVersion[0] > minimum[0]) { return false; } if (minimum[1] > animVersion[1]) { return true; } if (animVersion[1] > minimum[1]) { return false; } if (minimum[2] > animVersion[2]) { return true; } if (animVersion[2] > minimum[2]) { return false; } return null; } var checkText = (function () { var minimumVersion = [4, 4, 14]; function updateTextLayer(textLayer) { var documentData = textLayer.t.d; textLayer.t.d = { k: [ { s: documentData, t: 0, }, ], }; } function iterateLayers(layers) { var i; var len = layers.length; for (i = 0; i < len; i += 1) { if (layers[i].ty === 5) { updateTextLayer(layers[i]); } } } return function (animationData) { if (checkVersion(minimumVersion, animationData.v)) { iterateLayers(animationData.layers); if (animationData.assets) { var i; var len = animationData.assets.length; for (i = 0; i < len; i += 1) { if (animationData.assets[i].layers) { iterateLayers(animationData.assets[i].layers); } } } } }; }()); var checkChars = (function () { var minimumVersion = [4, 7, 99]; return function (animationData) { if (animationData.chars && !checkVersion(minimumVersion, animationData.v)) { var i; var len = animationData.chars.length; var j; var jLen; var pathData; var paths; for (i = 0; i < len; i += 1) { if (animationData.chars[i].data && animationData.chars[i].data.shapes) { paths = animationData.chars[i].data.shapes[0].it; jLen = paths.length; for (j = 0; j < jLen; j += 1) { pathData = paths[j].ks.k; if (!pathData.__converted) { convertPathsToAbsoluteValues(paths[j].ks.k); pathData.__converted = true; } } } } } }; }()); var checkPathProperties = (function () { var minimumVersion = [5, 7, 15]; function updateTextLayer(textLayer) { var pathData = textLayer.t.p; if (typeof pathData.a === 'number') { pathData.a = { a: 0, k: pathData.a, }; } if (typeof pathData.p === 'number') { pathData.p = { a: 0, k: pathData.p, }; } if (typeof pathData.r === 'number') { pathData.r = { a: 0, k: pathData.r, }; } } function iterateLayers(layers) { var i; var len = layers.length; for (i = 0; i < len; i += 1) { if (layers[i].ty === 5) { updateTextLayer(layers[i]); } } } return function (animationData) { if (checkVersion(minimumVersion, animationData.v)) { iterateLayers(animationData.layers); if (animationData.assets) { var i; var len = animationData.assets.length; for (i = 0; i < len; i += 1) { if (animationData.assets[i].layers) { iterateLayers(animationData.assets[i].layers); } } } } }; }()); var checkColors = (function () { var minimumVersion = [4, 1, 9]; function iterateShapes(shapes) { var i; var len = shapes.length; var j; var jLen; for (i = 0; i < len; i += 1) { if (shapes[i].ty === 'gr') { iterateShapes(shapes[i].it); } else if (shapes[i].ty === 'fl' || shapes[i].ty === 'st') { if (shapes[i].c.k && shapes[i].c.k[0].i) { jLen = shapes[i].c.k.length; for (j = 0; j < jLen; j += 1) { if (shapes[i].c.k[j].s) { shapes[i].c.k[j].s[0] /= 255; shapes[i].c.k[j].s[1] /= 255; shapes[i].c.k[j].s[2] /= 255; shapes[i].c.k[j].s[3] /= 255; } if (shapes[i].c.k[j].e) { shapes[i].c.k[j].e[0] /= 255; shapes[i].c.k[j].e[1] /= 255; shapes[i].c.k[j].e[2] /= 255; shapes[i].c.k[j].e[3] /= 255; } } } else { shapes[i].c.k[0] /= 255; shapes[i].c.k[1] /= 255; shapes[i].c.k[2] /= 255; shapes[i].c.k[3] /= 255; } } } } function iterateLayers(layers) { var i; var len = layers.length; for (i = 0; i < len; i += 1) { if (layers[i].ty === 4) { iterateShapes(layers[i].shapes); } } } return function (animationData) { if (checkVersion(minimumVersion, animationData.v)) { iterateLayers(animationData.layers); if (animationData.assets) { var i; var len = animationData.assets.length; for (i = 0; i < len; i += 1) { if (animationData.assets[i].layers) { iterateLayers(animationData.assets[i].layers); } } } } }; }()); var checkShapes = (function () { var minimumVersion = [4, 4, 18]; function completeClosingShapes(arr) { var i; var len = arr.length; var j; var jLen; for (i = len - 1; i >= 0; i -= 1) { if (arr[i].ty === 'sh') { if (arr[i].ks.k.i) { arr[i].ks.k.c = arr[i].closed; } else { jLen = arr[i].ks.k.length; for (j = 0; j < jLen; j += 1) { if (arr[i].ks.k[j].s) { arr[i].ks.k[j].s[0].c = arr[i].closed; } if (arr[i].ks.k[j].e) { arr[i].ks.k[j].e[0].c = arr[i].closed; } } } } else if (arr[i].ty === 'gr') { completeClosingShapes(arr[i].it); } } } function iterateLayers(layers) { var layerData; var i; var len = layers.length; var j; var jLen; var k; var kLen; for (i = 0; i < len; i += 1) { layerData = layers[i]; if (layerData.hasMask) { var maskProps = layerData.masksProperties; jLen = maskProps.length; for (j = 0; j < jLen; j += 1) { if (maskProps[j].pt.k.i) { maskProps[j].pt.k.c = maskProps[j].cl; } else { kLen = maskProps[j].pt.k.length; for (k = 0; k < kLen; k += 1) { if (maskProps[j].pt.k[k].s) { maskProps[j].pt.k[k].s[0].c = maskProps[j].cl; } if (maskProps[j].pt.k[k].e) { maskProps[j].pt.k[k].e[0].c = maskProps[j].cl; } } } } } if (layerData.ty === 4) { completeClosingShapes(layerData.shapes); } } } return function (animationData) { if (checkVersion(minimumVersion, animationData.v)) { iterateLayers(animationData.layers); if (animationData.assets) { var i; var len = animationData.assets.length; for (i = 0; i < len; i += 1) { if (animationData.assets[i].layers) { iterateLayers(animationData.assets[i].layers); } } } } }; }()); function completeData(animationData) { if (animationData.__complete) { return; } checkColors(animationData); checkText(animationData); checkChars(animationData); checkPathProperties(animationData); checkShapes(animationData); completeLayers(animationData.layers, animationData.assets); animationData.__complete = true; } function completeText(data) { if (data.t.a.length === 0 && !('m' in data.t.p)) { data.singleShape = true; } } var moduleOb = {}; moduleOb.completeData = completeData; moduleOb.checkColors = checkColors; moduleOb.checkChars = checkChars; moduleOb.checkPathProperties = checkPathProperties; moduleOb.checkShapes = checkShapes; moduleOb.completeLayers = completeLayers; return moduleOb; } if (!_workerSelf.dataManager) { _workerSelf.dataManager = dataFunctionManager(); } /* exported assetLoader */ if (!_workerSelf.assetLoader) { _workerSelf.assetLoader = (function () { function formatResponse(xhr) { // using typeof doubles the time of execution of this method, // so if available, it's better to use the header to validate the type var contentTypeHeader = xhr.getResponseHeader('content-type'); if (contentTypeHeader && xhr.responseType === 'json' && contentTypeHeader.indexOf('json') !== -1) { return xhr.response; } if (xhr.response && typeof xhr.response === 'object') { return xhr.response; } if (xhr.response && typeof xhr.response === 'string') { return JSON.parse(xhr.response); } if (xhr.responseText) { return JSON.parse(xhr.responseText); } return null; } function loadAsset(path, fullPath, callback, errorCallback) { var response; var xhr = new XMLHttpRequest(); // set responseType after calling open or IE will break. try { // This crashes on Android WebView prior to KitKat xhr.responseType = 'json'; } catch (err) {} // eslint-disable-line no-empty xhr.onreadystatechange = function () { if (xhr.readyState === 4) { if (xhr.status === 200) { response = formatResponse(xhr); callback(response); } else { try { response = formatResponse(xhr); callback(response); } catch (err) { if (errorCallback) { errorCallback(err); } } } } }; try { xhr.open('GET', path, true); } catch (error) { xhr.open('GET', fullPath + '/' + path, true); } xhr.send(); } return { load: loadAsset, }; }()); } if (e.data.type === 'loadAnimation') { _workerSelf.assetLoader.load( e.data.path, e.data.fullPath, function (data) { _workerSelf.dataManager.completeData(data); _workerSelf.postMessage({ id: e.data.id, payload: data, status: 'success', }); }, function () { _workerSelf.postMessage({ id: e.data.id, status: 'error', }); } ); } else if (e.data.type === 'complete') { var animation = e.data.animation; _workerSelf.dataManager.completeData(animation); _workerSelf.postMessage({ id: e.data.id, payload: animation, status: 'success', }); } else if (e.data.type === 'loadData') { _workerSelf.assetLoader.load( e.data.path, e.data.fullPath, function (data) { _workerSelf.postMessage({ id: e.data.id, payload: data, status: 'success', }); }, function () { _workerSelf.postMessage({ id: e.data.id, status: 'error', }); } ); } }); workerInstance.onmessage = function (event) { var data = event.data; var id = data.id; var process = processes[id]; processes[id] = null; if (data.status === 'success') { process.onComplete(data.payload); } else if (process.onError) { process.onError(); } }; } } function createProcess(onComplete, onError) { _counterId += 1; var id = 'processId_' + _counterId; processes[id] = { onComplete: onComplete, onError: onError, }; return id; } function loadAnimation(path, onComplete, onError) { setupWorker(); var processId = createProcess(onComplete, onError); workerInstance.postMessage({ type: 'loadAnimation', path: path, fullPath: window.location.origin + window.location.pathname, id: processId, }); } function loadData(path, onComplete, onError) { setupWorker(); var processId = createProcess(onComplete, onError); workerInstance.postMessage({ type: 'loadData', path: path, fullPath: window.location.origin + window.location.pathname, id: processId, }); } function completeAnimation(anim, onComplete, onError) { setupWorker(); var processId = createProcess(onComplete, onError); workerInstance.postMessage({ type: 'complete', animation: anim, id: processId, }); } return { loadAnimation: loadAnimation, loadData: loadData, completeAnimation: completeAnimation, }; }()); /* exported getFontProperties */ function getFontProperties(fontData) { var styles = fontData.fStyle ? fontData.fStyle.split(' ') : []; var fWeight = 'normal'; var fStyle = 'normal'; var len = styles.length; var styleName; for (var i = 0; i < len; i += 1) { styleName = styles[i].toLowerCase(); switch (styleName) { case 'italic': fStyle = 'italic'; break; case 'bold': fWeight = '700'; break; case 'black': fWeight = '900'; break; case 'medium': fWeight = '500'; break; case 'regular': case 'normal': fWeight = '400'; break; case 'light': case 'thin': fWeight = '200'; break; default: break; } } return { style: fStyle, weight: fontData.fWeight || fWeight, }; } /* global createNS, createTag, getFontProperties */ /* exported FontManager */ var FontManager = (function () { var maxWaitingTime = 5000; var emptyChar = { w: 0, size: 0, shapes: [], }; var combinedCharacters = []; // Hindi characters combinedCharacters = combinedCharacters.concat([2304, 2305, 2306, 2307, 2362, 2363, 2364, 2364, 2366, 2367, 2368, 2369, 2370, 2371, 2372, 2373, 2374, 2375, 2376, 2377, 2378, 2379, 2380, 2381, 2382, 2383, 2387, 2388, 2389, 2390, 2391, 2402, 2403]); var surrogateModifiers = [ 'd83cdffb', 'd83cdffc', 'd83cdffd', 'd83cdffe', 'd83cdfff', ]; var zeroWidthJoiner = [65039, 8205]; function trimFontOptions(font) { var familyArray = font.split(','); var i; var len = familyArray.length; var enabledFamilies = []; for (i = 0; i < len; i += 1) { if (familyArray[i] !== 'sans-serif' && familyArray[i] !== 'monospace') { enabledFamilies.push(familyArray[i]); } } return enabledFamilies.join(','); } function setUpNode(font, family) { var parentNode = createTag('span'); // Node is invisible to screen readers. parentNode.setAttribute('aria-hidden', true); parentNode.style.fontFamily = family; var node = createTag('span'); // Characters that vary significantly among different fonts node.innerText = 'giItT1WQy@!-/#'; // Visible - so we can measure it - but not on the screen parentNode.style.position = 'absolute'; parentNode.style.left = '-10000px'; parentNode.style.top = '-10000px'; // Large font size makes even subtle changes obvious parentNode.style.fontSize = '300px'; // Reset any font properties parentNode.style.fontVariant = 'normal'; parentNode.style.fontStyle = 'normal'; parentNode.style.fontWeight = 'normal'; parentNode.style.letterSpacing = '0'; parentNode.appendChild(node); document.body.appendChild(parentNode); // Remember width with no applied web font var width = node.offsetWidth; node.style.fontFamily = trimFontOptions(font) + ', ' + family; return { node: node, w: width, parent: parentNode }; } function checkLoadedFonts() { var i; var len = this.fonts.length; var node; var w; var loadedCount = len; for (i = 0; i < len; i += 1) { if (this.fonts[i].loaded) { loadedCount -= 1; } else if (this.fonts[i].fOrigin === 'n' || this.fonts[i].origin === 0) { this.fonts[i].loaded = true; } else { node = this.fonts[i].monoCase.node; w = this.fonts[i].monoCase.w; if (node.offsetWidth !== w) { loadedCount -= 1; this.fonts[i].loaded = true; } else { node = this.fonts[i].sansCase.node; w = this.fonts[i].sansCase.w; if (node.offsetWidth !== w) { loadedCount -= 1; this.fonts[i].loaded = true; } } if (this.fonts[i].loaded) { this.fonts[i].sansCase.parent.parentNode.removeChild(this.fonts[i].sansCase.parent); this.fonts[i].monoCase.parent.parentNode.removeChild(this.fonts[i].monoCase.parent); } } } if (loadedCount !== 0 && Date.now() - this.initTime < maxWaitingTime) { setTimeout(this.checkLoadedFontsBinded, 20); } else { setTimeout(this.setIsLoadedBinded, 10); } } function createHelper(def, fontData) { var tHelper = createNS('text'); tHelper.style.fontSize = '100px'; // tHelper.style.fontFamily = fontData.fFamily; var fontProps = getFontProperties(fontData); tHelper.setAttribute('font-family', fontData.fFamily); tHelper.setAttribute('font-style', fontProps.style); tHelper.setAttribute('font-weight', fontProps.weight); tHelper.textContent = '1'; if (fontData.fClass) { tHelper.style.fontFamily = 'inherit'; tHelper.setAttribute('class', fontData.fClass); } else { tHelper.style.fontFamily = fontData.fFamily; } def.appendChild(tHelper); var tCanvasHelper = createTag('canvas').getContext('2d'); tCanvasHelper.font = fontData.fWeight + ' ' + fontData.fStyle + ' 100px ' + fontData.fFamily; // tCanvasHelper.font = ' 100px '+ fontData.fFamily; return tHelper; } function addFonts(fontData, defs) { if (!fontData) { this.isLoaded = true; return; } if (this.chars) { this.isLoaded = true; this.fonts = fontData.list; return; } var fontArr = fontData.list; var i; var len = fontArr.length; var _pendingFonts = len; for (i = 0; i < len; i += 1) { var shouldLoadFont = true; var loadedSelector; var j; fontArr[i].loaded = false; fontArr[i].monoCase = setUpNode(fontArr[i].fFamily, 'monospace'); fontArr[i].sansCase = setUpNode(fontArr[i].fFamily, 'sans-serif'); if (!fontArr[i].fPath) { fontArr[i].loaded = true; _pendingFonts -= 1; } else if (fontArr[i].fOrigin === 'p' || fontArr[i].origin === 3) { loadedSelector = document.querySelectorAll('style[f-forigin="p"][f-family="' + fontArr[i].fFamily + '"], style[f-origin="3"][f-family="' + fontArr[i].fFamily + '"]'); if (loadedSelector.length > 0) { shouldLoadFont = false; } if (shouldLoadFont) { var s = createTag('style'); s.setAttribute('f-forigin', fontArr[i].fOrigin); s.setAttribute('f-origin', fontArr[i].origin); s.setAttribute('f-family', fontArr[i].fFamily); s.type = 'text/css'; s.innerText = '@font-face {font-family: ' + fontArr[i].fFamily + "; font-style: normal; src: url('" + fontArr[i].fPath + "');}"; defs.appendChild(s); } } else if (fontArr[i].fOrigin === 'g' || fontArr[i].origin === 1) { loadedSelector = document.querySelectorAll('link[f-forigin="g"], link[f-origin="1"]'); for (j = 0; j < loadedSelector.length; j += 1) { if (loadedSelector[j].href.indexOf(fontArr[i].fPath) !== -1) { // Font is already loaded shouldLoadFont = false; } } if (shouldLoadFont) { var l = createTag('link'); l.setAttribute('f-forigin', fontArr[i].fOrigin); l.setAttribute('f-origin', fontArr[i].origin); l.type = 'text/css'; l.rel = 'stylesheet'; l.href = fontArr[i].fPath; document.body.appendChild(l); } } else if (fontArr[i].fOrigin === 't' || fontArr[i].origin === 2) { loadedSelector = document.querySelectorAll('script[f-forigin="t"], script[f-origin="2"]'); for (j = 0; j < loadedSelector.length; j += 1) { if (fontArr[i].fPath === loadedSelector[j].src) { // Font is already loaded shouldLoadFont = false; } } if (shouldLoadFont) { var sc = createTag('link'); sc.setAttribute('f-forigin', fontArr[i].fOrigin); sc.setAttribute('f-origin', fontArr[i].origin); sc.setAttribute('rel', 'stylesheet'); sc.setAttribute('href', fontArr[i].fPath); defs.appendChild(sc); } } fontArr[i].helper = createHelper(defs, fontArr[i]); fontArr[i].cache = {}; this.fonts.push(fontArr[i]); } if (_pendingFonts === 0) { this.isLoaded = true; } else { // On some cases even if the font is loaded, it won't load correctly when measuring text on canvas. // Adding this timeout seems to fix it setTimeout(this.checkLoadedFonts.bind(this), 100); } } function addChars(chars) { if (!chars) { return; } if (!this.chars) { this.chars = []; } var i; var len = chars.length; var j; var jLen = this.chars.length; var found; for (i = 0; i < len; i += 1) { j = 0; found = false; while (j < jLen) { if (this.chars[j].style === chars[i].style && this.chars[j].fFamily === chars[i].fFamily && this.chars[j].ch === chars[i].ch) { found = true; } j += 1; } if (!found) { this.chars.push(chars[i]); jLen += 1; } } } function getCharData(char, style, font) { var i = 0; var len = this.chars.length; while (i < len) { if (this.chars[i].ch === char && this.chars[i].style === style && this.chars[i].fFamily === font) { return this.chars[i]; } i += 1; } if (((typeof char === 'string' && char.charCodeAt(0) !== 13) || !char) && console && console.warn // eslint-disable-line no-console && !this._warned ) { this._warned = true; console.warn('Missing character from exported characters list: ', char, style, font); // eslint-disable-line no-console } return emptyChar; } function measureText(char, fontName, size) { var fontData = this.getFontByName(fontName); var index = char.charCodeAt(0); if (!fontData.cache[index + 1]) { var tHelper = fontData.helper; // Canvas version // fontData.cache[index] = tHelper.measureText(char).width / 100; // SVG version // console.log(tHelper.getBBox().width) if (char === ' ') { tHelper.textContent = '|' + char + '|'; var doubleSize = tHelper.getComputedTextLength(); tHelper.textContent = '||'; var singleSize = tHelper.getComputedTextLength(); fontData.cache[index + 1] = (doubleSize - singleSize) / 100; } else { tHelper.textContent = char; fontData.cache[index + 1] = (tHelper.getComputedTextLength()) / 100; } } return fontData.cache[index + 1] * size; } function getFontByName(name) { var i = 0; var len = this.fonts.length; while (i < len) { if (this.fonts[i].fName === name) { return this.fonts[i]; } i += 1; } return this.fonts[0]; } function isModifier(firstCharCode, secondCharCode) { var sum = firstCharCode.toString(16) + secondCharCode.toString(16); return surrogateModifiers.indexOf(sum) !== -1; } function isZeroWidthJoiner(firstCharCode, secondCharCode) { if (!secondCharCode) { return firstCharCode === zeroWidthJoiner[1]; } return firstCharCode === zeroWidthJoiner[0] && secondCharCode === zeroWidthJoiner[1]; } function isCombinedCharacter(char) { return combinedCharacters.indexOf(char) !== -1; } function setIsLoaded() { this.isLoaded = true; } var Font = function () { this.fonts = []; this.chars = null; this.typekitLoaded = 0; this.isLoaded = false; this._warned = false; this.initTime = Date.now(); this.setIsLoadedBinded = this.setIsLoaded.bind(this); this.checkLoadedFontsBinded = this.checkLoadedFonts.bind(this); }; Font.isModifier = isModifier; Font.isZeroWidthJoiner = isZeroWidthJoiner; Font.isCombinedCharacter = isCombinedCharacter; var fontPrototype = { addChars: addChars, addFonts: addFonts, getCharData: getCharData, getFontByName: getFontByName, measureText: measureText, checkLoadedFonts: checkLoadedFonts, setIsLoaded: setIsLoaded, }; Font.prototype = fontPrototype; return Font; }()); /* global initialDefaultFrame, BezierFactory, degToRads, bez, createTypedArray */ /* exported PropertyFactory */ var PropertyFactory = (function () { var initFrame = initialDefaultFrame; var mathAbs = Math.abs; function interpolateValue(frameNum, caching) { var offsetTime = this.offsetTime; var newValue; if (this.propType === 'multidimensional') { newValue = createTypedArray('float32', this.pv.length); } var iterationIndex = caching.lastIndex; var i = iterationIndex; var len = this.keyframes.length - 1; var flag = true; var keyData; var nextKeyData; var keyframeMetadata; while (flag) { keyData = this.keyframes[i]; nextKeyData = this.keyframes[i + 1]; if (i === len - 1 && frameNum >= nextKeyData.t - offsetTime) { if (keyData.h) { keyData = nextKeyData; } iterationIndex = 0; break; } if ((nextKeyData.t - offsetTime) > frameNum) { iterationIndex = i; break; } if (i < len - 1) { i += 1; } else { iterationIndex = 0; flag = false; } } keyframeMetadata = this.keyframesMetadata[i] || {}; var k; var kLen; var perc; var jLen; var j; var fnc; var nextKeyTime = nextKeyData.t - offsetTime; var keyTime = keyData.t - offsetTime; var endValue; if (keyData.to) { if (!keyframeMetadata.bezierData) { keyframeMetadata.bezierData = bez.buildBezierData(keyData.s, nextKeyData.s || keyData.e, keyData.to, keyData.ti); } var bezierData = keyframeMetadata.bezierData; if (frameNum >= nextKeyTime || frameNum < keyTime) { var ind = frameNum >= nextKeyTime ? bezierData.points.length - 1 : 0; kLen = bezierData.points[ind].point.length; for (k = 0; k < kLen; k += 1) { newValue[k] = bezierData.points[ind].point[k]; } // caching._lastKeyframeIndex = -1; } else { if (keyframeMetadata.__fnct) { fnc = keyframeMetadata.__fnct; } else { fnc = BezierFactory.getBezierEasing(keyData.o.x, keyData.o.y, keyData.i.x, keyData.i.y, keyData.n).get; keyframeMetadata.__fnct = fnc; } perc = fnc((frameNum - keyTime) / (nextKeyTime - keyTime)); var distanceInLine = bezierData.segmentLength * perc; var segmentPerc; var addedLength = (caching.lastFrame < frameNum && caching._lastKeyframeIndex === i) ? caching._lastAddedLength : 0; j = (caching.lastFrame < frameNum && caching._lastKeyframeIndex === i) ? caching._lastPoint : 0; flag = true; jLen = bezierData.points.length; while (flag) { addedLength += bezierData.points[j].partialLength; if (distanceInLine === 0 || perc === 0 || j === bezierData.points.length - 1) { kLen = bezierData.points[j].point.length; for (k = 0; k < kLen; k += 1) { newValue[k] = bezierData.points[j].point[k]; } break; } else if (distanceInLine >= addedLength && distanceInLine < addedLength + bezierData.points[j + 1].partialLength) { segmentPerc = (distanceInLine - addedLength) / bezierData.points[j + 1].partialLength; kLen = bezierData.points[j].point.length; for (k = 0; k < kLen; k += 1) { newValue[k] = bezierData.points[j].point[k] + (bezierData.points[j + 1].point[k] - bezierData.points[j].point[k]) * segmentPerc; } break; } if (j < jLen - 1) { j += 1; } else { flag = false; } } caching._lastPoint = j; caching._lastAddedLength = addedLength - bezierData.points[j].partialLength; caching._lastKeyframeIndex = i; } } else { var outX; var outY; var inX; var inY; var keyValue; len = keyData.s.length; endValue = nextKeyData.s || keyData.e; if (this.sh && keyData.h !== 1) { if (frameNum >= nextKeyTime) { newValue[0] = endValue[0]; newValue[1] = endValue[1]; newValue[2] = endValue[2]; } else if (frameNum <= keyTime) { newValue[0] = keyData.s[0]; newValue[1] = keyData.s[1]; newValue[2] = keyData.s[2]; } else { var quatStart = createQuaternion(keyData.s); var quatEnd = createQuaternion(endValue); var time = (frameNum - keyTime) / (nextKeyTime - keyTime); quaternionToEuler(newValue, slerp(quatStart, quatEnd, time)); } } else { for (i = 0; i < len; i += 1) { if (keyData.h !== 1) { if (frameNum >= nextKeyTime) { perc = 1; } else if (frameNum < keyTime) { perc = 0; } else { if (keyData.o.x.constructor === Array) { if (!keyframeMetadata.__fnct) { keyframeMetadata.__fnct = []; } if (!keyframeMetadata.__fnct[i]) { outX = keyData.o.x[i] === undefined ? keyData.o.x[0] : keyData.o.x[i]; outY = keyData.o.y[i] === undefined ? keyData.o.y[0] : keyData.o.y[i]; inX = keyData.i.x[i] === undefined ? keyData.i.x[0] : keyData.i.x[i]; inY = keyData.i.y[i] === undefined ? keyData.i.y[0] : keyData.i.y[i]; fnc = BezierFactory.getBezierEasing(outX, outY, inX, inY).get; keyframeMetadata.__fnct[i] = fnc; } else { fnc = keyframeMetadata.__fnct[i]; } } else if (!keyframeMetadata.__fnct) { outX = keyData.o.x; outY = keyData.o.y; inX = keyData.i.x; inY = keyData.i.y; fnc = BezierFactory.getBezierEasing(outX, outY, inX, inY).get; keyData.keyframeMetadata = fnc; } else { fnc = keyframeMetadata.__fnct; } perc = fnc((frameNum - keyTime) / (nextKeyTime - keyTime)); } } endValue = nextKeyData.s || keyData.e; keyValue = keyData.h === 1 ? keyData.s[i] : keyData.s[i] + (endValue[i] - keyData.s[i]) * perc; if (this.propType === 'multidimensional') { newValue[i] = keyValue; } else { newValue = keyValue; } } } } caching.lastIndex = iterationIndex; return newValue; } // based on @Toji's https://github.com/toji/gl-matrix/ function slerp(a, b, t) { var out = []; var ax = a[0]; var ay = a[1]; var az = a[2]; var aw = a[3]; var bx = b[0]; var by = b[1]; var bz = b[2]; var bw = b[3]; var omega; var cosom; var sinom; var scale0; var scale1; cosom = ax * bx + ay * by + az * bz + aw * bw; if (cosom < 0.0) { cosom = -cosom; bx = -bx; by = -by; bz = -bz; bw = -bw; } if ((1.0 - cosom) > 0.000001) { omega = Math.acos(cosom); sinom = Math.sin(omega); scale0 = Math.sin((1.0 - t) * omega) / sinom; scale1 = Math.sin(t * omega) / sinom; } else { scale0 = 1.0 - t; scale1 = t; } out[0] = scale0 * ax + scale1 * bx; out[1] = scale0 * ay + scale1 * by; out[2] = scale0 * az + scale1 * bz; out[3] = scale0 * aw + scale1 * bw; return out; } function quaternionToEuler(out, quat) { var qx = quat[0]; var qy = quat[1]; var qz = quat[2]; var qw = quat[3]; var heading = Math.atan2(2 * qy * qw - 2 * qx * qz, 1 - 2 * qy * qy - 2 * qz * qz); var attitude = Math.asin(2 * qx * qy + 2 * qz * qw); var bank = Math.atan2(2 * qx * qw - 2 * qy * qz, 1 - 2 * qx * qx - 2 * qz * qz); out[0] = heading / degToRads; out[1] = attitude / degToRads; out[2] = bank / degToRads; } function createQuaternion(values) { var heading = values[0] * degToRads; var attitude = values[1] * degToRads; var bank = values[2] * degToRads; var c1 = Math.cos(heading / 2); var c2 = Math.cos(attitude / 2); var c3 = Math.cos(bank / 2); var s1 = Math.sin(heading / 2); var s2 = Math.sin(attitude / 2); var s3 = Math.sin(bank / 2); var w = c1 * c2 * c3 - s1 * s2 * s3; var x = s1 * s2 * c3 + c1 * c2 * s3; var y = s1 * c2 * c3 + c1 * s2 * s3; var z = c1 * s2 * c3 - s1 * c2 * s3; return [x, y, z, w]; } function getValueAtCurrentTime() { var frameNum = this.comp.renderedFrame - this.offsetTime; var initTime = this.keyframes[0].t - this.offsetTime; var endTime = this.keyframes[this.keyframes.length - 1].t - this.offsetTime; if (!(frameNum === this._caching.lastFrame || (this._caching.lastFrame !== initFrame && ((this._caching.lastFrame >= endTime && frameNum >= endTime) || (this._caching.lastFrame < initTime && frameNum < initTime))))) { if (this._caching.lastFrame >= frameNum) { this._caching._lastKeyframeIndex = -1; this._caching.lastIndex = 0; } var renderResult = this.interpolateValue(frameNum, this._caching); this.pv = renderResult; } this._caching.lastFrame = frameNum; return this.pv; } function setVValue(val) { var multipliedValue; if (this.propType === 'unidimensional') { multipliedValue = val * this.mult; if (mathAbs(this.v - multipliedValue) > 0.00001) { this.v = multipliedValue; this._mdf = true; } } else { var i = 0; var len = this.v.length; while (i < len) { multipliedValue = val[i] * this.mult; if (mathAbs(this.v[i] - multipliedValue) > 0.00001) { this.v[i] = multipliedValue; this._mdf = true; } i += 1; } } } function processEffectsSequence() { if (this.elem.globalData.frameId === this.frameId || !this.effectsSequence.length) { return; } if (this.lock) { this.setVValue(this.pv); return; } this.lock = true; this._mdf = this._isFirstFrame; var i; var len = this.effectsSequence.length; var finalValue = this.kf ? this.pv : this.data.k; for (i = 0; i < len; i += 1) { finalValue = this.effectsSequence[i](finalValue); } this.setVValue(finalValue); this._isFirstFrame = false; this.lock = false; this.frameId = this.elem.globalData.frameId; } function addEffect(effectFunction) { this.effectsSequence.push(effectFunction); this.container.addDynamicProperty(this); } function ValueProperty(elem, data, mult, container) { this.propType = 'unidimensional'; this.mult = mult || 1; this.data = data; this.v = mult ? data.k * mult : data.k; this.pv = data.k; this._mdf = false; this.elem = elem; this.container = container; this.comp = elem.comp; this.k = false; this.kf = false; this.vel = 0; this.effectsSequence = []; this._isFirstFrame = true; this.getValue = processEffectsSequence; this.setVValue = setVValue; this.addEffect = addEffect; } function MultiDimensionalProperty(elem, data, mult, container) { this.propType = 'multidimensional'; this.mult = mult || 1; this.data = data; this._mdf = false; this.elem = elem; this.container = container; this.comp = elem.comp; this.k = false; this.kf = false; this.frameId = -1; var i; var len = data.k.length; this.v = createTypedArray('float32', len); this.pv = createTypedArray('float32', len); this.vel = createTypedArray('float32', len); for (i = 0; i < len; i += 1) { this.v[i] = data.k[i] * this.mult; this.pv[i] = data.k[i]; } this._isFirstFrame = true; this.effectsSequence = []; this.getValue = processEffectsSequence; this.setVValue = setVValue; this.addEffect = addEffect; } function KeyframedValueProperty(elem, data, mult, container) { this.propType = 'unidimensional'; this.keyframes = data.k; this.keyframesMetadata = []; this.offsetTime = elem.data.st; this.frameId = -1; this._caching = { lastFrame: initFrame, lastIndex: 0, value: 0, _lastKeyframeIndex: -1, }; this.k = true; this.kf = true; this.data = data; this.mult = mult || 1; this.elem = elem; this.container = container; this.comp = elem.comp; this.v = initFrame; this.pv = initFrame; this._isFirstFrame = true; this.getValue = processEffectsSequence; this.setVValue = setVValue; this.interpolateValue = interpolateValue; this.effectsSequence = [getValueAtCurrentTime.bind(this)]; this.addEffect = addEffect; } function KeyframedMultidimensionalProperty(elem, data, mult, container) { this.propType = 'multidimensional'; var i; var len = data.k.length; var s; var e; var to; var ti; for (i = 0; i < len - 1; i += 1) { if (data.k[i].to && data.k[i].s && data.k[i + 1] && data.k[i + 1].s) { s = data.k[i].s; e = data.k[i + 1].s; to = data.k[i].to; ti = data.k[i].ti; if ((s.length === 2 && !(s[0] === e[0] && s[1] === e[1]) && bez.pointOnLine2D(s[0], s[1], e[0], e[1], s[0] + to[0], s[1] + to[1]) && bez.pointOnLine2D(s[0], s[1], e[0], e[1], e[0] + ti[0], e[1] + ti[1])) || (s.length === 3 && !(s[0] === e[0] && s[1] === e[1] && s[2] === e[2]) && bez.pointOnLine3D(s[0], s[1], s[2], e[0], e[1], e[2], s[0] + to[0], s[1] + to[1], s[2] + to[2]) && bez.pointOnLine3D(s[0], s[1], s[2], e[0], e[1], e[2], e[0] + ti[0], e[1] + ti[1], e[2] + ti[2]))) { data.k[i].to = null; data.k[i].ti = null; } if (s[0] === e[0] && s[1] === e[1] && to[0] === 0 && to[1] === 0 && ti[0] === 0 && ti[1] === 0) { if (s.length === 2 || (s[2] === e[2] && to[2] === 0 && ti[2] === 0)) { data.k[i].to = null; data.k[i].ti = null; } } } } this.effectsSequence = [getValueAtCurrentTime.bind(this)]; this.data = data; this.keyframes = data.k; this.keyframesMetadata = []; this.offsetTime = elem.data.st; this.k = true; this.kf = true; this._isFirstFrame = true; this.mult = mult || 1; this.elem = elem; this.container = container; this.comp = elem.comp; this.getValue = processEffectsSequence; this.setVValue = setVValue; this.interpolateValue = interpolateValue; this.frameId = -1; var arrLen = data.k[0].s.length; this.v = createTypedArray('float32', arrLen); this.pv = createTypedArray('float32', arrLen); for (i = 0; i < arrLen; i += 1) { this.v[i] = initFrame; this.pv[i] = initFrame; } this._caching = { lastFrame: initFrame, lastIndex: 0, value: createTypedArray('float32', arrLen) }; this.addEffect = addEffect; } function getProp(elem, data, type, mult, container) { var p; if (!data.k.length) { p = new ValueProperty(elem, data, mult, container); } else if (typeof (data.k[0]) === 'number') { p = new MultiDimensionalProperty(elem, data, mult, container); } else { switch (type) { case 0: p = new KeyframedValueProperty(elem, data, mult, container); break; case 1: p = new KeyframedMultidimensionalProperty(elem, data, mult, container); break; default: break; } } if (p.effectsSequence.length) { container.addDynamicProperty(p); } return p; } var ob = { getProp: getProp, }; return ob; }()); /* global Matrix, degToRads, PropertyFactory, extendPrototype, DynamicPropertyContainer */ /* exported TransformPropertyFactory */ var TransformPropertyFactory = (function () { var defaultVector = [0, 0]; function applyToMatrix(mat) { var _mdf = this._mdf; this.iterateDynamicProperties(); this._mdf = this._mdf || _mdf; if (this.a) { mat.translate(-this.a.v[0], -this.a.v[1], this.a.v[2]); } if (this.s) { mat.scale(this.s.v[0], this.s.v[1], this.s.v[2]); } if (this.sk) { mat.skewFromAxis(-this.sk.v, this.sa.v); } if (this.r) { mat.rotate(-this.r.v); } else { mat.rotateZ(-this.rz.v).rotateY(this.ry.v).rotateX(this.rx.v).rotateZ(-this.or.v[2]) .rotateY(this.or.v[1]) .rotateX(this.or.v[0]); } if (this.data.p.s) { if (this.data.p.z) { mat.translate(this.px.v, this.py.v, -this.pz.v); } else { mat.translate(this.px.v, this.py.v, 0); } } else { mat.translate(this.p.v[0], this.p.v[1], -this.p.v[2]); } } function processKeys(forceRender) { if (this.elem.globalData.frameId === this.frameId) { return; } if (this._isDirty) { this.precalculateMatrix(); this._isDirty = false; } this.iterateDynamicProperties(); if (this._mdf || forceRender) { var frameRate; this.v.cloneFromProps(this.pre.props); if (this.appliedTransformations < 1) { this.v.translate(-this.a.v[0], -this.a.v[1], this.a.v[2]); } if (this.appliedTransformations < 2) { this.v.scale(this.s.v[0], this.s.v[1], this.s.v[2]); } if (this.sk && this.appliedTransformations < 3) { this.v.skewFromAxis(-this.sk.v, this.sa.v); } if (this.r && this.appliedTransformations < 4) { this.v.rotate(-this.r.v); } else if (!this.r && this.appliedTransformations < 4) { this.v.rotateZ(-this.rz.v).rotateY(this.ry.v).rotateX(this.rx.v).rotateZ(-this.or.v[2]) .rotateY(this.or.v[1]) .rotateX(this.or.v[0]); } if (this.autoOriented) { var v1; var v2; frameRate = this.elem.globalData.frameRate; if (this.p && this.p.keyframes && this.p.getValueAtTime) { if (this.p._caching.lastFrame + this.p.offsetTime <= this.p.keyframes[0].t) { v1 = this.p.getValueAtTime((this.p.keyframes[0].t + 0.01) / frameRate, 0); v2 = this.p.getValueAtTime(this.p.keyframes[0].t / frameRate, 0); } else if (this.p._caching.lastFrame + this.p.offsetTime >= this.p.keyframes[this.p.keyframes.length - 1].t) { v1 = this.p.getValueAtTime((this.p.keyframes[this.p.keyframes.length - 1].t / frameRate), 0); v2 = this.p.getValueAtTime((this.p.keyframes[this.p.keyframes.length - 1].t - 0.05) / frameRate, 0); } else { v1 = this.p.pv; v2 = this.p.getValueAtTime((this.p._caching.lastFrame + this.p.offsetTime - 0.01) / frameRate, this.p.offsetTime); } } else if (this.px && this.px.keyframes && this.py.keyframes && this.px.getValueAtTime && this.py.getValueAtTime) { v1 = []; v2 = []; var px = this.px; var py = this.py; if (px._caching.lastFrame + px.offsetTime <= px.keyframes[0].t) { v1[0] = px.getValueAtTime((px.keyframes[0].t + 0.01) / frameRate, 0); v1[1] = py.getValueAtTime((py.keyframes[0].t + 0.01) / frameRate, 0); v2[0] = px.getValueAtTime((px.keyframes[0].t) / frameRate, 0); v2[1] = py.getValueAtTime((py.keyframes[0].t) / frameRate, 0); } else if (px._caching.lastFrame + px.offsetTime >= px.keyframes[px.keyframes.length - 1].t) { v1[0] = px.getValueAtTime((px.keyframes[px.keyframes.length - 1].t / frameRate), 0); v1[1] = py.getValueAtTime((py.keyframes[py.keyframes.length - 1].t / frameRate), 0); v2[0] = px.getValueAtTime((px.keyframes[px.keyframes.length - 1].t - 0.01) / frameRate, 0); v2[1] = py.getValueAtTime((py.keyframes[py.keyframes.length - 1].t - 0.01) / frameRate, 0); } else { v1 = [px.pv, py.pv]; v2[0] = px.getValueAtTime((px._caching.lastFrame + px.offsetTime - 0.01) / frameRate, px.offsetTime); v2[1] = py.getValueAtTime((py._caching.lastFrame + py.offsetTime - 0.01) / frameRate, py.offsetTime); } } else { v2 = defaultVector; v1 = v2; } this.v.rotate(-Math.atan2(v1[1] - v2[1], v1[0] - v2[0])); } if (this.data.p && this.data.p.s) { if (this.data.p.z) { this.v.translate(this.px.v, this.py.v, -this.pz.v); } else { this.v.translate(this.px.v, this.py.v, 0); } } else { this.v.translate(this.p.v[0], this.p.v[1], -this.p.v[2]); } } this.frameId = this.elem.globalData.frameId; } function precalculateMatrix() { if (!this.a.k) { this.pre.translate(-this.a.v[0], -this.a.v[1], this.a.v[2]); this.appliedTransformations = 1; } else { return; } if (!this.s.effectsSequence.length) { this.pre.scale(this.s.v[0], this.s.v[1], this.s.v[2]); this.appliedTransformations = 2; } else { return; } if (this.sk) { if (!this.sk.effectsSequence.length && !this.sa.effectsSequence.length) { this.pre.skewFromAxis(-this.sk.v, this.sa.v); this.appliedTransformations = 3; } else { return; } } if (this.r) { if (!this.r.effectsSequence.length) { this.pre.rotate(-this.r.v); this.appliedTransformations = 4; } } else if (!this.rz.effectsSequence.length && !this.ry.effectsSequence.length && !this.rx.effectsSequence.length && !this.or.effectsSequence.length) { this.pre.rotateZ(-this.rz.v).rotateY(this.ry.v).rotateX(this.rx.v).rotateZ(-this.or.v[2]) .rotateY(this.or.v[1]) .rotateX(this.or.v[0]); this.appliedTransformations = 4; } } function autoOrient() { // // var prevP = this.getValueAtTime(); } function addDynamicProperty(prop) { this._addDynamicProperty(prop); this.elem.addDynamicProperty(prop); this._isDirty = true; } function TransformProperty(elem, data, container) { this.elem = elem; this.frameId = -1; this.propType = 'transform'; this.data = data; this.v = new Matrix(); // Precalculated matrix with non animated properties this.pre = new Matrix(); this.appliedTransformations = 0; this.initDynamicPropertyContainer(container || elem); if (data.p && data.p.s) { this.px = PropertyFactory.getProp(elem, data.p.x, 0, 0, this); this.py = PropertyFactory.getProp(elem, data.p.y, 0, 0, this); if (data.p.z) { this.pz = PropertyFactory.getProp(elem, data.p.z, 0, 0, this); } } else { this.p = PropertyFactory.getProp(elem, data.p || { k: [0, 0, 0] }, 1, 0, this); } if (data.rx) { this.rx = PropertyFactory.getProp(elem, data.rx, 0, degToRads, this); this.ry = PropertyFactory.getProp(elem, data.ry, 0, degToRads, this); this.rz = PropertyFactory.getProp(elem, data.rz, 0, degToRads, this); if (data.or.k[0].ti) { var i; var len = data.or.k.length; for (i = 0; i < len; i += 1) { data.or.k[i].to = null; data.or.k[i].ti = null; } } this.or = PropertyFactory.getProp(elem, data.or, 1, degToRads, this); // sh Indicates it needs to be capped between -180 and 180 this.or.sh = true; } else { this.r = PropertyFactory.getProp(elem, data.r || { k: 0 }, 0, degToRads, this); } if (data.sk) { this.sk = PropertyFactory.getProp(elem, data.sk, 0, degToRads, this); this.sa = PropertyFactory.getProp(elem, data.sa, 0, degToRads, this); } this.a = PropertyFactory.getProp(elem, data.a || { k: [0, 0, 0] }, 1, 0, this); this.s = PropertyFactory.getProp(elem, data.s || { k: [100, 100, 100] }, 1, 0.01, this); // Opacity is not part of the transform properties, that's why it won't use this.dynamicProperties. That way transforms won't get updated if opacity changes. if (data.o) { this.o = PropertyFactory.getProp(elem, data.o, 0, 0.01, elem); } else { this.o = { _mdf: false, v: 1 }; } this._isDirty = true; if (!this.dynamicProperties.length) { this.getValue(true); } } TransformProperty.prototype = { applyToMatrix: applyToMatrix, getValue: processKeys, precalculateMatrix: precalculateMatrix, autoOrient: autoOrient, }; extendPrototype([DynamicPropertyContainer], TransformProperty); TransformProperty.prototype.addDynamicProperty = addDynamicProperty; TransformProperty.prototype._addDynamicProperty = DynamicPropertyContainer.prototype.addDynamicProperty; function getTransformProperty(elem, data, container) { return new TransformProperty(elem, data, container); } return { getTransformProperty: getTransformProperty, }; }()); /* global createSizedArray, createSizedArray, pointPool */ function ShapePath() { this.c = false; this._length = 0; this._maxLength = 8; this.v = createSizedArray(this._maxLength); this.o = createSizedArray(this._maxLength); this.i = createSizedArray(this._maxLength); } ShapePath.prototype.setPathData = function (closed, len) { this.c = closed; this.setLength(len); var i = 0; while (i < len) { this.v[i] = pointPool.newElement(); this.o[i] = pointPool.newElement(); this.i[i] = pointPool.newElement(); i += 1; } }; ShapePath.prototype.setLength = function (len) { while (this._maxLength < len) { this.doubleArrayLength(); } this._length = len; }; ShapePath.prototype.doubleArrayLength = function () { this.v = this.v.concat(createSizedArray(this._maxLength)); this.i = this.i.concat(createSizedArray(this._maxLength)); this.o = this.o.concat(createSizedArray(this._maxLength)); this._maxLength *= 2; }; ShapePath.prototype.setXYAt = function (x, y, type, pos, replace) { var arr; this._length = Math.max(this._length, pos + 1); if (this._length >= this._maxLength) { this.doubleArrayLength(); } switch (type) { case 'v': arr = this.v; break; case 'i': arr = this.i; break; case 'o': arr = this.o; break; default: arr = []; break; } if (!arr[pos] || (arr[pos] && !replace)) { arr[pos] = pointPool.newElement(); } arr[pos][0] = x; arr[pos][1] = y; }; ShapePath.prototype.setTripleAt = function (vX, vY, oX, oY, iX, iY, pos, replace) { this.setXYAt(vX, vY, 'v', pos, replace); this.setXYAt(oX, oY, 'o', pos, replace); this.setXYAt(iX, iY, 'i', pos, replace); }; ShapePath.prototype.reverse = function () { var newPath = new ShapePath(); newPath.setPathData(this.c, this._length); var vertices = this.v; var outPoints = this.o; var inPoints = this.i; var init = 0; if (this.c) { newPath.setTripleAt(vertices[0][0], vertices[0][1], inPoints[0][0], inPoints[0][1], outPoints[0][0], outPoints[0][1], 0, false); init = 1; } var cnt = this._length - 1; var len = this._length; var i; for (i = init; i < len; i += 1) { newPath.setTripleAt(vertices[cnt][0], vertices[cnt][1], inPoints[cnt][0], inPoints[cnt][1], outPoints[cnt][0], outPoints[cnt][1], i, false); cnt -= 1; } return newPath; }; /* global extendPrototype, roundCorner, BezierFactory, shapePool, degToRads, shapeCollectionPool, PropertyFactory, bmMin, DynamicPropertyContainer */ /* exported ShapePropertyFactory */ var ShapePropertyFactory = (function () { var initFrame = -999999; function interpolateShape(frameNum, previousValue, caching) { var iterationIndex = caching.lastIndex; var keyPropS; var keyPropE; var isHold; var j; var k; var jLen; var kLen; var perc; var vertexValue; var kf = this.keyframes; if (frameNum < kf[0].t - this.offsetTime) { keyPropS = kf[0].s[0]; isHold = true; iterationIndex = 0; } else if (frameNum >= kf[kf.length - 1].t - this.offsetTime) { keyPropS = kf[kf.length - 1].s ? kf[kf.length - 1].s[0] : kf[kf.length - 2].e[0]; /* if(kf[kf.length - 1].s){ keyPropS = kf[kf.length - 1].s[0]; }else{ keyPropS = kf[kf.length - 2].e[0]; } */ isHold = true; } else { var i = iterationIndex; var len = kf.length - 1; var flag = true; var keyData; var nextKeyData; var keyframeMetadata; while (flag) { keyData = kf[i]; nextKeyData = kf[i + 1]; if ((nextKeyData.t - this.offsetTime) > frameNum) { break; } if (i < len - 1) { i += 1; } else { flag = false; } } keyframeMetadata = this.keyframesMetadata[i] || {}; isHold = keyData.h === 1; iterationIndex = i; if (!isHold) { if (frameNum >= nextKeyData.t - this.offsetTime) { perc = 1; } else if (frameNum < keyData.t - this.offsetTime) { perc = 0; } else { var fnc; if (keyframeMetadata.__fnct) { fnc = keyframeMetadata.__fnct; } else { fnc = BezierFactory.getBezierEasing(keyData.o.x, keyData.o.y, keyData.i.x, keyData.i.y).get; keyframeMetadata.__fnct = fnc; } perc = fnc((frameNum - (keyData.t - this.offsetTime)) / ((nextKeyData.t - this.offsetTime) - (keyData.t - this.offsetTime))); } keyPropE = nextKeyData.s ? nextKeyData.s[0] : keyData.e[0]; } keyPropS = keyData.s[0]; } jLen = previousValue._length; kLen = keyPropS.i[0].length; caching.lastIndex = iterationIndex; for (j = 0; j < jLen; j += 1) { for (k = 0; k < kLen; k += 1) { vertexValue = isHold ? keyPropS.i[j][k] : keyPropS.i[j][k] + (keyPropE.i[j][k] - keyPropS.i[j][k]) * perc; previousValue.i[j][k] = vertexValue; vertexValue = isHold ? keyPropS.o[j][k] : keyPropS.o[j][k] + (keyPropE.o[j][k] - keyPropS.o[j][k]) * perc; previousValue.o[j][k] = vertexValue; vertexValue = isHold ? keyPropS.v[j][k] : keyPropS.v[j][k] + (keyPropE.v[j][k] - keyPropS.v[j][k]) * perc; previousValue.v[j][k] = vertexValue; } } } function interpolateShapeCurrentTime() { var frameNum = this.comp.renderedFrame - this.offsetTime; var initTime = this.keyframes[0].t - this.offsetTime; var endTime = this.keyframes[this.keyframes.length - 1].t - this.offsetTime; var lastFrame = this._caching.lastFrame; if (!(lastFrame !== initFrame && ((lastFrame < initTime && frameNum < initTime) || (lastFrame > endTime && frameNum > endTime)))) { /// / this._caching.lastIndex = lastFrame < frameNum ? this._caching.lastIndex : 0; this.interpolateShape(frameNum, this.pv, this._caching); /// / } this._caching.lastFrame = frameNum; return this.pv; } function resetShape() { this.paths = this.localShapeCollection; } function shapesEqual(shape1, shape2) { if (shape1._length !== shape2._length || shape1.c !== shape2.c) { return false; } var i; var len = shape1._length; for (i = 0; i < len; i += 1) { if (shape1.v[i][0] !== shape2.v[i][0] || shape1.v[i][1] !== shape2.v[i][1] || shape1.o[i][0] !== shape2.o[i][0] || shape1.o[i][1] !== shape2.o[i][1] || shape1.i[i][0] !== shape2.i[i][0] || shape1.i[i][1] !== shape2.i[i][1]) { return false; } } return true; } function setVValue(newPath) { if (!shapesEqual(this.v, newPath)) { this.v = shapePool.clone(newPath); this.localShapeCollection.releaseShapes(); this.localShapeCollection.addShape(this.v); this._mdf = true; this.paths = this.localShapeCollection; } } function processEffectsSequence() { if (this.elem.globalData.frameId === this.frameId) { return; } if (!this.effectsSequence.length) { this._mdf = false; return; } if (this.lock) { this.setVValue(this.pv); return; } this.lock = true; this._mdf = false; var finalValue; if (this.kf) { finalValue = this.pv; } else if (this.data.ks) { finalValue = this.data.ks.k; } else { finalValue = this.data.pt.k; } var i; var len = this.effectsSequence.length; for (i = 0; i < len; i += 1) { finalValue = this.effectsSequence[i](finalValue); } this.setVValue(finalValue); this.lock = false; this.frameId = this.elem.globalData.frameId; } function ShapeProperty(elem, data, type) { this.propType = 'shape'; this.comp = elem.comp; this.container = elem; this.elem = elem; this.data = data; this.k = false; this.kf = false; this._mdf = false; var pathData = type === 3 ? data.pt.k : data.ks.k; this.v = shapePool.clone(pathData); this.pv = shapePool.clone(this.v); this.localShapeCollection = shapeCollectionPool.newShapeCollection(); this.paths = this.localShapeCollection; this.paths.addShape(this.v); this.reset = resetShape; this.effectsSequence = []; } function addEffect(effectFunction) { this.effectsSequence.push(effectFunction); this.container.addDynamicProperty(this); } ShapeProperty.prototype.interpolateShape = interpolateShape; ShapeProperty.prototype.getValue = processEffectsSequence; ShapeProperty.prototype.setVValue = setVValue; ShapeProperty.prototype.addEffect = addEffect; function KeyframedShapeProperty(elem, data, type) { this.propType = 'shape'; this.comp = elem.comp; this.elem = elem; this.container = elem; this.offsetTime = elem.data.st; this.keyframes = type === 3 ? data.pt.k : data.ks.k; this.keyframesMetadata = []; this.k = true; this.kf = true; var len = this.keyframes[0].s[0].i.length; this.v = shapePool.newElement(); this.v.setPathData(this.keyframes[0].s[0].c, len); this.pv = shapePool.clone(this.v); this.localShapeCollection = shapeCollectionPool.newShapeCollection(); this.paths = this.localShapeCollection; this.paths.addShape(this.v); this.lastFrame = initFrame; this.reset = resetShape; this._caching = { lastFrame: initFrame, lastIndex: 0 }; this.effectsSequence = [interpolateShapeCurrentTime.bind(this)]; } KeyframedShapeProperty.prototype.getValue = processEffectsSequence; KeyframedShapeProperty.prototype.interpolateShape = interpolateShape; KeyframedShapeProperty.prototype.setVValue = setVValue; KeyframedShapeProperty.prototype.addEffect = addEffect; var EllShapeProperty = (function () { var cPoint = roundCorner; function EllShapePropertyFactory(elem, data) { /* this.v = { v: createSizedArray(4), i: createSizedArray(4), o: createSizedArray(4), c: true }; */ this.v = shapePool.newElement(); this.v.setPathData(true, 4); this.localShapeCollection = shapeCollectionPool.newShapeCollection(); this.paths = this.localShapeCollection; this.localShapeCollection.addShape(this.v); this.d = data.d; this.elem = elem; this.comp = elem.comp; this.frameId = -1; this.initDynamicPropertyContainer(elem); this.p = PropertyFactory.getProp(elem, data.p, 1, 0, this); this.s = PropertyFactory.getProp(elem, data.s, 1, 0, this); if (this.dynamicProperties.length) { this.k = true; } else { this.k = false; this.convertEllToPath(); } } EllShapePropertyFactory.prototype = { reset: resetShape, getValue: function () { if (this.elem.globalData.frameId === this.frameId) { return; } this.frameId = this.elem.globalData.frameId; this.iterateDynamicProperties(); if (this._mdf) { this.convertEllToPath(); } }, convertEllToPath: function () { var p0 = this.p.v[0]; var p1 = this.p.v[1]; var s0 = this.s.v[0] / 2; var s1 = this.s.v[1] / 2; var _cw = this.d !== 3; var _v = this.v; _v.v[0][0] = p0; _v.v[0][1] = p1 - s1; _v.v[1][0] = _cw ? p0 + s0 : p0 - s0; _v.v[1][1] = p1; _v.v[2][0] = p0; _v.v[2][1] = p1 + s1; _v.v[3][0] = _cw ? p0 - s0 : p0 + s0; _v.v[3][1] = p1; _v.i[0][0] = _cw ? p0 - s0 * cPoint : p0 + s0 * cPoint; _v.i[0][1] = p1 - s1; _v.i[1][0] = _cw ? p0 + s0 : p0 - s0; _v.i[1][1] = p1 - s1 * cPoint; _v.i[2][0] = _cw ? p0 + s0 * cPoint : p0 - s0 * cPoint; _v.i[2][1] = p1 + s1; _v.i[3][0] = _cw ? p0 - s0 : p0 + s0; _v.i[3][1] = p1 + s1 * cPoint; _v.o[0][0] = _cw ? p0 + s0 * cPoint : p0 - s0 * cPoint; _v.o[0][1] = p1 - s1; _v.o[1][0] = _cw ? p0 + s0 : p0 - s0; _v.o[1][1] = p1 + s1 * cPoint; _v.o[2][0] = _cw ? p0 - s0 * cPoint : p0 + s0 * cPoint; _v.o[2][1] = p1 + s1; _v.o[3][0] = _cw ? p0 - s0 : p0 + s0; _v.o[3][1] = p1 - s1 * cPoint; }, }; extendPrototype([DynamicPropertyContainer], EllShapePropertyFactory); return EllShapePropertyFactory; }()); var StarShapeProperty = (function () { function StarShapePropertyFactory(elem, data) { this.v = shapePool.newElement(); this.v.setPathData(true, 0); this.elem = elem; this.comp = elem.comp; this.data = data; this.frameId = -1; this.d = data.d; this.initDynamicPropertyContainer(elem); if (data.sy === 1) { this.ir = PropertyFactory.getProp(elem, data.ir, 0, 0, this); this.is = PropertyFactory.getProp(elem, data.is, 0, 0.01, this); this.convertToPath = this.convertStarToPath; } else { this.convertToPath = this.convertPolygonToPath; } this.pt = PropertyFactory.getProp(elem, data.pt, 0, 0, this); this.p = PropertyFactory.getProp(elem, data.p, 1, 0, this); this.r = PropertyFactory.getProp(elem, data.r, 0, degToRads, this); this.or = PropertyFactory.getProp(elem, data.or, 0, 0, this); this.os = PropertyFactory.getProp(elem, data.os, 0, 0.01, this); this.localShapeCollection = shapeCollectionPool.newShapeCollection(); this.localShapeCollection.addShape(this.v); this.paths = this.localShapeCollection; if (this.dynamicProperties.length) { this.k = true; } else { this.k = false; this.convertToPath(); } } StarShapePropertyFactory.prototype = { reset: resetShape, getValue: function () { if (this.elem.globalData.frameId === this.frameId) { return; } this.frameId = this.elem.globalData.frameId; this.iterateDynamicProperties(); if (this._mdf) { this.convertToPath(); } }, convertStarToPath: function () { var numPts = Math.floor(this.pt.v) * 2; var angle = (Math.PI * 2) / numPts; /* this.v.v.length = numPts; this.v.i.length = numPts; this.v.o.length = numPts; */ var longFlag = true; var longRad = this.or.v; var shortRad = this.ir.v; var longRound = this.os.v; var shortRound = this.is.v; var longPerimSegment = (2 * Math.PI * longRad) / (numPts * 2); var shortPerimSegment = (2 * Math.PI * shortRad) / (numPts * 2); var i; var rad; var roundness; var perimSegment; var currentAng = -Math.PI / 2; currentAng += this.r.v; var dir = this.data.d === 3 ? -1 : 1; this.v._length = 0; for (i = 0; i < numPts; i += 1) { rad = longFlag ? longRad : shortRad; roundness = longFlag ? longRound : shortRound; perimSegment = longFlag ? longPerimSegment : shortPerimSegment; var x = rad * Math.cos(currentAng); var y = rad * Math.sin(currentAng); var ox = x === 0 && y === 0 ? 0 : y / Math.sqrt(x * x + y * y); var oy = x === 0 && y === 0 ? 0 : -x / Math.sqrt(x * x + y * y); x += +this.p.v[0]; y += +this.p.v[1]; this.v.setTripleAt(x, y, x - ox * perimSegment * roundness * dir, y - oy * perimSegment * roundness * dir, x + ox * perimSegment * roundness * dir, y + oy * perimSegment * roundness * dir, i, true); /* this.v.v[i] = [x,y]; this.v.i[i] = [x+ox*perimSegment*roundness*dir,y+oy*perimSegment*roundness*dir]; this.v.o[i] = [x-ox*perimSegment*roundness*dir,y-oy*perimSegment*roundness*dir]; this.v._length = numPts; */ longFlag = !longFlag; currentAng += angle * dir; } }, convertPolygonToPath: function () { var numPts = Math.floor(this.pt.v); var angle = (Math.PI * 2) / numPts; var rad = this.or.v; var roundness = this.os.v; var perimSegment = (2 * Math.PI * rad) / (numPts * 4); var i; var currentAng = -Math.PI * 0.5; var dir = this.data.d === 3 ? -1 : 1; currentAng += this.r.v; this.v._length = 0; for (i = 0; i < numPts; i += 1) { var x = rad * Math.cos(currentAng); var y = rad * Math.sin(currentAng); var ox = x === 0 && y === 0 ? 0 : y / Math.sqrt(x * x + y * y); var oy = x === 0 && y === 0 ? 0 : -x / Math.sqrt(x * x + y * y); x += +this.p.v[0]; y += +this.p.v[1]; this.v.setTripleAt(x, y, x - ox * perimSegment * roundness * dir, y - oy * perimSegment * roundness * dir, x + ox * perimSegment * roundness * dir, y + oy * perimSegment * roundness * dir, i, true); currentAng += angle * dir; } this.paths.length = 0; this.paths[0] = this.v; }, }; extendPrototype([DynamicPropertyContainer], StarShapePropertyFactory); return StarShapePropertyFactory; }()); var RectShapeProperty = (function () { function RectShapePropertyFactory(elem, data) { this.v = shapePool.newElement(); this.v.c = true; this.localShapeCollection = shapeCollectionPool.newShapeCollection(); this.localShapeCollection.addShape(this.v); this.paths = this.localShapeCollection; this.elem = elem; this.comp = elem.comp; this.frameId = -1; this.d = data.d; this.initDynamicPropertyContainer(elem); this.p = PropertyFactory.getProp(elem, data.p, 1, 0, this); this.s = PropertyFactory.getProp(elem, data.s, 1, 0, this); this.r = PropertyFactory.getProp(elem, data.r, 0, 0, this); if (this.dynamicProperties.length) { this.k = true; } else { this.k = false; this.convertRectToPath(); } } RectShapePropertyFactory.prototype = { convertRectToPath: function () { var p0 = this.p.v[0]; var p1 = this.p.v[1]; var v0 = this.s.v[0] / 2; var v1 = this.s.v[1] / 2; var round = bmMin(v0, v1, this.r.v); var cPoint = round * (1 - roundCorner); this.v._length = 0; if (this.d === 2 || this.d === 1) { this.v.setTripleAt(p0 + v0, p1 - v1 + round, p0 + v0, p1 - v1 + round, p0 + v0, p1 - v1 + cPoint, 0, true); this.v.setTripleAt(p0 + v0, p1 + v1 - round, p0 + v0, p1 + v1 - cPoint, p0 + v0, p1 + v1 - round, 1, true); if (round !== 0) { this.v.setTripleAt(p0 + v0 - round, p1 + v1, p0 + v0 - round, p1 + v1, p0 + v0 - cPoint, p1 + v1, 2, true); this.v.setTripleAt(p0 - v0 + round, p1 + v1, p0 - v0 + cPoint, p1 + v1, p0 - v0 + round, p1 + v1, 3, true); this.v.setTripleAt(p0 - v0, p1 + v1 - round, p0 - v0, p1 + v1 - round, p0 - v0, p1 + v1 - cPoint, 4, true); this.v.setTripleAt(p0 - v0, p1 - v1 + round, p0 - v0, p1 - v1 + cPoint, p0 - v0, p1 - v1 + round, 5, true); this.v.setTripleAt(p0 - v0 + round, p1 - v1, p0 - v0 + round, p1 - v1, p0 - v0 + cPoint, p1 - v1, 6, true); this.v.setTripleAt(p0 + v0 - round, p1 - v1, p0 + v0 - cPoint, p1 - v1, p0 + v0 - round, p1 - v1, 7, true); } else { this.v.setTripleAt(p0 - v0, p1 + v1, p0 - v0 + cPoint, p1 + v1, p0 - v0, p1 + v1, 2); this.v.setTripleAt(p0 - v0, p1 - v1, p0 - v0, p1 - v1 + cPoint, p0 - v0, p1 - v1, 3); } } else { this.v.setTripleAt(p0 + v0, p1 - v1 + round, p0 + v0, p1 - v1 + cPoint, p0 + v0, p1 - v1 + round, 0, true); if (round !== 0) { this.v.setTripleAt(p0 + v0 - round, p1 - v1, p0 + v0 - round, p1 - v1, p0 + v0 - cPoint, p1 - v1, 1, true); this.v.setTripleAt(p0 - v0 + round, p1 - v1, p0 - v0 + cPoint, p1 - v1, p0 - v0 + round, p1 - v1, 2, true); this.v.setTripleAt(p0 - v0, p1 - v1 + round, p0 - v0, p1 - v1 + round, p0 - v0, p1 - v1 + cPoint, 3, true); this.v.setTripleAt(p0 - v0, p1 + v1 - round, p0 - v0, p1 + v1 - cPoint, p0 - v0, p1 + v1 - round, 4, true); this.v.setTripleAt(p0 - v0 + round, p1 + v1, p0 - v0 + round, p1 + v1, p0 - v0 + cPoint, p1 + v1, 5, true); this.v.setTripleAt(p0 + v0 - round, p1 + v1, p0 + v0 - cPoint, p1 + v1, p0 + v0 - round, p1 + v1, 6, true); this.v.setTripleAt(p0 + v0, p1 + v1 - round, p0 + v0, p1 + v1 - round, p0 + v0, p1 + v1 - cPoint, 7, true); } else { this.v.setTripleAt(p0 - v0, p1 - v1, p0 - v0 + cPoint, p1 - v1, p0 - v0, p1 - v1, 1, true); this.v.setTripleAt(p0 - v0, p1 + v1, p0 - v0, p1 + v1 - cPoint, p0 - v0, p1 + v1, 2, true); this.v.setTripleAt(p0 + v0, p1 + v1, p0 + v0 - cPoint, p1 + v1, p0 + v0, p1 + v1, 3, true); } } }, getValue: function () { if (this.elem.globalData.frameId === this.frameId) { return; } this.frameId = this.elem.globalData.frameId; this.iterateDynamicProperties(); if (this._mdf) { this.convertRectToPath(); } }, reset: resetShape, }; extendPrototype([DynamicPropertyContainer], RectShapePropertyFactory); return RectShapePropertyFactory; }()); function getShapeProp(elem, data, type) { var prop; if (type === 3 || type === 4) { var dataProp = type === 3 ? data.pt : data.ks; var keys = dataProp.k; if (keys.length) { prop = new KeyframedShapeProperty(elem, data, type); } else { prop = new ShapeProperty(elem, data, type); } } else if (type === 5) { prop = new RectShapeProperty(elem, data); } else if (type === 6) { prop = new EllShapeProperty(elem, data); } else if (type === 7) { prop = new StarShapeProperty(elem, data); } if (prop.k) { elem.addDynamicProperty(prop); } return prop; } function getConstructorFunction() { return ShapeProperty; } function getKeyframedConstructorFunction() { return KeyframedShapeProperty; } var ob = {}; ob.getShapeProp = getShapeProp; ob.getConstructorFunction = getConstructorFunction; ob.getKeyframedConstructorFunction = getKeyframedConstructorFunction; return ob; }()); /* global shapeCollectionPool, initialDefaultFrame, extendPrototype, DynamicPropertyContainer */ /* exported ShapeModifiers */ var ShapeModifiers = (function () { var ob = {}; var modifiers = {}; ob.registerModifier = registerModifier; ob.getModifier = getModifier; function registerModifier(nm, factory) { if (!modifiers[nm]) { modifiers[nm] = factory; } } function getModifier(nm, elem, data) { return new modifiers[nm](elem, data); } return ob; }()); function ShapeModifier() {} ShapeModifier.prototype.initModifierProperties = function () {}; ShapeModifier.prototype.addShapeToModifier = function () {}; ShapeModifier.prototype.addShape = function (data) { if (!this.closed) { // Adding shape to dynamic properties. It covers the case where a shape has no effects applied, to reset it's _mdf state on every tick. data.sh.container.addDynamicProperty(data.sh); var shapeData = { shape: data.sh, data: data, localShapeCollection: shapeCollectionPool.newShapeCollection() }; this.shapes.push(shapeData); this.addShapeToModifier(shapeData); if (this._isAnimated) { data.setAsAnimated(); } } }; ShapeModifier.prototype.init = function (elem, data) { this.shapes = []; this.elem = elem; this.initDynamicPropertyContainer(elem); this.initModifierProperties(elem, data); this.frameId = initialDefaultFrame; this.closed = false; this.k = false; if (this.dynamicProperties.length) { this.k = true; } else { this.getValue(true); } }; ShapeModifier.prototype.processKeys = function () { if (this.elem.globalData.frameId === this.frameId) { return; } this.frameId = this.elem.globalData.frameId; this.iterateDynamicProperties(); }; extendPrototype([DynamicPropertyContainer], ShapeModifier); /* global extendPrototype, ShapeModifier, PropertyFactory, segmentsLengthPool, bez, shapePool, ShapeModifiers */ function TrimModifier() { } extendPrototype([ShapeModifier], TrimModifier); TrimModifier.prototype.initModifierProperties = function (elem, data) { this.s = PropertyFactory.getProp(elem, data.s, 0, 0.01, this); this.e = PropertyFactory.getProp(elem, data.e, 0, 0.01, this); this.o = PropertyFactory.getProp(elem, data.o, 0, 0, this); this.sValue = 0; this.eValue = 0; this.getValue = this.processKeys; this.m = data.m; this._isAnimated = !!this.s.effectsSequence.length || !!this.e.effectsSequence.length || !!this.o.effectsSequence.length; }; TrimModifier.prototype.addShapeToModifier = function (shapeData) { shapeData.pathsData = []; }; TrimModifier.prototype.calculateShapeEdges = function (s, e, shapeLength, addedLength, totalModifierLength) { var segments = []; if (e <= 1) { segments.push({ s: s, e: e, }); } else if (s >= 1) { segments.push({ s: s - 1, e: e - 1, }); } else { segments.push({ s: s, e: 1, }); segments.push({ s: 0, e: e - 1, }); } var shapeSegments = []; var i; var len = segments.length; var segmentOb; for (i = 0; i < len; i += 1) { segmentOb = segments[i]; if (!(segmentOb.e * totalModifierLength < addedLength || segmentOb.s * totalModifierLength > addedLength + shapeLength)) { var shapeS; var shapeE; if (segmentOb.s * totalModifierLength <= addedLength) { shapeS = 0; } else { shapeS = (segmentOb.s * totalModifierLength - addedLength) / shapeLength; } if (segmentOb.e * totalModifierLength >= addedLength + shapeLength) { shapeE = 1; } else { shapeE = ((segmentOb.e * totalModifierLength - addedLength) / shapeLength); } shapeSegments.push([shapeS, shapeE]); } } if (!shapeSegments.length) { shapeSegments.push([0, 0]); } return shapeSegments; }; TrimModifier.prototype.releasePathsData = function (pathsData) { var i; var len = pathsData.length; for (i = 0; i < len; i += 1) { segmentsLengthPool.release(pathsData[i]); } pathsData.length = 0; return pathsData; }; TrimModifier.prototype.processShapes = function (_isFirstFrame) { var s; var e; if (this._mdf || _isFirstFrame) { var o = (this.o.v % 360) / 360; if (o < 0) { o += 1; } if (this.s.v > 1) { s = 1 + o; } else if (this.s.v < 0) { s = 0 + o; } else { s = this.s.v + o; } if (this.e.v > 1) { e = 1 + o; } else if (this.e.v < 0) { e = 0 + o; } else { e = this.e.v + o; } if (s > e) { var _s = s; s = e; e = _s; } s = Math.round(s * 10000) * 0.0001; e = Math.round(e * 10000) * 0.0001; this.sValue = s; this.eValue = e; } else { s = this.sValue; e = this.eValue; } var shapePaths; var i; var len = this.shapes.length; var j; var jLen; var pathsData; var pathData; var totalShapeLength; var totalModifierLength = 0; if (e === s) { for (i = 0; i < len; i += 1) { this.shapes[i].localShapeCollection.releaseShapes(); this.shapes[i].shape._mdf = true; this.shapes[i].shape.paths = this.shapes[i].localShapeCollection; if (this._mdf) { this.shapes[i].pathsData.length = 0; } } } else if (!((e === 1 && s === 0) || (e === 0 && s === 1))) { var segments = []; var shapeData; var localShapeCollection; for (i = 0; i < len; i += 1) { shapeData = this.shapes[i]; // if shape hasn't changed and trim properties haven't changed, cached previous path can be used if (!shapeData.shape._mdf && !this._mdf && !_isFirstFrame && this.m !== 2) { shapeData.shape.paths = shapeData.localShapeCollection; } else { shapePaths = shapeData.shape.paths; jLen = shapePaths._length; totalShapeLength = 0; if (!shapeData.shape._mdf && shapeData.pathsData.length) { totalShapeLength = shapeData.totalShapeLength; } else { pathsData = this.releasePathsData(shapeData.pathsData); for (j = 0; j < jLen; j += 1) { pathData = bez.getSegmentsLength(shapePaths.shapes[j]); pathsData.push(pathData); totalShapeLength += pathData.totalLength; } shapeData.totalShapeLength = totalShapeLength; shapeData.pathsData = pathsData; } totalModifierLength += totalShapeLength; shapeData.shape._mdf = true; } } var shapeS = s; var shapeE = e; var addedLength = 0; var edges; for (i = len - 1; i >= 0; i -= 1) { shapeData = this.shapes[i]; if (shapeData.shape._mdf) { localShapeCollection = shapeData.localShapeCollection; localShapeCollection.releaseShapes(); // if m === 2 means paths are trimmed individually so edges need to be found for this specific shape relative to whoel group if (this.m === 2 && len > 1) { edges = this.calculateShapeEdges(s, e, shapeData.totalShapeLength, addedLength, totalModifierLength); addedLength += shapeData.totalShapeLength; } else { edges = [[shapeS, shapeE]]; } jLen = edges.length; for (j = 0; j < jLen; j += 1) { shapeS = edges[j][0]; shapeE = edges[j][1]; segments.length = 0; if (shapeE <= 1) { segments.push({ s: shapeData.totalShapeLength * shapeS, e: shapeData.totalShapeLength * shapeE, }); } else if (shapeS >= 1) { segments.push({ s: shapeData.totalShapeLength * (shapeS - 1), e: shapeData.totalShapeLength * (shapeE - 1), }); } else { segments.push({ s: shapeData.totalShapeLength * shapeS, e: shapeData.totalShapeLength, }); segments.push({ s: 0, e: shapeData.totalShapeLength * (shapeE - 1), }); } var newShapesData = this.addShapes(shapeData, segments[0]); if (segments[0].s !== segments[0].e) { if (segments.length > 1) { var lastShapeInCollection = shapeData.shape.paths.shapes[shapeData.shape.paths._length - 1]; if (lastShapeInCollection.c) { var lastShape = newShapesData.pop(); this.addPaths(newShapesData, localShapeCollection); newShapesData = this.addShapes(shapeData, segments[1], lastShape); } else { this.addPaths(newShapesData, localShapeCollection); newShapesData = this.addShapes(shapeData, segments[1]); } } this.addPaths(newShapesData, localShapeCollection); } } shapeData.shape.paths = localShapeCollection; } } } else if (this._mdf) { for (i = 0; i < len; i += 1) { // Releasign Trim Cached paths data when no trim applied in case shapes are modified inbetween. // Don't remove this even if it's losing cached info. this.shapes[i].pathsData.length = 0; this.shapes[i].shape._mdf = true; } } }; TrimModifier.prototype.addPaths = function (newPaths, localShapeCollection) { var i; var len = newPaths.length; for (i = 0; i < len; i += 1) { localShapeCollection.addShape(newPaths[i]); } }; TrimModifier.prototype.addSegment = function (pt1, pt2, pt3, pt4, shapePath, pos, newShape) { shapePath.setXYAt(pt2[0], pt2[1], 'o', pos); shapePath.setXYAt(pt3[0], pt3[1], 'i', pos + 1); if (newShape) { shapePath.setXYAt(pt1[0], pt1[1], 'v', pos); } shapePath.setXYAt(pt4[0], pt4[1], 'v', pos + 1); }; TrimModifier.prototype.addSegmentFromArray = function (points, shapePath, pos, newShape) { shapePath.setXYAt(points[1], points[5], 'o', pos); shapePath.setXYAt(points[2], points[6], 'i', pos + 1); if (newShape) { shapePath.setXYAt(points[0], points[4], 'v', pos); } shapePath.setXYAt(points[3], points[7], 'v', pos + 1); }; TrimModifier.prototype.addShapes = function (shapeData, shapeSegment, shapePath) { var pathsData = shapeData.pathsData; var shapePaths = shapeData.shape.paths.shapes; var i; var len = shapeData.shape.paths._length; var j; var jLen; var addedLength = 0; var currentLengthData; var segmentCount; var lengths; var segment; var shapes = []; var initPos; var newShape = true; if (!shapePath) { shapePath = shapePool.newElement(); segmentCount = 0; initPos = 0; } else { segmentCount = shapePath._length; initPos = shapePath._length; } shapes.push(shapePath); for (i = 0; i < len; i += 1) { lengths = pathsData[i].lengths; shapePath.c = shapePaths[i].c; jLen = shapePaths[i].c ? lengths.length : lengths.length + 1; for (j = 1; j < jLen; j += 1) { currentLengthData = lengths[j - 1]; if (addedLength + currentLengthData.addedLength < shapeSegment.s) { addedLength += currentLengthData.addedLength; shapePath.c = false; } else if (addedLength > shapeSegment.e) { shapePath.c = false; break; } else { if (shapeSegment.s <= addedLength && shapeSegment.e >= addedLength + currentLengthData.addedLength) { this.addSegment(shapePaths[i].v[j - 1], shapePaths[i].o[j - 1], shapePaths[i].i[j], shapePaths[i].v[j], shapePath, segmentCount, newShape); newShape = false; } else { segment = bez.getNewSegment(shapePaths[i].v[j - 1], shapePaths[i].v[j], shapePaths[i].o[j - 1], shapePaths[i].i[j], (shapeSegment.s - addedLength) / currentLengthData.addedLength, (shapeSegment.e - addedLength) / currentLengthData.addedLength, lengths[j - 1]); this.addSegmentFromArray(segment, shapePath, segmentCount, newShape); // this.addSegment(segment.pt1, segment.pt3, segment.pt4, segment.pt2, shapePath, segmentCount, newShape); newShape = false; shapePath.c = false; } addedLength += currentLengthData.addedLength; segmentCount += 1; } } if (shapePaths[i].c && lengths.length) { currentLengthData = lengths[j - 1]; if (addedLength <= shapeSegment.e) { var segmentLength = lengths[j - 1].addedLength; if (shapeSegment.s <= addedLength && shapeSegment.e >= addedLength + segmentLength) { this.addSegment(shapePaths[i].v[j - 1], shapePaths[i].o[j - 1], shapePaths[i].i[0], shapePaths[i].v[0], shapePath, segmentCount, newShape); newShape = false; } else { segment = bez.getNewSegment(shapePaths[i].v[j - 1], shapePaths[i].v[0], shapePaths[i].o[j - 1], shapePaths[i].i[0], (shapeSegment.s - addedLength) / segmentLength, (shapeSegment.e - addedLength) / segmentLength, lengths[j - 1]); this.addSegmentFromArray(segment, shapePath, segmentCount, newShape); // this.addSegment(segment.pt1, segment.pt3, segment.pt4, segment.pt2, shapePath, segmentCount, newShape); newShape = false; shapePath.c = false; } } else { shapePath.c = false; } addedLength += currentLengthData.addedLength; segmentCount += 1; } if (shapePath._length) { shapePath.setXYAt(shapePath.v[initPos][0], shapePath.v[initPos][1], 'i', initPos); shapePath.setXYAt(shapePath.v[shapePath._length - 1][0], shapePath.v[shapePath._length - 1][1], 'o', shapePath._length - 1); } if (addedLength > shapeSegment.e) { break; } if (i < len - 1) { shapePath = shapePool.newElement(); newShape = true; shapes.push(shapePath); segmentCount = 0; } } return shapes; }; ShapeModifiers.registerModifier('tm', TrimModifier); /* global extendPrototype, ShapeModifier, PropertyFactory, shapePool, roundCorner, ShapeModifiers */ function RoundCornersModifier() {} extendPrototype([ShapeModifier], RoundCornersModifier); RoundCornersModifier.prototype.initModifierProperties = function (elem, data) { this.getValue = this.processKeys; this.rd = PropertyFactory.getProp(elem, data.r, 0, null, this); this._isAnimated = !!this.rd.effectsSequence.length; }; RoundCornersModifier.prototype.processPath = function (path, round) { var clonedPath = shapePool.newElement(); clonedPath.c = path.c; var i; var len = path._length; var currentV; var currentI; var currentO; var closerV; var distance; var newPosPerc; var index = 0; var vX; var vY; var oX; var oY; var iX; var iY; for (i = 0; i < len; i += 1) { currentV = path.v[i]; currentO = path.o[i]; currentI = path.i[i]; if (currentV[0] === currentO[0] && currentV[1] === currentO[1] && currentV[0] === currentI[0] && currentV[1] === currentI[1]) { if ((i === 0 || i === len - 1) && !path.c) { clonedPath.setTripleAt(currentV[0], currentV[1], currentO[0], currentO[1], currentI[0], currentI[1], index); /* clonedPath.v[index] = currentV; clonedPath.o[index] = currentO; clonedPath.i[index] = currentI; */ index += 1; } else { if (i === 0) { closerV = path.v[len - 1]; } else { closerV = path.v[i - 1]; } distance = Math.sqrt(Math.pow(currentV[0] - closerV[0], 2) + Math.pow(currentV[1] - closerV[1], 2)); newPosPerc = distance ? Math.min(distance / 2, round) / distance : 0; iX = currentV[0] + (closerV[0] - currentV[0]) * newPosPerc; vX = iX; iY = currentV[1] - (currentV[1] - closerV[1]) * newPosPerc; vY = iY; oX = vX - (vX - currentV[0]) * roundCorner; oY = vY - (vY - currentV[1]) * roundCorner; clonedPath.setTripleAt(vX, vY, oX, oY, iX, iY, index); index += 1; if (i === len - 1) { closerV = path.v[0]; } else { closerV = path.v[i + 1]; } distance = Math.sqrt(Math.pow(currentV[0] - closerV[0], 2) + Math.pow(currentV[1] - closerV[1], 2)); newPosPerc = distance ? Math.min(distance / 2, round) / distance : 0; oX = currentV[0] + (closerV[0] - currentV[0]) * newPosPerc; vX = oX; oY = currentV[1] + (closerV[1] - currentV[1]) * newPosPerc; vY = oY; iX = vX - (vX - currentV[0]) * roundCorner; iY = vY - (vY - currentV[1]) * roundCorner; clonedPath.setTripleAt(vX, vY, oX, oY, iX, iY, index); index += 1; } } else { clonedPath.setTripleAt(path.v[i][0], path.v[i][1], path.o[i][0], path.o[i][1], path.i[i][0], path.i[i][1], index); index += 1; } } return clonedPath; }; RoundCornersModifier.prototype.processShapes = function (_isFirstFrame) { var shapePaths; var i; var len = this.shapes.length; var j; var jLen; var rd = this.rd.v; if (rd !== 0) { var shapeData; var localShapeCollection; for (i = 0; i < len; i += 1) { shapeData = this.shapes[i]; localShapeCollection = shapeData.localShapeCollection; if (!(!shapeData.shape._mdf && !this._mdf && !_isFirstFrame)) { localShapeCollection.releaseShapes(); shapeData.shape._mdf = true; shapePaths = shapeData.shape.paths.shapes; jLen = shapeData.shape.paths._length; for (j = 0; j < jLen; j += 1) { localShapeCollection.addShape(this.processPath(shapePaths[j], rd)); } } shapeData.shape.paths = shapeData.localShapeCollection; } } if (!this.dynamicProperties.length) { this._mdf = false; } }; ShapeModifiers.registerModifier('rd', RoundCornersModifier); /* global extendPrototype, ShapeModifier, PropertyFactory, shapePool, ShapeModifiers */ function PuckerAndBloatModifier() {} extendPrototype([ShapeModifier], PuckerAndBloatModifier); PuckerAndBloatModifier.prototype.initModifierProperties = function (elem, data) { this.getValue = this.processKeys; this.amount = PropertyFactory.getProp(elem, data.a, 0, null, this); this._isAnimated = !!this.amount.effectsSequence.length; }; PuckerAndBloatModifier.prototype.processPath = function (path, amount) { var percent = amount / 100; var centerPoint = [0, 0]; var pathLength = path._length; var i = 0; for (i = 0; i < pathLength; i += 1) { centerPoint[0] += path.v[i][0]; centerPoint[1] += path.v[i][1]; } centerPoint[0] /= pathLength; centerPoint[1] /= pathLength; var clonedPath = shapePool.newElement(); clonedPath.c = path.c; var vX; var vY; var oX; var oY; var iX; var iY; for (i = 0; i < pathLength; i += 1) { vX = path.v[i][0] + (centerPoint[0] - path.v[i][0]) * percent; vY = path.v[i][1] + (centerPoint[1] - path.v[i][1]) * percent; oX = path.o[i][0] + (centerPoint[0] - path.o[i][0]) * -percent; oY = path.o[i][1] + (centerPoint[1] - path.o[i][1]) * -percent; iX = path.i[i][0] + (centerPoint[0] - path.i[i][0]) * -percent; iY = path.i[i][1] + (centerPoint[1] - path.i[i][1]) * -percent; clonedPath.setTripleAt(vX, vY, oX, oY, iX, iY, i); } return clonedPath; }; PuckerAndBloatModifier.prototype.processShapes = function (_isFirstFrame) { var shapePaths; var i; var len = this.shapes.length; var j; var jLen; var amount = this.amount.v; if (amount !== 0) { var shapeData; var localShapeCollection; for (i = 0; i < len; i += 1) { shapeData = this.shapes[i]; localShapeCollection = shapeData.localShapeCollection; if (!(!shapeData.shape._mdf && !this._mdf && !_isFirstFrame)) { localShapeCollection.releaseShapes(); shapeData.shape._mdf = true; shapePaths = shapeData.shape.paths.shapes; jLen = shapeData.shape.paths._length; for (j = 0; j < jLen; j += 1) { localShapeCollection.addShape(this.processPath(shapePaths[j], amount)); } } shapeData.shape.paths = shapeData.localShapeCollection; } } if (!this.dynamicProperties.length) { this._mdf = false; } }; ShapeModifiers.registerModifier('pb', PuckerAndBloatModifier); /* global extendPrototype, ShapeModifier, TransformPropertyFactory, PropertyFactory, Matrix, ShapeModifiers */ function RepeaterModifier() {} extendPrototype([ShapeModifier], RepeaterModifier); RepeaterModifier.prototype.initModifierProperties = function (elem, data) { this.getValue = this.processKeys; this.c = PropertyFactory.getProp(elem, data.c, 0, null, this); this.o = PropertyFactory.getProp(elem, data.o, 0, null, this); this.tr = TransformPropertyFactory.getTransformProperty(elem, data.tr, this); this.so = PropertyFactory.getProp(elem, data.tr.so, 0, 0.01, this); this.eo = PropertyFactory.getProp(elem, data.tr.eo, 0, 0.01, this); this.data = data; if (!this.dynamicProperties.length) { this.getValue(true); } this._isAnimated = !!this.dynamicProperties.length; this.pMatrix = new Matrix(); this.rMatrix = new Matrix(); this.sMatrix = new Matrix(); this.tMatrix = new Matrix(); this.matrix = new Matrix(); }; RepeaterModifier.prototype.applyTransforms = function (pMatrix, rMatrix, sMatrix, transform, perc, inv) { var dir = inv ? -1 : 1; var scaleX = transform.s.v[0] + (1 - transform.s.v[0]) * (1 - perc); var scaleY = transform.s.v[1] + (1 - transform.s.v[1]) * (1 - perc); pMatrix.translate(transform.p.v[0] * dir * perc, transform.p.v[1] * dir * perc, transform.p.v[2]); rMatrix.translate(-transform.a.v[0], -transform.a.v[1], transform.a.v[2]); rMatrix.rotate(-transform.r.v * dir * perc); rMatrix.translate(transform.a.v[0], transform.a.v[1], transform.a.v[2]); sMatrix.translate(-transform.a.v[0], -transform.a.v[1], transform.a.v[2]); sMatrix.scale(inv ? 1 / scaleX : scaleX, inv ? 1 / scaleY : scaleY); sMatrix.translate(transform.a.v[0], transform.a.v[1], transform.a.v[2]); }; RepeaterModifier.prototype.init = function (elem, arr, pos, elemsData) { this.elem = elem; this.arr = arr; this.pos = pos; this.elemsData = elemsData; this._currentCopies = 0; this._elements = []; this._groups = []; this.frameId = -1; this.initDynamicPropertyContainer(elem); this.initModifierProperties(elem, arr[pos]); while (pos > 0) { pos -= 1; // this._elements.unshift(arr.splice(pos,1)[0]); this._elements.unshift(arr[pos]); } if (this.dynamicProperties.length) { this.k = true; } else { this.getValue(true); } }; RepeaterModifier.prototype.resetElements = function (elements) { var i; var len = elements.length; for (i = 0; i < len; i += 1) { elements[i]._processed = false; if (elements[i].ty === 'gr') { this.resetElements(elements[i].it); } } }; RepeaterModifier.prototype.cloneElements = function (elements) { var newElements = JSON.parse(JSON.stringify(elements)); this.resetElements(newElements); return newElements; }; RepeaterModifier.prototype.changeGroupRender = function (elements, renderFlag) { var i; var len = elements.length; for (i = 0; i < len; i += 1) { elements[i]._render = renderFlag; if (elements[i].ty === 'gr') { this.changeGroupRender(elements[i].it, renderFlag); } } }; RepeaterModifier.prototype.processShapes = function (_isFirstFrame) { var items; var itemsTransform; var i; var dir; var cont; var hasReloaded = false; if (this._mdf || _isFirstFrame) { var copies = Math.ceil(this.c.v); if (this._groups.length < copies) { while (this._groups.length < copies) { var group = { it: this.cloneElements(this._elements), ty: 'gr', }; group.it.push({ a: { a: 0, ix: 1, k: [0, 0] }, nm: 'Transform', o: { a: 0, ix: 7, k: 100 }, p: { a: 0, ix: 2, k: [0, 0] }, r: { a: 1, ix: 6, k: [{ s: 0, e: 0, t: 0 }, { s: 0, e: 0, t: 1 }] }, s: { a: 0, ix: 3, k: [100, 100] }, sa: { a: 0, ix: 5, k: 0 }, sk: { a: 0, ix: 4, k: 0 }, ty: 'tr', }); this.arr.splice(0, 0, group); this._groups.splice(0, 0, group); this._currentCopies += 1; } this.elem.reloadShapes(); hasReloaded = true; } cont = 0; var renderFlag; for (i = 0; i <= this._groups.length - 1; i += 1) { renderFlag = cont < copies; this._groups[i]._render = renderFlag; this.changeGroupRender(this._groups[i].it, renderFlag); if (!renderFlag) { var elems = this.elemsData[i].it; var transformData = elems[elems.length - 1]; if (transformData.transform.op.v !== 0) { transformData.transform.op._mdf = true; transformData.transform.op.v = 0; } else { transformData.transform.op._mdf = false; } } cont += 1; } this._currentCopies = copies; /// / var offset = this.o.v; var offsetModulo = offset % 1; var roundOffset = offset > 0 ? Math.floor(offset) : Math.ceil(offset); var pProps = this.pMatrix.props; var rProps = this.rMatrix.props; var sProps = this.sMatrix.props; this.pMatrix.reset(); this.rMatrix.reset(); this.sMatrix.reset(); this.tMatrix.reset(); this.matrix.reset(); var iteration = 0; if (offset > 0) { while (iteration < roundOffset) { this.applyTransforms(this.pMatrix, this.rMatrix, this.sMatrix, this.tr, 1, false); iteration += 1; } if (offsetModulo) { this.applyTransforms(this.pMatrix, this.rMatrix, this.sMatrix, this.tr, offsetModulo, false); iteration += offsetModulo; } } else if (offset < 0) { while (iteration > roundOffset) { this.applyTransforms(this.pMatrix, this.rMatrix, this.sMatrix, this.tr, 1, true); iteration -= 1; } if (offsetModulo) { this.applyTransforms(this.pMatrix, this.rMatrix, this.sMatrix, this.tr, -offsetModulo, true); iteration -= offsetModulo; } } i = this.data.m === 1 ? 0 : this._currentCopies - 1; dir = this.data.m === 1 ? 1 : -1; cont = this._currentCopies; var j; var jLen; while (cont) { items = this.elemsData[i].it; itemsTransform = items[items.length - 1].transform.mProps.v.props; jLen = itemsTransform.length; items[items.length - 1].transform.mProps._mdf = true; items[items.length - 1].transform.op._mdf = true; items[items.length - 1].transform.op.v = this._currentCopies === 1 ? this.so.v : this.so.v + (this.eo.v - this.so.v) * (i / (this._currentCopies - 1)); if (iteration !== 0) { if ((i !== 0 && dir === 1) || (i !== this._currentCopies - 1 && dir === -1)) { this.applyTransforms(this.pMatrix, this.rMatrix, this.sMatrix, this.tr, 1, false); } this.matrix.transform(rProps[0], rProps[1], rProps[2], rProps[3], rProps[4], rProps[5], rProps[6], rProps[7], rProps[8], rProps[9], rProps[10], rProps[11], rProps[12], rProps[13], rProps[14], rProps[15]); this.matrix.transform(sProps[0], sProps[1], sProps[2], sProps[3], sProps[4], sProps[5], sProps[6], sProps[7], sProps[8], sProps[9], sProps[10], sProps[11], sProps[12], sProps[13], sProps[14], sProps[15]); this.matrix.transform(pProps[0], pProps[1], pProps[2], pProps[3], pProps[4], pProps[5], pProps[6], pProps[7], pProps[8], pProps[9], pProps[10], pProps[11], pProps[12], pProps[13], pProps[14], pProps[15]); for (j = 0; j < jLen; j += 1) { itemsTransform[j] = this.matrix.props[j]; } this.matrix.reset(); } else { this.matrix.reset(); for (j = 0; j < jLen; j += 1) { itemsTransform[j] = this.matrix.props[j]; } } iteration += 1; cont -= 1; i += dir; } } else { cont = this._currentCopies; i = 0; dir = 1; while (cont) { items = this.elemsData[i].it; itemsTransform = items[items.length - 1].transform.mProps.v.props; items[items.length - 1].transform.mProps._mdf = false; items[items.length - 1].transform.op._mdf = false; cont -= 1; i += dir; } } return hasReloaded; }; RepeaterModifier.prototype.addShape = function () {}; ShapeModifiers.registerModifier('rp', RepeaterModifier); /* global createSizedArray, shapePool */ function ShapeCollection() { this._length = 0; this._maxLength = 4; this.shapes = createSizedArray(this._maxLength); } ShapeCollection.prototype.addShape = function (shapeData) { if (this._length === this._maxLength) { this.shapes = this.shapes.concat(createSizedArray(this._maxLength)); this._maxLength *= 2; } this.shapes[this._length] = shapeData; this._length += 1; }; ShapeCollection.prototype.releaseShapes = function () { var i; for (i = 0; i < this._length; i += 1) { shapePool.release(this.shapes[i]); } this._length = 0; }; /* global createSizedArray, createTypedArray, PropertyFactory, extendPrototype, DynamicPropertyContainer */ function DashProperty(elem, data, renderer, container) { this.elem = elem; this.frameId = -1; this.dataProps = createSizedArray(data.length); this.renderer = renderer; this.k = false; this.dashStr = ''; this.dashArray = createTypedArray('float32', data.length ? data.length - 1 : 0); this.dashoffset = createTypedArray('float32', 1); this.initDynamicPropertyContainer(container); var i; var len = data.length || 0; var prop; for (i = 0; i < len; i += 1) { prop = PropertyFactory.getProp(elem, data[i].v, 0, 0, this); this.k = prop.k || this.k; this.dataProps[i] = { n: data[i].n, p: prop }; } if (!this.k) { this.getValue(true); } this._isAnimated = this.k; } DashProperty.prototype.getValue = function (forceRender) { if (this.elem.globalData.frameId === this.frameId && !forceRender) { return; } this.frameId = this.elem.globalData.frameId; this.iterateDynamicProperties(); this._mdf = this._mdf || forceRender; if (this._mdf) { var i = 0; var len = this.dataProps.length; if (this.renderer === 'svg') { this.dashStr = ''; } for (i = 0; i < len; i += 1) { if (this.dataProps[i].n !== 'o') { if (this.renderer === 'svg') { this.dashStr += ' ' + this.dataProps[i].p.v; } else { this.dashArray[i] = this.dataProps[i].p.v; } } else { this.dashoffset[0] = this.dataProps[i].p.v; } } } }; extendPrototype([DynamicPropertyContainer], DashProperty); /* global createTypedArray, PropertyFactory, extendPrototype, DynamicPropertyContainer */ function GradientProperty(elem, data, container) { this.data = data; this.c = createTypedArray('uint8c', data.p * 4); var cLength = data.k.k[0].s ? (data.k.k[0].s.length - data.p * 4) : data.k.k.length - data.p * 4; this.o = createTypedArray('float32', cLength); this._cmdf = false; this._omdf = false; this._collapsable = this.checkCollapsable(); this._hasOpacity = cLength; this.initDynamicPropertyContainer(container); this.prop = PropertyFactory.getProp(elem, data.k, 1, null, this); this.k = this.prop.k; this.getValue(true); } GradientProperty.prototype.comparePoints = function (values, points) { var i = 0; var len = this.o.length / 2; var diff; while (i < len) { diff = Math.abs(values[i * 4] - values[points * 4 + i * 2]); if (diff > 0.01) { return false; } i += 1; } return true; }; GradientProperty.prototype.checkCollapsable = function () { if (this.o.length / 2 !== this.c.length / 4) { return false; } if (this.data.k.k[0].s) { var i = 0; var len = this.data.k.k.length; while (i < len) { if (!this.comparePoints(this.data.k.k[i].s, this.data.p)) { return false; } i += 1; } } else if (!this.comparePoints(this.data.k.k, this.data.p)) { return false; } return true; }; GradientProperty.prototype.getValue = function (forceRender) { this.prop.getValue(); this._mdf = false; this._cmdf = false; this._omdf = false; if (this.prop._mdf || forceRender) { var i; var len = this.data.p * 4; var mult; var val; for (i = 0; i < len; i += 1) { mult = i % 4 === 0 ? 100 : 255; val = Math.round(this.prop.v[i] * mult); if (this.c[i] !== val) { this.c[i] = val; this._cmdf = !forceRender; } } if (this.o.length) { len = this.prop.v.length; for (i = this.data.p * 4; i < len; i += 1) { mult = i % 2 === 0 ? 100 : 1; val = i % 2 === 0 ? Math.round(this.prop.v[i] * 100) : this.prop.v[i]; if (this.o[i - this.data.p * 4] !== val) { this.o[i - this.data.p * 4] = val; this._omdf = !forceRender; } } } this._mdf = !forceRender; } }; extendPrototype([DynamicPropertyContainer], GradientProperty); /* exported buildShapeString */ var buildShapeString = function (pathNodes, length, closed, mat) { if (length === 0) { return ''; } var _o = pathNodes.o; var _i = pathNodes.i; var _v = pathNodes.v; var i; var shapeString = ' M' + mat.applyToPointStringified(_v[0][0], _v[0][1]); for (i = 1; i < length; i += 1) { shapeString += ' C' + mat.applyToPointStringified(_o[i - 1][0], _o[i - 1][1]) + ' ' + mat.applyToPointStringified(_i[i][0], _i[i][1]) + ' ' + mat.applyToPointStringified(_v[i][0], _v[i][1]); } if (closed && length) { shapeString += ' C' + mat.applyToPointStringified(_o[i - 1][0], _o[i - 1][1]) + ' ' + mat.applyToPointStringified(_i[0][0], _i[0][1]) + ' ' + mat.applyToPointStringified(_v[0][0], _v[0][1]); shapeString += 'z'; } return shapeString; }; /* global Howl */ /* exported audioControllerFactory */ var audioControllerFactory = (function () { function AudioController(audioFactory) { this.audios = []; this.audioFactory = audioFactory; this._volume = 1; this._isMuted = false; } AudioController.prototype = { addAudio: function (audio) { this.audios.push(audio); }, pause: function () { var i; var len = this.audios.length; for (i = 0; i < len; i += 1) { this.audios[i].pause(); } }, resume: function () { var i; var len = this.audios.length; for (i = 0; i < len; i += 1) { this.audios[i].resume(); } }, setRate: function (rateValue) { var i; var len = this.audios.length; for (i = 0; i < len; i += 1) { this.audios[i].setRate(rateValue); } }, createAudio: function (assetPath) { if (this.audioFactory) { return this.audioFactory(assetPath); } if (Howl) { return new Howl({ src: [assetPath], }); } return { isPlaying: false, play: function () { this.isPlaying = true; }, seek: function () { this.isPlaying = false; }, playing: function () {}, rate: function () {}, setVolume: function () {}, }; }, setAudioFactory: function (audioFactory) { this.audioFactory = audioFactory; }, setVolume: function (value) { this._volume = value; this._updateVolume(); }, mute: function () { this._isMuted = true; this._updateVolume(); }, unmute: function () { this._isMuted = false; this._updateVolume(); }, getVolume: function () { return this._volume; }, _updateVolume: function () { var i; var len = this.audios.length; for (i = 0; i < len; i += 1) { this.audios[i].volume(this._volume * (this._isMuted ? 0 : 1)); } }, }; return function () { return new AudioController(); }; }()); /* global createTag, createNS, isSafari, dataManager */ /* exported ImagePreloader */ var ImagePreloader = (function () { var proxyImage = (function () { var canvas = createTag('canvas'); canvas.width = 1; canvas.height = 1; var ctx = canvas.getContext('2d'); ctx.fillStyle = 'rgba(0,0,0,0)'; ctx.fillRect(0, 0, 1, 1); return canvas; }()); function imageLoaded() { this.loadedAssets += 1; if (this.loadedAssets === this.totalImages && this.loadedFootagesCount === this.totalFootages) { if (this.imagesLoadedCb) { this.imagesLoadedCb(null); } } } function footageLoaded() { this.loadedFootagesCount += 1; if (this.loadedAssets === this.totalImages && this.loadedFootagesCount === this.totalFootages) { if (this.imagesLoadedCb) { this.imagesLoadedCb(null); } } } function getAssetsPath(assetData, assetsPath, originalPath) { var path = ''; if (assetData.e) { path = assetData.p; } else if (assetsPath) { var imagePath = assetData.p; if (imagePath.indexOf('images/') !== -1) { imagePath = imagePath.split('/')[1]; } path = assetsPath + imagePath; } else { path = originalPath; path += assetData.u ? assetData.u : ''; path += assetData.p; } return path; } function testImageLoaded(img) { var _count = 0; var intervalId = setInterval(function () { var box = img.getBBox(); if (box.width || _count > 500) { this._imageLoaded(); clearInterval(intervalId); } _count += 1; }.bind(this), 50); } function createImageData(assetData) { var path = getAssetsPath(assetData, this.assetsPath, this.path); var img = createNS('image'); if (isSafari) { this.testImageLoaded(img); } else { img.addEventListener('load', this._imageLoaded, false); } img.addEventListener('error', function () { ob.img = proxyImage; this._imageLoaded(); }.bind(this), false); img.setAttributeNS('http://www.w3.org/1999/xlink', 'href', path); if (this._elementHelper.append) { this._elementHelper.append(img); } else { this._elementHelper.appendChild(img); } var ob = { img: img, assetData: assetData, }; return ob; } function createImgData(assetData) { var path = getAssetsPath(assetData, this.assetsPath, this.path); var img = createTag('img'); img.crossOrigin = 'anonymous'; img.addEventListener('load', this._imageLoaded, false); img.addEventListener('error', function () { ob.img = proxyImage; this._imageLoaded(); }.bind(this), false); img.src = path; var ob = { img: img, assetData: assetData, }; return ob; } function createFootageData(data) { var ob = { assetData: data, }; var path = getAssetsPath(data, this.assetsPath, this.path); dataManager.loadData(path, function (footageData) { ob.img = footageData; this._footageLoaded(); }.bind(this), function () { ob.img = {}; this._footageLoaded(); }.bind(this)); return ob; } function loadAssets(assets, cb) { this.imagesLoadedCb = cb; var i; var len = assets.length; for (i = 0; i < len; i += 1) { if (!assets[i].layers) { if (!assets[i].t || assets[i].t === 'seq') { this.totalImages += 1; this.images.push(this._createImageData(assets[i])); } else if (assets[i].t === 3) { this.totalFootages += 1; this.images.push(this.createFootageData(assets[i])); } } } } function setPath(path) { this.path = path || ''; } function setAssetsPath(path) { this.assetsPath = path || ''; } function getAsset(assetData) { var i = 0; var len = this.images.length; while (i < len) { if (this.images[i].assetData === assetData) { return this.images[i].img; } i += 1; } return null; } function destroy() { this.imagesLoadedCb = null; this.images.length = 0; } function loadedImages() { return this.totalImages === this.loadedAssets; } function loadedFootages() { return this.totalFootages === this.loadedFootagesCount; } function setCacheType(type, elementHelper) { if (type === 'svg') { this._elementHelper = elementHelper; this._createImageData = this.createImageData.bind(this); } else { this._createImageData = this.createImgData.bind(this); } } function ImagePreloaderFactory() { this._imageLoaded = imageLoaded.bind(this); this._footageLoaded = footageLoaded.bind(this); this.testImageLoaded = testImageLoaded.bind(this); this.createFootageData = createFootageData.bind(this); this.assetsPath = ''; this.path = ''; this.totalImages = 0; this.totalFootages = 0; this.loadedAssets = 0; this.loadedFootagesCount = 0; this.imagesLoadedCb = null; this.images = []; } ImagePreloaderFactory.prototype = { loadAssets: loadAssets, setAssetsPath: setAssetsPath, setPath: setPath, loadedImages: loadedImages, loadedFootages: loadedFootages, destroy: destroy, getAsset: getAsset, createImgData: createImgData, createImageData: createImageData, imageLoaded: imageLoaded, footageLoaded: footageLoaded, setCacheType: setCacheType, }; return ImagePreloaderFactory; }()); /* exported featureSupport */ var featureSupport = (function () { var ob = { maskType: true, }; if (/MSIE 10/i.test(navigator.userAgent) || /MSIE 9/i.test(navigator.userAgent) || /rv:11.0/i.test(navigator.userAgent) || /Edge\/\d./i.test(navigator.userAgent)) { ob.maskType = false; } return ob; }()); /* global createNS */ /* exported filtersFactory */ var filtersFactory = (function () { var ob = {}; ob.createFilter = createFilter; ob.createAlphaToLuminanceFilter = createAlphaToLuminanceFilter; function createFilter(filId, skipCoordinates) { var fil = createNS('filter'); fil.setAttribute('id', filId); if (skipCoordinates !== true) { fil.setAttribute('filterUnits', 'objectBoundingBox'); fil.setAttribute('x', '0%'); fil.setAttribute('y', '0%'); fil.setAttribute('width', '100%'); fil.setAttribute('height', '100%'); } return fil; } function createAlphaToLuminanceFilter() { var feColorMatrix = createNS('feColorMatrix'); feColorMatrix.setAttribute('type', 'matrix'); feColorMatrix.setAttribute('color-interpolation-filters', 'sRGB'); feColorMatrix.setAttribute('values', '0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 1'); return feColorMatrix; } return ob; }()); /* global createSizedArray, PropertyFactory, TextAnimatorDataProperty, bez, addHueToRGB, addSaturationToRGB, addBrightnessToRGB, LetterProps, Matrix, extendPrototype, DynamicPropertyContainer */ function TextAnimatorProperty(textData, renderType, elem) { this._isFirstFrame = true; this._hasMaskedPath = false; this._frameId = -1; this._textData = textData; this._renderType = renderType; this._elem = elem; this._animatorsData = createSizedArray(this._textData.a.length); this._pathData = {}; this._moreOptions = { alignment: {}, }; this.renderedLetters = []; this.lettersChangedFlag = false; this.initDynamicPropertyContainer(elem); } TextAnimatorProperty.prototype.searchProperties = function () { var i; var len = this._textData.a.length; var animatorProps; var getProp = PropertyFactory.getProp; for (i = 0; i < len; i += 1) { animatorProps = this._textData.a[i]; this._animatorsData[i] = new TextAnimatorDataProperty(this._elem, animatorProps, this); } if (this._textData.p && 'm' in this._textData.p) { this._pathData = { a: getProp(this._elem, this._textData.p.a, 0, 0, this), f: getProp(this._elem, this._textData.p.f, 0, 0, this), l: getProp(this._elem, this._textData.p.l, 0, 0, this), r: getProp(this._elem, this._textData.p.r, 0, 0, this), p: getProp(this._elem, this._textData.p.p, 0, 0, this), m: this._elem.maskManager.getMaskProperty(this._textData.p.m), }; this._hasMaskedPath = true; } else { this._hasMaskedPath = false; } this._moreOptions.alignment = getProp(this._elem, this._textData.m.a, 1, 0, this); }; TextAnimatorProperty.prototype.getMeasures = function (documentData, lettersChangedFlag) { this.lettersChangedFlag = lettersChangedFlag; if (!this._mdf && !this._isFirstFrame && !lettersChangedFlag && (!this._hasMaskedPath || !this._pathData.m._mdf)) { return; } this._isFirstFrame = false; var alignment = this._moreOptions.alignment.v; var animators = this._animatorsData; var textData = this._textData; var matrixHelper = this.mHelper; var renderType = this._renderType; var renderedLettersCount = this.renderedLetters.length; var xPos; var yPos; var i; var len; var letters = documentData.l; var pathInfo; var currentLength; var currentPoint; var segmentLength; var flag; var pointInd; var segmentInd; var prevPoint; var points; var segments; var partialLength; var totalLength; var perc; var tanAngle; var mask; if (this._hasMaskedPath) { mask = this._pathData.m; if (!this._pathData.n || this._pathData._mdf) { var paths = mask.v; if (this._pathData.r.v) { paths = paths.reverse(); } // TODO: release bezier data cached from previous pathInfo: this._pathData.pi pathInfo = { tLength: 0, segments: [], }; len = paths._length - 1; var bezierData; totalLength = 0; for (i = 0; i < len; i += 1) { bezierData = bez.buildBezierData(paths.v[i], paths.v[i + 1], [paths.o[i][0] - paths.v[i][0], paths.o[i][1] - paths.v[i][1]], [paths.i[i + 1][0] - paths.v[i + 1][0], paths.i[i + 1][1] - paths.v[i + 1][1]]); pathInfo.tLength += bezierData.segmentLength; pathInfo.segments.push(bezierData); totalLength += bezierData.segmentLength; } i = len; if (mask.v.c) { bezierData = bez.buildBezierData(paths.v[i], paths.v[0], [paths.o[i][0] - paths.v[i][0], paths.o[i][1] - paths.v[i][1]], [paths.i[0][0] - paths.v[0][0], paths.i[0][1] - paths.v[0][1]]); pathInfo.tLength += bezierData.segmentLength; pathInfo.segments.push(bezierData); totalLength += bezierData.segmentLength; } this._pathData.pi = pathInfo; } pathInfo = this._pathData.pi; currentLength = this._pathData.f.v; segmentInd = 0; pointInd = 1; segmentLength = 0; flag = true; segments = pathInfo.segments; if (currentLength < 0 && mask.v.c) { if (pathInfo.tLength < Math.abs(currentLength)) { currentLength = -Math.abs(currentLength) % pathInfo.tLength; } segmentInd = segments.length - 1; points = segments[segmentInd].points; pointInd = points.length - 1; while (currentLength < 0) { currentLength += points[pointInd].partialLength; pointInd -= 1; if (pointInd < 0) { segmentInd -= 1; points = segments[segmentInd].points; pointInd = points.length - 1; } } } points = segments[segmentInd].points; prevPoint = points[pointInd - 1]; currentPoint = points[pointInd]; partialLength = currentPoint.partialLength; } len = letters.length; xPos = 0; yPos = 0; var yOff = documentData.finalSize * 1.2 * 0.714; var firstLine = true; var animatorProps; var animatorSelector; var j; var jLen; var letterValue; jLen = animators.length; var mult; var ind = -1; var offf; var xPathPos; var yPathPos; var initPathPos = currentLength; var initSegmentInd = segmentInd; var initPointInd = pointInd; var currentLine = -1; var elemOpacity; var sc; var sw; var fc; var k; var letterSw; var letterSc; var letterFc; var letterM = ''; var letterP = this.defaultPropsArray; var letterO; // if (documentData.j === 2 || documentData.j === 1) { var animatorJustifyOffset = 0; var animatorFirstCharOffset = 0; var justifyOffsetMult = documentData.j === 2 ? -0.5 : -1; var lastIndex = 0; var isNewLine = true; for (i = 0; i < len; i += 1) { if (letters[i].n) { if (animatorJustifyOffset) { animatorJustifyOffset += animatorFirstCharOffset; } while (lastIndex < i) { letters[lastIndex].animatorJustifyOffset = animatorJustifyOffset; lastIndex += 1; } animatorJustifyOffset = 0; isNewLine = true; } else { for (j = 0; j < jLen; j += 1) { animatorProps = animators[j].a; if (animatorProps.t.propType) { if (isNewLine && documentData.j === 2) { animatorFirstCharOffset += animatorProps.t.v * justifyOffsetMult; } animatorSelector = animators[j].s; mult = animatorSelector.getMult(letters[i].anIndexes[j], textData.a[j].s.totalChars); if (mult.length) { animatorJustifyOffset += animatorProps.t.v * mult[0] * justifyOffsetMult; } else { animatorJustifyOffset += animatorProps.t.v * mult * justifyOffsetMult; } } } isNewLine = false; } } if (animatorJustifyOffset) { animatorJustifyOffset += animatorFirstCharOffset; } while (lastIndex < i) { letters[lastIndex].animatorJustifyOffset = animatorJustifyOffset; lastIndex += 1; } } // for (i = 0; i < len; i += 1) { matrixHelper.reset(); elemOpacity = 1; if (letters[i].n) { xPos = 0; yPos += documentData.yOffset; yPos += firstLine ? 1 : 0; currentLength = initPathPos; firstLine = false; if (this._hasMaskedPath) { segmentInd = initSegmentInd; pointInd = initPointInd; points = segments[segmentInd].points; prevPoint = points[pointInd - 1]; currentPoint = points[pointInd]; partialLength = currentPoint.partialLength; segmentLength = 0; } letterM = ''; letterFc = ''; letterSw = ''; letterO = ''; letterP = this.defaultPropsArray; } else { if (this._hasMaskedPath) { if (currentLine !== letters[i].line) { switch (documentData.j) { case 1: currentLength += totalLength - documentData.lineWidths[letters[i].line]; break; case 2: currentLength += (totalLength - documentData.lineWidths[letters[i].line]) / 2; break; default: break; } currentLine = letters[i].line; } if (ind !== letters[i].ind) { if (letters[ind]) { currentLength += letters[ind].extra; } currentLength += letters[i].an / 2; ind = letters[i].ind; } currentLength += (alignment[0] * letters[i].an) * 0.005; var animatorOffset = 0; for (j = 0; j < jLen; j += 1) { animatorProps = animators[j].a; if (animatorProps.p.propType) { animatorSelector = animators[j].s; mult = animatorSelector.getMult(letters[i].anIndexes[j], textData.a[j].s.totalChars); if (mult.length) { animatorOffset += animatorProps.p.v[0] * mult[0]; } else { animatorOffset += animatorProps.p.v[0] * mult; } } if (animatorProps.a.propType) { animatorSelector = animators[j].s; mult = animatorSelector.getMult(letters[i].anIndexes[j], textData.a[j].s.totalChars); if (mult.length) { animatorOffset += animatorProps.a.v[0] * mult[0]; } else { animatorOffset += animatorProps.a.v[0] * mult; } } } flag = true; // Force alignment only works with a single line for now if (this._pathData.a.v) { currentLength = letters[0].an * 0.5 + ((totalLength - this._pathData.f.v - letters[0].an * 0.5 - letters[letters.length - 1].an * 0.5) * ind) / (len - 1); currentLength += this._pathData.f.v; } while (flag) { if (segmentLength + partialLength >= currentLength + animatorOffset || !points) { perc = (currentLength + animatorOffset - segmentLength) / currentPoint.partialLength; xPathPos = prevPoint.point[0] + (currentPoint.point[0] - prevPoint.point[0]) * perc; yPathPos = prevPoint.point[1] + (currentPoint.point[1] - prevPoint.point[1]) * perc; matrixHelper.translate((-alignment[0] * letters[i].an) * 0.005, -(alignment[1] * yOff) * 0.01); flag = false; } else if (points) { segmentLength += currentPoint.partialLength; pointInd += 1; if (pointInd >= points.length) { pointInd = 0; segmentInd += 1; if (!segments[segmentInd]) { if (mask.v.c) { pointInd = 0; segmentInd = 0; points = segments[segmentInd].points; } else { segmentLength -= currentPoint.partialLength; points = null; } } else { points = segments[segmentInd].points; } } if (points) { prevPoint = currentPoint; currentPoint = points[pointInd]; partialLength = currentPoint.partialLength; } } } offf = letters[i].an / 2 - letters[i].add; matrixHelper.translate(-offf, 0, 0); } else { offf = letters[i].an / 2 - letters[i].add; matrixHelper.translate(-offf, 0, 0); // Grouping alignment matrixHelper.translate((-alignment[0] * letters[i].an) * 0.005, (-alignment[1] * yOff) * 0.01, 0); } for (j = 0; j < jLen; j += 1) { animatorProps = animators[j].a; if (animatorProps.t.propType) { animatorSelector = animators[j].s; mult = animatorSelector.getMult(letters[i].anIndexes[j], textData.a[j].s.totalChars); // This condition is to prevent applying tracking to first character in each line. Might be better to use a boolean "isNewLine" if (xPos !== 0 || documentData.j !== 0) { if (this._hasMaskedPath) { if (mult.length) { currentLength += animatorProps.t.v * mult[0]; } else { currentLength += animatorProps.t.v * mult; } } else if (mult.length) { xPos += animatorProps.t.v * mult[0]; } else { xPos += animatorProps.t.v * mult; } } } } if (documentData.strokeWidthAnim) { sw = documentData.sw || 0; } if (documentData.strokeColorAnim) { if (documentData.sc) { sc = [documentData.sc[0], documentData.sc[1], documentData.sc[2]]; } else { sc = [0, 0, 0]; } } if (documentData.fillColorAnim && documentData.fc) { fc = [documentData.fc[0], documentData.fc[1], documentData.fc[2]]; } for (j = 0; j < jLen; j += 1) { animatorProps = animators[j].a; if (animatorProps.a.propType) { animatorSelector = animators[j].s; mult = animatorSelector.getMult(letters[i].anIndexes[j], textData.a[j].s.totalChars); if (mult.length) { matrixHelper.translate(-animatorProps.a.v[0] * mult[0], -animatorProps.a.v[1] * mult[1], animatorProps.a.v[2] * mult[2]); } else { matrixHelper.translate(-animatorProps.a.v[0] * mult, -animatorProps.a.v[1] * mult, animatorProps.a.v[2] * mult); } } } for (j = 0; j < jLen; j += 1) { animatorProps = animators[j].a; if (animatorProps.s.propType) { animatorSelector = animators[j].s; mult = animatorSelector.getMult(letters[i].anIndexes[j], textData.a[j].s.totalChars); if (mult.length) { matrixHelper.scale(1 + ((animatorProps.s.v[0] - 1) * mult[0]), 1 + ((animatorProps.s.v[1] - 1) * mult[1]), 1); } else { matrixHelper.scale(1 + ((animatorProps.s.v[0] - 1) * mult), 1 + ((animatorProps.s.v[1] - 1) * mult), 1); } } } for (j = 0; j < jLen; j += 1) { animatorProps = animators[j].a; animatorSelector = animators[j].s; mult = animatorSelector.getMult(letters[i].anIndexes[j], textData.a[j].s.totalChars); if (animatorProps.sk.propType) { if (mult.length) { matrixHelper.skewFromAxis(-animatorProps.sk.v * mult[0], animatorProps.sa.v * mult[1]); } else { matrixHelper.skewFromAxis(-animatorProps.sk.v * mult, animatorProps.sa.v * mult); } } if (animatorProps.r.propType) { if (mult.length) { matrixHelper.rotateZ(-animatorProps.r.v * mult[2]); } else { matrixHelper.rotateZ(-animatorProps.r.v * mult); } } if (animatorProps.ry.propType) { if (mult.length) { matrixHelper.rotateY(animatorProps.ry.v * mult[1]); } else { matrixHelper.rotateY(animatorProps.ry.v * mult); } } if (animatorProps.rx.propType) { if (mult.length) { matrixHelper.rotateX(animatorProps.rx.v * mult[0]); } else { matrixHelper.rotateX(animatorProps.rx.v * mult); } } if (animatorProps.o.propType) { if (mult.length) { elemOpacity += ((animatorProps.o.v) * mult[0] - elemOpacity) * mult[0]; } else { elemOpacity += ((animatorProps.o.v) * mult - elemOpacity) * mult; } } if (documentData.strokeWidthAnim && animatorProps.sw.propType) { if (mult.length) { sw += animatorProps.sw.v * mult[0]; } else { sw += animatorProps.sw.v * mult; } } if (documentData.strokeColorAnim && animatorProps.sc.propType) { for (k = 0; k < 3; k += 1) { if (mult.length) { sc[k] += (animatorProps.sc.v[k] - sc[k]) * mult[0]; } else { sc[k] += (animatorProps.sc.v[k] - sc[k]) * mult; } } } if (documentData.fillColorAnim && documentData.fc) { if (animatorProps.fc.propType) { for (k = 0; k < 3; k += 1) { if (mult.length) { fc[k] += (animatorProps.fc.v[k] - fc[k]) * mult[0]; } else { fc[k] += (animatorProps.fc.v[k] - fc[k]) * mult; } } } if (animatorProps.fh.propType) { if (mult.length) { fc = addHueToRGB(fc, animatorProps.fh.v * mult[0]); } else { fc = addHueToRGB(fc, animatorProps.fh.v * mult); } } if (animatorProps.fs.propType) { if (mult.length) { fc = addSaturationToRGB(fc, animatorProps.fs.v * mult[0]); } else { fc = addSaturationToRGB(fc, animatorProps.fs.v * mult); } } if (animatorProps.fb.propType) { if (mult.length) { fc = addBrightnessToRGB(fc, animatorProps.fb.v * mult[0]); } else { fc = addBrightnessToRGB(fc, animatorProps.fb.v * mult); } } } } for (j = 0; j < jLen; j += 1) { animatorProps = animators[j].a; if (animatorProps.p.propType) { animatorSelector = animators[j].s; mult = animatorSelector.getMult(letters[i].anIndexes[j], textData.a[j].s.totalChars); if (this._hasMaskedPath) { if (mult.length) { matrixHelper.translate(0, animatorProps.p.v[1] * mult[0], -animatorProps.p.v[2] * mult[1]); } else { matrixHelper.translate(0, animatorProps.p.v[1] * mult, -animatorProps.p.v[2] * mult); } } else if (mult.length) { matrixHelper.translate(animatorProps.p.v[0] * mult[0], animatorProps.p.v[1] * mult[1], -animatorProps.p.v[2] * mult[2]); } else { matrixHelper.translate(animatorProps.p.v[0] * mult, animatorProps.p.v[1] * mult, -animatorProps.p.v[2] * mult); } } } if (documentData.strokeWidthAnim) { letterSw = sw < 0 ? 0 : sw; } if (documentData.strokeColorAnim) { letterSc = 'rgb(' + Math.round(sc[0] * 255) + ',' + Math.round(sc[1] * 255) + ',' + Math.round(sc[2] * 255) + ')'; } if (documentData.fillColorAnim && documentData.fc) { letterFc = 'rgb(' + Math.round(fc[0] * 255) + ',' + Math.round(fc[1] * 255) + ',' + Math.round(fc[2] * 255) + ')'; } if (this._hasMaskedPath) { matrixHelper.translate(0, -documentData.ls); matrixHelper.translate(0, (alignment[1] * yOff) * 0.01 + yPos, 0); if (this._pathData.p.v) { tanAngle = (currentPoint.point[1] - prevPoint.point[1]) / (currentPoint.point[0] - prevPoint.point[0]); var rot = (Math.atan(tanAngle) * 180) / Math.PI; if (currentPoint.point[0] < prevPoint.point[0]) { rot += 180; } matrixHelper.rotate((-rot * Math.PI) / 180); } matrixHelper.translate(xPathPos, yPathPos, 0); currentLength -= (alignment[0] * letters[i].an) * 0.005; if (letters[i + 1] && ind !== letters[i + 1].ind) { currentLength += letters[i].an / 2; currentLength += (documentData.tr * 0.001) * documentData.finalSize; } } else { matrixHelper.translate(xPos, yPos, 0); if (documentData.ps) { // matrixHelper.translate(documentData.ps[0],documentData.ps[1],0); matrixHelper.translate(documentData.ps[0], documentData.ps[1] + documentData.ascent, 0); } switch (documentData.j) { case 1: matrixHelper.translate(letters[i].animatorJustifyOffset + documentData.justifyOffset + (documentData.boxWidth - documentData.lineWidths[letters[i].line]), 0, 0); break; case 2: matrixHelper.translate(letters[i].animatorJustifyOffset + documentData.justifyOffset + (documentData.boxWidth - documentData.lineWidths[letters[i].line]) / 2, 0, 0); break; default: break; } matrixHelper.translate(0, -documentData.ls); matrixHelper.translate(offf, 0, 0); matrixHelper.translate((alignment[0] * letters[i].an) * 0.005, (alignment[1] * yOff) * 0.01, 0); xPos += letters[i].l + (documentData.tr * 0.001) * documentData.finalSize; } if (renderType === 'html') { letterM = matrixHelper.toCSS(); } else if (renderType === 'svg') { letterM = matrixHelper.to2dCSS(); } else { letterP = [matrixHelper.props[0], matrixHelper.props[1], matrixHelper.props[2], matrixHelper.props[3], matrixHelper.props[4], matrixHelper.props[5], matrixHelper.props[6], matrixHelper.props[7], matrixHelper.props[8], matrixHelper.props[9], matrixHelper.props[10], matrixHelper.props[11], matrixHelper.props[12], matrixHelper.props[13], matrixHelper.props[14], matrixHelper.props[15]]; } letterO = elemOpacity; } if (renderedLettersCount <= i) { letterValue = new LetterProps(letterO, letterSw, letterSc, letterFc, letterM, letterP); this.renderedLetters.push(letterValue); renderedLettersCount += 1; this.lettersChangedFlag = true; } else { letterValue = this.renderedLetters[i]; this.lettersChangedFlag = letterValue.update(letterO, letterSw, letterSc, letterFc, letterM, letterP) || this.lettersChangedFlag; } } }; TextAnimatorProperty.prototype.getValue = function () { if (this._elem.globalData.frameId === this._frameId) { return; } this._frameId = this._elem.globalData.frameId; this.iterateDynamicProperties(); }; TextAnimatorProperty.prototype.mHelper = new Matrix(); TextAnimatorProperty.prototype.defaultPropsArray = []; extendPrototype([DynamicPropertyContainer], TextAnimatorProperty); /* global PropertyFactory, degToRads, TextSelectorProp */ /* exported TextAnimatorDataProperty */ function TextAnimatorDataProperty(elem, animatorProps, container) { var defaultData = { propType: false }; var getProp = PropertyFactory.getProp; var textAnimatorAnimatables = animatorProps.a; this.a = { r: textAnimatorAnimatables.r ? getProp(elem, textAnimatorAnimatables.r, 0, degToRads, container) : defaultData, rx: textAnimatorAnimatables.rx ? getProp(elem, textAnimatorAnimatables.rx, 0, degToRads, container) : defaultData, ry: textAnimatorAnimatables.ry ? getProp(elem, textAnimatorAnimatables.ry, 0, degToRads, container) : defaultData, sk: textAnimatorAnimatables.sk ? getProp(elem, textAnimatorAnimatables.sk, 0, degToRads, container) : defaultData, sa: textAnimatorAnimatables.sa ? getProp(elem, textAnimatorAnimatables.sa, 0, degToRads, container) : defaultData, s: textAnimatorAnimatables.s ? getProp(elem, textAnimatorAnimatables.s, 1, 0.01, container) : defaultData, a: textAnimatorAnimatables.a ? getProp(elem, textAnimatorAnimatables.a, 1, 0, container) : defaultData, o: textAnimatorAnimatables.o ? getProp(elem, textAnimatorAnimatables.o, 0, 0.01, container) : defaultData, p: textAnimatorAnimatables.p ? getProp(elem, textAnimatorAnimatables.p, 1, 0, container) : defaultData, sw: textAnimatorAnimatables.sw ? getProp(elem, textAnimatorAnimatables.sw, 0, 0, container) : defaultData, sc: textAnimatorAnimatables.sc ? getProp(elem, textAnimatorAnimatables.sc, 1, 0, container) : defaultData, fc: textAnimatorAnimatables.fc ? getProp(elem, textAnimatorAnimatables.fc, 1, 0, container) : defaultData, fh: textAnimatorAnimatables.fh ? getProp(elem, textAnimatorAnimatables.fh, 0, 0, container) : defaultData, fs: textAnimatorAnimatables.fs ? getProp(elem, textAnimatorAnimatables.fs, 0, 0.01, container) : defaultData, fb: textAnimatorAnimatables.fb ? getProp(elem, textAnimatorAnimatables.fb, 0, 0.01, container) : defaultData, t: textAnimatorAnimatables.t ? getProp(elem, textAnimatorAnimatables.t, 0, 0, container) : defaultData, }; this.s = TextSelectorProp.getTextSelectorProp(elem, animatorProps.s, container); this.s.t = animatorProps.s.t; } function LetterProps(o, sw, sc, fc, m, p) { this.o = o; this.sw = sw; this.sc = sc; this.fc = fc; this.m = m; this.p = p; this._mdf = { o: true, sw: !!sw, sc: !!sc, fc: !!fc, m: true, p: true, }; } LetterProps.prototype.update = function (o, sw, sc, fc, m, p) { this._mdf.o = false; this._mdf.sw = false; this._mdf.sc = false; this._mdf.fc = false; this._mdf.m = false; this._mdf.p = false; var updated = false; if (this.o !== o) { this.o = o; this._mdf.o = true; updated = true; } if (this.sw !== sw) { this.sw = sw; this._mdf.sw = true; updated = true; } if (this.sc !== sc) { this.sc = sc; this._mdf.sc = true; updated = true; } if (this.fc !== fc) { this.fc = fc; this._mdf.fc = true; updated = true; } if (this.m !== m) { this.m = m; this._mdf.m = true; updated = true; } if (p.length && (this.p[0] !== p[0] || this.p[1] !== p[1] || this.p[4] !== p[4] || this.p[5] !== p[5] || this.p[12] !== p[12] || this.p[13] !== p[13])) { this.p = p; this._mdf.p = true; updated = true; } return updated; }; /* global FontManager, initialDefaultFrame, getFontProperties */ /* exported TextProperty */ function TextProperty(elem, data) { this._frameId = initialDefaultFrame; this.pv = ''; this.v = ''; this.kf = false; this._isFirstFrame = true; this._mdf = false; this.data = data; this.elem = elem; this.comp = this.elem.comp; this.keysIndex = 0; this.canResize = false; this.minimumFontSize = 1; this.effectsSequence = []; this.currentData = { ascent: 0, boxWidth: this.defaultBoxWidth, f: '', fStyle: '', fWeight: '', fc: '', j: '', justifyOffset: '', l: [], lh: 0, lineWidths: [], ls: '', of: '', s: '', sc: '', sw: 0, t: 0, tr: 0, sz: 0, ps: null, fillColorAnim: false, strokeColorAnim: false, strokeWidthAnim: false, yOffset: 0, finalSize: 0, finalText: [], finalLineHeight: 0, __complete: false, }; this.copyData(this.currentData, this.data.d.k[0].s); if (!this.searchProperty()) { this.completeTextData(this.currentData); } } TextProperty.prototype.defaultBoxWidth = [0, 0]; TextProperty.prototype.copyData = function (obj, data) { for (var s in data) { if (Object.prototype.hasOwnProperty.call(data, s)) { obj[s] = data[s]; } } return obj; }; TextProperty.prototype.setCurrentData = function (data) { if (!data.__complete) { this.completeTextData(data); } this.currentData = data; this.currentData.boxWidth = this.currentData.boxWidth || this.defaultBoxWidth; this._mdf = true; }; TextProperty.prototype.searchProperty = function () { return this.searchKeyframes(); }; TextProperty.prototype.searchKeyframes = function () { this.kf = this.data.d.k.length > 1; if (this.kf) { this.addEffect(this.getKeyframeValue.bind(this)); } return this.kf; }; TextProperty.prototype.addEffect = function (effectFunction) { this.effectsSequence.push(effectFunction); this.elem.addDynamicProperty(this); }; TextProperty.prototype.getValue = function (_finalValue) { if ((this.elem.globalData.frameId === this.frameId || !this.effectsSequence.length) && !_finalValue) { return; } this.currentData.t = this.data.d.k[this.keysIndex].s.t; var currentValue = this.currentData; var currentIndex = this.keysIndex; if (this.lock) { this.setCurrentData(this.currentData); return; } this.lock = true; this._mdf = false; var i; var len = this.effectsSequence.length; var finalValue = _finalValue || this.data.d.k[this.keysIndex].s; for (i = 0; i < len; i += 1) { // Checking if index changed to prevent creating a new object every time the expression updates. if (currentIndex !== this.keysIndex) { finalValue = this.effectsSequence[i](finalValue, finalValue.t); } else { finalValue = this.effectsSequence[i](this.currentData, finalValue.t); } } if (currentValue !== finalValue) { this.setCurrentData(finalValue); } this.v = this.currentData; this.pv = this.v; this.lock = false; this.frameId = this.elem.globalData.frameId; }; TextProperty.prototype.getKeyframeValue = function () { var textKeys = this.data.d.k; var frameNum = this.elem.comp.renderedFrame; var i = 0; var len = textKeys.length; while (i <= len - 1) { if (i === len - 1 || textKeys[i + 1].t > frameNum) { break; } i += 1; } if (this.keysIndex !== i) { this.keysIndex = i; } return this.data.d.k[this.keysIndex].s; }; TextProperty.prototype.buildFinalText = function (text) { var charactersArray = []; var i = 0; var len = text.length; var charCode; var secondCharCode; var shouldCombine = false; while (i < len) { charCode = text.charCodeAt(i); if (FontManager.isCombinedCharacter(charCode)) { charactersArray[charactersArray.length - 1] += text.charAt(i); } else if (charCode >= 0xD800 && charCode <= 0xDBFF) { secondCharCode = text.charCodeAt(i + 1); if (secondCharCode >= 0xDC00 && secondCharCode <= 0xDFFF) { if (shouldCombine || FontManager.isModifier(charCode, secondCharCode)) { charactersArray[charactersArray.length - 1] += text.substr(i, 2); shouldCombine = false; } else { charactersArray.push(text.substr(i, 2)); } i += 1; } else { charactersArray.push(text.charAt(i)); } } else if (charCode > 0xDBFF) { secondCharCode = text.charCodeAt(i + 1); if (FontManager.isZeroWidthJoiner(charCode, secondCharCode)) { shouldCombine = true; charactersArray[charactersArray.length - 1] += text.substr(i, 2); i += 1; } else { charactersArray.push(text.charAt(i)); } } else if (FontManager.isZeroWidthJoiner(charCode)) { charactersArray[charactersArray.length - 1] += text.charAt(i); shouldCombine = true; } else { charactersArray.push(text.charAt(i)); } i += 1; } return charactersArray; }; TextProperty.prototype.completeTextData = function (documentData) { documentData.__complete = true; var fontManager = this.elem.globalData.fontManager; var data = this.data; var letters = []; var i; var len; var newLineFlag; var index = 0; var val; var anchorGrouping = data.m.g; var currentSize = 0; var currentPos = 0; var currentLine = 0; var lineWidths = []; var lineWidth = 0; var maxLineWidth = 0; var j; var jLen; var fontData = fontManager.getFontByName(documentData.f); var charData; var cLength = 0; var fontProps = getFontProperties(fontData); documentData.fWeight = fontProps.weight; documentData.fStyle = fontProps.style; documentData.finalSize = documentData.s; documentData.finalText = this.buildFinalText(documentData.t); len = documentData.finalText.length; documentData.finalLineHeight = documentData.lh; var trackingOffset = (documentData.tr / 1000) * documentData.finalSize; var charCode; if (documentData.sz) { var flag = true; var boxWidth = documentData.sz[0]; var boxHeight = documentData.sz[1]; var currentHeight; var finalText; while (flag) { finalText = this.buildFinalText(documentData.t); currentHeight = 0; lineWidth = 0; len = finalText.length; trackingOffset = (documentData.tr / 1000) * documentData.finalSize; var lastSpaceIndex = -1; for (i = 0; i < len; i += 1) { charCode = finalText[i].charCodeAt(0); newLineFlag = false; if (finalText[i] === ' ') { lastSpaceIndex = i; } else if (charCode === 13 || charCode === 3) { lineWidth = 0; newLineFlag = true; currentHeight += documentData.finalLineHeight || documentData.finalSize * 1.2; } if (fontManager.chars) { charData = fontManager.getCharData(finalText[i], fontData.fStyle, fontData.fFamily); cLength = newLineFlag ? 0 : (charData.w * documentData.finalSize) / 100; } else { // tCanvasHelper.font = documentData.s + 'px '+ fontData.fFamily; cLength = fontManager.measureText(finalText[i], documentData.f, documentData.finalSize); } if (lineWidth + cLength > boxWidth && finalText[i] !== ' ') { if (lastSpaceIndex === -1) { len += 1; } else { i = lastSpaceIndex; } currentHeight += documentData.finalLineHeight || documentData.finalSize * 1.2; finalText.splice(i, lastSpaceIndex === i ? 1 : 0, '\r'); // finalText = finalText.substr(0,i) + "\r" + finalText.substr(i === lastSpaceIndex ? i + 1 : i); lastSpaceIndex = -1; lineWidth = 0; } else { lineWidth += cLength; lineWidth += trackingOffset; } } currentHeight += (fontData.ascent * documentData.finalSize) / 100; if (this.canResize && documentData.finalSize > this.minimumFontSize && boxHeight < currentHeight) { documentData.finalSize -= 1; documentData.finalLineHeight = (documentData.finalSize * documentData.lh) / documentData.s; } else { documentData.finalText = finalText; len = documentData.finalText.length; flag = false; } } } lineWidth = -trackingOffset; cLength = 0; var uncollapsedSpaces = 0; var currentChar; for (i = 0; i < len; i += 1) { newLineFlag = false; currentChar = documentData.finalText[i]; charCode = currentChar.charCodeAt(0); if (charCode === 13 || charCode === 3) { uncollapsedSpaces = 0; lineWidths.push(lineWidth); maxLineWidth = lineWidth > maxLineWidth ? lineWidth : maxLineWidth; lineWidth = -2 * trackingOffset; val = ''; newLineFlag = true; currentLine += 1; } else { val = currentChar; } if (fontManager.chars) { charData = fontManager.getCharData(currentChar, fontData.fStyle, fontManager.getFontByName(documentData.f).fFamily); cLength = newLineFlag ? 0 : (charData.w * documentData.finalSize) / 100; } else { // var charWidth = fontManager.measureText(val, documentData.f, documentData.finalSize); // tCanvasHelper.font = documentData.finalSize + 'px '+ fontManager.getFontByName(documentData.f).fFamily; cLength = fontManager.measureText(val, documentData.f, documentData.finalSize); } // if (currentChar === ' ') { uncollapsedSpaces += cLength + trackingOffset; } else { lineWidth += cLength + trackingOffset + uncollapsedSpaces; uncollapsedSpaces = 0; } letters.push({ l: cLength, an: cLength, add: currentSize, n: newLineFlag, anIndexes: [], val: val, line: currentLine, animatorJustifyOffset: 0, }); if (anchorGrouping == 2) { // eslint-disable-line eqeqeq currentSize += cLength; if (val === '' || val === ' ' || i === len - 1) { if (val === '' || val === ' ') { currentSize -= cLength; } while (currentPos <= i) { letters[currentPos].an = currentSize; letters[currentPos].ind = index; letters[currentPos].extra = cLength; currentPos += 1; } index += 1; currentSize = 0; } } else if (anchorGrouping == 3) { // eslint-disable-line eqeqeq currentSize += cLength; if (val === '' || i === len - 1) { if (val === '') { currentSize -= cLength; } while (currentPos <= i) { letters[currentPos].an = currentSize; letters[currentPos].ind = index; letters[currentPos].extra = cLength; currentPos += 1; } currentSize = 0; index += 1; } } else { letters[index].ind = index; letters[index].extra = 0; index += 1; } } documentData.l = letters; maxLineWidth = lineWidth > maxLineWidth ? lineWidth : maxLineWidth; lineWidths.push(lineWidth); if (documentData.sz) { documentData.boxWidth = documentData.sz[0]; documentData.justifyOffset = 0; } else { documentData.boxWidth = maxLineWidth; switch (documentData.j) { case 1: documentData.justifyOffset = -documentData.boxWidth; break; case 2: documentData.justifyOffset = -documentData.boxWidth / 2; break; default: documentData.justifyOffset = 0; } } documentData.lineWidths = lineWidths; var animators = data.a; var animatorData; var letterData; jLen = animators.length; var based; var ind; var indexes = []; for (j = 0; j < jLen; j += 1) { animatorData = animators[j]; if (animatorData.a.sc) { documentData.strokeColorAnim = true; } if (animatorData.a.sw) { documentData.strokeWidthAnim = true; } if (animatorData.a.fc || animatorData.a.fh || animatorData.a.fs || animatorData.a.fb) { documentData.fillColorAnim = true; } ind = 0; based = animatorData.s.b; for (i = 0; i < len; i += 1) { letterData = letters[i]; letterData.anIndexes[j] = ind; if ((based == 1 && letterData.val !== '') || (based == 2 && letterData.val !== '' && letterData.val !== ' ') || (based == 3 && (letterData.n || letterData.val == ' ' || i == len - 1)) || (based == 4 && (letterData.n || i == len - 1))) { // eslint-disable-line eqeqeq if (animatorData.s.rn === 1) { indexes.push(ind); } ind += 1; } } data.a[j].s.totalChars = ind; var currentInd = -1; var newInd; if (animatorData.s.rn === 1) { for (i = 0; i < len; i += 1) { letterData = letters[i]; if (currentInd != letterData.anIndexes[j]) { // eslint-disable-line eqeqeq currentInd = letterData.anIndexes[j]; newInd = indexes.splice(Math.floor(Math.random() * indexes.length), 1)[0]; } letterData.anIndexes[j] = newInd; } } } documentData.yOffset = documentData.finalLineHeight || documentData.finalSize * 1.2; documentData.ls = documentData.ls || 0; documentData.ascent = (fontData.ascent * documentData.finalSize) / 100; }; TextProperty.prototype.updateDocumentData = function (newData, index) { index = index === undefined ? this.keysIndex : index; var dData = this.copyData({}, this.data.d.k[index].s); dData = this.copyData(dData, newData); this.data.d.k[index].s = dData; this.recalculate(index); this.elem.addDynamicProperty(this); }; TextProperty.prototype.recalculate = function (index) { var dData = this.data.d.k[index].s; dData.__complete = false; this.keysIndex = 0; this._isFirstFrame = true; this.getValue(dData); }; TextProperty.prototype.canResizeFont = function (_canResize) { this.canResize = _canResize; this.recalculate(this.keysIndex); this.elem.addDynamicProperty(this); }; TextProperty.prototype.setMinimumFontSize = function (_fontValue) { this.minimumFontSize = Math.floor(_fontValue) || 1; this.recalculate(this.keysIndex); this.elem.addDynamicProperty(this); }; /* global extendPrototype, BezierFactory, PropertyFactory, DynamicPropertyContainer */ /* exported TextSelectorProp */ var TextSelectorProp = (function () { var max = Math.max; var min = Math.min; var floor = Math.floor; function TextSelectorPropFactory(elem, data) { this._currentTextLength = -1; this.k = false; this.data = data; this.elem = elem; this.comp = elem.comp; this.finalS = 0; this.finalE = 0; this.initDynamicPropertyContainer(elem); this.s = PropertyFactory.getProp(elem, data.s || { k: 0 }, 0, 0, this); if ('e' in data) { this.e = PropertyFactory.getProp(elem, data.e, 0, 0, this); } else { this.e = { v: 100 }; } this.o = PropertyFactory.getProp(elem, data.o || { k: 0 }, 0, 0, this); this.xe = PropertyFactory.getProp(elem, data.xe || { k: 0 }, 0, 0, this); this.ne = PropertyFactory.getProp(elem, data.ne || { k: 0 }, 0, 0, this); this.sm = PropertyFactory.getProp(elem, data.sm || { k: 100 }, 0, 0, this); this.a = PropertyFactory.getProp(elem, data.a, 0, 0.01, this); if (!this.dynamicProperties.length) { this.getValue(); } } TextSelectorPropFactory.prototype = { getMult: function (ind) { if (this._currentTextLength !== this.elem.textProperty.currentData.l.length) { this.getValue(); } // var easer = bez.getEasingCurve(this.ne.v/100,0,1-this.xe.v/100,1); var x1 = 0; var y1 = 0; var x2 = 1; var y2 = 1; if (this.ne.v > 0) { x1 = this.ne.v / 100.0; } else { y1 = -this.ne.v / 100.0; } if (this.xe.v > 0) { x2 = 1.0 - this.xe.v / 100.0; } else { y2 = 1.0 + this.xe.v / 100.0; } var easer = BezierFactory.getBezierEasing(x1, y1, x2, y2).get; var mult = 0; var s = this.finalS; var e = this.finalE; var type = this.data.sh; if (type === 2) { if (e === s) { mult = ind >= e ? 1 : 0; } else { mult = max(0, min(0.5 / (e - s) + (ind - s) / (e - s), 1)); } mult = easer(mult); } else if (type === 3) { if (e === s) { mult = ind >= e ? 0 : 1; } else { mult = 1 - max(0, min(0.5 / (e - s) + (ind - s) / (e - s), 1)); } mult = easer(mult); } else if (type === 4) { if (e === s) { mult = 0; } else { mult = max(0, min(0.5 / (e - s) + (ind - s) / (e - s), 1)); if (mult < 0.5) { mult *= 2; } else { mult = 1 - 2 * (mult - 0.5); } } mult = easer(mult); } else if (type === 5) { if (e === s) { mult = 0; } else { var tot = e - s; /* ind += 0.5; mult = -4/(tot*tot)*(ind*ind)+(4/tot)*ind; */ ind = min(max(0, ind + 0.5 - s), e - s); var x = -tot / 2 + ind; var a = tot / 2; mult = Math.sqrt(1 - (x * x) / (a * a)); } mult = easer(mult); } else if (type === 6) { if (e === s) { mult = 0; } else { ind = min(max(0, ind + 0.5 - s), e - s); mult = (1 + (Math.cos((Math.PI + Math.PI * 2 * (ind) / (e - s))))) / 2; // eslint-disable-line } mult = easer(mult); } else { if (ind >= floor(s)) { if (ind - s < 0) { mult = max(0, min(min(e, 1) - (s - ind), 1)); } else { mult = max(0, min(e - ind, 1)); } } mult = easer(mult); } // Smoothness implementation. // The smoothness represents a reduced range of the original [0; 1] range. // if smoothness is 25%, the new range will be [0.375; 0.625] // Steps are: // - find the lower value of the new range (threshold) // - if multiplier is smaller than that value, floor it to 0 // - if it is larger, // - subtract the threshold // - divide it by the smoothness (this will return the range to [0; 1]) // Note: If it doesn't work on some scenarios, consider applying it before the easer. if (this.sm.v !== 100) { var smoothness = this.sm.v * 0.01; if (smoothness === 0) { smoothness = 0.00000001; } var threshold = 0.5 - smoothness * 0.5; if (mult < threshold) { mult = 0; } else { mult = (mult - threshold) / smoothness; if (mult > 1) { mult = 1; } } } return mult * this.a.v; }, getValue: function (newCharsFlag) { this.iterateDynamicProperties(); this._mdf = newCharsFlag || this._mdf; this._currentTextLength = this.elem.textProperty.currentData.l.length || 0; if (newCharsFlag && this.data.r === 2) { this.e.v = this._currentTextLength; } var divisor = this.data.r === 2 ? 1 : 100 / this.data.totalChars; var o = this.o.v / divisor; var s = this.s.v / divisor + o; var e = (this.e.v / divisor) + o; if (s > e) { var _s = s; s = e; e = _s; } this.finalS = s; this.finalE = e; }, }; extendPrototype([DynamicPropertyContainer], TextSelectorPropFactory); function getTextSelectorProp(elem, data, arr) { return new TextSelectorPropFactory(elem, data, arr); } return { getTextSelectorProp: getTextSelectorProp, }; }()); /* global createSizedArray, pooling */ /* exported poolFactory */ var poolFactory = (function () { return function (initialLength, _create, _release) { var _length = 0; var _maxLength = initialLength; var pool = createSizedArray(_maxLength); var ob = { newElement: newElement, release: release, }; function newElement() { var element; if (_length) { _length -= 1; element = pool[_length]; } else { element = _create(); } return element; } function release(element) { if (_length === _maxLength) { pool = pooling.double(pool); _maxLength *= 2; } if (_release) { _release(element); } pool[_length] = element; _length += 1; } return ob; }; }()); /* global createSizedArray */ /* exported pooling */ var pooling = (function () { function double(arr) { return arr.concat(createSizedArray(arr.length)); } return { double: double, }; }()); /* global createTypedArray, poolFactory */ /* exported pointPool */ var pointPool = (function () { function create() { return createTypedArray('float32', 2); } return poolFactory(8, create); }()); /* global ShapePath, pointPool, poolFactory */ /* exported shapePool */ var shapePool = (function () { function create() { return new ShapePath(); } function release(shapePath) { var len = shapePath._length; var i; for (i = 0; i < len; i += 1) { pointPool.release(shapePath.v[i]); pointPool.release(shapePath.i[i]); pointPool.release(shapePath.o[i]); shapePath.v[i] = null; shapePath.i[i] = null; shapePath.o[i] = null; } shapePath._length = 0; shapePath.c = false; } function clone(shape) { var cloned = factory.newElement(); var i; var len = shape._length === undefined ? shape.v.length : shape._length; cloned.setLength(len); cloned.c = shape.c; for (i = 0; i < len; i += 1) { cloned.setTripleAt(shape.v[i][0], shape.v[i][1], shape.o[i][0], shape.o[i][1], shape.i[i][0], shape.i[i][1], i); } return cloned; } var factory = poolFactory(4, create, release); factory.clone = clone; return factory; }()); /* global createSizedArray, ShapeCollection, shapePool, pooling */ /* exported shapeCollectionPool */ var shapeCollectionPool = (function () { var ob = { newShapeCollection: newShapeCollection, release: release, }; var _length = 0; var _maxLength = 4; var pool = createSizedArray(_maxLength); function newShapeCollection() { var shapeCollection; if (_length) { _length -= 1; shapeCollection = pool[_length]; } else { shapeCollection = new ShapeCollection(); } return shapeCollection; } function release(shapeCollection) { var i; var len = shapeCollection._length; for (i = 0; i < len; i += 1) { shapePool.release(shapeCollection.shapes[i]); } shapeCollection._length = 0; if (_length === _maxLength) { pool = pooling.double(pool); _maxLength *= 2; } pool[_length] = shapeCollection; _length += 1; } return ob; }()); /* global poolFactory, bezierLengthPool */ /* exported segmentsLengthPool */ var segmentsLengthPool = (function () { function create() { return { lengths: [], totalLength: 0, }; } function release(element) { var i; var len = element.lengths.length; for (i = 0; i < len; i += 1) { bezierLengthPool.release(element.lengths[i]); } element.lengths.length = 0; } return poolFactory(8, create, release); }()); /* global createTypedArray, defaultCurveSegments, poolFactory */ /* exported bezierLengthPool */ var bezierLengthPool = (function () { function create() { return { addedLength: 0, percents: createTypedArray('float32', defaultCurveSegments), lengths: createTypedArray('float32', defaultCurveSegments), }; } return poolFactory(8, create); }()); /* exported markerParser */ var markerParser = ( function () { function parsePayloadLines(payload) { var lines = payload.split('\r\n'); var keys = {}; var line; var keysCount = 0; for (var i = 0; i < lines.length; i += 1) { line = lines[i].split(':'); if (line.length === 2) { keys[line[0]] = line[1].trim(); keysCount += 1; } } if (keysCount === 0) { throw new Error(); } return keys; } return function (_markers) { var markers = []; for (var i = 0; i < _markers.length; i += 1) { var _marker = _markers[i]; var markerData = { time: _marker.tm, duration: _marker.dr, }; try { markerData.payload = JSON.parse(_markers[i].cm); } catch (_) { try { markerData.payload = parsePayloadLines(_markers[i].cm); } catch (__) { markerData.payload = { name: _markers[i], }; } } markers.push(markerData); } return markers; }; }()); /* global AudioElement, FootageElement, FontManager */ function BaseRenderer() {} BaseRenderer.prototype.checkLayers = function (num) { var i; var len = this.layers.length; var data; this.completeLayers = true; for (i = len - 1; i >= 0; i -= 1) { if (!this.elements[i]) { data = this.layers[i]; if (data.ip - data.st <= (num - this.layers[i].st) && data.op - data.st > (num - this.layers[i].st)) { this.buildItem(i); } } this.completeLayers = this.elements[i] ? this.completeLayers : false; } this.checkPendingElements(); }; BaseRenderer.prototype.createItem = function (layer) { switch (layer.ty) { case 2: return this.createImage(layer); case 0: return this.createComp(layer); case 1: return this.createSolid(layer); case 3: return this.createNull(layer); case 4: return this.createShape(layer); case 5: return this.createText(layer); case 6: return this.createAudio(layer); case 13: return this.createCamera(layer); case 15: return this.createFootage(layer); default: return this.createNull(layer); } }; BaseRenderer.prototype.createCamera = function () { throw new Error('You\'re using a 3d camera. Try the html renderer.'); }; BaseRenderer.prototype.createAudio = function (data) { return new AudioElement(data, this.globalData, this); }; BaseRenderer.prototype.createFootage = function (data) { return new FootageElement(data, this.globalData, this); }; BaseRenderer.prototype.buildAllItems = function () { var i; var len = this.layers.length; for (i = 0; i < len; i += 1) { this.buildItem(i); } this.checkPendingElements(); }; BaseRenderer.prototype.includeLayers = function (newLayers) { this.completeLayers = false; var i; var len = newLayers.length; var j; var jLen = this.layers.length; for (i = 0; i < len; i += 1) { j = 0; while (j < jLen) { if (this.layers[j].id === newLayers[i].id) { this.layers[j] = newLayers[i]; break; } j += 1; } } }; BaseRenderer.prototype.setProjectInterface = function (pInterface) { this.globalData.projectInterface = pInterface; }; BaseRenderer.prototype.initItems = function () { if (!this.globalData.progressiveLoad) { this.buildAllItems(); } }; BaseRenderer.prototype.buildElementParenting = function (element, parentName, hierarchy) { var elements = this.elements; var layers = this.layers; var i = 0; var len = layers.length; while (i < len) { if (layers[i].ind == parentName) { // eslint-disable-line eqeqeq if (!elements[i] || elements[i] === true) { this.buildItem(i); this.addPendingElement(element); } else { hierarchy.push(elements[i]); elements[i].setAsParent(); if (layers[i].parent !== undefined) { this.buildElementParenting(element, layers[i].parent, hierarchy); } else { element.setHierarchy(hierarchy); } } } i += 1; } }; BaseRenderer.prototype.addPendingElement = function (element) { this.pendingElements.push(element); }; BaseRenderer.prototype.searchExtraCompositions = function (assets) { var i; var len = assets.length; for (i = 0; i < len; i += 1) { if (assets[i].xt) { var comp = this.createComp(assets[i]); comp.initExpressions(); this.globalData.projectInterface.registerComposition(comp); } } }; BaseRenderer.prototype.setupGlobalData = function (animData, fontsContainer) { this.globalData.fontManager = new FontManager(); this.globalData.fontManager.addChars(animData.chars); this.globalData.fontManager.addFonts(animData.fonts, fontsContainer); this.globalData.getAssetData = this.animationItem.getAssetData.bind(this.animationItem); this.globalData.getAssetsPath = this.animationItem.getAssetsPath.bind(this.animationItem); this.globalData.imageLoader = this.animationItem.imagePreloader; this.globalData.audioController = this.animationItem.audioController; this.globalData.frameId = 0; this.globalData.frameRate = animData.fr; this.globalData.nm = animData.nm; this.globalData.compSize = { w: animData.w, h: animData.h, }; }; /* global createElementID, extendPrototype, BaseRenderer, NullElement, SVGShapeElement, SVGTextLottieElement, IImageElement, SVGCompElement, ISolidElement, createNS, locationHref, createSizedArray, expressionsPlugin */ function SVGRenderer(animationItem, config) { this.animationItem = animationItem; this.layers = null; this.renderedFrame = -1; this.svgElement = createNS('svg'); var ariaLabel = ''; if (config && config.title) { var titleElement = createNS('title'); var titleId = createElementID(); titleElement.setAttribute('id', titleId); titleElement.textContent = config.title; this.svgElement.appendChild(titleElement); ariaLabel += titleId; } if (config && config.description) { var descElement = createNS('desc'); var descId = createElementID(); descElement.setAttribute('id', descId); descElement.textContent = config.description; this.svgElement.appendChild(descElement); ariaLabel += ' ' + descId; } if (ariaLabel) { this.svgElement.setAttribute('aria-labelledby', ariaLabel); } var defs = createNS('defs'); this.svgElement.appendChild(defs); var maskElement = createNS('g'); this.svgElement.appendChild(maskElement); this.layerElement = maskElement; this.renderConfig = { preserveAspectRatio: (config && config.preserveAspectRatio) || 'xMidYMid meet', imagePreserveAspectRatio: (config && config.imagePreserveAspectRatio) || 'xMidYMid slice', contentVisibility: (config && config.contentVisibility) || 'visible', progressiveLoad: (config && config.progressiveLoad) || false, hideOnTransparent: !((config && config.hideOnTransparent === false)), viewBoxOnly: (config && config.viewBoxOnly) || false, viewBoxSize: (config && config.viewBoxSize) || false, className: (config && config.className) || '', id: (config && config.id) || '', focusable: config && config.focusable, filterSize: { width: (config && config.filterSize && config.filterSize.width) || '100%', height: (config && config.filterSize && config.filterSize.height) || '100%', x: (config && config.filterSize && config.filterSize.x) || '0%', y: (config && config.filterSize && config.filterSize.y) || '0%', }, }; this.globalData = { _mdf: false, frameNum: -1, defs: defs, renderConfig: this.renderConfig, }; this.elements = []; this.pendingElements = []; this.destroyed = false; this.rendererType = 'svg'; } extendPrototype([BaseRenderer], SVGRenderer); SVGRenderer.prototype.createNull = function (data) { return new NullElement(data, this.globalData, this); }; SVGRenderer.prototype.createShape = function (data) { return new SVGShapeElement(data, this.globalData, this); }; SVGRenderer.prototype.createText = function (data) { return new SVGTextLottieElement(data, this.globalData, this); }; SVGRenderer.prototype.createImage = function (data) { return new IImageElement(data, this.globalData, this); }; SVGRenderer.prototype.createComp = function (data) { return new SVGCompElement(data, this.globalData, this); }; SVGRenderer.prototype.createSolid = function (data) { return new ISolidElement(data, this.globalData, this); }; SVGRenderer.prototype.configAnimation = function (animData) { this.svgElement.setAttribute('xmlns', 'http://www.w3.org/2000/svg'); if (this.renderConfig.viewBoxSize) { this.svgElement.setAttribute('viewBox', this.renderConfig.viewBoxSize); } else { this.svgElement.setAttribute('viewBox', '0 0 ' + animData.w + ' ' + animData.h); } if (!this.renderConfig.viewBoxOnly) { this.svgElement.setAttribute('width', animData.w); this.svgElement.setAttribute('height', animData.h); this.svgElement.style.width = '100%'; this.svgElement.style.height = '100%'; this.svgElement.style.transform = 'translate3d(0,0,0)'; this.svgElement.style.contentVisibility = this.renderConfig.contentVisibility; } if (this.renderConfig.className) { this.svgElement.setAttribute('class', this.renderConfig.className); } if (this.renderConfig.id) { this.svgElement.setAttribute('id', this.renderConfig.id); } if (this.renderConfig.focusable !== undefined) { this.svgElement.setAttribute('focusable', this.renderConfig.focusable); } this.svgElement.setAttribute('preserveAspectRatio', this.renderConfig.preserveAspectRatio); // this.layerElement.style.transform = 'translate3d(0,0,0)'; // this.layerElement.style.transformOrigin = this.layerElement.style.mozTransformOrigin = this.layerElement.style.webkitTransformOrigin = this.layerElement.style['-webkit-transform'] = "0px 0px 0px"; this.animationItem.wrapper.appendChild(this.svgElement); // Mask animation var defs = this.globalData.defs; this.setupGlobalData(animData, defs); this.globalData.progressiveLoad = this.renderConfig.progressiveLoad; this.data = animData; var maskElement = createNS('clipPath'); var rect = createNS('rect'); rect.setAttribute('width', animData.w); rect.setAttribute('height', animData.h); rect.setAttribute('x', 0); rect.setAttribute('y', 0); var maskId = createElementID(); maskElement.setAttribute('id', maskId); maskElement.appendChild(rect); this.layerElement.setAttribute('clip-path', 'url(' + locationHref + '#' + maskId + ')'); defs.appendChild(maskElement); this.layers = animData.layers; this.elements = createSizedArray(animData.layers.length); }; SVGRenderer.prototype.destroy = function () { if (this.animationItem.wrapper) { this.animationItem.wrapper.innerText = ''; } this.layerElement = null; this.globalData.defs = null; var i; var len = this.layers ? this.layers.length : 0; for (i = 0; i < len; i += 1) { if (this.elements[i]) { this.elements[i].destroy(); } } this.elements.length = 0; this.destroyed = true; this.animationItem = null; }; SVGRenderer.prototype.updateContainerSize = function () { }; SVGRenderer.prototype.buildItem = function (pos) { var elements = this.elements; if (elements[pos] || this.layers[pos].ty === 99) { return; } elements[pos] = true; var element = this.createItem(this.layers[pos]); elements[pos] = element; if (expressionsPlugin) { if (this.layers[pos].ty === 0) { this.globalData.projectInterface.registerComposition(element); } element.initExpressions(); } this.appendElementInPos(element, pos); if (this.layers[pos].tt) { if (!this.elements[pos - 1] || this.elements[pos - 1] === true) { this.buildItem(pos - 1); this.addPendingElement(element); } else { element.setMatte(elements[pos - 1].layerId); } } }; SVGRenderer.prototype.checkPendingElements = function () { while (this.pendingElements.length) { var element = this.pendingElements.pop(); element.checkParenting(); if (element.data.tt) { var i = 0; var len = this.elements.length; while (i < len) { if (this.elements[i] === element) { element.setMatte(this.elements[i - 1].layerId); break; } i += 1; } } } }; SVGRenderer.prototype.renderFrame = function (num) { if (this.renderedFrame === num || this.destroyed) { return; } if (num === null) { num = this.renderedFrame; } else { this.renderedFrame = num; } // console.log('-------'); // console.log('FRAME ',num); this.globalData.frameNum = num; this.globalData.frameId += 1; this.globalData.projectInterface.currentFrame = num; this.globalData._mdf = false; var i; var len = this.layers.length; if (!this.completeLayers) { this.checkLayers(num); } for (i = len - 1; i >= 0; i -= 1) { if (this.completeLayers || this.elements[i]) { this.elements[i].prepareFrame(num - this.layers[i].st); } } if (this.globalData._mdf) { for (i = 0; i < len; i += 1) { if (this.completeLayers || this.elements[i]) { this.elements[i].renderFrame(); } } } }; SVGRenderer.prototype.appendElementInPos = function (element, pos) { var newElement = element.getBaseElement(); if (!newElement) { return; } var i = 0; var nextElement; while (i < pos) { if (this.elements[i] && this.elements[i] !== true && this.elements[i].getBaseElement()) { nextElement = this.elements[i].getBaseElement(); } i += 1; } if (nextElement) { this.layerElement.insertBefore(newElement, nextElement); } else { this.layerElement.appendChild(newElement); } }; SVGRenderer.prototype.hide = function () { this.layerElement.style.display = 'none'; }; SVGRenderer.prototype.show = function () { this.layerElement.style.display = 'block'; }; /* global CVContextData, Matrix, extendPrototype, BaseRenderer, CVShapeElement, CVTextElement, CVImageElement, CVCompElement, CVSolidElement, SVGRenderer, createTag, createSizedArray */ function CanvasRenderer(animationItem, config) { this.animationItem = animationItem; this.renderConfig = { clearCanvas: (config && config.clearCanvas !== undefined) ? config.clearCanvas : true, context: (config && config.context) || null, progressiveLoad: (config && config.progressiveLoad) || false, preserveAspectRatio: (config && config.preserveAspectRatio) || 'xMidYMid meet', imagePreserveAspectRatio: (config && config.imagePreserveAspectRatio) || 'xMidYMid slice', contentVisibility: (config && config.contentVisibility) || 'visible', className: (config && config.className) || '', id: (config && config.id) || '', }; this.renderConfig.dpr = (config && config.dpr) || 1; if (this.animationItem.wrapper) { this.renderConfig.dpr = (config && config.dpr) || window.devicePixelRatio || 1; } this.renderedFrame = -1; this.globalData = { frameNum: -1, _mdf: false, renderConfig: this.renderConfig, currentGlobalAlpha: -1, }; this.contextData = new CVContextData(); this.elements = []; this.pendingElements = []; this.transformMat = new Matrix(); this.completeLayers = false; this.rendererType = 'canvas'; } extendPrototype([BaseRenderer], CanvasRenderer); CanvasRenderer.prototype.createShape = function (data) { return new CVShapeElement(data, this.globalData, this); }; CanvasRenderer.prototype.createText = function (data) { return new CVTextElement(data, this.globalData, this); }; CanvasRenderer.prototype.createImage = function (data) { return new CVImageElement(data, this.globalData, this); }; CanvasRenderer.prototype.createComp = function (data) { return new CVCompElement(data, this.globalData, this); }; CanvasRenderer.prototype.createSolid = function (data) { return new CVSolidElement(data, this.globalData, this); }; CanvasRenderer.prototype.createNull = SVGRenderer.prototype.createNull; CanvasRenderer.prototype.ctxTransform = function (props) { if (props[0] === 1 && props[1] === 0 && props[4] === 0 && props[5] === 1 && props[12] === 0 && props[13] === 0) { return; } if (!this.renderConfig.clearCanvas) { this.canvasContext.transform(props[0], props[1], props[4], props[5], props[12], props[13]); return; } this.transformMat.cloneFromProps(props); var cProps = this.contextData.cTr.props; this.transformMat.transform(cProps[0], cProps[1], cProps[2], cProps[3], cProps[4], cProps[5], cProps[6], cProps[7], cProps[8], cProps[9], cProps[10], cProps[11], cProps[12], cProps[13], cProps[14], cProps[15]); // this.contextData.cTr.transform(props[0],props[1],props[2],props[3],props[4],props[5],props[6],props[7],props[8],props[9],props[10],props[11],props[12],props[13],props[14],props[15]); this.contextData.cTr.cloneFromProps(this.transformMat.props); var trProps = this.contextData.cTr.props; this.canvasContext.setTransform(trProps[0], trProps[1], trProps[4], trProps[5], trProps[12], trProps[13]); }; CanvasRenderer.prototype.ctxOpacity = function (op) { /* if(op === 1){ return; } */ if (!this.renderConfig.clearCanvas) { this.canvasContext.globalAlpha *= op < 0 ? 0 : op; this.globalData.currentGlobalAlpha = this.contextData.cO; return; } this.contextData.cO *= op < 0 ? 0 : op; if (this.globalData.currentGlobalAlpha !== this.contextData.cO) { this.canvasContext.globalAlpha = this.contextData.cO; this.globalData.currentGlobalAlpha = this.contextData.cO; } }; CanvasRenderer.prototype.reset = function () { if (!this.renderConfig.clearCanvas) { this.canvasContext.restore(); return; } this.contextData.reset(); }; CanvasRenderer.prototype.save = function (actionFlag) { if (!this.renderConfig.clearCanvas) { this.canvasContext.save(); return; } if (actionFlag) { this.canvasContext.save(); } var props = this.contextData.cTr.props; if (this.contextData._length <= this.contextData.cArrPos) { this.contextData.duplicate(); } var i; var arr = this.contextData.saved[this.contextData.cArrPos]; for (i = 0; i < 16; i += 1) { arr[i] = props[i]; } this.contextData.savedOp[this.contextData.cArrPos] = this.contextData.cO; this.contextData.cArrPos += 1; }; CanvasRenderer.prototype.restore = function (actionFlag) { if (!this.renderConfig.clearCanvas) { this.canvasContext.restore(); return; } if (actionFlag) { this.canvasContext.restore(); this.globalData.blendMode = 'source-over'; } this.contextData.cArrPos -= 1; var popped = this.contextData.saved[this.contextData.cArrPos]; var i; var arr = this.contextData.cTr.props; for (i = 0; i < 16; i += 1) { arr[i] = popped[i]; } this.canvasContext.setTransform(popped[0], popped[1], popped[4], popped[5], popped[12], popped[13]); popped = this.contextData.savedOp[this.contextData.cArrPos]; this.contextData.cO = popped; if (this.globalData.currentGlobalAlpha !== popped) { this.canvasContext.globalAlpha = popped; this.globalData.currentGlobalAlpha = popped; } }; CanvasRenderer.prototype.configAnimation = function (animData) { if (this.animationItem.wrapper) { this.animationItem.container = createTag('canvas'); var containerStyle = this.animationItem.container.style; containerStyle.width = '100%'; containerStyle.height = '100%'; var origin = '0px 0px 0px'; containerStyle.transformOrigin = origin; containerStyle.mozTransformOrigin = origin; containerStyle.webkitTransformOrigin = origin; containerStyle['-webkit-transform'] = origin; containerStyle.contentVisibility = this.renderConfig.contentVisibility; this.animationItem.wrapper.appendChild(this.animationItem.container); this.canvasContext = this.animationItem.container.getContext('2d'); if (this.renderConfig.className) { this.animationItem.container.setAttribute('class', this.renderConfig.className); } if (this.renderConfig.id) { this.animationItem.container.setAttribute('id', this.renderConfig.id); } } else { this.canvasContext = this.renderConfig.context; } this.data = animData; this.layers = animData.layers; this.transformCanvas = { w: animData.w, h: animData.h, sx: 0, sy: 0, tx: 0, ty: 0, }; this.setupGlobalData(animData, document.body); this.globalData.canvasContext = this.canvasContext; this.globalData.renderer = this; this.globalData.isDashed = false; this.globalData.progressiveLoad = this.renderConfig.progressiveLoad; this.globalData.transformCanvas = this.transformCanvas; this.elements = createSizedArray(animData.layers.length); this.updateContainerSize(); }; CanvasRenderer.prototype.updateContainerSize = function () { this.reset(); var elementWidth; var elementHeight; if (this.animationItem.wrapper && this.animationItem.container) { elementWidth = this.animationItem.wrapper.offsetWidth; elementHeight = this.animationItem.wrapper.offsetHeight; this.animationItem.container.setAttribute('width', elementWidth * this.renderConfig.dpr); this.animationItem.container.setAttribute('height', elementHeight * this.renderConfig.dpr); } else { elementWidth = this.canvasContext.canvas.width * this.renderConfig.dpr; elementHeight = this.canvasContext.canvas.height * this.renderConfig.dpr; } var elementRel; var animationRel; if (this.renderConfig.preserveAspectRatio.indexOf('meet') !== -1 || this.renderConfig.preserveAspectRatio.indexOf('slice') !== -1) { var par = this.renderConfig.preserveAspectRatio.split(' '); var fillType = par[1] || 'meet'; var pos = par[0] || 'xMidYMid'; var xPos = pos.substr(0, 4); var yPos = pos.substr(4); elementRel = elementWidth / elementHeight; animationRel = this.transformCanvas.w / this.transformCanvas.h; if ((animationRel > elementRel && fillType === 'meet') || (animationRel < elementRel && fillType === 'slice')) { this.transformCanvas.sx = elementWidth / (this.transformCanvas.w / this.renderConfig.dpr); this.transformCanvas.sy = elementWidth / (this.transformCanvas.w / this.renderConfig.dpr); } else { this.transformCanvas.sx = elementHeight / (this.transformCanvas.h / this.renderConfig.dpr); this.transformCanvas.sy = elementHeight / (this.transformCanvas.h / this.renderConfig.dpr); } if (xPos === 'xMid' && ((animationRel < elementRel && fillType === 'meet') || (animationRel > elementRel && fillType === 'slice'))) { this.transformCanvas.tx = ((elementWidth - this.transformCanvas.w * (elementHeight / this.transformCanvas.h)) / 2) * this.renderConfig.dpr; } else if (xPos === 'xMax' && ((animationRel < elementRel && fillType === 'meet') || (animationRel > elementRel && fillType === 'slice'))) { this.transformCanvas.tx = (elementWidth - this.transformCanvas.w * (elementHeight / this.transformCanvas.h)) * this.renderConfig.dpr; } else { this.transformCanvas.tx = 0; } if (yPos === 'YMid' && ((animationRel > elementRel && fillType === 'meet') || (animationRel < elementRel && fillType === 'slice'))) { this.transformCanvas.ty = ((elementHeight - this.transformCanvas.h * (elementWidth / this.transformCanvas.w)) / 2) * this.renderConfig.dpr; } else if (yPos === 'YMax' && ((animationRel > elementRel && fillType === 'meet') || (animationRel < elementRel && fillType === 'slice'))) { this.transformCanvas.ty = ((elementHeight - this.transformCanvas.h * (elementWidth / this.transformCanvas.w))) * this.renderConfig.dpr; } else { this.transformCanvas.ty = 0; } } else if (this.renderConfig.preserveAspectRatio === 'none') { this.transformCanvas.sx = elementWidth / (this.transformCanvas.w / this.renderConfig.dpr); this.transformCanvas.sy = elementHeight / (this.transformCanvas.h / this.renderConfig.dpr); this.transformCanvas.tx = 0; this.transformCanvas.ty = 0; } else { this.transformCanvas.sx = this.renderConfig.dpr; this.transformCanvas.sy = this.renderConfig.dpr; this.transformCanvas.tx = 0; this.transformCanvas.ty = 0; } this.transformCanvas.props = [this.transformCanvas.sx, 0, 0, 0, 0, this.transformCanvas.sy, 0, 0, 0, 0, 1, 0, this.transformCanvas.tx, this.transformCanvas.ty, 0, 1]; /* var i, len = this.elements.length; for(i=0;i<len;i+=1){ if(this.elements[i] && this.elements[i].data.ty === 0){ this.elements[i].resize(this.globalData.transformCanvas); } } */ this.ctxTransform(this.transformCanvas.props); this.canvasContext.beginPath(); this.canvasContext.rect(0, 0, this.transformCanvas.w, this.transformCanvas.h); this.canvasContext.closePath(); this.canvasContext.clip(); this.renderFrame(this.renderedFrame, true); }; CanvasRenderer.prototype.destroy = function () { if (this.renderConfig.clearCanvas && this.animationItem.wrapper) { this.animationItem.wrapper.innerText = ''; } var i; var len = this.layers ? this.layers.length : 0; for (i = len - 1; i >= 0; i -= 1) { if (this.elements[i]) { this.elements[i].destroy(); } } this.elements.length = 0; this.globalData.canvasContext = null; this.animationItem.container = null; this.destroyed = true; }; CanvasRenderer.prototype.renderFrame = function (num, forceRender) { if ((this.renderedFrame === num && this.renderConfig.clearCanvas === true && !forceRender) || this.destroyed || num === -1) { return; } this.renderedFrame = num; this.globalData.frameNum = num - this.animationItem._isFirstFrame; this.globalData.frameId += 1; this.globalData._mdf = !this.renderConfig.clearCanvas || forceRender; this.globalData.projectInterface.currentFrame = num; // console.log('--------'); // console.log('NEW: ',num); var i; var len = this.layers.length; if (!this.completeLayers) { this.checkLayers(num); } for (i = 0; i < len; i += 1) { if (this.completeLayers || this.elements[i]) { this.elements[i].prepareFrame(num - this.layers[i].st); } } if (this.globalData._mdf) { if (this.renderConfig.clearCanvas === true) { this.canvasContext.clearRect(0, 0, this.transformCanvas.w, this.transformCanvas.h); } else { this.save(); } for (i = len - 1; i >= 0; i -= 1) { if (this.completeLayers || this.elements[i]) { this.elements[i].renderFrame(); } } if (this.renderConfig.clearCanvas !== true) { this.restore(); } } }; CanvasRenderer.prototype.buildItem = function (pos) { var elements = this.elements; if (elements[pos] || this.layers[pos].ty === 99) { return; } var element = this.createItem(this.layers[pos], this, this.globalData); elements[pos] = element; element.initExpressions(); /* if(this.layers[pos].ty === 0){ element.resize(this.globalData.transformCanvas); } */ }; CanvasRenderer.prototype.checkPendingElements = function () { while (this.pendingElements.length) { var element = this.pendingElements.pop(); element.checkParenting(); } }; CanvasRenderer.prototype.hide = function () { this.animationItem.container.style.display = 'none'; }; CanvasRenderer.prototype.show = function () { this.animationItem.container.style.display = 'block'; }; /* global extendPrototype, BaseRenderer, SVGRenderer, SVGShapeElement, HShapeElement, SVGTextLottieElement, HTextElement, HCameraElement, IImageElement, HImageElement, SVGCompElement, HCompElement, ISolidElement, HSolidElement, styleDiv, createTag, createNS */ function HybridRenderer(animationItem, config) { this.animationItem = animationItem; this.layers = null; this.renderedFrame = -1; this.renderConfig = { className: (config && config.className) || '', imagePreserveAspectRatio: (config && config.imagePreserveAspectRatio) || 'xMidYMid slice', hideOnTransparent: !(config && config.hideOnTransparent === false), filterSize: { width: (config && config.filterSize && config.filterSize.width) || '400%', height: (config && config.filterSize && config.filterSize.height) || '400%', x: (config && config.filterSize && config.filterSize.x) || '-100%', y: (config && config.filterSize && config.filterSize.y) || '-100%', }, }; this.globalData = { _mdf: false, frameNum: -1, renderConfig: this.renderConfig, }; this.pendingElements = []; this.elements = []; this.threeDElements = []; this.destroyed = false; this.camera = null; this.supports3d = true; this.rendererType = 'html'; } extendPrototype([BaseRenderer], HybridRenderer); HybridRenderer.prototype.buildItem = SVGRenderer.prototype.buildItem; HybridRenderer.prototype.checkPendingElements = function () { while (this.pendingElements.length) { var element = this.pendingElements.pop(); element.checkParenting(); } }; HybridRenderer.prototype.appendElementInPos = function (element, pos) { var newDOMElement = element.getBaseElement(); if (!newDOMElement) { return; } var layer = this.layers[pos]; if (!layer.ddd || !this.supports3d) { if (this.threeDElements) { this.addTo3dContainer(newDOMElement, pos); } else { var i = 0; var nextDOMElement; var nextLayer; var tmpDOMElement; while (i < pos) { if (this.elements[i] && this.elements[i] !== true && this.elements[i].getBaseElement) { nextLayer = this.elements[i]; tmpDOMElement = this.layers[i].ddd ? this.getThreeDContainerByPos(i) : nextLayer.getBaseElement(); nextDOMElement = tmpDOMElement || nextDOMElement; } i += 1; } if (nextDOMElement) { if (!layer.ddd || !this.supports3d) { this.layerElement.insertBefore(newDOMElement, nextDOMElement); } } else if (!layer.ddd || !this.supports3d) { this.layerElement.appendChild(newDOMElement); } } } else { this.addTo3dContainer(newDOMElement, pos); } }; HybridRenderer.prototype.createShape = function (data) { if (!this.supports3d) { return new SVGShapeElement(data, this.globalData, this); } return new HShapeElement(data, this.globalData, this); }; HybridRenderer.prototype.createText = function (data) { if (!this.supports3d) { return new SVGTextLottieElement(data, this.globalData, this); } return new HTextElement(data, this.globalData, this); }; HybridRenderer.prototype.createCamera = function (data) { this.camera = new HCameraElement(data, this.globalData, this); return this.camera; }; HybridRenderer.prototype.createImage = function (data) { if (!this.supports3d) { return new IImageElement(data, this.globalData, this); } return new HImageElement(data, this.globalData, this); }; HybridRenderer.prototype.createComp = function (data) { if (!this.supports3d) { return new SVGCompElement(data, this.globalData, this); } return new HCompElement(data, this.globalData, this); }; HybridRenderer.prototype.createSolid = function (data) { if (!this.supports3d) { return new ISolidElement(data, this.globalData, this); } return new HSolidElement(data, this.globalData, this); }; HybridRenderer.prototype.createNull = SVGRenderer.prototype.createNull; HybridRenderer.prototype.getThreeDContainerByPos = function (pos) { var i = 0; var len = this.threeDElements.length; while (i < len) { if (this.threeDElements[i].startPos <= pos && this.threeDElements[i].endPos >= pos) { return this.threeDElements[i].perspectiveElem; } i += 1; } return null; }; HybridRenderer.prototype.createThreeDContainer = function (pos, type) { var perspectiveElem = createTag('div'); var style; var containerStyle; styleDiv(perspectiveElem); var container = createTag('div'); styleDiv(container); if (type === '3d') { style = perspectiveElem.style; style.width = this.globalData.compSize.w + 'px'; style.height = this.globalData.compSize.h + 'px'; var center = '50% 50%'; style.webkitTransformOrigin = center; style.mozTransformOrigin = center; style.transformOrigin = center; containerStyle = container.style; var matrix = 'matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1)'; containerStyle.transform = matrix; containerStyle.webkitTransform = matrix; } perspectiveElem.appendChild(container); // this.resizerElem.appendChild(perspectiveElem); var threeDContainerData = { container: container, perspectiveElem: perspectiveElem, startPos: pos, endPos: pos, type: type, }; this.threeDElements.push(threeDContainerData); return threeDContainerData; }; HybridRenderer.prototype.build3dContainers = function () { var i; var len = this.layers.length; var lastThreeDContainerData; var currentContainer = ''; for (i = 0; i < len; i += 1) { if (this.layers[i].ddd && this.layers[i].ty !== 3) { if (currentContainer !== '3d') { currentContainer = '3d'; lastThreeDContainerData = this.createThreeDContainer(i, '3d'); } lastThreeDContainerData.endPos = Math.max(lastThreeDContainerData.endPos, i); } else { if (currentContainer !== '2d') { currentContainer = '2d'; lastThreeDContainerData = this.createThreeDContainer(i, '2d'); } lastThreeDContainerData.endPos = Math.max(lastThreeDContainerData.endPos, i); } } len = this.threeDElements.length; for (i = len - 1; i >= 0; i -= 1) { this.resizerElem.appendChild(this.threeDElements[i].perspectiveElem); } }; HybridRenderer.prototype.addTo3dContainer = function (elem, pos) { var i = 0; var len = this.threeDElements.length; while (i < len) { if (pos <= this.threeDElements[i].endPos) { var j = this.threeDElements[i].startPos; var nextElement; while (j < pos) { if (this.elements[j] && this.elements[j].getBaseElement) { nextElement = this.elements[j].getBaseElement(); } j += 1; } if (nextElement) { this.threeDElements[i].container.insertBefore(elem, nextElement); } else { this.threeDElements[i].container.appendChild(elem); } break; } i += 1; } }; HybridRenderer.prototype.configAnimation = function (animData) { var resizerElem = createTag('div'); var wrapper = this.animationItem.wrapper; var style = resizerElem.style; style.width = animData.w + 'px'; style.height = animData.h + 'px'; this.resizerElem = resizerElem; styleDiv(resizerElem); style.transformStyle = 'flat'; style.mozTransformStyle = 'flat'; style.webkitTransformStyle = 'flat'; if (this.renderConfig.className) { resizerElem.setAttribute('class', this.renderConfig.className); } wrapper.appendChild(resizerElem); style.overflow = 'hidden'; var svg = createNS('svg'); svg.setAttribute('width', '1'); svg.setAttribute('height', '1'); styleDiv(svg); this.resizerElem.appendChild(svg); var defs = createNS('defs'); svg.appendChild(defs); this.data = animData; // Mask animation this.setupGlobalData(animData, svg); this.globalData.defs = defs; this.layers = animData.layers; this.layerElement = this.resizerElem; this.build3dContainers(); this.updateContainerSize(); }; HybridRenderer.prototype.destroy = function () { if (this.animationItem.wrapper) { this.animationItem.wrapper.innerText = ''; } this.animationItem.container = null; this.globalData.defs = null; var i; var len = this.layers ? this.layers.length : 0; for (i = 0; i < len; i += 1) { this.elements[i].destroy(); } this.elements.length = 0; this.destroyed = true; this.animationItem = null; }; HybridRenderer.prototype.updateContainerSize = function () { var elementWidth = this.animationItem.wrapper.offsetWidth; var elementHeight = this.animationItem.wrapper.offsetHeight; var elementRel = elementWidth / elementHeight; var animationRel = this.globalData.compSize.w / this.globalData.compSize.h; var sx; var sy; var tx; var ty; if (animationRel > elementRel) { sx = elementWidth / (this.globalData.compSize.w); sy = elementWidth / (this.globalData.compSize.w); tx = 0; ty = ((elementHeight - this.globalData.compSize.h * (elementWidth / this.globalData.compSize.w)) / 2); } else { sx = elementHeight / (this.globalData.compSize.h); sy = elementHeight / (this.globalData.compSize.h); tx = (elementWidth - this.globalData.compSize.w * (elementHeight / this.globalData.compSize.h)) / 2; ty = 0; } var style = this.resizerElem.style; style.webkitTransform = 'matrix3d(' + sx + ',0,0,0,0,' + sy + ',0,0,0,0,1,0,' + tx + ',' + ty + ',0,1)'; style.transform = style.webkitTransform; }; HybridRenderer.prototype.renderFrame = SVGRenderer.prototype.renderFrame; HybridRenderer.prototype.hide = function () { this.resizerElem.style.display = 'none'; }; HybridRenderer.prototype.show = function () { this.resizerElem.style.display = 'block'; }; HybridRenderer.prototype.initItems = function () { this.buildAllItems(); if (this.camera) { this.camera.setup(); } else { var cWidth = this.globalData.compSize.w; var cHeight = this.globalData.compSize.h; var i; var len = this.threeDElements.length; for (i = 0; i < len; i += 1) { var style = this.threeDElements[i].perspectiveElem.style; style.webkitPerspective = Math.sqrt(Math.pow(cWidth, 2) + Math.pow(cHeight, 2)) + 'px'; style.perspective = style.webkitPerspective; } } }; HybridRenderer.prototype.searchExtraCompositions = function (assets) { var i; var len = assets.length; var floatingContainer = createTag('div'); for (i = 0; i < len; i += 1) { if (assets[i].xt) { var comp = this.createComp(assets[i], floatingContainer, this.globalData.comp, null); comp.initExpressions(); this.globalData.projectInterface.registerComposition(comp); } } }; /* global createSizedArray, createElementID, PropertyFactory, ShapePropertyFactory, createNS, locationHref */ function MaskElement(data, element, globalData) { this.data = data; this.element = element; this.globalData = globalData; this.storedData = []; this.masksProperties = this.data.masksProperties || []; this.maskElement = null; var defs = this.globalData.defs; var i; var len = this.masksProperties ? this.masksProperties.length : 0; this.viewData = createSizedArray(len); this.solidPath = ''; var path; var properties = this.masksProperties; var count = 0; var currentMasks = []; var j; var jLen; var layerId = createElementID(); var rect; var expansor; var feMorph; var x; var maskType = 'clipPath'; var maskRef = 'clip-path'; for (i = 0; i < len; i += 1) { if ((properties[i].mode !== 'a' && properties[i].mode !== 'n') || properties[i].inv || properties[i].o.k !== 100 || properties[i].o.x) { maskType = 'mask'; maskRef = 'mask'; } if ((properties[i].mode === 's' || properties[i].mode === 'i') && count === 0) { rect = createNS('rect'); rect.setAttribute('fill', '#ffffff'); rect.setAttribute('width', this.element.comp.data.w || 0); rect.setAttribute('height', this.element.comp.data.h || 0); currentMasks.push(rect); } else { rect = null; } path = createNS('path'); if (properties[i].mode === 'n') { // TODO move this to a factory or to a constructor this.viewData[i] = { op: PropertyFactory.getProp(this.element, properties[i].o, 0, 0.01, this.element), prop: ShapePropertyFactory.getShapeProp(this.element, properties[i], 3), elem: path, lastPath: '', }; defs.appendChild(path); } else { count += 1; path.setAttribute('fill', properties[i].mode === 's' ? '#000000' : '#ffffff'); path.setAttribute('clip-rule', 'nonzero'); var filterID; if (properties[i].x.k !== 0) { maskType = 'mask'; maskRef = 'mask'; x = PropertyFactory.getProp(this.element, properties[i].x, 0, null, this.element); filterID = createElementID(); expansor = createNS('filter'); expansor.setAttribute('id', filterID); feMorph = createNS('feMorphology'); feMorph.setAttribute('operator', 'erode'); feMorph.setAttribute('in', 'SourceGraphic'); feMorph.setAttribute('radius', '0'); expansor.appendChild(feMorph); defs.appendChild(expansor); path.setAttribute('stroke', properties[i].mode === 's' ? '#000000' : '#ffffff'); } else { feMorph = null; x = null; } // TODO move this to a factory or to a constructor this.storedData[i] = { elem: path, x: x, expan: feMorph, lastPath: '', lastOperator: '', filterId: filterID, lastRadius: 0, }; if (properties[i].mode === 'i') { jLen = currentMasks.length; var g = createNS('g'); for (j = 0; j < jLen; j += 1) { g.appendChild(currentMasks[j]); } var mask = createNS('mask'); mask.setAttribute('mask-type', 'alpha'); mask.setAttribute('id', layerId + '_' + count); mask.appendChild(path); defs.appendChild(mask); g.setAttribute('mask', 'url(' + locationHref + '#' + layerId + '_' + count + ')'); currentMasks.length = 0; currentMasks.push(g); } else { currentMasks.push(path); } if (properties[i].inv && !this.solidPath) { this.solidPath = this.createLayerSolidPath(); } // TODO move this to a factory or to a constructor this.viewData[i] = { elem: path, lastPath: '', op: PropertyFactory.getProp(this.element, properties[i].o, 0, 0.01, this.element), prop: ShapePropertyFactory.getShapeProp(this.element, properties[i], 3), invRect: rect, }; if (!this.viewData[i].prop.k) { this.drawPath(properties[i], this.viewData[i].prop.v, this.viewData[i]); } } } this.maskElement = createNS(maskType); len = currentMasks.length; for (i = 0; i < len; i += 1) { this.maskElement.appendChild(currentMasks[i]); } if (count > 0) { this.maskElement.setAttribute('id', layerId); this.element.maskedElement.setAttribute(maskRef, 'url(' + locationHref + '#' + layerId + ')'); defs.appendChild(this.maskElement); } if (this.viewData.length) { this.element.addRenderableComponent(this); } } MaskElement.prototype.getMaskProperty = function (pos) { return this.viewData[pos].prop; }; MaskElement.prototype.renderFrame = function (isFirstFrame) { var finalMat = this.element.finalTransform.mat; var i; var len = this.masksProperties.length; for (i = 0; i < len; i += 1) { if (this.viewData[i].prop._mdf || isFirstFrame) { this.drawPath(this.masksProperties[i], this.viewData[i].prop.v, this.viewData[i]); } if (this.viewData[i].op._mdf || isFirstFrame) { this.viewData[i].elem.setAttribute('fill-opacity', this.viewData[i].op.v); } if (this.masksProperties[i].mode !== 'n') { if (this.viewData[i].invRect && (this.element.finalTransform.mProp._mdf || isFirstFrame)) { this.viewData[i].invRect.setAttribute('transform', finalMat.getInverseMatrix().to2dCSS()); } if (this.storedData[i].x && (this.storedData[i].x._mdf || isFirstFrame)) { var feMorph = this.storedData[i].expan; if (this.storedData[i].x.v < 0) { if (this.storedData[i].lastOperator !== 'erode') { this.storedData[i].lastOperator = 'erode'; this.storedData[i].elem.setAttribute('filter', 'url(' + locationHref + '#' + this.storedData[i].filterId + ')'); } feMorph.setAttribute('radius', -this.storedData[i].x.v); } else { if (this.storedData[i].lastOperator !== 'dilate') { this.storedData[i].lastOperator = 'dilate'; this.storedData[i].elem.setAttribute('filter', null); } this.storedData[i].elem.setAttribute('stroke-width', this.storedData[i].x.v * 2); } } } } }; MaskElement.prototype.getMaskelement = function () { return this.maskElement; }; MaskElement.prototype.createLayerSolidPath = function () { var path = 'M0,0 '; path += ' h' + this.globalData.compSize.w; path += ' v' + this.globalData.compSize.h; path += ' h-' + this.globalData.compSize.w; path += ' v-' + this.globalData.compSize.h + ' '; return path; }; MaskElement.prototype.drawPath = function (pathData, pathNodes, viewData) { var pathString = ' M' + pathNodes.v[0][0] + ',' + pathNodes.v[0][1]; var i; var len; len = pathNodes._length; for (i = 1; i < len; i += 1) { // pathString += " C"+pathNodes.o[i-1][0]+','+pathNodes.o[i-1][1] + " "+pathNodes.i[i][0]+','+pathNodes.i[i][1] + " "+pathNodes.v[i][0]+','+pathNodes.v[i][1]; pathString += ' C' + pathNodes.o[i - 1][0] + ',' + pathNodes.o[i - 1][1] + ' ' + pathNodes.i[i][0] + ',' + pathNodes.i[i][1] + ' ' + pathNodes.v[i][0] + ',' + pathNodes.v[i][1]; } // pathString += " C"+pathNodes.o[i-1][0]+','+pathNodes.o[i-1][1] + " "+pathNodes.i[0][0]+','+pathNodes.i[0][1] + " "+pathNodes.v[0][0]+','+pathNodes.v[0][1]; if (pathNodes.c && len > 1) { pathString += ' C' + pathNodes.o[i - 1][0] + ',' + pathNodes.o[i - 1][1] + ' ' + pathNodes.i[0][0] + ',' + pathNodes.i[0][1] + ' ' + pathNodes.v[0][0] + ',' + pathNodes.v[0][1]; } // pathNodes.__renderedString = pathString; if (viewData.lastPath !== pathString) { var pathShapeValue = ''; if (viewData.elem) { if (pathNodes.c) { pathShapeValue = pathData.inv ? this.solidPath + pathString : pathString; } viewData.elem.setAttribute('d', pathShapeValue); } viewData.lastPath = pathString; } }; MaskElement.prototype.destroy = function () { this.element = null; this.globalData = null; this.maskElement = null; this.data = null; this.masksProperties = null; }; /** * @file * Handles AE's layer parenting property. * */ function HierarchyElement() {} HierarchyElement.prototype = { /** * @function * Initializes hierarchy properties * */ initHierarchy: function () { // element's parent list this.hierarchy = []; // if element is parent of another layer _isParent will be true this._isParent = false; this.checkParenting(); }, /** * @function * Sets layer's hierarchy. * @param {array} hierarch * layer's parent list * */ setHierarchy: function (hierarchy) { this.hierarchy = hierarchy; }, /** * @function * Sets layer as parent. * */ setAsParent: function () { this._isParent = true; }, /** * @function * Searches layer's parenting chain * */ checkParenting: function () { if (this.data.parent !== undefined) { this.comp.buildElementParenting(this, this.data.parent, []); } }, }; /** * @file * Handles element's layer frame update. * Checks layer in point and out point * */ function FrameElement() {} FrameElement.prototype = { /** * @function * Initializes frame related properties. * */ initFrame: function () { // set to true when inpoint is rendered this._isFirstFrame = false; // list of animated properties this.dynamicProperties = []; // If layer has been modified in current tick this will be true this._mdf = false; }, /** * @function * Calculates all dynamic values * * @param {number} num * current frame number in Layer's time * @param {boolean} isVisible * if layers is currently in range * */ prepareProperties: function (num, isVisible) { var i; var len = this.dynamicProperties.length; for (i = 0; i < len; i += 1) { if (isVisible || (this._isParent && this.dynamicProperties[i].propType === 'transform')) { this.dynamicProperties[i].getValue(); if (this.dynamicProperties[i]._mdf) { this.globalData._mdf = true; this._mdf = true; } } } }, addDynamicProperty: function (prop) { if (this.dynamicProperties.indexOf(prop) === -1) { this.dynamicProperties.push(prop); } }, }; /* global TransformPropertyFactory, Matrix */ function TransformElement() {} TransformElement.prototype = { initTransform: function () { this.finalTransform = { mProp: this.data.ks ? TransformPropertyFactory.getTransformProperty(this, this.data.ks, this) : { o: 0 }, _matMdf: false, _opMdf: false, mat: new Matrix(), }; if (this.data.ao) { this.finalTransform.mProp.autoOriented = true; } // TODO: check TYPE 11: Guided elements if (this.data.ty !== 11) { // this.createElements(); } }, renderTransform: function () { this.finalTransform._opMdf = this.finalTransform.mProp.o._mdf || this._isFirstFrame; this.finalTransform._matMdf = this.finalTransform.mProp._mdf || this._isFirstFrame; if (this.hierarchy) { var mat; var finalMat = this.finalTransform.mat; var i = 0; var len = this.hierarchy.length; // Checking if any of the transformation matrices in the hierarchy chain has changed. if (!this.finalTransform._matMdf) { while (i < len) { if (this.hierarchy[i].finalTransform.mProp._mdf) { this.finalTransform._matMdf = true; break; } i += 1; } } if (this.finalTransform._matMdf) { mat = this.finalTransform.mProp.v.props; finalMat.cloneFromProps(mat); for (i = 0; i < len; i += 1) { mat = this.hierarchy[i].finalTransform.mProp.v.props; finalMat.transform(mat[0], mat[1], mat[2], mat[3], mat[4], mat[5], mat[6], mat[7], mat[8], mat[9], mat[10], mat[11], mat[12], mat[13], mat[14], mat[15]); } } } }, globalToLocal: function (pt) { var transforms = []; transforms.push(this.finalTransform); var flag = true; var comp = this.comp; while (flag) { if (comp.finalTransform) { if (comp.data.hasMask) { transforms.splice(0, 0, comp.finalTransform); } comp = comp.comp; } else { flag = false; } } var i; var len = transforms.length; var ptNew; for (i = 0; i < len; i += 1) { ptNew = transforms[i].mat.applyToPointArray(0, 0, 0); // ptNew = transforms[i].mat.applyToPointArray(pt[0],pt[1],pt[2]); pt = [pt[0] - ptNew[0], pt[1] - ptNew[1], 0]; } return pt; }, mHelper: new Matrix(), }; function RenderableElement() { } RenderableElement.prototype = { initRenderable: function () { // layer's visibility related to inpoint and outpoint. Rename isVisible to isInRange this.isInRange = false; // layer's display state this.hidden = false; // If layer's transparency equals 0, it can be hidden this.isTransparent = false; // list of animated components this.renderableComponents = []; }, addRenderableComponent: function (component) { if (this.renderableComponents.indexOf(component) === -1) { this.renderableComponents.push(component); } }, removeRenderableComponent: function (component) { if (this.renderableComponents.indexOf(component) !== -1) { this.renderableComponents.splice(this.renderableComponents.indexOf(component), 1); } }, prepareRenderableFrame: function (num) { this.checkLayerLimits(num); }, checkTransparency: function () { if (this.finalTransform.mProp.o.v <= 0) { if (!this.isTransparent && this.globalData.renderConfig.hideOnTransparent) { this.isTransparent = true; this.hide(); } } else if (this.isTransparent) { this.isTransparent = false; this.show(); } }, /** * @function * Initializes frame related properties. * * @param {number} num * current frame number in Layer's time * */ checkLayerLimits: function (num) { if (this.data.ip - this.data.st <= num && this.data.op - this.data.st > num) { if (this.isInRange !== true) { this.globalData._mdf = true; this._mdf = true; this.isInRange = true; this.show(); } } else if (this.isInRange !== false) { this.globalData._mdf = true; this.isInRange = false; this.hide(); } }, renderRenderable: function () { var i; var len = this.renderableComponents.length; for (i = 0; i < len; i += 1) { this.renderableComponents[i].renderFrame(this._isFirstFrame); } /* this.maskManager.renderFrame(this.finalTransform.mat); this.renderableEffectsManager.renderFrame(this._isFirstFrame); */ }, sourceRectAtTime: function () { return { top: 0, left: 0, width: 100, height: 100, }; }, getLayerSize: function () { if (this.data.ty === 5) { return { w: this.data.textData.width, h: this.data.textData.height }; } return { w: this.data.width, h: this.data.height }; }, }; /* global extendPrototype, RenderableElement, createProxyFunction */ function RenderableDOMElement() {} (function () { var _prototype = { initElement: function (data, globalData, comp) { this.initFrame(); this.initBaseData(data, globalData, comp); this.initTransform(data, globalData, comp); this.initHierarchy(); this.initRenderable(); this.initRendererElement(); this.createContainerElements(); this.createRenderableComponents(); this.createContent(); this.hide(); }, hide: function () { if (!this.hidden && (!this.isInRange || this.isTransparent)) { var elem = this.baseElement || this.layerElement; elem.style.display = 'none'; this.hidden = true; } }, show: function () { if (this.isInRange && !this.isTransparent) { if (!this.data.hd) { var elem = this.baseElement || this.layerElement; elem.style.display = 'block'; } this.hidden = false; this._isFirstFrame = true; } }, renderFrame: function () { // If it is exported as hidden (data.hd === true) no need to render // If it is not visible no need to render if (this.data.hd || this.hidden) { return; } this.renderTransform(); this.renderRenderable(); this.renderElement(); this.renderInnerContent(); if (this._isFirstFrame) { this._isFirstFrame = false; } }, renderInnerContent: function () {}, prepareFrame: function (num) { this._mdf = false; this.prepareRenderableFrame(num); this.prepareProperties(num, this.isInRange); this.checkTransparency(); }, destroy: function () { this.innerElem = null; this.destroyBaseElement(); }, }; extendPrototype([RenderableElement, createProxyFunction(_prototype)], RenderableDOMElement); }()); /* exported ProcessedElement */ function ProcessedElement(element, position) { this.elem = element; this.pos = position; } /* global createNS */ function SVGStyleData(data, level) { this.data = data; this.type = data.ty; this.d = ''; this.lvl = level; this._mdf = false; this.closed = data.hd === true; this.pElem = createNS('path'); this.msElem = null; } SVGStyleData.prototype.reset = function () { this.d = ''; this._mdf = false; }; function SVGShapeData(transformers, level, shape) { this.caches = []; this.styles = []; this.transformers = transformers; this.lStr = ''; this.sh = shape; this.lvl = level; // TODO find if there are some cases where _isAnimated can be false. // For now, since shapes add up with other shapes. They have to be calculated every time. // One way of finding out is checking if all styles associated to this shape depend only of this shape this._isAnimated = !!shape.k; // TODO: commenting this for now since all shapes are animated var i = 0; var len = transformers.length; while (i < len) { if (transformers[i].mProps.dynamicProperties.length) { this._isAnimated = true; break; } i += 1; } } SVGShapeData.prototype.setAsAnimated = function () { this._isAnimated = true; }; /* exported SVGTransformData */ function SVGTransformData(mProps, op, container) { this.transform = { mProps: mProps, op: op, container: container, }; this.elements = []; this._isAnimated = this.transform.mProps.dynamicProperties.length || this.transform.op.effectsSequence.length; } /* global DashProperty, PropertyFactory, extendPrototype, DynamicPropertyContainer */ function SVGStrokeStyleData(elem, data, styleOb) { this.initDynamicPropertyContainer(elem); this.getValue = this.iterateDynamicProperties; this.o = PropertyFactory.getProp(elem, data.o, 0, 0.01, this); this.w = PropertyFactory.getProp(elem, data.w, 0, null, this); this.d = new DashProperty(elem, data.d || {}, 'svg', this); this.c = PropertyFactory.getProp(elem, data.c, 1, 255, this); this.style = styleOb; this._isAnimated = !!this._isAnimated; } extendPrototype([DynamicPropertyContainer], SVGStrokeStyleData); /* global PropertyFactory, extendPrototype, DynamicPropertyContainer */ function SVGFillStyleData(elem, data, styleOb) { this.initDynamicPropertyContainer(elem); this.getValue = this.iterateDynamicProperties; this.o = PropertyFactory.getProp(elem, data.o, 0, 0.01, this); this.c = PropertyFactory.getProp(elem, data.c, 1, 255, this); this.style = styleOb; } extendPrototype([DynamicPropertyContainer], SVGFillStyleData); /* global PropertyFactory, degToRads, GradientProperty, createElementID, createNS, locationHref, extendPrototype, DynamicPropertyContainer, lineCapEnum, lineJoinEnum */ function SVGGradientFillStyleData(elem, data, styleOb) { this.initDynamicPropertyContainer(elem); this.getValue = this.iterateDynamicProperties; this.initGradientData(elem, data, styleOb); } SVGGradientFillStyleData.prototype.initGradientData = function (elem, data, styleOb) { this.o = PropertyFactory.getProp(elem, data.o, 0, 0.01, this); this.s = PropertyFactory.getProp(elem, data.s, 1, null, this); this.e = PropertyFactory.getProp(elem, data.e, 1, null, this); this.h = PropertyFactory.getProp(elem, data.h || { k: 0 }, 0, 0.01, this); this.a = PropertyFactory.getProp(elem, data.a || { k: 0 }, 0, degToRads, this); this.g = new GradientProperty(elem, data.g, this); this.style = styleOb; this.stops = []; this.setGradientData(styleOb.pElem, data); this.setGradientOpacity(data, styleOb); this._isAnimated = !!this._isAnimated; }; SVGGradientFillStyleData.prototype.setGradientData = function (pathElement, data) { var gradientId = createElementID(); var gfill = createNS(data.t === 1 ? 'linearGradient' : 'radialGradient'); gfill.setAttribute('id', gradientId); gfill.setAttribute('spreadMethod', 'pad'); gfill.setAttribute('gradientUnits', 'userSpaceOnUse'); var stops = []; var stop; var j; var jLen; jLen = data.g.p * 4; for (j = 0; j < jLen; j += 4) { stop = createNS('stop'); gfill.appendChild(stop); stops.push(stop); } pathElement.setAttribute(data.ty === 'gf' ? 'fill' : 'stroke', 'url(' + locationHref + '#' + gradientId + ')'); this.gf = gfill; this.cst = stops; }; SVGGradientFillStyleData.prototype.setGradientOpacity = function (data, styleOb) { if (this.g._hasOpacity && !this.g._collapsable) { var stop; var j; var jLen; var mask = createNS('mask'); var maskElement = createNS('path'); mask.appendChild(maskElement); var opacityId = createElementID(); var maskId = createElementID(); mask.setAttribute('id', maskId); var opFill = createNS(data.t === 1 ? 'linearGradient' : 'radialGradient'); opFill.setAttribute('id', opacityId); opFill.setAttribute('spreadMethod', 'pad'); opFill.setAttribute('gradientUnits', 'userSpaceOnUse'); jLen = data.g.k.k[0].s ? data.g.k.k[0].s.length : data.g.k.k.length; var stops = this.stops; for (j = data.g.p * 4; j < jLen; j += 2) { stop = createNS('stop'); stop.setAttribute('stop-color', 'rgb(255,255,255)'); opFill.appendChild(stop); stops.push(stop); } maskElement.setAttribute(data.ty === 'gf' ? 'fill' : 'stroke', 'url(' + locationHref + '#' + opacityId + ')'); if (data.ty === 'gs') { maskElement.setAttribute('stroke-linecap', lineCapEnum[data.lc || 2]); maskElement.setAttribute('stroke-linejoin', lineJoinEnum[data.lj || 2]); if (data.lj === 1) { maskElement.setAttribute('stroke-miterlimit', data.ml); } } this.of = opFill; this.ms = mask; this.ost = stops; this.maskId = maskId; styleOb.msElem = maskElement; } }; extendPrototype([DynamicPropertyContainer], SVGGradientFillStyleData); /* global PropertyFactory, DashProperty, extendPrototype, SVGGradientFillStyleData, DynamicPropertyContainer */ function SVGGradientStrokeStyleData(elem, data, styleOb) { this.initDynamicPropertyContainer(elem); this.getValue = this.iterateDynamicProperties; this.w = PropertyFactory.getProp(elem, data.w, 0, null, this); this.d = new DashProperty(elem, data.d || {}, 'svg', this); this.initGradientData(elem, data, styleOb); this._isAnimated = !!this._isAnimated; } extendPrototype([SVGGradientFillStyleData, DynamicPropertyContainer], SVGGradientStrokeStyleData); /* global createNS */ /* exported ShapeGroupData */ function ShapeGroupData() { this.it = []; this.prevViewData = []; this.gr = createNS('g'); } /* global Matrix, buildShapeString, bmFloor */ /* exported SVGElementsRenderer */ var SVGElementsRenderer = (function () { var _identityMatrix = new Matrix(); var _matrixHelper = new Matrix(); var ob = { createRenderFunction: createRenderFunction, }; function createRenderFunction(data) { switch (data.ty) { case 'fl': return renderFill; case 'gf': return renderGradient; case 'gs': return renderGradientStroke; case 'st': return renderStroke; case 'sh': case 'el': case 'rc': case 'sr': return renderPath; case 'tr': return renderContentTransform; default: return null; } } function renderContentTransform(styleData, itemData, isFirstFrame) { if (isFirstFrame || itemData.transform.op._mdf) { itemData.transform.container.setAttribute('opacity', itemData.transform.op.v); } if (isFirstFrame || itemData.transform.mProps._mdf) { itemData.transform.container.setAttribute('transform', itemData.transform.mProps.v.to2dCSS()); } } function renderPath(styleData, itemData, isFirstFrame) { var j; var jLen; var pathStringTransformed; var redraw; var pathNodes; var l; var lLen = itemData.styles.length; var lvl = itemData.lvl; var paths; var mat; var props; var iterations; var k; for (l = 0; l < lLen; l += 1) { redraw = itemData.sh._mdf || isFirstFrame; if (itemData.styles[l].lvl < lvl) { mat = _matrixHelper.reset(); iterations = lvl - itemData.styles[l].lvl; k = itemData.transformers.length - 1; while (!redraw && iterations > 0) { redraw = itemData.transformers[k].mProps._mdf || redraw; iterations -= 1; k -= 1; } if (redraw) { iterations = lvl - itemData.styles[l].lvl; k = itemData.transformers.length - 1; while (iterations > 0) { props = itemData.transformers[k].mProps.v.props; mat.transform(props[0], props[1], props[2], props[3], props[4], props[5], props[6], props[7], props[8], props[9], props[10], props[11], props[12], props[13], props[14], props[15]); iterations -= 1; k -= 1; } } } else { mat = _identityMatrix; } paths = itemData.sh.paths; jLen = paths._length; if (redraw) { pathStringTransformed = ''; for (j = 0; j < jLen; j += 1) { pathNodes = paths.shapes[j]; if (pathNodes && pathNodes._length) { pathStringTransformed += buildShapeString(pathNodes, pathNodes._length, pathNodes.c, mat); } } itemData.caches[l] = pathStringTransformed; } else { pathStringTransformed = itemData.caches[l]; } itemData.styles[l].d += styleData.hd === true ? '' : pathStringTransformed; itemData.styles[l]._mdf = redraw || itemData.styles[l]._mdf; } } function renderFill(styleData, itemData, isFirstFrame) { var styleElem = itemData.style; if (itemData.c._mdf || isFirstFrame) { styleElem.pElem.setAttribute('fill', 'rgb(' + bmFloor(itemData.c.v[0]) + ',' + bmFloor(itemData.c.v[1]) + ',' + bmFloor(itemData.c.v[2]) + ')'); } if (itemData.o._mdf || isFirstFrame) { styleElem.pElem.setAttribute('fill-opacity', itemData.o.v); } } function renderGradientStroke(styleData, itemData, isFirstFrame) { renderGradient(styleData, itemData, isFirstFrame); renderStroke(styleData, itemData, isFirstFrame); } function renderGradient(styleData, itemData, isFirstFrame) { var gfill = itemData.gf; var hasOpacity = itemData.g._hasOpacity; var pt1 = itemData.s.v; var pt2 = itemData.e.v; if (itemData.o._mdf || isFirstFrame) { var attr = styleData.ty === 'gf' ? 'fill-opacity' : 'stroke-opacity'; itemData.style.pElem.setAttribute(attr, itemData.o.v); } if (itemData.s._mdf || isFirstFrame) { var attr1 = styleData.t === 1 ? 'x1' : 'cx'; var attr2 = attr1 === 'x1' ? 'y1' : 'cy'; gfill.setAttribute(attr1, pt1[0]); gfill.setAttribute(attr2, pt1[1]); if (hasOpacity && !itemData.g._collapsable) { itemData.of.setAttribute(attr1, pt1[0]); itemData.of.setAttribute(attr2, pt1[1]); } } var stops; var i; var len; var stop; if (itemData.g._cmdf || isFirstFrame) { stops = itemData.cst; var cValues = itemData.g.c; len = stops.length; for (i = 0; i < len; i += 1) { stop = stops[i]; stop.setAttribute('offset', cValues[i * 4] + '%'); stop.setAttribute('stop-color', 'rgb(' + cValues[i * 4 + 1] + ',' + cValues[i * 4 + 2] + ',' + cValues[i * 4 + 3] + ')'); } } if (hasOpacity && (itemData.g._omdf || isFirstFrame)) { var oValues = itemData.g.o; if (itemData.g._collapsable) { stops = itemData.cst; } else { stops = itemData.ost; } len = stops.length; for (i = 0; i < len; i += 1) { stop = stops[i]; if (!itemData.g._collapsable) { stop.setAttribute('offset', oValues[i * 2] + '%'); } stop.setAttribute('stop-opacity', oValues[i * 2 + 1]); } } if (styleData.t === 1) { if (itemData.e._mdf || isFirstFrame) { gfill.setAttribute('x2', pt2[0]); gfill.setAttribute('y2', pt2[1]); if (hasOpacity && !itemData.g._collapsable) { itemData.of.setAttribute('x2', pt2[0]); itemData.of.setAttribute('y2', pt2[1]); } } } else { var rad; if (itemData.s._mdf || itemData.e._mdf || isFirstFrame) { rad = Math.sqrt(Math.pow(pt1[0] - pt2[0], 2) + Math.pow(pt1[1] - pt2[1], 2)); gfill.setAttribute('r', rad); if (hasOpacity && !itemData.g._collapsable) { itemData.of.setAttribute('r', rad); } } if (itemData.e._mdf || itemData.h._mdf || itemData.a._mdf || isFirstFrame) { if (!rad) { rad = Math.sqrt(Math.pow(pt1[0] - pt2[0], 2) + Math.pow(pt1[1] - pt2[1], 2)); } var ang = Math.atan2(pt2[1] - pt1[1], pt2[0] - pt1[0]); var percent = itemData.h.v; if (percent >= 1) { percent = 0.99; } else if (percent <= -1) { percent = -0.99; } var dist = rad * percent; var x = Math.cos(ang + itemData.a.v) * dist + pt1[0]; var y = Math.sin(ang + itemData.a.v) * dist + pt1[1]; gfill.setAttribute('fx', x); gfill.setAttribute('fy', y); if (hasOpacity && !itemData.g._collapsable) { itemData.of.setAttribute('fx', x); itemData.of.setAttribute('fy', y); } } // gfill.setAttribute('fy','200'); } } function renderStroke(styleData, itemData, isFirstFrame) { var styleElem = itemData.style; var d = itemData.d; if (d && (d._mdf || isFirstFrame) && d.dashStr) { styleElem.pElem.setAttribute('stroke-dasharray', d.dashStr); styleElem.pElem.setAttribute('stroke-dashoffset', d.dashoffset[0]); } if (itemData.c && (itemData.c._mdf || isFirstFrame)) { styleElem.pElem.setAttribute('stroke', 'rgb(' + bmFloor(itemData.c.v[0]) + ',' + bmFloor(itemData.c.v[1]) + ',' + bmFloor(itemData.c.v[2]) + ')'); } if (itemData.o._mdf || isFirstFrame) { styleElem.pElem.setAttribute('stroke-opacity', itemData.o.v); } if (itemData.w._mdf || isFirstFrame) { styleElem.pElem.setAttribute('stroke-width', itemData.w.v); if (styleElem.msElem) { styleElem.msElem.setAttribute('stroke-width', itemData.w.v); } } } return ob; }()); /* global Matrix */ function ShapeTransformManager() { this.sequences = {}; this.sequenceList = []; this.transform_key_count = 0; } ShapeTransformManager.prototype = { addTransformSequence: function (transforms) { var i; var len = transforms.length; var key = '_'; for (i = 0; i < len; i += 1) { key += transforms[i].transform.key + '_'; } var sequence = this.sequences[key]; if (!sequence) { sequence = { transforms: [].concat(transforms), finalTransform: new Matrix(), _mdf: false, }; this.sequences[key] = sequence; this.sequenceList.push(sequence); } return sequence; }, processSequence: function (sequence, isFirstFrame) { var i = 0; var len = sequence.transforms.length; var _mdf = isFirstFrame; while (i < len && !isFirstFrame) { if (sequence.transforms[i].transform.mProps._mdf) { _mdf = true; break; } i += 1; } if (_mdf) { var props; sequence.finalTransform.reset(); for (i = len - 1; i >= 0; i -= 1) { props = sequence.transforms[i].transform.mProps.v.props; sequence.finalTransform.transform(props[0], props[1], props[2], props[3], props[4], props[5], props[6], props[7], props[8], props[9], props[10], props[11], props[12], props[13], props[14], props[15]); } } sequence._mdf = _mdf; }, processSequences: function (isFirstFrame) { var i; var len = this.sequenceList.length; for (i = 0; i < len; i += 1) { this.processSequence(this.sequenceList[i], isFirstFrame); } }, getNewKey: function () { this.transform_key_count += 1; return '_' + this.transform_key_count; }, }; /* global ShapePropertyFactory, SVGShapeData */ function CVShapeData(element, data, styles, transformsManager) { this.styledShapes = []; this.tr = [0, 0, 0, 0, 0, 0]; var ty = 4; if (data.ty === 'rc') { ty = 5; } else if (data.ty === 'el') { ty = 6; } else if (data.ty === 'sr') { ty = 7; } this.sh = ShapePropertyFactory.getShapeProp(element, data, ty, element); var i; var len = styles.length; var styledShape; for (i = 0; i < len; i += 1) { if (!styles[i].closed) { styledShape = { transforms: transformsManager.addTransformSequence(styles[i].transforms), trNodes: [], }; this.styledShapes.push(styledShape); styles[i].elements.push(styledShape); } } } CVShapeData.prototype.setAsAnimated = SVGShapeData.prototype.setAsAnimated; /* global LayerExpressionInterface, EffectsExpressionInterface, CompExpressionInterface, ShapeExpressionInterface, TextExpressionInterface, getBlendMode,createElementID, EffectsManager */ function BaseElement() { } BaseElement.prototype = { checkMasks: function () { if (!this.data.hasMask) { return false; } var i = 0; var len = this.data.masksProperties.length; while (i < len) { if ((this.data.masksProperties[i].mode !== 'n' && this.data.masksProperties[i].cl !== false)) { return true; } i += 1; } return false; }, initExpressions: function () { this.layerInterface = LayerExpressionInterface(this); if (this.data.hasMask && this.maskManager) { this.layerInterface.registerMaskInterface(this.maskManager); } var effectsInterface = EffectsExpressionInterface.createEffectsInterface(this, this.layerInterface); this.layerInterface.registerEffectsInterface(effectsInterface); if (this.data.ty === 0 || this.data.xt) { this.compInterface = CompExpressionInterface(this); } else if (this.data.ty === 4) { this.layerInterface.shapeInterface = ShapeExpressionInterface(this.shapesData, this.itemsData, this.layerInterface); this.layerInterface.content = this.layerInterface.shapeInterface; } else if (this.data.ty === 5) { this.layerInterface.textInterface = TextExpressionInterface(this); this.layerInterface.text = this.layerInterface.textInterface; } }, setBlendMode: function () { var blendModeValue = getBlendMode(this.data.bm); var elem = this.baseElement || this.layerElement; elem.style['mix-blend-mode'] = blendModeValue; }, initBaseData: function (data, globalData, comp) { this.globalData = globalData; this.comp = comp; this.data = data; this.layerId = createElementID(); // Stretch factor for old animations missing this property. if (!this.data.sr) { this.data.sr = 1; } // effects manager this.effectsManager = new EffectsManager(this.data, this, this.dynamicProperties); }, getType: function () { return this.type; }, sourceRectAtTime: function () {}, }; /* global extendPrototype, BaseElement, TransformElement, HierarchyElement, FrameElement */ function NullElement(data, globalData, comp) { this.initFrame(); this.initBaseData(data, globalData, comp); this.initFrame(); this.initTransform(data, globalData, comp); this.initHierarchy(); } NullElement.prototype.prepareFrame = function (num) { this.prepareProperties(num, true); }; NullElement.prototype.renderFrame = function () { }; NullElement.prototype.getBaseElement = function () { return null; }; NullElement.prototype.destroy = function () { }; NullElement.prototype.sourceRectAtTime = function () { }; NullElement.prototype.hide = function () { }; extendPrototype([BaseElement, TransformElement, HierarchyElement, FrameElement], NullElement); /* global filtersFactory, featureSupport, filtersFactory, createElementID, createNS, MaskElement, SVGEffects, locationHref */ function SVGBaseElement() { } SVGBaseElement.prototype = { initRendererElement: function () { this.layerElement = createNS('g'); }, createContainerElements: function () { this.matteElement = createNS('g'); this.transformedElement = this.layerElement; this.maskedElement = this.layerElement; this._sizeChanged = false; var layerElementParent = null; // If this layer acts as a mask for the following layer var filId; var fil; var gg; if (this.data.td) { if (this.data.td == 3 || this.data.td == 1) { // eslint-disable-line eqeqeq var masker = createNS('mask'); masker.setAttribute('id', this.layerId); masker.setAttribute('mask-type', this.data.td == 3 ? 'luminance' : 'alpha'); // eslint-disable-line eqeqeq masker.appendChild(this.layerElement); layerElementParent = masker; this.globalData.defs.appendChild(masker); // This is only for IE and Edge when mask if of type alpha if (!featureSupport.maskType && this.data.td == 1) { // eslint-disable-line eqeqeq masker.setAttribute('mask-type', 'luminance'); filId = createElementID(); fil = filtersFactory.createFilter(filId); this.globalData.defs.appendChild(fil); fil.appendChild(filtersFactory.createAlphaToLuminanceFilter()); gg = createNS('g'); gg.appendChild(this.layerElement); layerElementParent = gg; masker.appendChild(gg); gg.setAttribute('filter', 'url(' + locationHref + '#' + filId + ')'); } } else if (this.data.td == 2) { // eslint-disable-line eqeqeq var maskGroup = createNS('mask'); maskGroup.setAttribute('id', this.layerId); maskGroup.setAttribute('mask-type', 'alpha'); var maskGrouper = createNS('g'); maskGroup.appendChild(maskGrouper); filId = createElementID(); fil = filtersFactory.createFilter(filId); /// / // This solution doesn't work on Android when meta tag with viewport attribute is set /* var feColorMatrix = createNS('feColorMatrix'); feColorMatrix.setAttribute('type', 'matrix'); feColorMatrix.setAttribute('color-interpolation-filters', 'sRGB'); feColorMatrix.setAttribute('values','1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 -1 1'); fil.appendChild(feColorMatrix); */ /// / var feCTr = createNS('feComponentTransfer'); feCTr.setAttribute('in', 'SourceGraphic'); fil.appendChild(feCTr); var feFunc = createNS('feFuncA'); feFunc.setAttribute('type', 'table'); feFunc.setAttribute('tableValues', '1.0 0.0'); feCTr.appendChild(feFunc); /// / this.globalData.defs.appendChild(fil); var alphaRect = createNS('rect'); alphaRect.setAttribute('width', this.comp.data.w); alphaRect.setAttribute('height', this.comp.data.h); alphaRect.setAttribute('x', '0'); alphaRect.setAttribute('y', '0'); alphaRect.setAttribute('fill', '#ffffff'); alphaRect.setAttribute('opacity', '0'); maskGrouper.setAttribute('filter', 'url(' + locationHref + '#' + filId + ')'); maskGrouper.appendChild(alphaRect); maskGrouper.appendChild(this.layerElement); layerElementParent = maskGrouper; if (!featureSupport.maskType) { maskGroup.setAttribute('mask-type', 'luminance'); fil.appendChild(filtersFactory.createAlphaToLuminanceFilter()); gg = createNS('g'); maskGrouper.appendChild(alphaRect); gg.appendChild(this.layerElement); layerElementParent = gg; maskGrouper.appendChild(gg); } this.globalData.defs.appendChild(maskGroup); } } else if (this.data.tt) { this.matteElement.appendChild(this.layerElement); layerElementParent = this.matteElement; this.baseElement = this.matteElement; } else { this.baseElement = this.layerElement; } if (this.data.ln) { this.layerElement.setAttribute('id', this.data.ln); } if (this.data.cl) { this.layerElement.setAttribute('class', this.data.cl); } // Clipping compositions to hide content that exceeds boundaries. If collapsed transformations is on, component should not be clipped if (this.data.ty === 0 && !this.data.hd) { var cp = createNS('clipPath'); var pt = createNS('path'); pt.setAttribute('d', 'M0,0 L' + this.data.w + ',0 L' + this.data.w + ',' + this.data.h + ' L0,' + this.data.h + 'z'); var clipId = createElementID(); cp.setAttribute('id', clipId); cp.appendChild(pt); this.globalData.defs.appendChild(cp); if (this.checkMasks()) { var cpGroup = createNS('g'); cpGroup.setAttribute('clip-path', 'url(' + locationHref + '#' + clipId + ')'); cpGroup.appendChild(this.layerElement); this.transformedElement = cpGroup; if (layerElementParent) { layerElementParent.appendChild(this.transformedElement); } else { this.baseElement = this.transformedElement; } } else { this.layerElement.setAttribute('clip-path', 'url(' + locationHref + '#' + clipId + ')'); } } if (this.data.bm !== 0) { this.setBlendMode(); } }, renderElement: function () { if (this.finalTransform._matMdf) { this.transformedElement.setAttribute('transform', this.finalTransform.mat.to2dCSS()); } if (this.finalTransform._opMdf) { this.transformedElement.setAttribute('opacity', this.finalTransform.mProp.o.v); } }, destroyBaseElement: function () { this.layerElement = null; this.matteElement = null; this.maskManager.destroy(); }, getBaseElement: function () { if (this.data.hd) { return null; } return this.baseElement; }, createRenderableComponents: function () { this.maskManager = new MaskElement(this.data, this, this.globalData); this.renderableEffectsManager = new SVGEffects(this); }, setMatte: function (id) { if (!this.matteElement) { return; } this.matteElement.setAttribute('mask', 'url(' + locationHref + '#' + id + ')'); }, }; /* global ProcessedElement */ function IShapeElement() { } IShapeElement.prototype = { addShapeToModifiers: function (data) { var i; var len = this.shapeModifiers.length; for (i = 0; i < len; i += 1) { this.shapeModifiers[i].addShape(data); } }, isShapeInAnimatedModifiers: function (data) { var i = 0; var len = this.shapeModifiers.length; while (i < len) { if (this.shapeModifiers[i].isAnimatedWithShape(data)) { return true; } } return false; }, renderModifiers: function () { if (!this.shapeModifiers.length) { return; } var i; var len = this.shapes.length; for (i = 0; i < len; i += 1) { this.shapes[i].sh.reset(); } len = this.shapeModifiers.length; var shouldBreakProcess; for (i = len - 1; i >= 0; i -= 1) { shouldBreakProcess = this.shapeModifiers[i].processShapes(this._isFirstFrame); // workaround to fix cases where a repeater resets the shape so the following processes get called twice // TODO: find a better solution for this if (shouldBreakProcess) { break; } } }, searchProcessedElement: function (elem) { var elements = this.processedElements; var i = 0; var len = elements.length; while (i < len) { if (elements[i].elem === elem) { return elements[i].pos; } i += 1; } return 0; }, addProcessedElement: function (elem, pos) { var elements = this.processedElements; var i = elements.length; while (i) { i -= 1; if (elements[i].elem === elem) { elements[i].pos = pos; return; } } elements.push(new ProcessedElement(elem, pos)); }, prepareFrame: function (num) { this.prepareRenderableFrame(num); this.prepareProperties(num, this.isInRange); }, }; /* global TextProperty, TextAnimatorProperty, buildShapeString, LetterProps */ function ITextElement() { } ITextElement.prototype.initElement = function (data, globalData, comp) { this.lettersChangedFlag = true; this.initFrame(); this.initBaseData(data, globalData, comp); this.textProperty = new TextProperty(this, data.t, this.dynamicProperties); this.textAnimator = new TextAnimatorProperty(data.t, this.renderType, this); this.initTransform(data, globalData, comp); this.initHierarchy(); this.initRenderable(); this.initRendererElement(); this.createContainerElements(); this.createRenderableComponents(); this.createContent(); this.hide(); this.textAnimator.searchProperties(this.dynamicProperties); }; ITextElement.prototype.prepareFrame = function (num) { this._mdf = false; this.prepareRenderableFrame(num); this.prepareProperties(num, this.isInRange); if (this.textProperty._mdf || this.textProperty._isFirstFrame) { this.buildNewText(); this.textProperty._isFirstFrame = false; this.textProperty._mdf = false; } }; ITextElement.prototype.createPathShape = function (matrixHelper, shapes) { var j; var jLen = shapes.length; var pathNodes; var shapeStr = ''; for (j = 0; j < jLen; j += 1) { pathNodes = shapes[j].ks.k; shapeStr += buildShapeString(pathNodes, pathNodes.i.length, true, matrixHelper); } return shapeStr; }; ITextElement.prototype.updateDocumentData = function (newData, index) { this.textProperty.updateDocumentData(newData, index); }; ITextElement.prototype.canResizeFont = function (_canResize) { this.textProperty.canResizeFont(_canResize); }; ITextElement.prototype.setMinimumFontSize = function (_fontSize) { this.textProperty.setMinimumFontSize(_fontSize); }; ITextElement.prototype.applyTextPropertiesToMatrix = function (documentData, matrixHelper, lineNumber, xPos, yPos) { if (documentData.ps) { matrixHelper.translate(documentData.ps[0], documentData.ps[1] + documentData.ascent, 0); } matrixHelper.translate(0, -documentData.ls, 0); switch (documentData.j) { case 1: matrixHelper.translate(documentData.justifyOffset + (documentData.boxWidth - documentData.lineWidths[lineNumber]), 0, 0); break; case 2: matrixHelper.translate(documentData.justifyOffset + (documentData.boxWidth - documentData.lineWidths[lineNumber]) / 2, 0, 0); break; default: break; } matrixHelper.translate(xPos, yPos, 0); }; ITextElement.prototype.buildColor = function (colorData) { return 'rgb(' + Math.round(colorData[0] * 255) + ',' + Math.round(colorData[1] * 255) + ',' + Math.round(colorData[2] * 255) + ')'; }; ITextElement.prototype.emptyProp = new LetterProps(); ITextElement.prototype.destroy = function () { }; /* global extendPrototype, BaseElement, TransformElement, HierarchyElement, FrameElement, RenderableDOMElement */ function ICompElement() {} extendPrototype([BaseElement, TransformElement, HierarchyElement, FrameElement, RenderableDOMElement], ICompElement); ICompElement.prototype.initElement = function (data, globalData, comp) { this.initFrame(); this.initBaseData(data, globalData, comp); this.initTransform(data, globalData, comp); this.initRenderable(); this.initHierarchy(); this.initRendererElement(); this.createContainerElements(); this.createRenderableComponents(); if (this.data.xt || !globalData.progressiveLoad) { this.buildAllItems(); } this.hide(); }; /* ICompElement.prototype.hide = function(){ if(!this.hidden){ this.hideElement(); var i,len = this.elements.length; for( i = 0; i < len; i+=1 ){ if(this.elements[i]){ this.elements[i].hide(); } } } }; */ ICompElement.prototype.prepareFrame = function (num) { this._mdf = false; this.prepareRenderableFrame(num); this.prepareProperties(num, this.isInRange); if (!this.isInRange && !this.data.xt) { return; } if (!this.tm._placeholder) { var timeRemapped = this.tm.v; if (timeRemapped === this.data.op) { timeRemapped = this.data.op - 1; } this.renderedFrame = timeRemapped; } else { this.renderedFrame = num / this.data.sr; } var i; var len = this.elements.length; if (!this.completeLayers) { this.checkLayers(this.renderedFrame); } // This iteration needs to be backwards because of how expressions connect between each other for (i = len - 1; i >= 0; i -= 1) { if (this.completeLayers || this.elements[i]) { this.elements[i].prepareFrame(this.renderedFrame - this.layers[i].st); if (this.elements[i]._mdf) { this._mdf = true; } } } }; ICompElement.prototype.renderInnerContent = function () { var i; var len = this.layers.length; for (i = 0; i < len; i += 1) { if (this.completeLayers || this.elements[i]) { this.elements[i].renderFrame(); } } }; ICompElement.prototype.setElements = function (elems) { this.elements = elems; }; ICompElement.prototype.getElements = function () { return this.elements; }; ICompElement.prototype.destroyElements = function () { var i; var len = this.layers.length; for (i = 0; i < len; i += 1) { if (this.elements[i]) { this.elements[i].destroy(); } } }; ICompElement.prototype.destroy = function () { this.destroyElements(); this.destroyBaseElement(); }; /* global extendPrototype, BaseElement, TransformElement, SVGBaseElement, HierarchyElement, FrameElement, RenderableDOMElement, createNS */ function IImageElement(data, globalData, comp) { this.assetData = globalData.getAssetData(data.refId); this.initElement(data, globalData, comp); this.sourceRect = { top: 0, left: 0, width: this.assetData.w, height: this.assetData.h, }; } extendPrototype([BaseElement, TransformElement, SVGBaseElement, HierarchyElement, FrameElement, RenderableDOMElement], IImageElement); IImageElement.prototype.createContent = function () { var assetPath = this.globalData.getAssetsPath(this.assetData); this.innerElem = createNS('image'); this.innerElem.setAttribute('width', this.assetData.w + 'px'); this.innerElem.setAttribute('height', this.assetData.h + 'px'); this.innerElem.setAttribute('preserveAspectRatio', this.assetData.pr || this.globalData.renderConfig.imagePreserveAspectRatio); this.innerElem.setAttributeNS('http://www.w3.org/1999/xlink', 'href', assetPath); this.layerElement.appendChild(this.innerElem); }; IImageElement.prototype.sourceRectAtTime = function () { return this.sourceRect; }; /* global extendPrototype, IImageElement, createNS */ function ISolidElement(data, globalData, comp) { this.initElement(data, globalData, comp); } extendPrototype([IImageElement], ISolidElement); ISolidElement.prototype.createContent = function () { var rect = createNS('rect'); /// /rect.style.width = this.data.sw; /// /rect.style.height = this.data.sh; /// /rect.style.fill = this.data.sc; rect.setAttribute('width', this.data.sw); rect.setAttribute('height', this.data.sh); rect.setAttribute('fill', this.data.sc); this.layerElement.appendChild(rect); }; /* global PropertyFactory, extendPrototype, RenderableElement, BaseElement, FrameElement */ function AudioElement(data, globalData, comp) { this.initFrame(); this.initRenderable(); this.assetData = globalData.getAssetData(data.refId); this.initBaseData(data, globalData, comp); this._isPlaying = false; this._canPlay = false; var assetPath = this.globalData.getAssetsPath(this.assetData); this.audio = this.globalData.audioController.createAudio(assetPath); this._currentTime = 0; this.globalData.audioController.addAudio(this); this.tm = data.tm ? PropertyFactory.getProp(this, data.tm, 0, globalData.frameRate, this) : { _placeholder: true }; } AudioElement.prototype.prepareFrame = function (num) { this.prepareRenderableFrame(num, true); this.prepareProperties(num, true); if (!this.tm._placeholder) { var timeRemapped = this.tm.v; this._currentTime = timeRemapped; } else { this._currentTime = num / this.data.sr; } }; extendPrototype([RenderableElement, BaseElement, FrameElement], AudioElement); AudioElement.prototype.renderFrame = function () { if (this.isInRange && this._canPlay) { if (!this._isPlaying) { this.audio.play(); this.audio.seek(this._currentTime / this.globalData.frameRate); this._isPlaying = true; } else if (!this.audio.playing() || Math.abs(this._currentTime / this.globalData.frameRate - this.audio.seek()) > 0.1 ) { this.audio.seek(this._currentTime / this.globalData.frameRate); } } }; AudioElement.prototype.show = function () { // this.audio.play() }; AudioElement.prototype.hide = function () { this.audio.pause(); this._isPlaying = false; }; AudioElement.prototype.pause = function () { this.audio.pause(); this._isPlaying = false; this._canPlay = false; }; AudioElement.prototype.resume = function () { this._canPlay = true; }; AudioElement.prototype.setRate = function (rateValue) { this.audio.rate(rateValue); }; AudioElement.prototype.volume = function (volumeValue) { this.audio.volume(volumeValue); }; AudioElement.prototype.getBaseElement = function () { return null; }; AudioElement.prototype.destroy = function () { }; AudioElement.prototype.sourceRectAtTime = function () { }; AudioElement.prototype.initExpressions = function () { }; /* global extendPrototype, RenderableElement, BaseElement, FrameElement, FootageInterface */ function FootageElement(data, globalData, comp) { this.initFrame(); this.initRenderable(); this.assetData = globalData.getAssetData(data.refId); this.footageData = globalData.imageLoader.getAsset(this.assetData); this.initBaseData(data, globalData, comp); } FootageElement.prototype.prepareFrame = function () { }; extendPrototype([RenderableElement, BaseElement, FrameElement], FootageElement); FootageElement.prototype.getBaseElement = function () { return null; }; FootageElement.prototype.renderFrame = function () { }; FootageElement.prototype.destroy = function () { }; FootageElement.prototype.initExpressions = function () { this.layerInterface = FootageInterface(this); }; FootageElement.prototype.getFootageData = function () { return this.footageData; }; /* global createSizedArray, PropertyFactory, extendPrototype, SVGRenderer, ICompElement, SVGBaseElement */ function SVGCompElement(data, globalData, comp) { this.layers = data.layers; this.supports3d = true; this.completeLayers = false; this.pendingElements = []; this.elements = this.layers ? createSizedArray(this.layers.length) : []; // this.layerElement = createNS('g'); this.initElement(data, globalData, comp); this.tm = data.tm ? PropertyFactory.getProp(this, data.tm, 0, globalData.frameRate, this) : { _placeholder: true }; } extendPrototype([SVGRenderer, ICompElement, SVGBaseElement], SVGCompElement); /* global extendPrototype, BaseElement, TransformElement, SVGBaseElement, HierarchyElement, FrameElement, RenderableDOMElement, ITextElement, createSizedArray, createNS */ function SVGTextLottieElement(data, globalData, comp) { this.textSpans = []; this.renderType = 'svg'; this.initElement(data, globalData, comp); } extendPrototype([BaseElement, TransformElement, SVGBaseElement, HierarchyElement, FrameElement, RenderableDOMElement, ITextElement], SVGTextLottieElement); SVGTextLottieElement.prototype.createContent = function () { if (this.data.singleShape && !this.globalData.fontManager.chars) { this.textContainer = createNS('text'); } }; SVGTextLottieElement.prototype.buildTextContents = function (textArray) { var i = 0; var len = textArray.length; var textContents = []; var currentTextContent = ''; while (i < len) { if (textArray[i] === String.fromCharCode(13) || textArray[i] === String.fromCharCode(3)) { textContents.push(currentTextContent); currentTextContent = ''; } else { currentTextContent += textArray[i]; } i += 1; } textContents.push(currentTextContent); return textContents; }; SVGTextLottieElement.prototype.buildNewText = function () { var i; var len; var documentData = this.textProperty.currentData; this.renderedLetters = createSizedArray(documentData ? documentData.l.length : 0); if (documentData.fc) { this.layerElement.setAttribute('fill', this.buildColor(documentData.fc)); } else { this.layerElement.setAttribute('fill', 'rgba(0,0,0,0)'); } if (documentData.sc) { this.layerElement.setAttribute('stroke', this.buildColor(documentData.sc)); this.layerElement.setAttribute('stroke-width', documentData.sw); } this.layerElement.setAttribute('font-size', documentData.finalSize); var fontData = this.globalData.fontManager.getFontByName(documentData.f); if (fontData.fClass) { this.layerElement.setAttribute('class', fontData.fClass); } else { this.layerElement.setAttribute('font-family', fontData.fFamily); var fWeight = documentData.fWeight; var fStyle = documentData.fStyle; this.layerElement.setAttribute('font-style', fStyle); this.layerElement.setAttribute('font-weight', fWeight); } this.layerElement.setAttribute('aria-label', documentData.t); var letters = documentData.l || []; var usesGlyphs = !!this.globalData.fontManager.chars; len = letters.length; var tSpan; var matrixHelper = this.mHelper; var shapes; var shapeStr = ''; var singleShape = this.data.singleShape; var xPos = 0; var yPos = 0; var firstLine = true; var trackingOffset = documentData.tr * 0.001 * documentData.finalSize; if (singleShape && !usesGlyphs && !documentData.sz) { var tElement = this.textContainer; var justify = 'start'; switch (documentData.j) { case 1: justify = 'end'; break; case 2: justify = 'middle'; break; default: justify = 'start'; break; } tElement.setAttribute('text-anchor', justify); tElement.setAttribute('letter-spacing', trackingOffset); var textContent = this.buildTextContents(documentData.finalText); len = textContent.length; yPos = documentData.ps ? documentData.ps[1] + documentData.ascent : 0; for (i = 0; i < len; i += 1) { tSpan = this.textSpans[i] || createNS('tspan'); tSpan.textContent = textContent[i]; tSpan.setAttribute('x', 0); tSpan.setAttribute('y', yPos); tSpan.style.display = 'inherit'; tElement.appendChild(tSpan); this.textSpans[i] = tSpan; yPos += documentData.finalLineHeight; } this.layerElement.appendChild(tElement); } else { var cachedSpansLength = this.textSpans.length; var shapeData; var charData; for (i = 0; i < len; i += 1) { if (!usesGlyphs || !singleShape || i === 0) { tSpan = cachedSpansLength > i ? this.textSpans[i] : createNS(usesGlyphs ? 'path' : 'text'); if (cachedSpansLength <= i) { tSpan.setAttribute('stroke-linecap', 'butt'); tSpan.setAttribute('stroke-linejoin', 'round'); tSpan.setAttribute('stroke-miterlimit', '4'); this.textSpans[i] = tSpan; this.layerElement.appendChild(tSpan); } tSpan.style.display = 'inherit'; } matrixHelper.reset(); matrixHelper.scale(documentData.finalSize / 100, documentData.finalSize / 100); if (singleShape) { if (letters[i].n) { xPos = -trackingOffset; yPos += documentData.yOffset; yPos += firstLine ? 1 : 0; firstLine = false; } this.applyTextPropertiesToMatrix(documentData, matrixHelper, letters[i].line, xPos, yPos); xPos += letters[i].l || 0; // xPos += letters[i].val === ' ' ? 0 : trackingOffset; xPos += trackingOffset; } if (usesGlyphs) { charData = this.globalData.fontManager.getCharData(documentData.finalText[i], fontData.fStyle, this.globalData.fontManager.getFontByName(documentData.f).fFamily); shapeData = (charData && charData.data) || {}; shapes = shapeData.shapes ? shapeData.shapes[0].it : []; if (!singleShape) { tSpan.setAttribute('d', this.createPathShape(matrixHelper, shapes)); } else { shapeStr += this.createPathShape(matrixHelper, shapes); } } else { if (singleShape) { tSpan.setAttribute('transform', 'translate(' + matrixHelper.props[12] + ',' + matrixHelper.props[13] + ')'); } tSpan.textContent = letters[i].val; tSpan.setAttributeNS('http://www.w3.org/XML/1998/namespace', 'xml:space', 'preserve'); } // } if (singleShape && tSpan) { tSpan.setAttribute('d', shapeStr); } } while (i < this.textSpans.length) { this.textSpans[i].style.display = 'none'; i += 1; } this._sizeChanged = true; }; SVGTextLottieElement.prototype.sourceRectAtTime = function () { this.prepareFrame(this.comp.renderedFrame - this.data.st); this.renderInnerContent(); if (this._sizeChanged) { this._sizeChanged = false; var textBox = this.layerElement.getBBox(); this.bbox = { top: textBox.y, left: textBox.x, width: textBox.width, height: textBox.height, }; } return this.bbox; }; SVGTextLottieElement.prototype.renderInnerContent = function () { if (!this.data.singleShape) { this.textAnimator.getMeasures(this.textProperty.currentData, this.lettersChangedFlag); if (this.lettersChangedFlag || this.textAnimator.lettersChangedFlag) { this._sizeChanged = true; var i; var len; var renderedLetters = this.textAnimator.renderedLetters; var letters = this.textProperty.currentData.l; len = letters.length; var renderedLetter; var textSpan; for (i = 0; i < len; i += 1) { if (!letters[i].n) { renderedLetter = renderedLetters[i]; textSpan = this.textSpans[i]; if (renderedLetter._mdf.m) { textSpan.setAttribute('transform', renderedLetter.m); } if (renderedLetter._mdf.o) { textSpan.setAttribute('opacity', renderedLetter.o); } if (renderedLetter._mdf.sw) { textSpan.setAttribute('stroke-width', renderedLetter.sw); } if (renderedLetter._mdf.sc) { textSpan.setAttribute('stroke', renderedLetter.sc); } if (renderedLetter._mdf.fc) { textSpan.setAttribute('fill', renderedLetter.fc); } } } } } }; /* global extendPrototype, BaseElement, TransformElement, SVGBaseElement, IShapeElement, HierarchyElement, FrameElement, RenderableDOMElement, Matrix, SVGStyleData, SVGStrokeStyleData, SVGFillStyleData, SVGGradientFillStyleData, SVGGradientStrokeStyleData, locationHref, getBlendMode, ShapeGroupData, TransformPropertyFactory, SVGTransformData, ShapePropertyFactory, SVGShapeData, SVGElementsRenderer, ShapeModifiers, lineCapEnum, lineJoinEnum */ function SVGShapeElement(data, globalData, comp) { // List of drawable elements this.shapes = []; // Full shape data this.shapesData = data.shapes; // List of styles that will be applied to shapes this.stylesList = []; // List of modifiers that will be applied to shapes this.shapeModifiers = []; // List of items in shape tree this.itemsData = []; // List of items in previous shape tree this.processedElements = []; // List of animated components this.animatedContents = []; this.initElement(data, globalData, comp); // Moving any property that doesn't get too much access after initialization because of v8 way of handling more than 10 properties. // List of elements that have been created this.prevViewData = []; // Moving any property that doesn't get too much access after initialization because of v8 way of handling more than 10 properties. } extendPrototype([BaseElement, TransformElement, SVGBaseElement, IShapeElement, HierarchyElement, FrameElement, RenderableDOMElement], SVGShapeElement); SVGShapeElement.prototype.initSecondaryElement = function () { }; SVGShapeElement.prototype.identityMatrix = new Matrix(); SVGShapeElement.prototype.buildExpressionInterface = function () {}; SVGShapeElement.prototype.createContent = function () { this.searchShapes(this.shapesData, this.itemsData, this.prevViewData, this.layerElement, 0, [], true); this.filterUniqueShapes(); }; /* This method searches for multiple shapes that affect a single element and one of them is animated */ SVGShapeElement.prototype.filterUniqueShapes = function () { var i; var len = this.shapes.length; var shape; var j; var jLen = this.stylesList.length; var style; var tempShapes = []; var areAnimated = false; for (j = 0; j < jLen; j += 1) { style = this.stylesList[j]; areAnimated = false; tempShapes.length = 0; for (i = 0; i < len; i += 1) { shape = this.shapes[i]; if (shape.styles.indexOf(style) !== -1) { tempShapes.push(shape); areAnimated = shape._isAnimated || areAnimated; } } if (tempShapes.length > 1 && areAnimated) { this.setShapesAsAnimated(tempShapes); } } }; SVGShapeElement.prototype.setShapesAsAnimated = function (shapes) { var i; var len = shapes.length; for (i = 0; i < len; i += 1) { shapes[i].setAsAnimated(); } }; SVGShapeElement.prototype.createStyleElement = function (data, level) { // TODO: prevent drawing of hidden styles var elementData; var styleOb = new SVGStyleData(data, level); var pathElement = styleOb.pElem; if (data.ty === 'st') { elementData = new SVGStrokeStyleData(this, data, styleOb); } else if (data.ty === 'fl') { elementData = new SVGFillStyleData(this, data, styleOb); } else if (data.ty === 'gf' || data.ty === 'gs') { var GradientConstructor = data.ty === 'gf' ? SVGGradientFillStyleData : SVGGradientStrokeStyleData; elementData = new GradientConstructor(this, data, styleOb); this.globalData.defs.appendChild(elementData.gf); if (elementData.maskId) { this.globalData.defs.appendChild(elementData.ms); this.globalData.defs.appendChild(elementData.of); pathElement.setAttribute('mask', 'url(' + locationHref + '#' + elementData.maskId + ')'); } } if (data.ty === 'st' || data.ty === 'gs') { pathElement.setAttribute('stroke-linecap', lineCapEnum[data.lc || 2]); pathElement.setAttribute('stroke-linejoin', lineJoinEnum[data.lj || 2]); pathElement.setAttribute('fill-opacity', '0'); if (data.lj === 1) { pathElement.setAttribute('stroke-miterlimit', data.ml); } } if (data.r === 2) { pathElement.setAttribute('fill-rule', 'evenodd'); } if (data.ln) { pathElement.setAttribute('id', data.ln); } if (data.cl) { pathElement.setAttribute('class', data.cl); } if (data.bm) { pathElement.style['mix-blend-mode'] = getBlendMode(data.bm); } this.stylesList.push(styleOb); this.addToAnimatedContents(data, elementData); return elementData; }; SVGShapeElement.prototype.createGroupElement = function (data) { var elementData = new ShapeGroupData(); if (data.ln) { elementData.gr.setAttribute('id', data.ln); } if (data.cl) { elementData.gr.setAttribute('class', data.cl); } if (data.bm) { elementData.gr.style['mix-blend-mode'] = getBlendMode(data.bm); } return elementData; }; SVGShapeElement.prototype.createTransformElement = function (data, container) { var transformProperty = TransformPropertyFactory.getTransformProperty(this, data, this); var elementData = new SVGTransformData(transformProperty, transformProperty.o, container); this.addToAnimatedContents(data, elementData); return elementData; }; SVGShapeElement.prototype.createShapeElement = function (data, ownTransformers, level) { var ty = 4; if (data.ty === 'rc') { ty = 5; } else if (data.ty === 'el') { ty = 6; } else if (data.ty === 'sr') { ty = 7; } var shapeProperty = ShapePropertyFactory.getShapeProp(this, data, ty, this); var elementData = new SVGShapeData(ownTransformers, level, shapeProperty); this.shapes.push(elementData); this.addShapeToModifiers(elementData); this.addToAnimatedContents(data, elementData); return elementData; }; SVGShapeElement.prototype.addToAnimatedContents = function (data, element) { var i = 0; var len = this.animatedContents.length; while (i < len) { if (this.animatedContents[i].element === element) { return; } i += 1; } this.animatedContents.push({ fn: SVGElementsRenderer.createRenderFunction(data), element: element, data: data, }); }; SVGShapeElement.prototype.setElementStyles = function (elementData) { var arr = elementData.styles; var j; var jLen = this.stylesList.length; for (j = 0; j < jLen; j += 1) { if (!this.stylesList[j].closed) { arr.push(this.stylesList[j]); } } }; SVGShapeElement.prototype.reloadShapes = function () { this._isFirstFrame = true; var i; var len = this.itemsData.length; for (i = 0; i < len; i += 1) { this.prevViewData[i] = this.itemsData[i]; } this.searchShapes(this.shapesData, this.itemsData, this.prevViewData, this.layerElement, 0, [], true); this.filterUniqueShapes(); len = this.dynamicProperties.length; for (i = 0; i < len; i += 1) { this.dynamicProperties[i].getValue(); } this.renderModifiers(); }; SVGShapeElement.prototype.searchShapes = function (arr, itemsData, prevViewData, container, level, transformers, render) { var ownTransformers = [].concat(transformers); var i; var len = arr.length - 1; var j; var jLen; var ownStyles = []; var ownModifiers = []; var currentTransform; var modifier; var processedPos; for (i = len; i >= 0; i -= 1) { processedPos = this.searchProcessedElement(arr[i]); if (!processedPos) { arr[i]._render = render; } else { itemsData[i] = prevViewData[processedPos - 1]; } if (arr[i].ty === 'fl' || arr[i].ty === 'st' || arr[i].ty === 'gf' || arr[i].ty === 'gs') { if (!processedPos) { itemsData[i] = this.createStyleElement(arr[i], level); } else { itemsData[i].style.closed = false; } if (arr[i]._render) { if (itemsData[i].style.pElem.parentNode !== container) { container.appendChild(itemsData[i].style.pElem); } } ownStyles.push(itemsData[i].style); } else if (arr[i].ty === 'gr') { if (!processedPos) { itemsData[i] = this.createGroupElement(arr[i]); } else { jLen = itemsData[i].it.length; for (j = 0; j < jLen; j += 1) { itemsData[i].prevViewData[j] = itemsData[i].it[j]; } } this.searchShapes(arr[i].it, itemsData[i].it, itemsData[i].prevViewData, itemsData[i].gr, level + 1, ownTransformers, render); if (arr[i]._render) { if (itemsData[i].gr.parentNode !== container) { container.appendChild(itemsData[i].gr); } } } else if (arr[i].ty === 'tr') { if (!processedPos) { itemsData[i] = this.createTransformElement(arr[i], container); } currentTransform = itemsData[i].transform; ownTransformers.push(currentTransform); } else if (arr[i].ty === 'sh' || arr[i].ty === 'rc' || arr[i].ty === 'el' || arr[i].ty === 'sr') { if (!processedPos) { itemsData[i] = this.createShapeElement(arr[i], ownTransformers, level); } this.setElementStyles(itemsData[i]); } else if (arr[i].ty === 'tm' || arr[i].ty === 'rd' || arr[i].ty === 'ms' || arr[i].ty === 'pb') { if (!processedPos) { modifier = ShapeModifiers.getModifier(arr[i].ty); modifier.init(this, arr[i]); itemsData[i] = modifier; this.shapeModifiers.push(modifier); } else { modifier = itemsData[i]; modifier.closed = false; } ownModifiers.push(modifier); } else if (arr[i].ty === 'rp') { if (!processedPos) { modifier = ShapeModifiers.getModifier(arr[i].ty); itemsData[i] = modifier; modifier.init(this, arr, i, itemsData); this.shapeModifiers.push(modifier); render = false; } else { modifier = itemsData[i]; modifier.closed = true; } ownModifiers.push(modifier); } this.addProcessedElement(arr[i], i + 1); } len = ownStyles.length; for (i = 0; i < len; i += 1) { ownStyles[i].closed = true; } len = ownModifiers.length; for (i = 0; i < len; i += 1) { ownModifiers[i].closed = true; } }; SVGShapeElement.prototype.renderInnerContent = function () { this.renderModifiers(); var i; var len = this.stylesList.length; for (i = 0; i < len; i += 1) { this.stylesList[i].reset(); } this.renderShape(); for (i = 0; i < len; i += 1) { if (this.stylesList[i]._mdf || this._isFirstFrame) { if (this.stylesList[i].msElem) { this.stylesList[i].msElem.setAttribute('d', this.stylesList[i].d); // Adding M0 0 fixes same mask bug on all browsers this.stylesList[i].d = 'M0 0' + this.stylesList[i].d; } this.stylesList[i].pElem.setAttribute('d', this.stylesList[i].d || 'M0 0'); } } }; SVGShapeElement.prototype.renderShape = function () { var i; var len = this.animatedContents.length; var animatedContent; for (i = 0; i < len; i += 1) { animatedContent = this.animatedContents[i]; if ((this._isFirstFrame || animatedContent.element._isAnimated) && animatedContent.data !== true) { animatedContent.fn(animatedContent.data, animatedContent.element, this._isFirstFrame); } } }; SVGShapeElement.prototype.destroy = function () { this.destroyBaseElement(); this.shapesData = null; this.itemsData = null; }; /* global createNS */ function SVGTintFilter(filter, filterManager) { this.filterManager = filterManager; var feColorMatrix = createNS('feColorMatrix'); feColorMatrix.setAttribute('type', 'matrix'); feColorMatrix.setAttribute('color-interpolation-filters', 'linearRGB'); feColorMatrix.setAttribute('values', '0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0'); feColorMatrix.setAttribute('result', 'f1'); filter.appendChild(feColorMatrix); feColorMatrix = createNS('feColorMatrix'); feColorMatrix.setAttribute('type', 'matrix'); feColorMatrix.setAttribute('color-interpolation-filters', 'sRGB'); feColorMatrix.setAttribute('values', '1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1 0'); feColorMatrix.setAttribute('result', 'f2'); filter.appendChild(feColorMatrix); this.matrixFilter = feColorMatrix; if (filterManager.effectElements[2].p.v !== 100 || filterManager.effectElements[2].p.k) { var feMerge = createNS('feMerge'); filter.appendChild(feMerge); var feMergeNode; feMergeNode = createNS('feMergeNode'); feMergeNode.setAttribute('in', 'SourceGraphic'); feMerge.appendChild(feMergeNode); feMergeNode = createNS('feMergeNode'); feMergeNode.setAttribute('in', 'f2'); feMerge.appendChild(feMergeNode); } } SVGTintFilter.prototype.renderFrame = function (forceRender) { if (forceRender || this.filterManager._mdf) { var colorBlack = this.filterManager.effectElements[0].p.v; var colorWhite = this.filterManager.effectElements[1].p.v; var opacity = this.filterManager.effectElements[2].p.v / 100; this.matrixFilter.setAttribute('values', (colorWhite[0] - colorBlack[0]) + ' 0 0 0 ' + colorBlack[0] + ' ' + (colorWhite[1] - colorBlack[1]) + ' 0 0 0 ' + colorBlack[1] + ' ' + (colorWhite[2] - colorBlack[2]) + ' 0 0 0 ' + colorBlack[2] + ' 0 0 0 ' + opacity + ' 0'); } }; /* global createNS */ function SVGFillFilter(filter, filterManager) { this.filterManager = filterManager; var feColorMatrix = createNS('feColorMatrix'); feColorMatrix.setAttribute('type', 'matrix'); feColorMatrix.setAttribute('color-interpolation-filters', 'sRGB'); feColorMatrix.setAttribute('values', '1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1 0'); filter.appendChild(feColorMatrix); this.matrixFilter = feColorMatrix; } SVGFillFilter.prototype.renderFrame = function (forceRender) { if (forceRender || this.filterManager._mdf) { var color = this.filterManager.effectElements[2].p.v; var opacity = this.filterManager.effectElements[6].p.v; this.matrixFilter.setAttribute('values', '0 0 0 0 ' + color[0] + ' 0 0 0 0 ' + color[1] + ' 0 0 0 0 ' + color[2] + ' 0 0 0 ' + opacity + ' 0'); } }; /* global createNS */ function SVGGaussianBlurEffect(filter, filterManager) { // Outset the filter region by 100% on all sides to accommodate blur expansion. filter.setAttribute('x', '-100%'); filter.setAttribute('y', '-100%'); filter.setAttribute('width', '300%'); filter.setAttribute('height', '300%'); this.filterManager = filterManager; var feGaussianBlur = createNS('feGaussianBlur'); filter.appendChild(feGaussianBlur); this.feGaussianBlur = feGaussianBlur; } SVGGaussianBlurEffect.prototype.renderFrame = function (forceRender) { if (forceRender || this.filterManager._mdf) { // Empirical value, matching AE's blur appearance. var kBlurrinessToSigma = 0.3; var sigma = this.filterManager.effectElements[0].p.v * kBlurrinessToSigma; // Dimensions mapping: // // 1 -> horizontal & vertical // 2 -> horizontal only // 3 -> vertical only // var dimensions = this.filterManager.effectElements[1].p.v; var sigmaX = (dimensions == 3) ? 0 : sigma; // eslint-disable-line eqeqeq var sigmaY = (dimensions == 2) ? 0 : sigma; // eslint-disable-line eqeqeq this.feGaussianBlur.setAttribute('stdDeviation', sigmaX + ' ' + sigmaY); // Repeat edges mapping: // // 0 -> off -> duplicate // 1 -> on -> wrap var edgeMode = (this.filterManager.effectElements[2].p.v == 1) ? 'wrap' : 'duplicate'; // eslint-disable-line eqeqeq this.feGaussianBlur.setAttribute('edgeMode', edgeMode); } }; /* global createNS, createElementID, locationHref, bmFloor */ function SVGStrokeEffect(elem, filterManager) { this.initialized = false; this.filterManager = filterManager; this.elem = elem; this.paths = []; } SVGStrokeEffect.prototype.initialize = function () { var elemChildren = this.elem.layerElement.children || this.elem.layerElement.childNodes; var path; var groupPath; var i; var len; if (this.filterManager.effectElements[1].p.v === 1) { len = this.elem.maskManager.masksProperties.length; i = 0; } else { i = this.filterManager.effectElements[0].p.v - 1; len = i + 1; } groupPath = createNS('g'); groupPath.setAttribute('fill', 'none'); groupPath.setAttribute('stroke-linecap', 'round'); groupPath.setAttribute('stroke-dashoffset', 1); for (i; i < len; i += 1) { path = createNS('path'); groupPath.appendChild(path); this.paths.push({ p: path, m: i }); } if (this.filterManager.effectElements[10].p.v === 3) { var mask = createNS('mask'); var id = createElementID(); mask.setAttribute('id', id); mask.setAttribute('mask-type', 'alpha'); mask.appendChild(groupPath); this.elem.globalData.defs.appendChild(mask); var g = createNS('g'); g.setAttribute('mask', 'url(' + locationHref + '#' + id + ')'); while (elemChildren[0]) { g.appendChild(elemChildren[0]); } this.elem.layerElement.appendChild(g); this.masker = mask; groupPath.setAttribute('stroke', '#fff'); } else if (this.filterManager.effectElements[10].p.v === 1 || this.filterManager.effectElements[10].p.v === 2) { if (this.filterManager.effectElements[10].p.v === 2) { elemChildren = this.elem.layerElement.children || this.elem.layerElement.childNodes; while (elemChildren.length) { this.elem.layerElement.removeChild(elemChildren[0]); } } this.elem.layerElement.appendChild(groupPath); this.elem.layerElement.removeAttribute('mask'); groupPath.setAttribute('stroke', '#fff'); } this.initialized = true; this.pathMasker = groupPath; }; SVGStrokeEffect.prototype.renderFrame = function (forceRender) { if (!this.initialized) { this.initialize(); } var i; var len = this.paths.length; var mask; var path; for (i = 0; i < len; i += 1) { if (this.paths[i].m !== -1) { mask = this.elem.maskManager.viewData[this.paths[i].m]; path = this.paths[i].p; if (forceRender || this.filterManager._mdf || mask.prop._mdf) { path.setAttribute('d', mask.lastPath); } if (forceRender || this.filterManager.effectElements[9].p._mdf || this.filterManager.effectElements[4].p._mdf || this.filterManager.effectElements[7].p._mdf || this.filterManager.effectElements[8].p._mdf || mask.prop._mdf) { var dasharrayValue; if (this.filterManager.effectElements[7].p.v !== 0 || this.filterManager.effectElements[8].p.v !== 100) { var s = Math.min(this.filterManager.effectElements[7].p.v, this.filterManager.effectElements[8].p.v) * 0.01; var e = Math.max(this.filterManager.effectElements[7].p.v, this.filterManager.effectElements[8].p.v) * 0.01; var l = path.getTotalLength(); dasharrayValue = '0 0 0 ' + l * s + ' '; var lineLength = l * (e - s); var segment = 1 + this.filterManager.effectElements[4].p.v * 2 * this.filterManager.effectElements[9].p.v * 0.01; var units = Math.floor(lineLength / segment); var j; for (j = 0; j < units; j += 1) { dasharrayValue += '1 ' + this.filterManager.effectElements[4].p.v * 2 * this.filterManager.effectElements[9].p.v * 0.01 + ' '; } dasharrayValue += '0 ' + l * 10 + ' 0 0'; } else { dasharrayValue = '1 ' + this.filterManager.effectElements[4].p.v * 2 * this.filterManager.effectElements[9].p.v * 0.01; } path.setAttribute('stroke-dasharray', dasharrayValue); } } } if (forceRender || this.filterManager.effectElements[4].p._mdf) { this.pathMasker.setAttribute('stroke-width', this.filterManager.effectElements[4].p.v * 2); } if (forceRender || this.filterManager.effectElements[6].p._mdf) { this.pathMasker.setAttribute('opacity', this.filterManager.effectElements[6].p.v); } if (this.filterManager.effectElements[10].p.v === 1 || this.filterManager.effectElements[10].p.v === 2) { if (forceRender || this.filterManager.effectElements[3].p._mdf) { var color = this.filterManager.effectElements[3].p.v; this.pathMasker.setAttribute('stroke', 'rgb(' + bmFloor(color[0] * 255) + ',' + bmFloor(color[1] * 255) + ',' + bmFloor(color[2] * 255) + ')'); } } }; /* global createNS */ function SVGTritoneFilter(filter, filterManager) { this.filterManager = filterManager; var feColorMatrix = createNS('feColorMatrix'); feColorMatrix.setAttribute('type', 'matrix'); feColorMatrix.setAttribute('color-interpolation-filters', 'linearRGB'); feColorMatrix.setAttribute('values', '0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0'); feColorMatrix.setAttribute('result', 'f1'); filter.appendChild(feColorMatrix); var feComponentTransfer = createNS('feComponentTransfer'); feComponentTransfer.setAttribute('color-interpolation-filters', 'sRGB'); filter.appendChild(feComponentTransfer); this.matrixFilter = feComponentTransfer; var feFuncR = createNS('feFuncR'); feFuncR.setAttribute('type', 'table'); feComponentTransfer.appendChild(feFuncR); this.feFuncR = feFuncR; var feFuncG = createNS('feFuncG'); feFuncG.setAttribute('type', 'table'); feComponentTransfer.appendChild(feFuncG); this.feFuncG = feFuncG; var feFuncB = createNS('feFuncB'); feFuncB.setAttribute('type', 'table'); feComponentTransfer.appendChild(feFuncB); this.feFuncB = feFuncB; } SVGTritoneFilter.prototype.renderFrame = function (forceRender) { if (forceRender || this.filterManager._mdf) { var color1 = this.filterManager.effectElements[0].p.v; var color2 = this.filterManager.effectElements[1].p.v; var color3 = this.filterManager.effectElements[2].p.v; var tableR = color3[0] + ' ' + color2[0] + ' ' + color1[0]; var tableG = color3[1] + ' ' + color2[1] + ' ' + color1[1]; var tableB = color3[2] + ' ' + color2[2] + ' ' + color1[2]; this.feFuncR.setAttribute('tableValues', tableR); this.feFuncG.setAttribute('tableValues', tableG); this.feFuncB.setAttribute('tableValues', tableB); // var opacity = this.filterManager.effectElements[2].p.v/100; // this.matrixFilter.setAttribute('values',(colorWhite[0]- colorBlack[0])+' 0 0 0 '+ colorBlack[0] +' '+ (colorWhite[1]- colorBlack[1]) +' 0 0 0 '+ colorBlack[1] +' '+ (colorWhite[2]- colorBlack[2]) +' 0 0 0 '+ colorBlack[2] +' 0 0 0 ' + opacity + ' 0'); } }; /* global createNS */ function SVGProLevelsFilter(filter, filterManager) { this.filterManager = filterManager; var effectElements = this.filterManager.effectElements; var feComponentTransfer = createNS('feComponentTransfer'); if (effectElements[10].p.k || effectElements[10].p.v !== 0 || effectElements[11].p.k || effectElements[11].p.v !== 1 || effectElements[12].p.k || effectElements[12].p.v !== 1 || effectElements[13].p.k || effectElements[13].p.v !== 0 || effectElements[14].p.k || effectElements[14].p.v !== 1) { this.feFuncR = this.createFeFunc('feFuncR', feComponentTransfer); } if (effectElements[17].p.k || effectElements[17].p.v !== 0 || effectElements[18].p.k || effectElements[18].p.v !== 1 || effectElements[19].p.k || effectElements[19].p.v !== 1 || effectElements[20].p.k || effectElements[20].p.v !== 0 || effectElements[21].p.k || effectElements[21].p.v !== 1) { this.feFuncG = this.createFeFunc('feFuncG', feComponentTransfer); } if (effectElements[24].p.k || effectElements[24].p.v !== 0 || effectElements[25].p.k || effectElements[25].p.v !== 1 || effectElements[26].p.k || effectElements[26].p.v !== 1 || effectElements[27].p.k || effectElements[27].p.v !== 0 || effectElements[28].p.k || effectElements[28].p.v !== 1) { this.feFuncB = this.createFeFunc('feFuncB', feComponentTransfer); } if (effectElements[31].p.k || effectElements[31].p.v !== 0 || effectElements[32].p.k || effectElements[32].p.v !== 1 || effectElements[33].p.k || effectElements[33].p.v !== 1 || effectElements[34].p.k || effectElements[34].p.v !== 0 || effectElements[35].p.k || effectElements[35].p.v !== 1) { this.feFuncA = this.createFeFunc('feFuncA', feComponentTransfer); } if (this.feFuncR || this.feFuncG || this.feFuncB || this.feFuncA) { feComponentTransfer.setAttribute('color-interpolation-filters', 'sRGB'); filter.appendChild(feComponentTransfer); feComponentTransfer = createNS('feComponentTransfer'); } if (effectElements[3].p.k || effectElements[3].p.v !== 0 || effectElements[4].p.k || effectElements[4].p.v !== 1 || effectElements[5].p.k || effectElements[5].p.v !== 1 || effectElements[6].p.k || effectElements[6].p.v !== 0 || effectElements[7].p.k || effectElements[7].p.v !== 1) { feComponentTransfer.setAttribute('color-interpolation-filters', 'sRGB'); filter.appendChild(feComponentTransfer); this.feFuncRComposed = this.createFeFunc('feFuncR', feComponentTransfer); this.feFuncGComposed = this.createFeFunc('feFuncG', feComponentTransfer); this.feFuncBComposed = this.createFeFunc('feFuncB', feComponentTransfer); } } SVGProLevelsFilter.prototype.createFeFunc = function (type, feComponentTransfer) { var feFunc = createNS(type); feFunc.setAttribute('type', 'table'); feComponentTransfer.appendChild(feFunc); return feFunc; }; SVGProLevelsFilter.prototype.getTableValue = function (inputBlack, inputWhite, gamma, outputBlack, outputWhite) { var cnt = 0; var segments = 256; var perc; var min = Math.min(inputBlack, inputWhite); var max = Math.max(inputBlack, inputWhite); var table = Array.call(null, { length: segments }); var colorValue; var pos = 0; var outputDelta = outputWhite - outputBlack; var inputDelta = inputWhite - inputBlack; while (cnt <= 256) { perc = cnt / 256; if (perc <= min) { colorValue = inputDelta < 0 ? outputWhite : outputBlack; } else if (perc >= max) { colorValue = inputDelta < 0 ? outputBlack : outputWhite; } else { colorValue = (outputBlack + outputDelta * Math.pow((perc - inputBlack) / inputDelta, 1 / gamma)); } table[pos] = colorValue; pos += 1; cnt += 256 / (segments - 1); } return table.join(' '); }; SVGProLevelsFilter.prototype.renderFrame = function (forceRender) { if (forceRender || this.filterManager._mdf) { var val; var effectElements = this.filterManager.effectElements; if (this.feFuncRComposed && (forceRender || effectElements[3].p._mdf || effectElements[4].p._mdf || effectElements[5].p._mdf || effectElements[6].p._mdf || effectElements[7].p._mdf)) { val = this.getTableValue(effectElements[3].p.v, effectElements[4].p.v, effectElements[5].p.v, effectElements[6].p.v, effectElements[7].p.v); this.feFuncRComposed.setAttribute('tableValues', val); this.feFuncGComposed.setAttribute('tableValues', val); this.feFuncBComposed.setAttribute('tableValues', val); } if (this.feFuncR && (forceRender || effectElements[10].p._mdf || effectElements[11].p._mdf || effectElements[12].p._mdf || effectElements[13].p._mdf || effectElements[14].p._mdf)) { val = this.getTableValue(effectElements[10].p.v, effectElements[11].p.v, effectElements[12].p.v, effectElements[13].p.v, effectElements[14].p.v); this.feFuncR.setAttribute('tableValues', val); } if (this.feFuncG && (forceRender || effectElements[17].p._mdf || effectElements[18].p._mdf || effectElements[19].p._mdf || effectElements[20].p._mdf || effectElements[21].p._mdf)) { val = this.getTableValue(effectElements[17].p.v, effectElements[18].p.v, effectElements[19].p.v, effectElements[20].p.v, effectElements[21].p.v); this.feFuncG.setAttribute('tableValues', val); } if (this.feFuncB && (forceRender || effectElements[24].p._mdf || effectElements[25].p._mdf || effectElements[26].p._mdf || effectElements[27].p._mdf || effectElements[28].p._mdf)) { val = this.getTableValue(effectElements[24].p.v, effectElements[25].p.v, effectElements[26].p.v, effectElements[27].p.v, effectElements[28].p.v); this.feFuncB.setAttribute('tableValues', val); } if (this.feFuncA && (forceRender || effectElements[31].p._mdf || effectElements[32].p._mdf || effectElements[33].p._mdf || effectElements[34].p._mdf || effectElements[35].p._mdf)) { val = this.getTableValue(effectElements[31].p.v, effectElements[32].p.v, effectElements[33].p.v, effectElements[34].p.v, effectElements[35].p.v); this.feFuncA.setAttribute('tableValues', val); } } }; /* global createNS, rgbToHex, degToRads */ function SVGDropShadowEffect(filter, filterManager) { var filterSize = filterManager.container.globalData.renderConfig.filterSize; filter.setAttribute('x', filterSize.x); filter.setAttribute('y', filterSize.y); filter.setAttribute('width', filterSize.width); filter.setAttribute('height', filterSize.height); this.filterManager = filterManager; var feGaussianBlur = createNS('feGaussianBlur'); feGaussianBlur.setAttribute('in', 'SourceAlpha'); feGaussianBlur.setAttribute('result', 'drop_shadow_1'); feGaussianBlur.setAttribute('stdDeviation', '0'); this.feGaussianBlur = feGaussianBlur; filter.appendChild(feGaussianBlur); var feOffset = createNS('feOffset'); feOffset.setAttribute('dx', '25'); feOffset.setAttribute('dy', '0'); feOffset.setAttribute('in', 'drop_shadow_1'); feOffset.setAttribute('result', 'drop_shadow_2'); this.feOffset = feOffset; filter.appendChild(feOffset); var feFlood = createNS('feFlood'); feFlood.setAttribute('flood-color', '#00ff00'); feFlood.setAttribute('flood-opacity', '1'); feFlood.setAttribute('result', 'drop_shadow_3'); this.feFlood = feFlood; filter.appendChild(feFlood); var feComposite = createNS('feComposite'); feComposite.setAttribute('in', 'drop_shadow_3'); feComposite.setAttribute('in2', 'drop_shadow_2'); feComposite.setAttribute('operator', 'in'); feComposite.setAttribute('result', 'drop_shadow_4'); filter.appendChild(feComposite); var feMerge = createNS('feMerge'); filter.appendChild(feMerge); var feMergeNode; feMergeNode = createNS('feMergeNode'); feMerge.appendChild(feMergeNode); feMergeNode = createNS('feMergeNode'); feMergeNode.setAttribute('in', 'SourceGraphic'); this.feMergeNode = feMergeNode; this.feMerge = feMerge; this.originalNodeAdded = false; feMerge.appendChild(feMergeNode); } SVGDropShadowEffect.prototype.renderFrame = function (forceRender) { if (forceRender || this.filterManager._mdf) { if (forceRender || this.filterManager.effectElements[4].p._mdf) { this.feGaussianBlur.setAttribute('stdDeviation', this.filterManager.effectElements[4].p.v / 4); } if (forceRender || this.filterManager.effectElements[0].p._mdf) { var col = this.filterManager.effectElements[0].p.v; this.feFlood.setAttribute('flood-color', rgbToHex(Math.round(col[0] * 255), Math.round(col[1] * 255), Math.round(col[2] * 255))); } if (forceRender || this.filterManager.effectElements[1].p._mdf) { this.feFlood.setAttribute('flood-opacity', this.filterManager.effectElements[1].p.v / 255); } if (forceRender || this.filterManager.effectElements[2].p._mdf || this.filterManager.effectElements[3].p._mdf) { var distance = this.filterManager.effectElements[3].p.v; var angle = (this.filterManager.effectElements[2].p.v - 90) * degToRads; var x = distance * Math.cos(angle); var y = distance * Math.sin(angle); this.feOffset.setAttribute('dx', x); this.feOffset.setAttribute('dy', y); } /* if(forceRender || this.filterManager.effectElements[5].p._mdf){ if(this.filterManager.effectElements[5].p.v === 1 && this.originalNodeAdded) { this.feMerge.removeChild(this.feMergeNode); this.originalNodeAdded = false; } else if(this.filterManager.effectElements[5].p.v === 0 && !this.originalNodeAdded) { this.feMerge.appendChild(this.feMergeNode); this.originalNodeAdded = true; } } */ } }; /* global createElementID, createNS */ var _svgMatteSymbols = []; function SVGMatte3Effect(filterElem, filterManager, elem) { this.initialized = false; this.filterManager = filterManager; this.filterElem = filterElem; this.elem = elem; elem.matteElement = createNS('g'); elem.matteElement.appendChild(elem.layerElement); elem.matteElement.appendChild(elem.transformedElement); elem.baseElement = elem.matteElement; } SVGMatte3Effect.prototype.findSymbol = function (mask) { var i = 0; var len = _svgMatteSymbols.length; while (i < len) { if (_svgMatteSymbols[i] === mask) { return _svgMatteSymbols[i]; } i += 1; } return null; }; SVGMatte3Effect.prototype.replaceInParent = function (mask, symbolId) { var parentNode = mask.layerElement.parentNode; if (!parentNode) { return; } var children = parentNode.children; var i = 0; var len = children.length; while (i < len) { if (children[i] === mask.layerElement) { break; } i += 1; } var nextChild; if (i <= len - 2) { nextChild = children[i + 1]; } var useElem = createNS('use'); useElem.setAttribute('href', '#' + symbolId); if (nextChild) { parentNode.insertBefore(useElem, nextChild); } else { parentNode.appendChild(useElem); } }; SVGMatte3Effect.prototype.setElementAsMask = function (elem, mask) { if (!this.findSymbol(mask)) { var symbolId = createElementID(); var masker = createNS('mask'); masker.setAttribute('id', mask.layerId); masker.setAttribute('mask-type', 'alpha'); _svgMatteSymbols.push(mask); var defs = elem.globalData.defs; defs.appendChild(masker); var symbol = createNS('symbol'); symbol.setAttribute('id', symbolId); this.replaceInParent(mask, symbolId); symbol.appendChild(mask.layerElement); defs.appendChild(symbol); var useElem = createNS('use'); useElem.setAttribute('href', '#' + symbolId); masker.appendChild(useElem); mask.data.hd = false; mask.show(); } elem.setMatte(mask.layerId); }; SVGMatte3Effect.prototype.initialize = function () { var ind = this.filterManager.effectElements[0].p.v; var elements = this.elem.comp.elements; var i = 0; var len = elements.length; while (i < len) { if (elements[i] && elements[i].data.ind === ind) { this.setElementAsMask(this.elem, elements[i]); } i += 1; } this.initialized = true; }; SVGMatte3Effect.prototype.renderFrame = function () { if (!this.initialized) { this.initialize(); } }; /* global createElementID, filtersFactory, SVGTintFilter, SVGFillFilter, SVGStrokeEffect, SVGTritoneFilter, SVGProLevelsFilter, SVGDropShadowEffect, SVGMatte3Effect, SVGGaussianBlurEffect, locationHref */ function SVGEffects(elem) { var i; var len = elem.data.ef ? elem.data.ef.length : 0; var filId = createElementID(); var fil = filtersFactory.createFilter(filId, true); var count = 0; this.filters = []; var filterManager; for (i = 0; i < len; i += 1) { filterManager = null; if (elem.data.ef[i].ty === 20) { count += 1; filterManager = new SVGTintFilter(fil, elem.effectsManager.effectElements[i]); } else if (elem.data.ef[i].ty === 21) { count += 1; filterManager = new SVGFillFilter(fil, elem.effectsManager.effectElements[i]); } else if (elem.data.ef[i].ty === 22) { filterManager = new SVGStrokeEffect(elem, elem.effectsManager.effectElements[i]); } else if (elem.data.ef[i].ty === 23) { count += 1; filterManager = new SVGTritoneFilter(fil, elem.effectsManager.effectElements[i]); } else if (elem.data.ef[i].ty === 24) { count += 1; filterManager = new SVGProLevelsFilter(fil, elem.effectsManager.effectElements[i]); } else if (elem.data.ef[i].ty === 25) { count += 1; filterManager = new SVGDropShadowEffect(fil, elem.effectsManager.effectElements[i]); } else if (elem.data.ef[i].ty === 28) { // count += 1; filterManager = new SVGMatte3Effect(fil, elem.effectsManager.effectElements[i], elem); } else if (elem.data.ef[i].ty === 29) { count += 1; filterManager = new SVGGaussianBlurEffect(fil, elem.effectsManager.effectElements[i]); } if (filterManager) { this.filters.push(filterManager); } } if (count) { elem.globalData.defs.appendChild(fil); elem.layerElement.setAttribute('filter', 'url(' + locationHref + '#' + filId + ')'); } if (this.filters.length) { elem.addRenderableComponent(this); } } SVGEffects.prototype.renderFrame = function (_isFirstFrame) { var i; var len = this.filters.length; for (i = 0; i < len; i += 1) { this.filters[i].renderFrame(_isFirstFrame); } }; /* global Matrix, createTypedArray */ function CVContextData() { this.saved = []; this.cArrPos = 0; this.cTr = new Matrix(); this.cO = 1; var i; var len = 15; this.savedOp = createTypedArray('float32', len); for (i = 0; i < len; i += 1) { this.saved[i] = createTypedArray('float32', 16); } this._length = len; } CVContextData.prototype.duplicate = function () { var newLength = this._length * 2; var currentSavedOp = this.savedOp; this.savedOp = createTypedArray('float32', newLength); this.savedOp.set(currentSavedOp); var i = 0; for (i = this._length; i < newLength; i += 1) { this.saved[i] = createTypedArray('float32', 16); } this._length = newLength; }; CVContextData.prototype.reset = function () { this.cArrPos = 0; this.cTr.reset(); this.cO = 1; }; /* global CVEffects, getBlendMode, CVMaskElement, Matrix */ function CVBaseElement() { } CVBaseElement.prototype = { createElements: function () {}, initRendererElement: function () {}, createContainerElements: function () { this.canvasContext = this.globalData.canvasContext; this.renderableEffectsManager = new CVEffects(this); }, createContent: function () {}, setBlendMode: function () { var globalData = this.globalData; if (globalData.blendMode !== this.data.bm) { globalData.blendMode = this.data.bm; var blendModeValue = getBlendMode(this.data.bm); globalData.canvasContext.globalCompositeOperation = blendModeValue; } }, createRenderableComponents: function () { this.maskManager = new CVMaskElement(this.data, this); }, hideElement: function () { if (!this.hidden && (!this.isInRange || this.isTransparent)) { this.hidden = true; } }, showElement: function () { if (this.isInRange && !this.isTransparent) { this.hidden = false; this._isFirstFrame = true; this.maskManager._isFirstFrame = true; } }, renderFrame: function () { if (this.hidden || this.data.hd) { return; } this.renderTransform(); this.renderRenderable(); this.setBlendMode(); var forceRealStack = this.data.ty === 0; this.globalData.renderer.save(forceRealStack); this.globalData.renderer.ctxTransform(this.finalTransform.mat.props); this.globalData.renderer.ctxOpacity(this.finalTransform.mProp.o.v); this.renderInnerContent(); this.globalData.renderer.restore(forceRealStack); if (this.maskManager.hasMasks) { this.globalData.renderer.restore(true); } if (this._isFirstFrame) { this._isFirstFrame = false; } }, destroy: function () { this.canvasContext = null; this.data = null; this.globalData = null; this.maskManager.destroy(); }, mHelper: new Matrix(), }; CVBaseElement.prototype.hide = CVBaseElement.prototype.hideElement; CVBaseElement.prototype.show = CVBaseElement.prototype.showElement; /* global extendPrototype, BaseElement, TransformElement, CVBaseElement,HierarchyElement, FrameElement, RenderableElement, SVGShapeElement, IImageElement, createTag */ function CVImageElement(data, globalData, comp) { this.assetData = globalData.getAssetData(data.refId); this.img = globalData.imageLoader.getAsset(this.assetData); this.initElement(data, globalData, comp); } extendPrototype([BaseElement, TransformElement, CVBaseElement, HierarchyElement, FrameElement, RenderableElement], CVImageElement); CVImageElement.prototype.initElement = SVGShapeElement.prototype.initElement; CVImageElement.prototype.prepareFrame = IImageElement.prototype.prepareFrame; CVImageElement.prototype.createContent = function () { if (this.img.width && (this.assetData.w !== this.img.width || this.assetData.h !== this.img.height)) { var canvas = createTag('canvas'); canvas.width = this.assetData.w; canvas.height = this.assetData.h; var ctx = canvas.getContext('2d'); var imgW = this.img.width; var imgH = this.img.height; var imgRel = imgW / imgH; var canvasRel = this.assetData.w / this.assetData.h; var widthCrop; var heightCrop; var par = this.assetData.pr || this.globalData.renderConfig.imagePreserveAspectRatio; if ((imgRel > canvasRel && par === 'xMidYMid slice') || (imgRel < canvasRel && par !== 'xMidYMid slice')) { heightCrop = imgH; widthCrop = heightCrop * canvasRel; } else { widthCrop = imgW; heightCrop = widthCrop / canvasRel; } ctx.drawImage(this.img, (imgW - widthCrop) / 2, (imgH - heightCrop) / 2, widthCrop, heightCrop, 0, 0, this.assetData.w, this.assetData.h); this.img = canvas; } }; CVImageElement.prototype.renderInnerContent = function () { this.canvasContext.drawImage(this.img, 0, 0); }; CVImageElement.prototype.destroy = function () { this.img = null; }; /* global createSizedArray, PropertyFactory, extendPrototype, CanvasRenderer, ICompElement, CVBaseElement */ function CVCompElement(data, globalData, comp) { this.completeLayers = false; this.layers = data.layers; this.pendingElements = []; this.elements = createSizedArray(this.layers.length); this.initElement(data, globalData, comp); this.tm = data.tm ? PropertyFactory.getProp(this, data.tm, 0, globalData.frameRate, this) : { _placeholder: true }; } extendPrototype([CanvasRenderer, ICompElement, CVBaseElement], CVCompElement); CVCompElement.prototype.renderInnerContent = function () { var ctx = this.canvasContext; ctx.beginPath(); ctx.moveTo(0, 0); ctx.lineTo(this.data.w, 0); ctx.lineTo(this.data.w, this.data.h); ctx.lineTo(0, this.data.h); ctx.lineTo(0, 0); ctx.clip(); var i; var len = this.layers.length; for (i = len - 1; i >= 0; i -= 1) { if (this.completeLayers || this.elements[i]) { this.elements[i].renderFrame(); } } }; CVCompElement.prototype.destroy = function () { var i; var len = this.layers.length; for (i = len - 1; i >= 0; i -= 1) { if (this.elements[i]) { this.elements[i].destroy(); } } this.layers = null; this.elements = null; }; /* global createSizedArray, ShapePropertyFactory, MaskElement */ function CVMaskElement(data, element) { this.data = data; this.element = element; this.masksProperties = this.data.masksProperties || []; this.viewData = createSizedArray(this.masksProperties.length); var i; var len = this.masksProperties.length; var hasMasks = false; for (i = 0; i < len; i += 1) { if (this.masksProperties[i].mode !== 'n') { hasMasks = true; } this.viewData[i] = ShapePropertyFactory.getShapeProp(this.element, this.masksProperties[i], 3); } this.hasMasks = hasMasks; if (hasMasks) { this.element.addRenderableComponent(this); } } CVMaskElement.prototype.renderFrame = function () { if (!this.hasMasks) { return; } var transform = this.element.finalTransform.mat; var ctx = this.element.canvasContext; var i; var len = this.masksProperties.length; var pt; var pts; var data; ctx.beginPath(); for (i = 0; i < len; i += 1) { if (this.masksProperties[i].mode !== 'n') { if (this.masksProperties[i].inv) { ctx.moveTo(0, 0); ctx.lineTo(this.element.globalData.compSize.w, 0); ctx.lineTo(this.element.globalData.compSize.w, this.element.globalData.compSize.h); ctx.lineTo(0, this.element.globalData.compSize.h); ctx.lineTo(0, 0); } data = this.viewData[i].v; pt = transform.applyToPointArray(data.v[0][0], data.v[0][1], 0); ctx.moveTo(pt[0], pt[1]); var j; var jLen = data._length; for (j = 1; j < jLen; j += 1) { pts = transform.applyToTriplePoints(data.o[j - 1], data.i[j], data.v[j]); ctx.bezierCurveTo(pts[0], pts[1], pts[2], pts[3], pts[4], pts[5]); } pts = transform.applyToTriplePoints(data.o[j - 1], data.i[0], data.v[0]); ctx.bezierCurveTo(pts[0], pts[1], pts[2], pts[3], pts[4], pts[5]); } } this.element.globalData.renderer.save(true); ctx.clip(); }; CVMaskElement.prototype.getMaskProperty = MaskElement.prototype.getMaskProperty; CVMaskElement.prototype.destroy = function () { this.element = null; }; /* global ShapeTransformManager, extendPrototype, BaseElement, TransformElement, CVBaseElement, IShapeElement, HierarchyElement, FrameElement, RenderableElement, RenderableDOMElement, PropertyFactory, degToRads, GradientProperty, DashProperty, TransformPropertyFactory, CVShapeData, ShapeModifiers, bmFloor, lineCapEnum, lineJoinEnum */ function CVShapeElement(data, globalData, comp) { this.shapes = []; this.shapesData = data.shapes; this.stylesList = []; this.itemsData = []; this.prevViewData = []; this.shapeModifiers = []; this.processedElements = []; this.transformsManager = new ShapeTransformManager(); this.initElement(data, globalData, comp); } extendPrototype([BaseElement, TransformElement, CVBaseElement, IShapeElement, HierarchyElement, FrameElement, RenderableElement], CVShapeElement); CVShapeElement.prototype.initElement = RenderableDOMElement.prototype.initElement; CVShapeElement.prototype.transformHelper = { opacity: 1, _opMdf: false }; CVShapeElement.prototype.dashResetter = []; CVShapeElement.prototype.createContent = function () { this.searchShapes(this.shapesData, this.itemsData, this.prevViewData, true, []); }; CVShapeElement.prototype.createStyleElement = function (data, transforms) { var styleElem = { data: data, type: data.ty, preTransforms: this.transformsManager.addTransformSequence(transforms), transforms: [], elements: [], closed: data.hd === true, }; var elementData = {}; if (data.ty === 'fl' || data.ty === 'st') { elementData.c = PropertyFactory.getProp(this, data.c, 1, 255, this); if (!elementData.c.k) { styleElem.co = 'rgb(' + bmFloor(elementData.c.v[0]) + ',' + bmFloor(elementData.c.v[1]) + ',' + bmFloor(elementData.c.v[2]) + ')'; } } else if (data.ty === 'gf' || data.ty === 'gs') { elementData.s = PropertyFactory.getProp(this, data.s, 1, null, this); elementData.e = PropertyFactory.getProp(this, data.e, 1, null, this); elementData.h = PropertyFactory.getProp(this, data.h || { k: 0 }, 0, 0.01, this); elementData.a = PropertyFactory.getProp(this, data.a || { k: 0 }, 0, degToRads, this); elementData.g = new GradientProperty(this, data.g, this); } elementData.o = PropertyFactory.getProp(this, data.o, 0, 0.01, this); if (data.ty === 'st' || data.ty === 'gs') { styleElem.lc = lineCapEnum[data.lc || 2]; styleElem.lj = lineJoinEnum[data.lj || 2]; if (data.lj == 1) { // eslint-disable-line eqeqeq styleElem.ml = data.ml; } elementData.w = PropertyFactory.getProp(this, data.w, 0, null, this); if (!elementData.w.k) { styleElem.wi = elementData.w.v; } if (data.d) { var d = new DashProperty(this, data.d, 'canvas', this); elementData.d = d; if (!elementData.d.k) { styleElem.da = elementData.d.dashArray; styleElem.do = elementData.d.dashoffset[0]; } } } else { styleElem.r = data.r === 2 ? 'evenodd' : 'nonzero'; } this.stylesList.push(styleElem); elementData.style = styleElem; return elementData; }; CVShapeElement.prototype.createGroupElement = function () { var elementData = { it: [], prevViewData: [], }; return elementData; }; CVShapeElement.prototype.createTransformElement = function (data) { var elementData = { transform: { opacity: 1, _opMdf: false, key: this.transformsManager.getNewKey(), op: PropertyFactory.getProp(this, data.o, 0, 0.01, this), mProps: TransformPropertyFactory.getTransformProperty(this, data, this), }, }; return elementData; }; CVShapeElement.prototype.createShapeElement = function (data) { var elementData = new CVShapeData(this, data, this.stylesList, this.transformsManager); this.shapes.push(elementData); this.addShapeToModifiers(elementData); return elementData; }; CVShapeElement.prototype.reloadShapes = function () { this._isFirstFrame = true; var i; var len = this.itemsData.length; for (i = 0; i < len; i += 1) { this.prevViewData[i] = this.itemsData[i]; } this.searchShapes(this.shapesData, this.itemsData, this.prevViewData, true, []); len = this.dynamicProperties.length; for (i = 0; i < len; i += 1) { this.dynamicProperties[i].getValue(); } this.renderModifiers(); this.transformsManager.processSequences(this._isFirstFrame); }; CVShapeElement.prototype.addTransformToStyleList = function (transform) { var i; var len = this.stylesList.length; for (i = 0; i < len; i += 1) { if (!this.stylesList[i].closed) { this.stylesList[i].transforms.push(transform); } } }; CVShapeElement.prototype.removeTransformFromStyleList = function () { var i; var len = this.stylesList.length; for (i = 0; i < len; i += 1) { if (!this.stylesList[i].closed) { this.stylesList[i].transforms.pop(); } } }; CVShapeElement.prototype.closeStyles = function (styles) { var i; var len = styles.length; for (i = 0; i < len; i += 1) { styles[i].closed = true; } }; CVShapeElement.prototype.searchShapes = function (arr, itemsData, prevViewData, shouldRender, transforms) { var i; var len = arr.length - 1; var j; var jLen; var ownStyles = []; var ownModifiers = []; var processedPos; var modifier; var currentTransform; var ownTransforms = [].concat(transforms); for (i = len; i >= 0; i -= 1) { processedPos = this.searchProcessedElement(arr[i]); if (!processedPos) { arr[i]._shouldRender = shouldRender; } else { itemsData[i] = prevViewData[processedPos - 1]; } if (arr[i].ty === 'fl' || arr[i].ty === 'st' || arr[i].ty === 'gf' || arr[i].ty === 'gs') { if (!processedPos) { itemsData[i] = this.createStyleElement(arr[i], ownTransforms); } else { itemsData[i].style.closed = false; } ownStyles.push(itemsData[i].style); } else if (arr[i].ty === 'gr') { if (!processedPos) { itemsData[i] = this.createGroupElement(arr[i]); } else { jLen = itemsData[i].it.length; for (j = 0; j < jLen; j += 1) { itemsData[i].prevViewData[j] = itemsData[i].it[j]; } } this.searchShapes(arr[i].it, itemsData[i].it, itemsData[i].prevViewData, shouldRender, ownTransforms); } else if (arr[i].ty === 'tr') { if (!processedPos) { currentTransform = this.createTransformElement(arr[i]); itemsData[i] = currentTransform; } ownTransforms.push(itemsData[i]); this.addTransformToStyleList(itemsData[i]); } else if (arr[i].ty === 'sh' || arr[i].ty === 'rc' || arr[i].ty === 'el' || arr[i].ty === 'sr') { if (!processedPos) { itemsData[i] = this.createShapeElement(arr[i]); } } else if (arr[i].ty === 'tm' || arr[i].ty === 'rd' || arr[i].ty === 'pb') { if (!processedPos) { modifier = ShapeModifiers.getModifier(arr[i].ty); modifier.init(this, arr[i]); itemsData[i] = modifier; this.shapeModifiers.push(modifier); } else { modifier = itemsData[i]; modifier.closed = false; } ownModifiers.push(modifier); } else if (arr[i].ty === 'rp') { if (!processedPos) { modifier = ShapeModifiers.getModifier(arr[i].ty); itemsData[i] = modifier; modifier.init(this, arr, i, itemsData); this.shapeModifiers.push(modifier); shouldRender = false; } else { modifier = itemsData[i]; modifier.closed = true; } ownModifiers.push(modifier); } this.addProcessedElement(arr[i], i + 1); } this.removeTransformFromStyleList(); this.closeStyles(ownStyles); len = ownModifiers.length; for (i = 0; i < len; i += 1) { ownModifiers[i].closed = true; } }; CVShapeElement.prototype.renderInnerContent = function () { this.transformHelper.opacity = 1; this.transformHelper._opMdf = false; this.renderModifiers(); this.transformsManager.processSequences(this._isFirstFrame); this.renderShape(this.transformHelper, this.shapesData, this.itemsData, true); }; CVShapeElement.prototype.renderShapeTransform = function (parentTransform, groupTransform) { if (parentTransform._opMdf || groupTransform.op._mdf || this._isFirstFrame) { groupTransform.opacity = parentTransform.opacity; groupTransform.opacity *= groupTransform.op.v; groupTransform._opMdf = true; } }; CVShapeElement.prototype.drawLayer = function () { var i; var len = this.stylesList.length; var j; var jLen; var k; var kLen; var elems; var nodes; var renderer = this.globalData.renderer; var ctx = this.globalData.canvasContext; var type; var currentStyle; for (i = 0; i < len; i += 1) { currentStyle = this.stylesList[i]; type = currentStyle.type; // Skipping style when // Stroke width equals 0 // style should not be rendered (extra unused repeaters) // current opacity equals 0 // global opacity equals 0 if (!(((type === 'st' || type === 'gs') && currentStyle.wi === 0) || !currentStyle.data._shouldRender || currentStyle.coOp === 0 || this.globalData.currentGlobalAlpha === 0)) { renderer.save(); elems = currentStyle.elements; if (type === 'st' || type === 'gs') { ctx.strokeStyle = type === 'st' ? currentStyle.co : currentStyle.grd; ctx.lineWidth = currentStyle.wi; ctx.lineCap = currentStyle.lc; ctx.lineJoin = currentStyle.lj; ctx.miterLimit = currentStyle.ml || 0; } else { ctx.fillStyle = type === 'fl' ? currentStyle.co : currentStyle.grd; } renderer.ctxOpacity(currentStyle.coOp); if (type !== 'st' && type !== 'gs') { ctx.beginPath(); } renderer.ctxTransform(currentStyle.preTransforms.finalTransform.props); jLen = elems.length; for (j = 0; j < jLen; j += 1) { if (type === 'st' || type === 'gs') { ctx.beginPath(); if (currentStyle.da) { ctx.setLineDash(currentStyle.da); ctx.lineDashOffset = currentStyle.do; } } nodes = elems[j].trNodes; kLen = nodes.length; for (k = 0; k < kLen; k += 1) { if (nodes[k].t === 'm') { ctx.moveTo(nodes[k].p[0], nodes[k].p[1]); } else if (nodes[k].t === 'c') { ctx.bezierCurveTo(nodes[k].pts[0], nodes[k].pts[1], nodes[k].pts[2], nodes[k].pts[3], nodes[k].pts[4], nodes[k].pts[5]); } else { ctx.closePath(); } } if (type === 'st' || type === 'gs') { ctx.stroke(); if (currentStyle.da) { ctx.setLineDash(this.dashResetter); } } } if (type !== 'st' && type !== 'gs') { ctx.fill(currentStyle.r); } renderer.restore(); } } }; CVShapeElement.prototype.renderShape = function (parentTransform, items, data, isMain) { var i; var len = items.length - 1; var groupTransform; groupTransform = parentTransform; for (i = len; i >= 0; i -= 1) { if (items[i].ty === 'tr') { groupTransform = data[i].transform; this.renderShapeTransform(parentTransform, groupTransform); } else if (items[i].ty === 'sh' || items[i].ty === 'el' || items[i].ty === 'rc' || items[i].ty === 'sr') { this.renderPath(items[i], data[i]); } else if (items[i].ty === 'fl') { this.renderFill(items[i], data[i], groupTransform); } else if (items[i].ty === 'st') { this.renderStroke(items[i], data[i], groupTransform); } else if (items[i].ty === 'gf' || items[i].ty === 'gs') { this.renderGradientFill(items[i], data[i], groupTransform); } else if (items[i].ty === 'gr') { this.renderShape(groupTransform, items[i].it, data[i].it); } else if (items[i].ty === 'tm') { // } } if (isMain) { this.drawLayer(); } }; CVShapeElement.prototype.renderStyledShape = function (styledShape, shape) { if (this._isFirstFrame || shape._mdf || styledShape.transforms._mdf) { var shapeNodes = styledShape.trNodes; var paths = shape.paths; var i; var len; var j; var jLen = paths._length; shapeNodes.length = 0; var groupTransformMat = styledShape.transforms.finalTransform; for (j = 0; j < jLen; j += 1) { var pathNodes = paths.shapes[j]; if (pathNodes && pathNodes.v) { len = pathNodes._length; for (i = 1; i < len; i += 1) { if (i === 1) { shapeNodes.push({ t: 'm', p: groupTransformMat.applyToPointArray(pathNodes.v[0][0], pathNodes.v[0][1], 0), }); } shapeNodes.push({ t: 'c', pts: groupTransformMat.applyToTriplePoints(pathNodes.o[i - 1], pathNodes.i[i], pathNodes.v[i]), }); } if (len === 1) { shapeNodes.push({ t: 'm', p: groupTransformMat.applyToPointArray(pathNodes.v[0][0], pathNodes.v[0][1], 0), }); } if (pathNodes.c && len) { shapeNodes.push({ t: 'c', pts: groupTransformMat.applyToTriplePoints(pathNodes.o[i - 1], pathNodes.i[0], pathNodes.v[0]), }); shapeNodes.push({ t: 'z', }); } } } styledShape.trNodes = shapeNodes; } }; CVShapeElement.prototype.renderPath = function (pathData, itemData) { if (pathData.hd !== true && pathData._shouldRender) { var i; var len = itemData.styledShapes.length; for (i = 0; i < len; i += 1) { this.renderStyledShape(itemData.styledShapes[i], itemData.sh); } } }; CVShapeElement.prototype.renderFill = function (styleData, itemData, groupTransform) { var styleElem = itemData.style; if (itemData.c._mdf || this._isFirstFrame) { styleElem.co = 'rgb(' + bmFloor(itemData.c.v[0]) + ',' + bmFloor(itemData.c.v[1]) + ',' + bmFloor(itemData.c.v[2]) + ')'; } if (itemData.o._mdf || groupTransform._opMdf || this._isFirstFrame) { styleElem.coOp = itemData.o.v * groupTransform.opacity; } }; CVShapeElement.prototype.renderGradientFill = function (styleData, itemData, groupTransform) { var styleElem = itemData.style; var grd; if (!styleElem.grd || itemData.g._mdf || itemData.s._mdf || itemData.e._mdf || (styleData.t !== 1 && (itemData.h._mdf || itemData.a._mdf))) { var ctx = this.globalData.canvasContext; var pt1 = itemData.s.v; var pt2 = itemData.e.v; if (styleData.t === 1) { grd = ctx.createLinearGradient(pt1[0], pt1[1], pt2[0], pt2[1]); } else { var rad = Math.sqrt(Math.pow(pt1[0] - pt2[0], 2) + Math.pow(pt1[1] - pt2[1], 2)); var ang = Math.atan2(pt2[1] - pt1[1], pt2[0] - pt1[0]); var percent = itemData.h.v; if (percent >= 1) { percent = 0.99; } else if (percent <= -1) { percent = -0.99; } var dist = rad * percent; var x = Math.cos(ang + itemData.a.v) * dist + pt1[0]; var y = Math.sin(ang + itemData.a.v) * dist + pt1[1]; grd = ctx.createRadialGradient(x, y, 0, pt1[0], pt1[1], rad); } var i; var len = styleData.g.p; var cValues = itemData.g.c; var opacity = 1; for (i = 0; i < len; i += 1) { if (itemData.g._hasOpacity && itemData.g._collapsable) { opacity = itemData.g.o[i * 2 + 1]; } grd.addColorStop(cValues[i * 4] / 100, 'rgba(' + cValues[i * 4 + 1] + ',' + cValues[i * 4 + 2] + ',' + cValues[i * 4 + 3] + ',' + opacity + ')'); } styleElem.grd = grd; } styleElem.coOp = itemData.o.v * groupTransform.opacity; }; CVShapeElement.prototype.renderStroke = function (styleData, itemData, groupTransform) { var styleElem = itemData.style; var d = itemData.d; if (d && (d._mdf || this._isFirstFrame)) { styleElem.da = d.dashArray; styleElem.do = d.dashoffset[0]; } if (itemData.c._mdf || this._isFirstFrame) { styleElem.co = 'rgb(' + bmFloor(itemData.c.v[0]) + ',' + bmFloor(itemData.c.v[1]) + ',' + bmFloor(itemData.c.v[2]) + ')'; } if (itemData.o._mdf || groupTransform._opMdf || this._isFirstFrame) { styleElem.coOp = itemData.o.v * groupTransform.opacity; } if (itemData.w._mdf || this._isFirstFrame) { styleElem.wi = itemData.w.v; } }; CVShapeElement.prototype.destroy = function () { this.shapesData = null; this.globalData = null; this.canvasContext = null; this.stylesList.length = 0; this.itemsData.length = 0; }; /* global extendPrototype, BaseElement, TransformElement, CVBaseElement, HierarchyElement, FrameElement, RenderableElement, SVGShapeElement, IImageElement */ function CVSolidElement(data, globalData, comp) { this.initElement(data, globalData, comp); } extendPrototype([BaseElement, TransformElement, CVBaseElement, HierarchyElement, FrameElement, RenderableElement], CVSolidElement); CVSolidElement.prototype.initElement = SVGShapeElement.prototype.initElement; CVSolidElement.prototype.prepareFrame = IImageElement.prototype.prepareFrame; CVSolidElement.prototype.renderInnerContent = function () { var ctx = this.canvasContext; ctx.fillStyle = this.data.sc; ctx.fillRect(0, 0, this.data.sw, this.data.sh); // }; /* global extendPrototype, BaseElement, TransformElement, CVBaseElement, HierarchyElement, FrameElement, RenderableElement, ITextElement, createTag, createSizedArray */ function CVTextElement(data, globalData, comp) { this.textSpans = []; this.yOffset = 0; this.fillColorAnim = false; this.strokeColorAnim = false; this.strokeWidthAnim = false; this.stroke = false; this.fill = false; this.justifyOffset = 0; this.currentRender = null; this.renderType = 'canvas'; this.values = { fill: 'rgba(0,0,0,0)', stroke: 'rgba(0,0,0,0)', sWidth: 0, fValue: '', }; this.initElement(data, globalData, comp); } extendPrototype([BaseElement, TransformElement, CVBaseElement, HierarchyElement, FrameElement, RenderableElement, ITextElement], CVTextElement); CVTextElement.prototype.tHelper = createTag('canvas').getContext('2d'); CVTextElement.prototype.buildNewText = function () { var documentData = this.textProperty.currentData; this.renderedLetters = createSizedArray(documentData.l ? documentData.l.length : 0); var hasFill = false; if (documentData.fc) { hasFill = true; this.values.fill = this.buildColor(documentData.fc); } else { this.values.fill = 'rgba(0,0,0,0)'; } this.fill = hasFill; var hasStroke = false; if (documentData.sc) { hasStroke = true; this.values.stroke = this.buildColor(documentData.sc); this.values.sWidth = documentData.sw; } var fontData = this.globalData.fontManager.getFontByName(documentData.f); var i; var len; var letters = documentData.l; var matrixHelper = this.mHelper; this.stroke = hasStroke; this.values.fValue = documentData.finalSize + 'px ' + this.globalData.fontManager.getFontByName(documentData.f).fFamily; len = documentData.finalText.length; // this.tHelper.font = this.values.fValue; var charData; var shapeData; var k; var kLen; var shapes; var j; var jLen; var pathNodes; var commands; var pathArr; var singleShape = this.data.singleShape; var trackingOffset = documentData.tr * 0.001 * documentData.finalSize; var xPos = 0; var yPos = 0; var firstLine = true; var cnt = 0; for (i = 0; i < len; i += 1) { charData = this.globalData.fontManager.getCharData(documentData.finalText[i], fontData.fStyle, this.globalData.fontManager.getFontByName(documentData.f).fFamily); shapeData = (charData && charData.data) || {}; matrixHelper.reset(); if (singleShape && letters[i].n) { xPos = -trackingOffset; yPos += documentData.yOffset; yPos += firstLine ? 1 : 0; firstLine = false; } shapes = shapeData.shapes ? shapeData.shapes[0].it : []; jLen = shapes.length; matrixHelper.scale(documentData.finalSize / 100, documentData.finalSize / 100); if (singleShape) { this.applyTextPropertiesToMatrix(documentData, matrixHelper, letters[i].line, xPos, yPos); } commands = createSizedArray(jLen); for (j = 0; j < jLen; j += 1) { kLen = shapes[j].ks.k.i.length; pathNodes = shapes[j].ks.k; pathArr = []; for (k = 1; k < kLen; k += 1) { if (k === 1) { pathArr.push(matrixHelper.applyToX(pathNodes.v[0][0], pathNodes.v[0][1], 0), matrixHelper.applyToY(pathNodes.v[0][0], pathNodes.v[0][1], 0)); } pathArr.push(matrixHelper.applyToX(pathNodes.o[k - 1][0], pathNodes.o[k - 1][1], 0), matrixHelper.applyToY(pathNodes.o[k - 1][0], pathNodes.o[k - 1][1], 0), matrixHelper.applyToX(pathNodes.i[k][0], pathNodes.i[k][1], 0), matrixHelper.applyToY(pathNodes.i[k][0], pathNodes.i[k][1], 0), matrixHelper.applyToX(pathNodes.v[k][0], pathNodes.v[k][1], 0), matrixHelper.applyToY(pathNodes.v[k][0], pathNodes.v[k][1], 0)); } pathArr.push(matrixHelper.applyToX(pathNodes.o[k - 1][0], pathNodes.o[k - 1][1], 0), matrixHelper.applyToY(pathNodes.o[k - 1][0], pathNodes.o[k - 1][1], 0), matrixHelper.applyToX(pathNodes.i[0][0], pathNodes.i[0][1], 0), matrixHelper.applyToY(pathNodes.i[0][0], pathNodes.i[0][1], 0), matrixHelper.applyToX(pathNodes.v[0][0], pathNodes.v[0][1], 0), matrixHelper.applyToY(pathNodes.v[0][0], pathNodes.v[0][1], 0)); commands[j] = pathArr; } if (singleShape) { xPos += letters[i].l; xPos += trackingOffset; } if (this.textSpans[cnt]) { this.textSpans[cnt].elem = commands; } else { this.textSpans[cnt] = { elem: commands }; } cnt += 1; } }; CVTextElement.prototype.renderInnerContent = function () { var ctx = this.canvasContext; ctx.font = this.values.fValue; ctx.lineCap = 'butt'; ctx.lineJoin = 'miter'; ctx.miterLimit = 4; if (!this.data.singleShape) { this.textAnimator.getMeasures(this.textProperty.currentData, this.lettersChangedFlag); } var i; var len; var j; var jLen; var k; var kLen; var renderedLetters = this.textAnimator.renderedLetters; var letters = this.textProperty.currentData.l; len = letters.length; var renderedLetter; var lastFill = null; var lastStroke = null; var lastStrokeW = null; var commands; var pathArr; for (i = 0; i < len; i += 1) { if (!letters[i].n) { renderedLetter = renderedLetters[i]; if (renderedLetter) { this.globalData.renderer.save(); this.globalData.renderer.ctxTransform(renderedLetter.p); this.globalData.renderer.ctxOpacity(renderedLetter.o); } if (this.fill) { if (renderedLetter && renderedLetter.fc) { if (lastFill !== renderedLetter.fc) { lastFill = renderedLetter.fc; ctx.fillStyle = renderedLetter.fc; } } else if (lastFill !== this.values.fill) { lastFill = this.values.fill; ctx.fillStyle = this.values.fill; } commands = this.textSpans[i].elem; jLen = commands.length; this.globalData.canvasContext.beginPath(); for (j = 0; j < jLen; j += 1) { pathArr = commands[j]; kLen = pathArr.length; this.globalData.canvasContext.moveTo(pathArr[0], pathArr[1]); for (k = 2; k < kLen; k += 6) { this.globalData.canvasContext.bezierCurveTo(pathArr[k], pathArr[k + 1], pathArr[k + 2], pathArr[k + 3], pathArr[k + 4], pathArr[k + 5]); } } this.globalData.canvasContext.closePath(); this.globalData.canvasContext.fill(); /// ctx.fillText(this.textSpans[i].val,0,0); } if (this.stroke) { if (renderedLetter && renderedLetter.sw) { if (lastStrokeW !== renderedLetter.sw) { lastStrokeW = renderedLetter.sw; ctx.lineWidth = renderedLetter.sw; } } else if (lastStrokeW !== this.values.sWidth) { lastStrokeW = this.values.sWidth; ctx.lineWidth = this.values.sWidth; } if (renderedLetter && renderedLetter.sc) { if (lastStroke !== renderedLetter.sc) { lastStroke = renderedLetter.sc; ctx.strokeStyle = renderedLetter.sc; } } else if (lastStroke !== this.values.stroke) { lastStroke = this.values.stroke; ctx.strokeStyle = this.values.stroke; } commands = this.textSpans[i].elem; jLen = commands.length; this.globalData.canvasContext.beginPath(); for (j = 0; j < jLen; j += 1) { pathArr = commands[j]; kLen = pathArr.length; this.globalData.canvasContext.moveTo(pathArr[0], pathArr[1]); for (k = 2; k < kLen; k += 6) { this.globalData.canvasContext.bezierCurveTo(pathArr[k], pathArr[k + 1], pathArr[k + 2], pathArr[k + 3], pathArr[k + 4], pathArr[k + 5]); } } this.globalData.canvasContext.closePath(); this.globalData.canvasContext.stroke(); /// ctx.strokeText(letters[i].val,0,0); } if (renderedLetter) { this.globalData.renderer.restore(); } } } }; function CVEffects() { } CVEffects.prototype.renderFrame = function () {}; /* global createTag, createNS, styleDiv, CVEffects, MaskElement, SVGBaseElement, HybridRenderer */ function HBaseElement() {} HBaseElement.prototype = { checkBlendMode: function () {}, initRendererElement: function () { this.baseElement = createTag(this.data.tg || 'div'); if (this.data.hasMask) { this.svgElement = createNS('svg'); this.layerElement = createNS('g'); this.maskedElement = this.layerElement; this.svgElement.appendChild(this.layerElement); this.baseElement.appendChild(this.svgElement); } else { this.layerElement = this.baseElement; } styleDiv(this.baseElement); }, createContainerElements: function () { this.renderableEffectsManager = new CVEffects(this); this.transformedElement = this.baseElement; this.maskedElement = this.layerElement; if (this.data.ln) { this.layerElement.setAttribute('id', this.data.ln); } if (this.data.cl) { this.layerElement.setAttribute('class', this.data.cl); } if (this.data.bm !== 0) { this.setBlendMode(); } }, renderElement: function () { var transformedElementStyle = this.transformedElement ? this.transformedElement.style : {}; if (this.finalTransform._matMdf) { var matrixValue = this.finalTransform.mat.toCSS(); transformedElementStyle.transform = matrixValue; transformedElementStyle.webkitTransform = matrixValue; } if (this.finalTransform._opMdf) { transformedElementStyle.opacity = this.finalTransform.mProp.o.v; } }, renderFrame: function () { // If it is exported as hidden (data.hd === true) no need to render // If it is not visible no need to render if (this.data.hd || this.hidden) { return; } this.renderTransform(); this.renderRenderable(); this.renderElement(); this.renderInnerContent(); if (this._isFirstFrame) { this._isFirstFrame = false; } }, destroy: function () { this.layerElement = null; this.transformedElement = null; if (this.matteElement) { this.matteElement = null; } if (this.maskManager) { this.maskManager.destroy(); this.maskManager = null; } }, createRenderableComponents: function () { this.maskManager = new MaskElement(this.data, this, this.globalData); }, addEffects: function () { }, setMatte: function () {}, }; HBaseElement.prototype.getBaseElement = SVGBaseElement.prototype.getBaseElement; HBaseElement.prototype.destroyBaseElement = HBaseElement.prototype.destroy; HBaseElement.prototype.buildElementParenting = HybridRenderer.prototype.buildElementParenting; /* global extendPrototype, BaseElement, TransformElement, HBaseElement, HierarchyElement, FrameElement, RenderableDOMElement, createNS, createTag */ function HSolidElement(data, globalData, comp) { this.initElement(data, globalData, comp); } extendPrototype([BaseElement, TransformElement, HBaseElement, HierarchyElement, FrameElement, RenderableDOMElement], HSolidElement); HSolidElement.prototype.createContent = function () { var rect; if (this.data.hasMask) { rect = createNS('rect'); rect.setAttribute('width', this.data.sw); rect.setAttribute('height', this.data.sh); rect.setAttribute('fill', this.data.sc); this.svgElement.setAttribute('width', this.data.sw); this.svgElement.setAttribute('height', this.data.sh); } else { rect = createTag('div'); rect.style.width = this.data.sw + 'px'; rect.style.height = this.data.sh + 'px'; rect.style.backgroundColor = this.data.sc; } this.layerElement.appendChild(rect); }; /* global createSizedArray, PropertyFactory, extendPrototype, HybridRenderer, ICompElement, HBaseElement */ function HCompElement(data, globalData, comp) { this.layers = data.layers; this.supports3d = !data.hasMask; this.completeLayers = false; this.pendingElements = []; this.elements = this.layers ? createSizedArray(this.layers.length) : []; this.initElement(data, globalData, comp); this.tm = data.tm ? PropertyFactory.getProp(this, data.tm, 0, globalData.frameRate, this) : { _placeholder: true }; } extendPrototype([HybridRenderer, ICompElement, HBaseElement], HCompElement); HCompElement.prototype._createBaseContainerElements = HCompElement.prototype.createContainerElements; HCompElement.prototype.createContainerElements = function () { this._createBaseContainerElements(); // divElement.style.clip = 'rect(0px, '+this.data.w+'px, '+this.data.h+'px, 0px)'; if (this.data.hasMask) { this.svgElement.setAttribute('width', this.data.w); this.svgElement.setAttribute('height', this.data.h); this.transformedElement = this.baseElement; } else { this.transformedElement = this.layerElement; } }; HCompElement.prototype.addTo3dContainer = function (elem, pos) { var j = 0; var nextElement; while (j < pos) { if (this.elements[j] && this.elements[j].getBaseElement) { nextElement = this.elements[j].getBaseElement(); } j += 1; } if (nextElement) { this.layerElement.insertBefore(elem, nextElement); } else { this.layerElement.appendChild(elem); } }; /* global createNS, extendPrototype, BaseElement, TransformElement, HSolidElement, SVGShapeElement, HBaseElement, HierarchyElement, FrameElement, RenderableElement, createNS, bmMin, bmSqrt, bmMin, bmMax, bmPow */ function HShapeElement(data, globalData, comp) { // List of drawable elements this.shapes = []; // Full shape data this.shapesData = data.shapes; // List of styles that will be applied to shapes this.stylesList = []; // List of modifiers that will be applied to shapes this.shapeModifiers = []; // List of items in shape tree this.itemsData = []; // List of items in previous shape tree this.processedElements = []; // List of animated components this.animatedContents = []; this.shapesContainer = createNS('g'); this.initElement(data, globalData, comp); // Moving any property that doesn't get too much access after initialization because of v8 way of handling more than 10 properties. // List of elements that have been created this.prevViewData = []; this.currentBBox = { x: 999999, y: -999999, h: 0, w: 0, }; } extendPrototype([BaseElement, TransformElement, HSolidElement, SVGShapeElement, HBaseElement, HierarchyElement, FrameElement, RenderableElement], HShapeElement); HShapeElement.prototype._renderShapeFrame = HShapeElement.prototype.renderInnerContent; HShapeElement.prototype.createContent = function () { var cont; this.baseElement.style.fontSize = 0; if (this.data.hasMask) { this.layerElement.appendChild(this.shapesContainer); cont = this.svgElement; } else { cont = createNS('svg'); var size = this.comp.data ? this.comp.data : this.globalData.compSize; cont.setAttribute('width', size.w); cont.setAttribute('height', size.h); cont.appendChild(this.shapesContainer); this.layerElement.appendChild(cont); } this.searchShapes(this.shapesData, this.itemsData, this.prevViewData, this.shapesContainer, 0, [], true); this.filterUniqueShapes(); this.shapeCont = cont; }; HShapeElement.prototype.getTransformedPoint = function (transformers, point) { var i; var len = transformers.length; for (i = 0; i < len; i += 1) { point = transformers[i].mProps.v.applyToPointArray(point[0], point[1], 0); } return point; }; HShapeElement.prototype.calculateShapeBoundingBox = function (item, boundingBox) { var shape = item.sh.v; var transformers = item.transformers; var i; var len = shape._length; var vPoint; var oPoint; var nextIPoint; var nextVPoint; if (len <= 1) { return; } for (i = 0; i < len - 1; i += 1) { vPoint = this.getTransformedPoint(transformers, shape.v[i]); oPoint = this.getTransformedPoint(transformers, shape.o[i]); nextIPoint = this.getTransformedPoint(transformers, shape.i[i + 1]); nextVPoint = this.getTransformedPoint(transformers, shape.v[i + 1]); this.checkBounds(vPoint, oPoint, nextIPoint, nextVPoint, boundingBox); } if (shape.c) { vPoint = this.getTransformedPoint(transformers, shape.v[i]); oPoint = this.getTransformedPoint(transformers, shape.o[i]); nextIPoint = this.getTransformedPoint(transformers, shape.i[0]); nextVPoint = this.getTransformedPoint(transformers, shape.v[0]); this.checkBounds(vPoint, oPoint, nextIPoint, nextVPoint, boundingBox); } }; HShapeElement.prototype.checkBounds = function (vPoint, oPoint, nextIPoint, nextVPoint, boundingBox) { this.getBoundsOfCurve(vPoint, oPoint, nextIPoint, nextVPoint); var bounds = this.shapeBoundingBox; boundingBox.x = bmMin(bounds.left, boundingBox.x); boundingBox.xMax = bmMax(bounds.right, boundingBox.xMax); boundingBox.y = bmMin(bounds.top, boundingBox.y); boundingBox.yMax = bmMax(bounds.bottom, boundingBox.yMax); }; HShapeElement.prototype.shapeBoundingBox = { left: 0, right: 0, top: 0, bottom: 0, }; HShapeElement.prototype.tempBoundingBox = { x: 0, xMax: 0, y: 0, yMax: 0, width: 0, height: 0, }; HShapeElement.prototype.getBoundsOfCurve = function (p0, p1, p2, p3) { var bounds = [[p0[0], p3[0]], [p0[1], p3[1]]]; for (var a, b, c, t, b2ac, t1, t2, i = 0; i < 2; ++i) { // eslint-disable-line no-plusplus b = 6 * p0[i] - 12 * p1[i] + 6 * p2[i]; a = -3 * p0[i] + 9 * p1[i] - 9 * p2[i] + 3 * p3[i]; c = 3 * p1[i] - 3 * p0[i]; b |= 0; // eslint-disable-line no-bitwise a |= 0; // eslint-disable-line no-bitwise c |= 0; // eslint-disable-line no-bitwise if (a === 0 && b === 0) { // } else if (a === 0) { t = -c / b; if (t > 0 && t < 1) { bounds[i].push(this.calculateF(t, p0, p1, p2, p3, i)); } } else { b2ac = b * b - 4 * c * a; if (b2ac >= 0) { t1 = (-b + bmSqrt(b2ac)) / (2 * a); if (t1 > 0 && t1 < 1) bounds[i].push(this.calculateF(t1, p0, p1, p2, p3, i)); t2 = (-b - bmSqrt(b2ac)) / (2 * a); if (t2 > 0 && t2 < 1) bounds[i].push(this.calculateF(t2, p0, p1, p2, p3, i)); } } } this.shapeBoundingBox.left = bmMin.apply(null, bounds[0]); this.shapeBoundingBox.top = bmMin.apply(null, bounds[1]); this.shapeBoundingBox.right = bmMax.apply(null, bounds[0]); this.shapeBoundingBox.bottom = bmMax.apply(null, bounds[1]); }; HShapeElement.prototype.calculateF = function (t, p0, p1, p2, p3, i) { return bmPow(1 - t, 3) * p0[i] + 3 * bmPow(1 - t, 2) * t * p1[i] + 3 * (1 - t) * bmPow(t, 2) * p2[i] + bmPow(t, 3) * p3[i]; }; HShapeElement.prototype.calculateBoundingBox = function (itemsData, boundingBox) { var i; var len = itemsData.length; for (i = 0; i < len; i += 1) { if (itemsData[i] && itemsData[i].sh) { this.calculateShapeBoundingBox(itemsData[i], boundingBox); } else if (itemsData[i] && itemsData[i].it) { this.calculateBoundingBox(itemsData[i].it, boundingBox); } } }; HShapeElement.prototype.currentBoxContains = function (box) { return this.currentBBox.x <= box.x && this.currentBBox.y <= box.y && this.currentBBox.width + this.currentBBox.x >= box.x + box.width && this.currentBBox.height + this.currentBBox.y >= box.y + box.height; }; HShapeElement.prototype.renderInnerContent = function () { this._renderShapeFrame(); if (!this.hidden && (this._isFirstFrame || this._mdf)) { var tempBoundingBox = this.tempBoundingBox; var max = 999999; tempBoundingBox.x = max; tempBoundingBox.xMax = -max; tempBoundingBox.y = max; tempBoundingBox.yMax = -max; this.calculateBoundingBox(this.itemsData, tempBoundingBox); tempBoundingBox.width = tempBoundingBox.xMax < tempBoundingBox.x ? 0 : tempBoundingBox.xMax - tempBoundingBox.x; tempBoundingBox.height = tempBoundingBox.yMax < tempBoundingBox.y ? 0 : tempBoundingBox.yMax - tempBoundingBox.y; // var tempBoundingBox = this.shapeCont.getBBox(); if (this.currentBoxContains(tempBoundingBox)) { return; } var changed = false; if (this.currentBBox.w !== tempBoundingBox.width) { this.currentBBox.w = tempBoundingBox.width; this.shapeCont.setAttribute('width', tempBoundingBox.width); changed = true; } if (this.currentBBox.h !== tempBoundingBox.height) { this.currentBBox.h = tempBoundingBox.height; this.shapeCont.setAttribute('height', tempBoundingBox.height); changed = true; } if (changed || this.currentBBox.x !== tempBoundingBox.x || this.currentBBox.y !== tempBoundingBox.y) { this.currentBBox.w = tempBoundingBox.width; this.currentBBox.h = tempBoundingBox.height; this.currentBBox.x = tempBoundingBox.x; this.currentBBox.y = tempBoundingBox.y; this.shapeCont.setAttribute('viewBox', this.currentBBox.x + ' ' + this.currentBBox.y + ' ' + this.currentBBox.w + ' ' + this.currentBBox.h); var shapeStyle = this.shapeCont.style; var shapeTransform = 'translate(' + this.currentBBox.x + 'px,' + this.currentBBox.y + 'px)'; shapeStyle.transform = shapeTransform; shapeStyle.webkitTransform = shapeTransform; } } }; /* global extendPrototype, BaseElement, TransformElement, HBaseElement, HierarchyElement, FrameElement, RenderableDOMElement, ITextElement, createSizedArray, createTag, styleDiv, createNS, lineJoinEnum, lineCapEnum */ function HTextElement(data, globalData, comp) { this.textSpans = []; this.textPaths = []; this.currentBBox = { x: 999999, y: -999999, h: 0, w: 0, }; this.renderType = 'svg'; this.isMasked = false; this.initElement(data, globalData, comp); } extendPrototype([BaseElement, TransformElement, HBaseElement, HierarchyElement, FrameElement, RenderableDOMElement, ITextElement], HTextElement); HTextElement.prototype.createContent = function () { this.isMasked = this.checkMasks(); if (this.isMasked) { this.renderType = 'svg'; this.compW = this.comp.data.w; this.compH = this.comp.data.h; this.svgElement.setAttribute('width', this.compW); this.svgElement.setAttribute('height', this.compH); var g = createNS('g'); this.maskedElement.appendChild(g); this.innerElem = g; } else { this.renderType = 'html'; this.innerElem = this.layerElement; } this.checkParenting(); }; HTextElement.prototype.buildNewText = function () { var documentData = this.textProperty.currentData; this.renderedLetters = createSizedArray(documentData.l ? documentData.l.length : 0); var innerElemStyle = this.innerElem.style; var textColor = documentData.fc ? this.buildColor(documentData.fc) : 'rgba(0,0,0,0)'; innerElemStyle.fill = textColor; innerElemStyle.color = textColor; if (documentData.sc) { innerElemStyle.stroke = this.buildColor(documentData.sc); innerElemStyle.strokeWidth = documentData.sw + 'px'; } var fontData = this.globalData.fontManager.getFontByName(documentData.f); if (!this.globalData.fontManager.chars) { innerElemStyle.fontSize = documentData.finalSize + 'px'; innerElemStyle.lineHeight = documentData.finalSize + 'px'; if (fontData.fClass) { this.innerElem.className = fontData.fClass; } else { innerElemStyle.fontFamily = fontData.fFamily; var fWeight = documentData.fWeight; var fStyle = documentData.fStyle; innerElemStyle.fontStyle = fStyle; innerElemStyle.fontWeight = fWeight; } } var i; var len; var letters = documentData.l; len = letters.length; var tSpan; var tParent; var tCont; var matrixHelper = this.mHelper; var shapes; var shapeStr = ''; var cnt = 0; for (i = 0; i < len; i += 1) { if (this.globalData.fontManager.chars) { if (!this.textPaths[cnt]) { tSpan = createNS('path'); tSpan.setAttribute('stroke-linecap', lineCapEnum[1]); tSpan.setAttribute('stroke-linejoin', lineJoinEnum[2]); tSpan.setAttribute('stroke-miterlimit', '4'); } else { tSpan = this.textPaths[cnt]; } if (!this.isMasked) { if (this.textSpans[cnt]) { tParent = this.textSpans[cnt]; tCont = tParent.children[0]; } else { tParent = createTag('div'); tParent.style.lineHeight = 0; tCont = createNS('svg'); tCont.appendChild(tSpan); styleDiv(tParent); } } } else if (!this.isMasked) { if (this.textSpans[cnt]) { tParent = this.textSpans[cnt]; tSpan = this.textPaths[cnt]; } else { tParent = createTag('span'); styleDiv(tParent); tSpan = createTag('span'); styleDiv(tSpan); tParent.appendChild(tSpan); } } else { tSpan = this.textPaths[cnt] ? this.textPaths[cnt] : createNS('text'); } // tSpan.setAttribute('visibility', 'hidden'); if (this.globalData.fontManager.chars) { var charData = this.globalData.fontManager.getCharData(documentData.finalText[i], fontData.fStyle, this.globalData.fontManager.getFontByName(documentData.f).fFamily); var shapeData; if (charData) { shapeData = charData.data; } else { shapeData = null; } matrixHelper.reset(); if (shapeData && shapeData.shapes) { shapes = shapeData.shapes[0].it; matrixHelper.scale(documentData.finalSize / 100, documentData.finalSize / 100); shapeStr = this.createPathShape(matrixHelper, shapes); tSpan.setAttribute('d', shapeStr); } if (!this.isMasked) { this.innerElem.appendChild(tParent); if (shapeData && shapeData.shapes) { // document.body.appendChild is needed to get exact measure of shape document.body.appendChild(tCont); var boundingBox = tCont.getBBox(); tCont.setAttribute('width', boundingBox.width + 2); tCont.setAttribute('height', boundingBox.height + 2); tCont.setAttribute('viewBox', (boundingBox.x - 1) + ' ' + (boundingBox.y - 1) + ' ' + (boundingBox.width + 2) + ' ' + (boundingBox.height + 2)); var tContStyle = tCont.style; var tContTranslation = 'translate(' + (boundingBox.x - 1) + 'px,' + (boundingBox.y - 1) + 'px)'; tContStyle.transform = tContTranslation; tContStyle.webkitTransform = tContTranslation; letters[i].yOffset = boundingBox.y - 1; } else { tCont.setAttribute('width', 1); tCont.setAttribute('height', 1); } tParent.appendChild(tCont); } else { this.innerElem.appendChild(tSpan); } } else { tSpan.textContent = letters[i].val; tSpan.setAttributeNS('http://www.w3.org/XML/1998/namespace', 'xml:space', 'preserve'); if (!this.isMasked) { this.innerElem.appendChild(tParent); // var tStyle = tSpan.style; var tSpanTranslation = 'translate3d(0,' + -documentData.finalSize / 1.2 + 'px,0)'; tStyle.transform = tSpanTranslation; tStyle.webkitTransform = tSpanTranslation; } else { this.innerElem.appendChild(tSpan); } } // if (!this.isMasked) { this.textSpans[cnt] = tParent; } else { this.textSpans[cnt] = tSpan; } this.textSpans[cnt].style.display = 'block'; this.textPaths[cnt] = tSpan; cnt += 1; } while (cnt < this.textSpans.length) { this.textSpans[cnt].style.display = 'none'; cnt += 1; } }; HTextElement.prototype.renderInnerContent = function () { var svgStyle; if (this.data.singleShape) { if (!this._isFirstFrame && !this.lettersChangedFlag) { return; } if (this.isMasked && this.finalTransform._matMdf) { // Todo Benchmark if using this is better than getBBox this.svgElement.setAttribute('viewBox', -this.finalTransform.mProp.p.v[0] + ' ' + -this.finalTransform.mProp.p.v[1] + ' ' + this.compW + ' ' + this.compH); svgStyle = this.svgElement.style; var translation = 'translate(' + -this.finalTransform.mProp.p.v[0] + 'px,' + -this.finalTransform.mProp.p.v[1] + 'px)'; svgStyle.transform = translation; svgStyle.webkitTransform = translation; } } this.textAnimator.getMeasures(this.textProperty.currentData, this.lettersChangedFlag); if (!this.lettersChangedFlag && !this.textAnimator.lettersChangedFlag) { return; } var i; var len; var count = 0; var renderedLetters = this.textAnimator.renderedLetters; var letters = this.textProperty.currentData.l; len = letters.length; var renderedLetter; var textSpan; var textPath; for (i = 0; i < len; i += 1) { if (letters[i].n) { count += 1; } else { textSpan = this.textSpans[i]; textPath = this.textPaths[i]; renderedLetter = renderedLetters[count]; count += 1; if (renderedLetter._mdf.m) { if (!this.isMasked) { textSpan.style.webkitTransform = renderedLetter.m; textSpan.style.transform = renderedLetter.m; } else { textSpan.setAttribute('transform', renderedLetter.m); } } /// /textSpan.setAttribute('opacity',renderedLetter.o); textSpan.style.opacity = renderedLetter.o; if (renderedLetter.sw && renderedLetter._mdf.sw) { textPath.setAttribute('stroke-width', renderedLetter.sw); } if (renderedLetter.sc && renderedLetter._mdf.sc) { textPath.setAttribute('stroke', renderedLetter.sc); } if (renderedLetter.fc && renderedLetter._mdf.fc) { textPath.setAttribute('fill', renderedLetter.fc); textPath.style.color = renderedLetter.fc; } } } if (this.innerElem.getBBox && !this.hidden && (this._isFirstFrame || this._mdf)) { var boundingBox = this.innerElem.getBBox(); if (this.currentBBox.w !== boundingBox.width) { this.currentBBox.w = boundingBox.width; this.svgElement.setAttribute('width', boundingBox.width); } if (this.currentBBox.h !== boundingBox.height) { this.currentBBox.h = boundingBox.height; this.svgElement.setAttribute('height', boundingBox.height); } var margin = 1; if (this.currentBBox.w !== (boundingBox.width + margin * 2) || this.currentBBox.h !== (boundingBox.height + margin * 2) || this.currentBBox.x !== (boundingBox.x - margin) || this.currentBBox.y !== (boundingBox.y - margin)) { this.currentBBox.w = boundingBox.width + margin * 2; this.currentBBox.h = boundingBox.height + margin * 2; this.currentBBox.x = boundingBox.x - margin; this.currentBBox.y = boundingBox.y - margin; this.svgElement.setAttribute('viewBox', this.currentBBox.x + ' ' + this.currentBBox.y + ' ' + this.currentBBox.w + ' ' + this.currentBBox.h); svgStyle = this.svgElement.style; var svgTransform = 'translate(' + this.currentBBox.x + 'px,' + this.currentBBox.y + 'px)'; svgStyle.transform = svgTransform; svgStyle.webkitTransform = svgTransform; } } }; /* global extendPrototype, BaseElement, TransformElement, HBaseElement, HSolidElement, HierarchyElement, FrameElement, RenderableElement, createNS */ function HImageElement(data, globalData, comp) { this.assetData = globalData.getAssetData(data.refId); this.initElement(data, globalData, comp); } extendPrototype([BaseElement, TransformElement, HBaseElement, HSolidElement, HierarchyElement, FrameElement, RenderableElement], HImageElement); HImageElement.prototype.createContent = function () { var assetPath = this.globalData.getAssetsPath(this.assetData); var img = new Image(); if (this.data.hasMask) { this.imageElem = createNS('image'); this.imageElem.setAttribute('width', this.assetData.w + 'px'); this.imageElem.setAttribute('height', this.assetData.h + 'px'); this.imageElem.setAttributeNS('http://www.w3.org/1999/xlink', 'href', assetPath); this.layerElement.appendChild(this.imageElem); this.baseElement.setAttribute('width', this.assetData.w); this.baseElement.setAttribute('height', this.assetData.h); } else { this.layerElement.appendChild(img); } img.crossOrigin = 'anonymous'; img.src = assetPath; if (this.data.ln) { this.baseElement.setAttribute('id', this.data.ln); } }; /* global PropertyFactory, degToRads, Matrix, extendPrototype, BaseElement, FrameElement, HierarchyElement */ function HCameraElement(data, globalData, comp) { this.initFrame(); this.initBaseData(data, globalData, comp); this.initHierarchy(); var getProp = PropertyFactory.getProp; this.pe = getProp(this, data.pe, 0, 0, this); if (data.ks.p.s) { this.px = getProp(this, data.ks.p.x, 1, 0, this); this.py = getProp(this, data.ks.p.y, 1, 0, this); this.pz = getProp(this, data.ks.p.z, 1, 0, this); } else { this.p = getProp(this, data.ks.p, 1, 0, this); } if (data.ks.a) { this.a = getProp(this, data.ks.a, 1, 0, this); } if (data.ks.or.k.length && data.ks.or.k[0].to) { var i; var len = data.ks.or.k.length; for (i = 0; i < len; i += 1) { data.ks.or.k[i].to = null; data.ks.or.k[i].ti = null; } } this.or = getProp(this, data.ks.or, 1, degToRads, this); this.or.sh = true; this.rx = getProp(this, data.ks.rx, 0, degToRads, this); this.ry = getProp(this, data.ks.ry, 0, degToRads, this); this.rz = getProp(this, data.ks.rz, 0, degToRads, this); this.mat = new Matrix(); this._prevMat = new Matrix(); this._isFirstFrame = true; // TODO: find a better way to make the HCamera element to be compatible with the LayerInterface and TransformInterface. this.finalTransform = { mProp: this, }; } extendPrototype([BaseElement, FrameElement, HierarchyElement], HCameraElement); HCameraElement.prototype.setup = function () { var i; var len = this.comp.threeDElements.length; var comp; var perspectiveStyle; var containerStyle; for (i = 0; i < len; i += 1) { // [perspectiveElem,container] comp = this.comp.threeDElements[i]; if (comp.type === '3d') { perspectiveStyle = comp.perspectiveElem.style; containerStyle = comp.container.style; var perspective = this.pe.v + 'px'; var origin = '0px 0px 0px'; var matrix = 'matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1)'; perspectiveStyle.perspective = perspective; perspectiveStyle.webkitPerspective = perspective; containerStyle.transformOrigin = origin; containerStyle.mozTransformOrigin = origin; containerStyle.webkitTransformOrigin = origin; perspectiveStyle.transform = matrix; perspectiveStyle.webkitTransform = matrix; } } }; HCameraElement.prototype.createElements = function () { }; HCameraElement.prototype.hide = function () { }; HCameraElement.prototype.renderFrame = function () { var _mdf = this._isFirstFrame; var i; var len; if (this.hierarchy) { len = this.hierarchy.length; for (i = 0; i < len; i += 1) { _mdf = this.hierarchy[i].finalTransform.mProp._mdf || _mdf; } } if (_mdf || this.pe._mdf || (this.p && this.p._mdf) || (this.px && (this.px._mdf || this.py._mdf || this.pz._mdf)) || this.rx._mdf || this.ry._mdf || this.rz._mdf || this.or._mdf || (this.a && this.a._mdf)) { this.mat.reset(); if (this.hierarchy) { len = this.hierarchy.length - 1; for (i = len; i >= 0; i -= 1) { var mTransf = this.hierarchy[i].finalTransform.mProp; this.mat.translate(-mTransf.p.v[0], -mTransf.p.v[1], mTransf.p.v[2]); this.mat.rotateX(-mTransf.or.v[0]).rotateY(-mTransf.or.v[1]).rotateZ(mTransf.or.v[2]); this.mat.rotateX(-mTransf.rx.v).rotateY(-mTransf.ry.v).rotateZ(mTransf.rz.v); this.mat.scale(1 / mTransf.s.v[0], 1 / mTransf.s.v[1], 1 / mTransf.s.v[2]); this.mat.translate(mTransf.a.v[0], mTransf.a.v[1], mTransf.a.v[2]); } } if (this.p) { this.mat.translate(-this.p.v[0], -this.p.v[1], this.p.v[2]); } else { this.mat.translate(-this.px.v, -this.py.v, this.pz.v); } if (this.a) { var diffVector; if (this.p) { diffVector = [this.p.v[0] - this.a.v[0], this.p.v[1] - this.a.v[1], this.p.v[2] - this.a.v[2]]; } else { diffVector = [this.px.v - this.a.v[0], this.py.v - this.a.v[1], this.pz.v - this.a.v[2]]; } var mag = Math.sqrt(Math.pow(diffVector[0], 2) + Math.pow(diffVector[1], 2) + Math.pow(diffVector[2], 2)); // var lookDir = getNormalizedPoint(getDiffVector(this.a.v,this.p.v)); var lookDir = [diffVector[0] / mag, diffVector[1] / mag, diffVector[2] / mag]; var lookLengthOnXZ = Math.sqrt(lookDir[2] * lookDir[2] + lookDir[0] * lookDir[0]); var mRotationX = (Math.atan2(lookDir[1], lookLengthOnXZ)); var mRotationY = (Math.atan2(lookDir[0], -lookDir[2])); this.mat.rotateY(mRotationY).rotateX(-mRotationX); } this.mat.rotateX(-this.rx.v).rotateY(-this.ry.v).rotateZ(this.rz.v); this.mat.rotateX(-this.or.v[0]).rotateY(-this.or.v[1]).rotateZ(this.or.v[2]); this.mat.translate(this.globalData.compSize.w / 2, this.globalData.compSize.h / 2, 0); this.mat.translate(0, 0, this.pe.v); var hasMatrixChanged = !this._prevMat.equals(this.mat); if ((hasMatrixChanged || this.pe._mdf) && this.comp.threeDElements) { len = this.comp.threeDElements.length; var comp; var perspectiveStyle; var containerStyle; for (i = 0; i < len; i += 1) { comp = this.comp.threeDElements[i]; if (comp.type === '3d') { if (hasMatrixChanged) { var matValue = this.mat.toCSS(); containerStyle = comp.container.style; containerStyle.transform = matValue; containerStyle.webkitTransform = matValue; } if (this.pe._mdf) { perspectiveStyle = comp.perspectiveElem.style; perspectiveStyle.perspective = this.pe.v + 'px'; perspectiveStyle.webkitPerspective = this.pe.v + 'px'; } } } this.mat.clone(this._prevMat); } } this._isFirstFrame = false; }; HCameraElement.prototype.prepareFrame = function (num) { this.prepareProperties(num, true); }; HCameraElement.prototype.destroy = function () { }; HCameraElement.prototype.getBaseElement = function () { return null; }; function HEffects() { } HEffects.prototype.renderFrame = function () {}; /* global createTag, AnimationItem */ /* exported animationManager */ var animationManager = (function () { var moduleOb = {}; var registeredAnimations = []; var initTime = 0; var len = 0; var playingAnimationsNum = 0; var _stopped = true; var _isFrozen = false; function removeElement(ev) { var i = 0; var animItem = ev.target; while (i < len) { if (registeredAnimations[i].animation === animItem) { registeredAnimations.splice(i, 1); i -= 1; len -= 1; if (!animItem.isPaused) { subtractPlayingCount(); } } i += 1; } } function registerAnimation(element, animationData) { if (!element) { return null; } var i = 0; while (i < len) { if (registeredAnimations[i].elem === element && registeredAnimations[i].elem !== null) { return registeredAnimations[i].animation; } i += 1; } var animItem = new AnimationItem(); setupAnimation(animItem, element); animItem.setData(element, animationData); return animItem; } function getRegisteredAnimations() { var i; var lenAnims = registeredAnimations.length; var animations = []; for (i = 0; i < lenAnims; i += 1) { animations.push(registeredAnimations[i].animation); } return animations; } function addPlayingCount() { playingAnimationsNum += 1; activate(); } function subtractPlayingCount() { playingAnimationsNum -= 1; } function setupAnimation(animItem, element) { animItem.addEventListener('destroy', removeElement); animItem.addEventListener('_active', addPlayingCount); animItem.addEventListener('_idle', subtractPlayingCount); registeredAnimations.push({ elem: element, animation: animItem }); len += 1; } function loadAnimation(params) { var animItem = new AnimationItem(); setupAnimation(animItem, null); animItem.setParams(params); return animItem; } function setSpeed(val, animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.setSpeed(val, animation); } } function setDirection(val, animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.setDirection(val, animation); } } function play(animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.play(animation); } } function resume(nowTime) { var elapsedTime = nowTime - initTime; var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.advanceTime(elapsedTime); } initTime = nowTime; if (playingAnimationsNum && !_isFrozen) { window.requestAnimationFrame(resume); } else { _stopped = true; } } function first(nowTime) { initTime = nowTime; window.requestAnimationFrame(resume); } function pause(animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.pause(animation); } } function goToAndStop(value, isFrame, animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.goToAndStop(value, isFrame, animation); } } function stop(animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.stop(animation); } } function togglePause(animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.togglePause(animation); } } function destroy(animation) { var i; for (i = (len - 1); i >= 0; i -= 1) { registeredAnimations[i].animation.destroy(animation); } } function searchAnimations(animationData, standalone, renderer) { var animElements = [].concat([].slice.call(document.getElementsByClassName('lottie')), [].slice.call(document.getElementsByClassName('bodymovin'))); var i; var lenAnims = animElements.length; for (i = 0; i < lenAnims; i += 1) { if (renderer) { animElements[i].setAttribute('data-bm-type', renderer); } registerAnimation(animElements[i], animationData); } if (standalone && lenAnims === 0) { if (!renderer) { renderer = 'svg'; } var body = document.getElementsByTagName('body')[0]; body.innerText = ''; var div = createTag('div'); div.style.width = '100%'; div.style.height = '100%'; div.setAttribute('data-bm-type', renderer); body.appendChild(div); registerAnimation(div, animationData); } } function resize() { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.resize(); } } function activate() { if (!_isFrozen && playingAnimationsNum) { if (_stopped) { window.requestAnimationFrame(first); _stopped = false; } } } function freeze() { _isFrozen = true; } function unfreeze() { _isFrozen = false; activate(); } function setVolume(val, animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.setVolume(val, animation); } } function mute(animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.mute(animation); } } function unmute(animation) { var i; for (i = 0; i < len; i += 1) { registeredAnimations[i].animation.unmute(animation); } } moduleOb.registerAnimation = registerAnimation; moduleOb.loadAnimation = loadAnimation; moduleOb.setSpeed = setSpeed; moduleOb.setDirection = setDirection; moduleOb.play = play; moduleOb.pause = pause; moduleOb.stop = stop; moduleOb.togglePause = togglePause; moduleOb.searchAnimations = searchAnimations; moduleOb.resize = resize; // moduleOb.start = start; moduleOb.goToAndStop = goToAndStop; moduleOb.destroy = destroy; moduleOb.freeze = freeze; moduleOb.unfreeze = unfreeze; moduleOb.setVolume = setVolume; moduleOb.mute = mute; moduleOb.unmute = unmute; moduleOb.getRegisteredAnimations = getRegisteredAnimations; return moduleOb; }()); /* global createElementID, subframeEnabled, ProjectInterface, ImagePreloader, audioControllerFactory, extendPrototype, BaseEvent, CanvasRenderer, SVGRenderer, HybridRenderer, dataManager, expressionsPlugin, BMEnterFrameEvent, BMCompleteLoopEvent, BMCompleteEvent, BMSegmentStartEvent, BMDestroyEvent, BMEnterFrameEvent, BMCompleteLoopEvent, BMCompleteEvent, BMSegmentStartEvent, BMDestroyEvent, BMRenderFrameErrorEvent, BMConfigErrorEvent, markerParser */ var AnimationItem = function () { this._cbs = []; this.name = ''; this.path = ''; this.isLoaded = false; this.currentFrame = 0; this.currentRawFrame = 0; this.firstFrame = 0; this.totalFrames = 0; this.frameRate = 0; this.frameMult = 0; this.playSpeed = 1; this.playDirection = 1; this.playCount = 0; this.animationData = {}; this.assets = []; this.isPaused = true; this.autoplay = false; this.loop = true; this.renderer = null; this.animationID = createElementID(); this.assetsPath = ''; this.timeCompleted = 0; this.segmentPos = 0; this.isSubframeEnabled = subframeEnabled; this.segments = []; this._idle = true; this._completedLoop = false; this.projectInterface = ProjectInterface(); this.imagePreloader = new ImagePreloader(); this.audioController = audioControllerFactory(); this.markers = []; this.configAnimation = this.configAnimation.bind(this); this.onSetupError = this.onSetupError.bind(this); this.onSegmentComplete = this.onSegmentComplete.bind(this); }; extendPrototype([BaseEvent], AnimationItem); AnimationItem.prototype.setParams = function (params) { if (params.wrapper || params.container) { this.wrapper = params.wrapper || params.container; } var animType = 'svg'; if (params.animType) { animType = params.animType; } else if (params.renderer) { animType = params.renderer; } switch (animType) { case 'canvas': this.renderer = new CanvasRenderer(this, params.rendererSettings); break; case 'svg': this.renderer = new SVGRenderer(this, params.rendererSettings); break; default: this.renderer = new HybridRenderer(this, params.rendererSettings); break; } this.imagePreloader.setCacheType(animType, this.renderer.globalData.defs); this.renderer.setProjectInterface(this.projectInterface); this.animType = animType; if (params.loop === '' || params.loop === null || params.loop === undefined || params.loop === true) { this.loop = true; } else if (params.loop === false) { this.loop = false; } else { this.loop = parseInt(params.loop, 10); } this.autoplay = 'autoplay' in params ? params.autoplay : true; this.name = params.name ? params.name : ''; this.autoloadSegments = Object.prototype.hasOwnProperty.call(params, 'autoloadSegments') ? params.autoloadSegments : true; this.assetsPath = params.assetsPath; this.initialSegment = params.initialSegment; if (params.audioFactory) { this.audioController.setAudioFactory(params.audioFactory); } if (params.animationData) { this.setupAnimation(params.animationData); } else if (params.path) { if (params.path.lastIndexOf('\\') !== -1) { this.path = params.path.substr(0, params.path.lastIndexOf('\\') + 1); } else { this.path = params.path.substr(0, params.path.lastIndexOf('/') + 1); } this.fileName = params.path.substr(params.path.lastIndexOf('/') + 1); this.fileName = this.fileName.substr(0, this.fileName.lastIndexOf('.json')); dataManager.loadAnimation( params.path, this.configAnimation, this.onSetupError ); } }; AnimationItem.prototype.onSetupError = function () { this.trigger('data_failed'); }; AnimationItem.prototype.setupAnimation = function (data) { dataManager.completeAnimation( data, this.configAnimation ); }; AnimationItem.prototype.setData = function (wrapper, animationData) { if (animationData) { if (typeof animationData !== 'object') { animationData = JSON.parse(animationData); } } var params = { wrapper: wrapper, animationData: animationData, }; var wrapperAttributes = wrapper.attributes; params.path = wrapperAttributes.getNamedItem('data-animation-path') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-animation-path').value : wrapperAttributes.getNamedItem('data-bm-path') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-bm-path').value : wrapperAttributes.getNamedItem('bm-path') ? wrapperAttributes.getNamedItem('bm-path').value : ''; params.animType = wrapperAttributes.getNamedItem('data-anim-type') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-anim-type').value : wrapperAttributes.getNamedItem('data-bm-type') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-bm-type').value : wrapperAttributes.getNamedItem('bm-type') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('bm-type').value : wrapperAttributes.getNamedItem('data-bm-renderer') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-bm-renderer').value : wrapperAttributes.getNamedItem('bm-renderer') ? wrapperAttributes.getNamedItem('bm-renderer').value : 'canvas'; var loop = wrapperAttributes.getNamedItem('data-anim-loop') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-anim-loop').value : wrapperAttributes.getNamedItem('data-bm-loop') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-bm-loop').value : wrapperAttributes.getNamedItem('bm-loop') ? wrapperAttributes.getNamedItem('bm-loop').value : ''; if (loop === 'false') { params.loop = false; } else if (loop === 'true') { params.loop = true; } else if (loop !== '') { params.loop = parseInt(loop, 10); } var autoplay = wrapperAttributes.getNamedItem('data-anim-autoplay') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-anim-autoplay').value : wrapperAttributes.getNamedItem('data-bm-autoplay') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-bm-autoplay').value : wrapperAttributes.getNamedItem('bm-autoplay') ? wrapperAttributes.getNamedItem('bm-autoplay').value : true; params.autoplay = autoplay !== 'false'; params.name = wrapperAttributes.getNamedItem('data-name') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-name').value : wrapperAttributes.getNamedItem('data-bm-name') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-bm-name').value : wrapperAttributes.getNamedItem('bm-name') ? wrapperAttributes.getNamedItem('bm-name').value : ''; var prerender = wrapperAttributes.getNamedItem('data-anim-prerender') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-anim-prerender').value : wrapperAttributes.getNamedItem('data-bm-prerender') // eslint-disable-line no-nested-ternary ? wrapperAttributes.getNamedItem('data-bm-prerender').value : wrapperAttributes.getNamedItem('bm-prerender') ? wrapperAttributes.getNamedItem('bm-prerender').value : ''; if (prerender === 'false') { params.prerender = false; } this.setParams(params); }; AnimationItem.prototype.includeLayers = function (data) { if (data.op > this.animationData.op) { this.animationData.op = data.op; this.totalFrames = Math.floor(data.op - this.animationData.ip); } var layers = this.animationData.layers; var i; var len = layers.length; var newLayers = data.layers; var j; var jLen = newLayers.length; for (j = 0; j < jLen; j += 1) { i = 0; while (i < len) { if (layers[i].id === newLayers[j].id) { layers[i] = newLayers[j]; break; } i += 1; } } if (data.chars || data.fonts) { this.renderer.globalData.fontManager.addChars(data.chars); this.renderer.globalData.fontManager.addFonts(data.fonts, this.renderer.globalData.defs); } if (data.assets) { len = data.assets.length; for (i = 0; i < len; i += 1) { this.animationData.assets.push(data.assets[i]); } } this.animationData.__complete = false; dataManager.completeAnimation( this.animationData, this.onSegmentComplete ); }; AnimationItem.prototype.onSegmentComplete = function (data) { this.animationData = data; if (expressionsPlugin) { expressionsPlugin.initExpressions(this); } this.loadNextSegment(); }; AnimationItem.prototype.loadNextSegment = function () { var segments = this.animationData.segments; if (!segments || segments.length === 0 || !this.autoloadSegments) { this.trigger('data_ready'); this.timeCompleted = this.totalFrames; return; } var segment = segments.shift(); this.timeCompleted = segment.time * this.frameRate; var segmentPath = this.path + this.fileName + '_' + this.segmentPos + '.json'; this.segmentPos += 1; dataManager.loadData(segmentPath, this.includeLayers.bind(this), function () { this.trigger('data_failed'); }.bind(this)); }; AnimationItem.prototype.loadSegments = function () { var segments = this.animationData.segments; if (!segments) { this.timeCompleted = this.totalFrames; } this.loadNextSegment(); }; AnimationItem.prototype.imagesLoaded = function () { this.trigger('loaded_images'); this.checkLoaded(); }; AnimationItem.prototype.preloadImages = function () { this.imagePreloader.setAssetsPath(this.assetsPath); this.imagePreloader.setPath(this.path); this.imagePreloader.loadAssets(this.animationData.assets, this.imagesLoaded.bind(this)); }; AnimationItem.prototype.configAnimation = function (animData) { if (!this.renderer) { return; } try { this.animationData = animData; if (this.initialSegment) { this.totalFrames = Math.floor(this.initialSegment[1] - this.initialSegment[0]); this.firstFrame = Math.round(this.initialSegment[0]); } else { this.totalFrames = Math.floor(this.animationData.op - this.animationData.ip); this.firstFrame = Math.round(this.animationData.ip); } this.renderer.configAnimation(animData); if (!animData.assets) { animData.assets = []; } this.assets = this.animationData.assets; this.frameRate = this.animationData.fr; this.frameMult = this.animationData.fr / 1000; this.renderer.searchExtraCompositions(animData.assets); this.markers = markerParser(animData.markers || []); this.trigger('config_ready'); this.preloadImages(); this.loadSegments(); this.updaFrameModifier(); this.waitForFontsLoaded(); if (this.isPaused) { this.audioController.pause(); } } catch (error) { this.triggerConfigError(error); } }; AnimationItem.prototype.waitForFontsLoaded = function () { if (!this.renderer) { return; } if (this.renderer.globalData.fontManager.isLoaded) { this.checkLoaded(); } else { setTimeout(this.waitForFontsLoaded.bind(this), 20); } }; AnimationItem.prototype.checkLoaded = function () { if (!this.isLoaded && this.renderer.globalData.fontManager.isLoaded && (this.imagePreloader.loadedImages() || this.renderer.rendererType !== 'canvas') && (this.imagePreloader.loadedFootages()) ) { this.isLoaded = true; if (expressionsPlugin) { expressionsPlugin.initExpressions(this); } this.renderer.initItems(); setTimeout(function () { this.trigger('DOMLoaded'); }.bind(this), 0); this.gotoFrame(); if (this.autoplay) { this.play(); } } }; AnimationItem.prototype.resize = function () { this.renderer.updateContainerSize(); }; AnimationItem.prototype.setSubframe = function (flag) { this.isSubframeEnabled = !!flag; }; AnimationItem.prototype.gotoFrame = function () { this.currentFrame = this.isSubframeEnabled ? this.currentRawFrame : ~~this.currentRawFrame; // eslint-disable-line no-bitwise if (this.timeCompleted !== this.totalFrames && this.currentFrame > this.timeCompleted) { this.currentFrame = this.timeCompleted; } this.trigger('enterFrame'); this.renderFrame(); this.trigger('drawnFrame'); }; AnimationItem.prototype.renderFrame = function () { if (this.isLoaded === false || !this.renderer) { return; } try { this.renderer.renderFrame(this.currentFrame + this.firstFrame); } catch (error) { this.triggerRenderFrameError(error); } }; AnimationItem.prototype.play = function (name) { if (name && this.name !== name) { return; } if (this.isPaused === true) { this.isPaused = false; this.audioController.resume(); if (this._idle) { this._idle = false; this.trigger('_active'); } } }; AnimationItem.prototype.pause = function (name) { if (name && this.name !== name) { return; } if (this.isPaused === false) { this.isPaused = true; this._idle = true; this.trigger('_idle'); this.audioController.pause(); } }; AnimationItem.prototype.togglePause = function (name) { if (name && this.name !== name) { return; } if (this.isPaused === true) { this.play(); } else { this.pause(); } }; AnimationItem.prototype.stop = function (name) { if (name && this.name !== name) { return; } this.pause(); this.playCount = 0; this._completedLoop = false; this.setCurrentRawFrameValue(0); }; AnimationItem.prototype.getMarkerData = function (markerName) { var marker; for (var i = 0; i < this.markers.length; i += 1) { marker = this.markers[i]; if (marker.payload && marker.payload.name === markerName) { return marker; } } return null; }; AnimationItem.prototype.goToAndStop = function (value, isFrame, name) { if (name && this.name !== name) { return; } var numValue = Number(value); if (isNaN(numValue)) { var marker = this.getMarkerData(value); if (marker) { this.goToAndStop(marker.time, true); } } else if (isFrame) { this.setCurrentRawFrameValue(value); } else { this.setCurrentRawFrameValue(value * this.frameModifier); } this.pause(); }; AnimationItem.prototype.goToAndPlay = function (value, isFrame, name) { if (name && this.name !== name) { return; } var numValue = Number(value); if (isNaN(numValue)) { var marker = this.getMarkerData(value); if (marker) { if (!marker.duration) { this.goToAndStop(marker.time, true); } else { this.playSegments([marker.time, marker.time + marker.duration], true); } } } else { this.goToAndStop(numValue, isFrame, name); } this.play(); }; AnimationItem.prototype.advanceTime = function (value) { if (this.isPaused === true || this.isLoaded === false) { return; } var nextValue = this.currentRawFrame + value * this.frameModifier; var _isComplete = false; // Checking if nextValue > totalFrames - 1 for addressing non looping and looping animations. // If animation won't loop, it should stop at totalFrames - 1. If it will loop it should complete the last frame and then loop. if (nextValue >= this.totalFrames - 1 && this.frameModifier > 0) { if (!this.loop || this.playCount === this.loop) { if (!this.checkSegments(nextValue > this.totalFrames ? nextValue % this.totalFrames : 0)) { _isComplete = true; nextValue = this.totalFrames - 1; } } else if (nextValue >= this.totalFrames) { this.playCount += 1; if (!this.checkSegments(nextValue % this.totalFrames)) { this.setCurrentRawFrameValue(nextValue % this.totalFrames); this._completedLoop = true; this.trigger('loopComplete'); } } else { this.setCurrentRawFrameValue(nextValue); } } else if (nextValue < 0) { if (!this.checkSegments(nextValue % this.totalFrames)) { if (this.loop && !(this.playCount-- <= 0 && this.loop !== true)) { // eslint-disable-line no-plusplus this.setCurrentRawFrameValue(this.totalFrames + (nextValue % this.totalFrames)); if (!this._completedLoop) { this._completedLoop = true; } else { this.trigger('loopComplete'); } } else { _isComplete = true; nextValue = 0; } } } else { this.setCurrentRawFrameValue(nextValue); } if (_isComplete) { this.setCurrentRawFrameValue(nextValue); this.pause(); this.trigger('complete'); } }; AnimationItem.prototype.adjustSegment = function (arr, offset) { this.playCount = 0; if (arr[1] < arr[0]) { if (this.frameModifier > 0) { if (this.playSpeed < 0) { this.setSpeed(-this.playSpeed); } else { this.setDirection(-1); } } this.totalFrames = arr[0] - arr[1]; this.timeCompleted = this.totalFrames; this.firstFrame = arr[1]; this.setCurrentRawFrameValue(this.totalFrames - 0.001 - offset); } else if (arr[1] > arr[0]) { if (this.frameModifier < 0) { if (this.playSpeed < 0) { this.setSpeed(-this.playSpeed); } else { this.setDirection(1); } } this.totalFrames = arr[1] - arr[0]; this.timeCompleted = this.totalFrames; this.firstFrame = arr[0]; this.setCurrentRawFrameValue(0.001 + offset); } this.trigger('segmentStart'); }; AnimationItem.prototype.setSegment = function (init, end) { var pendingFrame = -1; if (this.isPaused) { if (this.currentRawFrame + this.firstFrame < init) { pendingFrame = init; } else if (this.currentRawFrame + this.firstFrame > end) { pendingFrame = end - init; } } this.firstFrame = init; this.totalFrames = end - init; this.timeCompleted = this.totalFrames; if (pendingFrame !== -1) { this.goToAndStop(pendingFrame, true); } }; AnimationItem.prototype.playSegments = function (arr, forceFlag) { if (forceFlag) { this.segments.length = 0; } if (typeof arr[0] === 'object') { var i; var len = arr.length; for (i = 0; i < len; i += 1) { this.segments.push(arr[i]); } } else { this.segments.push(arr); } if (this.segments.length && forceFlag) { this.adjustSegment(this.segments.shift(), 0); } if (this.isPaused) { this.play(); } }; AnimationItem.prototype.resetSegments = function (forceFlag) { this.segments.length = 0; this.segments.push([this.animationData.ip, this.animationData.op]); if (forceFlag) { this.checkSegments(0); } }; AnimationItem.prototype.checkSegments = function (offset) { if (this.segments.length) { this.adjustSegment(this.segments.shift(), offset); return true; } return false; }; AnimationItem.prototype.destroy = function (name) { if ((name && this.name !== name) || !this.renderer) { return; } this.renderer.destroy(); this.imagePreloader.destroy(); this.trigger('destroy'); this._cbs = null; this.onEnterFrame = null; this.onLoopComplete = null; this.onComplete = null; this.onSegmentStart = null; this.onDestroy = null; this.renderer = null; this.renderer = null; this.imagePreloader = null; this.projectInterface = null; }; AnimationItem.prototype.setCurrentRawFrameValue = function (value) { this.currentRawFrame = value; this.gotoFrame(); }; AnimationItem.prototype.setSpeed = function (val) { this.playSpeed = val; this.updaFrameModifier(); }; AnimationItem.prototype.setDirection = function (val) { this.playDirection = val < 0 ? -1 : 1; this.updaFrameModifier(); }; AnimationItem.prototype.setVolume = function (val, name) { if (name && this.name !== name) { return; } this.audioController.setVolume(val); }; AnimationItem.prototype.getVolume = function () { return this.audioController.getVolume(); }; AnimationItem.prototype.mute = function (name) { if (name && this.name !== name) { return; } this.audioController.mute(); }; AnimationItem.prototype.unmute = function (name) { if (name && this.name !== name) { return; } this.audioController.unmute(); }; AnimationItem.prototype.updaFrameModifier = function () { this.frameModifier = this.frameMult * this.playSpeed * this.playDirection; this.audioController.setRate(this.playSpeed * this.playDirection); }; AnimationItem.prototype.getPath = function () { return this.path; }; AnimationItem.prototype.getAssetsPath = function (assetData) { var path = ''; if (assetData.e) { path = assetData.p; } else if (this.assetsPath) { var imagePath = assetData.p; if (imagePath.indexOf('images/') !== -1) { imagePath = imagePath.split('/')[1]; } path = this.assetsPath + imagePath; } else { path = this.path; path += assetData.u ? assetData.u : ''; path += assetData.p; } return path; }; AnimationItem.prototype.getAssetData = function (id) { var i = 0; var len = this.assets.length; while (i < len) { if (id === this.assets[i].id) { return this.assets[i]; } i += 1; } return null; }; AnimationItem.prototype.hide = function () { this.renderer.hide(); }; AnimationItem.prototype.show = function () { this.renderer.show(); }; AnimationItem.prototype.getDuration = function (isFrame) { return isFrame ? this.totalFrames : this.totalFrames / this.frameRate; }; AnimationItem.prototype.trigger = function (name) { if (this._cbs && this._cbs[name]) { switch (name) { case 'enterFrame': case 'drawnFrame': this.triggerEvent(name, new BMEnterFrameEvent(name, this.currentFrame, this.totalFrames, this.frameModifier)); break; case 'loopComplete': this.triggerEvent(name, new BMCompleteLoopEvent(name, this.loop, this.playCount, this.frameMult)); break; case 'complete': this.triggerEvent(name, new BMCompleteEvent(name, this.frameMult)); break; case 'segmentStart': this.triggerEvent(name, new BMSegmentStartEvent(name, this.firstFrame, this.totalFrames)); break; case 'destroy': this.triggerEvent(name, new BMDestroyEvent(name, this)); break; default: this.triggerEvent(name); } } if (name === 'enterFrame' && this.onEnterFrame) { this.onEnterFrame.call(this, new BMEnterFrameEvent(name, this.currentFrame, this.totalFrames, this.frameMult)); } if (name === 'loopComplete' && this.onLoopComplete) { this.onLoopComplete.call(this, new BMCompleteLoopEvent(name, this.loop, this.playCount, this.frameMult)); } if (name === 'complete' && this.onComplete) { this.onComplete.call(this, new BMCompleteEvent(name, this.frameMult)); } if (name === 'segmentStart' && this.onSegmentStart) { this.onSegmentStart.call(this, new BMSegmentStartEvent(name, this.firstFrame, this.totalFrames)); } if (name === 'destroy' && this.onDestroy) { this.onDestroy.call(this, new BMDestroyEvent(name, this)); } }; AnimationItem.prototype.triggerRenderFrameError = function (nativeError) { var error = new BMRenderFrameErrorEvent(nativeError, this.currentFrame); this.triggerEvent('error', error); if (this.onError) { this.onError.call(this, error); } }; AnimationItem.prototype.triggerConfigError = function (nativeError) { var error = new BMConfigErrorEvent(nativeError, this.currentFrame); this.triggerEvent('error', error); if (this.onError) { this.onError.call(this, error); } }; /* global CompExpressionInterface, expressionsPlugin: writable */ /* exported expressionsPlugin */ var Expressions = (function () { var ob = {}; ob.initExpressions = initExpressions; function initExpressions(animation) { var stackCount = 0; var registers = []; function pushExpression() { stackCount += 1; } function popExpression() { stackCount -= 1; if (stackCount === 0) { releaseInstances(); } } function registerExpressionProperty(expression) { if (registers.indexOf(expression) === -1) { registers.push(expression); } } function releaseInstances() { var i; var len = registers.length; for (i = 0; i < len; i += 1) { registers[i].release(); } registers.length = 0; } animation.renderer.compInterface = CompExpressionInterface(animation.renderer); animation.renderer.globalData.projectInterface.registerComposition(animation.renderer); animation.renderer.globalData.pushExpression = pushExpression; animation.renderer.globalData.popExpression = popExpression; animation.renderer.globalData.registerExpressionProperty = registerExpressionProperty; } return ob; }()); expressionsPlugin = Expressions; /* eslint-disable camelcase, no-unused-vars */ /* global BMMath, BezierFactory, createTypedArray, degToRads, shapePool */ var ExpressionManager = (function () { 'use strict'; var ob = {}; var Math = BMMath; var window = null; var document = null; var XMLHttpRequest = null; var fetch = null; var frames = null; function $bm_isInstanceOfArray(arr) { return arr.constructor === Array || arr.constructor === Float32Array; } function isNumerable(tOfV, v) { return tOfV === 'number' || tOfV === 'boolean' || tOfV === 'string' || v instanceof Number; } function $bm_neg(a) { var tOfA = typeof a; if (tOfA === 'number' || tOfA === 'boolean' || a instanceof Number) { return -a; } if ($bm_isInstanceOfArray(a)) { var i; var lenA = a.length; var retArr = []; for (i = 0; i < lenA; i += 1) { retArr[i] = -a[i]; } return retArr; } if (a.propType) { return a.v; } return -a; } var easeInBez = BezierFactory.getBezierEasing(0.333, 0, 0.833, 0.833, 'easeIn').get; var easeOutBez = BezierFactory.getBezierEasing(0.167, 0.167, 0.667, 1, 'easeOut').get; var easeInOutBez = BezierFactory.getBezierEasing(0.33, 0, 0.667, 1, 'easeInOut').get; function sum(a, b) { var tOfA = typeof a; var tOfB = typeof b; if (tOfA === 'string' || tOfB === 'string') { return a + b; } if (isNumerable(tOfA, a) && isNumerable(tOfB, b)) { return a + b; } if ($bm_isInstanceOfArray(a) && isNumerable(tOfB, b)) { a = a.slice(0); a[0] += b; return a; } if (isNumerable(tOfA, a) && $bm_isInstanceOfArray(b)) { b = b.slice(0); b[0] = a + b[0]; return b; } if ($bm_isInstanceOfArray(a) && $bm_isInstanceOfArray(b)) { var i = 0; var lenA = a.length; var lenB = b.length; var retArr = []; while (i < lenA || i < lenB) { if ((typeof a[i] === 'number' || a[i] instanceof Number) && (typeof b[i] === 'number' || b[i] instanceof Number)) { retArr[i] = a[i] + b[i]; } else { retArr[i] = b[i] === undefined ? a[i] : a[i] || b[i]; } i += 1; } return retArr; } return 0; } var add = sum; function sub(a, b) { var tOfA = typeof a; var tOfB = typeof b; if (isNumerable(tOfA, a) && isNumerable(tOfB, b)) { if (tOfA === 'string') { a = parseInt(a, 10); } if (tOfB === 'string') { b = parseInt(b, 10); } return a - b; } if ($bm_isInstanceOfArray(a) && isNumerable(tOfB, b)) { a = a.slice(0); a[0] -= b; return a; } if (isNumerable(tOfA, a) && $bm_isInstanceOfArray(b)) { b = b.slice(0); b[0] = a - b[0]; return b; } if ($bm_isInstanceOfArray(a) && $bm_isInstanceOfArray(b)) { var i = 0; var lenA = a.length; var lenB = b.length; var retArr = []; while (i < lenA || i < lenB) { if ((typeof a[i] === 'number' || a[i] instanceof Number) && (typeof b[i] === 'number' || b[i] instanceof Number)) { retArr[i] = a[i] - b[i]; } else { retArr[i] = b[i] === undefined ? a[i] : a[i] || b[i]; } i += 1; } return retArr; } return 0; } function mul(a, b) { var tOfA = typeof a; var tOfB = typeof b; var arr; if (isNumerable(tOfA, a) && isNumerable(tOfB, b)) { return a * b; } var i; var len; if ($bm_isInstanceOfArray(a) && isNumerable(tOfB, b)) { len = a.length; arr = createTypedArray('float32', len); for (i = 0; i < len; i += 1) { arr[i] = a[i] * b; } return arr; } if (isNumerable(tOfA, a) && $bm_isInstanceOfArray(b)) { len = b.length; arr = createTypedArray('float32', len); for (i = 0; i < len; i += 1) { arr[i] = a * b[i]; } return arr; } return 0; } function div(a, b) { var tOfA = typeof a; var tOfB = typeof b; var arr; if (isNumerable(tOfA, a) && isNumerable(tOfB, b)) { return a / b; } var i; var len; if ($bm_isInstanceOfArray(a) && isNumerable(tOfB, b)) { len = a.length; arr = createTypedArray('float32', len); for (i = 0; i < len; i += 1) { arr[i] = a[i] / b; } return arr; } if (isNumerable(tOfA, a) && $bm_isInstanceOfArray(b)) { len = b.length; arr = createTypedArray('float32', len); for (i = 0; i < len; i += 1) { arr[i] = a / b[i]; } return arr; } return 0; } function mod(a, b) { if (typeof a === 'string') { a = parseInt(a, 10); } if (typeof b === 'string') { b = parseInt(b, 10); } return a % b; } var $bm_sum = sum; var $bm_sub = sub; var $bm_mul = mul; var $bm_div = div; var $bm_mod = mod; function clamp(num, min, max) { if (min > max) { var mm = max; max = min; min = mm; } return Math.min(Math.max(num, min), max); } function radiansToDegrees(val) { return val / degToRads; } var radians_to_degrees = radiansToDegrees; function degreesToRadians(val) { return val * degToRads; } var degrees_to_radians = radiansToDegrees; var helperLengthArray = [0, 0, 0, 0, 0, 0]; function length(arr1, arr2) { if (typeof arr1 === 'number' || arr1 instanceof Number) { arr2 = arr2 || 0; return Math.abs(arr1 - arr2); } if (!arr2) { arr2 = helperLengthArray; } var i; var len = Math.min(arr1.length, arr2.length); var addedLength = 0; for (i = 0; i < len; i += 1) { addedLength += Math.pow(arr2[i] - arr1[i], 2); } return Math.sqrt(addedLength); } function normalize(vec) { return div(vec, length(vec)); } function rgbToHsl(val) { var r = val[0]; var g = val[1]; var b = val[2]; var max = Math.max(r, g, b); var min = Math.min(r, g, b); var h; var s; var l = (max + min) / 2; if (max === min) { h = 0; // achromatic s = 0; // achromatic } else { var d = max - min; s = l > 0.5 ? d / (2 - max - min) : d / (max + min); switch (max) { case r: h = (g - b) / d + (g < b ? 6 : 0); break; case g: h = (b - r) / d + 2; break; case b: h = (r - g) / d + 4; break; default: break; } h /= 6; } return [h, s, l, val[3]]; } function hue2rgb(p, q, t) { if (t < 0) t += 1; if (t > 1) t -= 1; if (t < 1 / 6) return p + (q - p) * 6 * t; if (t < 1 / 2) return q; if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6; return p; } function hslToRgb(val) { var h = val[0]; var s = val[1]; var l = val[2]; var r; var g; var b; if (s === 0) { r = l; // achromatic b = l; // achromatic g = l; // achromatic } else { var q = l < 0.5 ? l * (1 + s) : l + s - l * s; var p = 2 * l - q; r = hue2rgb(p, q, h + 1 / 3); g = hue2rgb(p, q, h); b = hue2rgb(p, q, h - 1 / 3); } return [r, g, b, val[3]]; } function linear(t, tMin, tMax, value1, value2) { if (value1 === undefined || value2 === undefined) { value1 = tMin; value2 = tMax; tMin = 0; tMax = 1; } if (tMax < tMin) { var _tMin = tMax; tMax = tMin; tMin = _tMin; } if (t <= tMin) { return value1; } if (t >= tMax) { return value2; } var perc = tMax === tMin ? 0 : (t - tMin) / (tMax - tMin); if (!value1.length) { return value1 + (value2 - value1) * perc; } var i; var len = value1.length; var arr = createTypedArray('float32', len); for (i = 0; i < len; i += 1) { arr[i] = value1[i] + (value2[i] - value1[i]) * perc; } return arr; } function random(min, max) { if (max === undefined) { if (min === undefined) { min = 0; max = 1; } else { max = min; min = undefined; } } if (max.length) { var i; var len = max.length; if (!min) { min = createTypedArray('float32', len); } var arr = createTypedArray('float32', len); var rnd = BMMath.random(); for (i = 0; i < len; i += 1) { arr[i] = min[i] + rnd * (max[i] - min[i]); } return arr; } if (min === undefined) { min = 0; } var rndm = BMMath.random(); return min + rndm * (max - min); } function createPath(points, inTangents, outTangents, closed) { var i; var len = points.length; var path = shapePool.newElement(); path.setPathData(!!closed, len); var arrPlaceholder = [0, 0]; var inVertexPoint; var outVertexPoint; for (i = 0; i < len; i += 1) { inVertexPoint = (inTangents && inTangents[i]) ? inTangents[i] : arrPlaceholder; outVertexPoint = (outTangents && outTangents[i]) ? outTangents[i] : arrPlaceholder; path.setTripleAt(points[i][0], points[i][1], outVertexPoint[0] + points[i][0], outVertexPoint[1] + points[i][1], inVertexPoint[0] + points[i][0], inVertexPoint[1] + points[i][1], i, true); } return path; } function initiateExpression(elem, data, property) { var val = data.x; var needsVelocity = /velocity(?![\w\d])/.test(val); var _needsRandom = val.indexOf('random') !== -1; var elemType = elem.data.ty; var transform; var $bm_transform; var content; var effect; var thisProperty = property; thisProperty.valueAtTime = thisProperty.getValueAtTime; Object.defineProperty(thisProperty, 'value', { get: function () { return thisProperty.v; }, }); elem.comp.frameDuration = 1 / elem.comp.globalData.frameRate; elem.comp.displayStartTime = 0; var inPoint = elem.data.ip / elem.comp.globalData.frameRate; var outPoint = elem.data.op / elem.comp.globalData.frameRate; var width = elem.data.sw ? elem.data.sw : 0; var height = elem.data.sh ? elem.data.sh : 0; var name = elem.data.nm; var loopIn; var loop_in; var loopOut; var loop_out; var smooth; var toWorld; var fromWorld; var fromComp; var toComp; var fromCompToSurface; var position; var rotation; var anchorPoint; var scale; var thisLayer; var thisComp; var mask; var valueAtTime; var velocityAtTime; var scoped_bm_rt; // val = val.replace(/(\\?"|')((http)(s)?(:\/))?\/.*?(\\?"|')/g, "\"\""); // deter potential network calls var expression_function = eval('[function _expression_function(){' + val + ';scoped_bm_rt=$bm_rt}]')[0]; // eslint-disable-line no-eval var numKeys = property.kf ? data.k.length : 0; var active = !this.data || this.data.hd !== true; var wiggle = function wiggle(freq, amp) { var iWiggle; var j; var lenWiggle = this.pv.length ? this.pv.length : 1; var addedAmps = createTypedArray('float32', lenWiggle); freq = 5; var iterations = Math.floor(time * freq); iWiggle = 0; j = 0; while (iWiggle < iterations) { // var rnd = BMMath.random(); for (j = 0; j < lenWiggle; j += 1) { addedAmps[j] += -amp + amp * 2 * BMMath.random(); // addedAmps[j] += -amp + amp*2*rnd; } iWiggle += 1; } // var rnd2 = BMMath.random(); var periods = time * freq; var perc = periods - Math.floor(periods); var arr = createTypedArray('float32', lenWiggle); if (lenWiggle > 1) { for (j = 0; j < lenWiggle; j += 1) { arr[j] = this.pv[j] + addedAmps[j] + (-amp + amp * 2 * BMMath.random()) * perc; // arr[j] = this.pv[j] + addedAmps[j] + (-amp + amp*2*rnd)*perc; // arr[i] = this.pv[i] + addedAmp + amp1*perc + amp2*(1-perc); } return arr; } return this.pv + addedAmps[0] + (-amp + amp * 2 * BMMath.random()) * perc; }.bind(this); if (thisProperty.loopIn) { loopIn = thisProperty.loopIn.bind(thisProperty); loop_in = loopIn; } if (thisProperty.loopOut) { loopOut = thisProperty.loopOut.bind(thisProperty); loop_out = loopOut; } if (thisProperty.smooth) { smooth = thisProperty.smooth.bind(thisProperty); } function loopInDuration(type, duration) { return loopIn(type, duration, true); } function loopOutDuration(type, duration) { return loopOut(type, duration, true); } if (this.getValueAtTime) { valueAtTime = this.getValueAtTime.bind(this); } if (this.getVelocityAtTime) { velocityAtTime = this.getVelocityAtTime.bind(this); } var comp = elem.comp.globalData.projectInterface.bind(elem.comp.globalData.projectInterface); function lookAt(elem1, elem2) { var fVec = [elem2[0] - elem1[0], elem2[1] - elem1[1], elem2[2] - elem1[2]]; var pitch = Math.atan2(fVec[0], Math.sqrt(fVec[1] * fVec[1] + fVec[2] * fVec[2])) / degToRads; var yaw = -Math.atan2(fVec[1], fVec[2]) / degToRads; return [yaw, pitch, 0]; } function easeOut(t, tMin, tMax, val1, val2) { return applyEase(easeOutBez, t, tMin, tMax, val1, val2); } function easeIn(t, tMin, tMax, val1, val2) { return applyEase(easeInBez, t, tMin, tMax, val1, val2); } function ease(t, tMin, tMax, val1, val2) { return applyEase(easeInOutBez, t, tMin, tMax, val1, val2); } function applyEase(fn, t, tMin, tMax, val1, val2) { if (val1 === undefined) { val1 = tMin; val2 = tMax; } else { t = (t - tMin) / (tMax - tMin); } if (t > 1) { t = 1; } else if (t < 0) { t = 0; } var mult = fn(t); if ($bm_isInstanceOfArray(val1)) { var iKey; var lenKey = val1.length; var arr = createTypedArray('float32', lenKey); for (iKey = 0; iKey < lenKey; iKey += 1) { arr[iKey] = (val2[iKey] - val1[iKey]) * mult + val1[iKey]; } return arr; } return (val2 - val1) * mult + val1; } function nearestKey(time) { var iKey; var lenKey = data.k.length; var index; var keyTime; if (!data.k.length || typeof (data.k[0]) === 'number') { index = 0; keyTime = 0; } else { index = -1; time *= elem.comp.globalData.frameRate; if (time < data.k[0].t) { index = 1; keyTime = data.k[0].t; } else { for (iKey = 0; iKey < lenKey - 1; iKey += 1) { if (time === data.k[iKey].t) { index = iKey + 1; keyTime = data.k[iKey].t; break; } else if (time > data.k[iKey].t && time < data.k[iKey + 1].t) { if (time - data.k[iKey].t > data.k[iKey + 1].t - time) { index = iKey + 2; keyTime = data.k[iKey + 1].t; } else { index = iKey + 1; keyTime = data.k[iKey].t; } break; } } if (index === -1) { index = iKey + 1; keyTime = data.k[iKey].t; } } } var obKey = {}; obKey.index = index; obKey.time = keyTime / elem.comp.globalData.frameRate; return obKey; } function key(ind) { var obKey; var iKey; var lenKey; if (!data.k.length || typeof (data.k[0]) === 'number') { throw new Error('The property has no keyframe at index ' + ind); } ind -= 1; obKey = { time: data.k[ind].t / elem.comp.globalData.frameRate, value: [], }; var arr = Object.prototype.hasOwnProperty.call(data.k[ind], 's') ? data.k[ind].s : data.k[ind - 1].e; lenKey = arr.length; for (iKey = 0; iKey < lenKey; iKey += 1) { obKey[iKey] = arr[iKey]; obKey.value[iKey] = arr[iKey]; } return obKey; } function framesToTime(fr, fps) { if (!fps) { fps = elem.comp.globalData.frameRate; } return fr / fps; } function timeToFrames(t, fps) { if (!t && t !== 0) { t = time; } if (!fps) { fps = elem.comp.globalData.frameRate; } return t * fps; } function seedRandom(seed) { BMMath.seedrandom(randSeed + seed); } function sourceRectAtTime() { return elem.sourceRectAtTime(); } function substring(init, end) { if (typeof value === 'string') { if (end === undefined) { return value.substring(init); } return value.substring(init, end); } return ''; } function substr(init, end) { if (typeof value === 'string') { if (end === undefined) { return value.substr(init); } return value.substr(init, end); } return ''; } function posterizeTime(framesPerSecond) { time = framesPerSecond === 0 ? 0 : Math.floor(time * framesPerSecond) / framesPerSecond; value = valueAtTime(time); } var time; var velocity; var value; var text; var textIndex; var textTotal; var selectorValue; var index = elem.data.ind; var hasParent = !!(elem.hierarchy && elem.hierarchy.length); var parent; var randSeed = Math.floor(Math.random() * 1000000); var globalData = elem.globalData; function executeExpression(_value) { // globalData.pushExpression(); value = _value; if (this.frameExpressionId === elem.globalData.frameId && this.propType !== 'textSelector') { return value; } if (this.propType === 'textSelector') { textIndex = this.textIndex; textTotal = this.textTotal; selectorValue = this.selectorValue; } if (!thisLayer) { text = elem.layerInterface.text; thisLayer = elem.layerInterface; thisComp = elem.comp.compInterface; toWorld = thisLayer.toWorld.bind(thisLayer); fromWorld = thisLayer.fromWorld.bind(thisLayer); fromComp = thisLayer.fromComp.bind(thisLayer); toComp = thisLayer.toComp.bind(thisLayer); mask = thisLayer.mask ? thisLayer.mask.bind(thisLayer) : null; fromCompToSurface = fromComp; } if (!transform) { transform = elem.layerInterface('ADBE Transform Group'); $bm_transform = transform; if (transform) { anchorPoint = transform.anchorPoint; /* position = transform.position; rotation = transform.rotation; scale = transform.scale; */ } } if (elemType === 4 && !content) { content = thisLayer('ADBE Root Vectors Group'); } if (!effect) { effect = thisLayer(4); } hasParent = !!(elem.hierarchy && elem.hierarchy.length); if (hasParent && !parent) { parent = elem.hierarchy[0].layerInterface; } time = this.comp.renderedFrame / this.comp.globalData.frameRate; if (_needsRandom) { seedRandom(randSeed + time); } if (needsVelocity) { velocity = velocityAtTime(time); } expression_function(); this.frameExpressionId = elem.globalData.frameId; // TODO: Check if it's possible to return on ShapeInterface the .v value if (scoped_bm_rt.propType === 'shape') { scoped_bm_rt = scoped_bm_rt.v; } // globalData.popExpression(); return scoped_bm_rt; } return executeExpression; } ob.initiateExpression = initiateExpression; return ob; }()); /* global ExpressionManager, createTypedArray */ /* exported expressionHelpers */ var expressionHelpers = (function () { function searchExpressions(elem, data, prop) { if (data.x) { prop.k = true; prop.x = true; prop.initiateExpression = ExpressionManager.initiateExpression; prop.effectsSequence.push(prop.initiateExpression(elem, data, prop).bind(prop)); } } function getValueAtTime(frameNum) { frameNum *= this.elem.globalData.frameRate; frameNum -= this.offsetTime; if (frameNum !== this._cachingAtTime.lastFrame) { this._cachingAtTime.lastIndex = this._cachingAtTime.lastFrame < frameNum ? this._cachingAtTime.lastIndex : 0; this._cachingAtTime.value = this.interpolateValue(frameNum, this._cachingAtTime); this._cachingAtTime.lastFrame = frameNum; } return this._cachingAtTime.value; } function getSpeedAtTime(frameNum) { var delta = -0.01; var v1 = this.getValueAtTime(frameNum); var v2 = this.getValueAtTime(frameNum + delta); var speed = 0; if (v1.length) { var i; for (i = 0; i < v1.length; i += 1) { speed += Math.pow(v2[i] - v1[i], 2); } speed = Math.sqrt(speed) * 100; } else { speed = 0; } return speed; } function getVelocityAtTime(frameNum) { if (this.vel !== undefined) { return this.vel; } var delta = -0.001; // frameNum += this.elem.data.st; var v1 = this.getValueAtTime(frameNum); var v2 = this.getValueAtTime(frameNum + delta); var velocity; if (v1.length) { velocity = createTypedArray('float32', v1.length); var i; for (i = 0; i < v1.length; i += 1) { // removing frameRate // if needed, don't add it here // velocity[i] = this.elem.globalData.frameRate*((v2[i] - v1[i])/delta); velocity[i] = (v2[i] - v1[i]) / delta; } } else { velocity = (v2 - v1) / delta; } return velocity; } function getStaticValueAtTime() { return this.pv; } function setGroupProperty(propertyGroup) { this.propertyGroup = propertyGroup; } return { searchExpressions: searchExpressions, getSpeedAtTime: getSpeedAtTime, getVelocityAtTime: getVelocityAtTime, getValueAtTime: getValueAtTime, getStaticValueAtTime: getStaticValueAtTime, setGroupProperty: setGroupProperty, }; }()); /* global createTypedArray, Matrix, TransformPropertyFactory, expressionHelpers, PropertyFactory, expressionHelpers, initialDefaultFrame, shapePool, ShapePropertyFactory, bez, extendPrototype, ExpressionManager, createSizedArray */ (function addPropertyDecorator() { function loopOut(type, duration, durationFlag) { if (!this.k || !this.keyframes) { return this.pv; } type = type ? type.toLowerCase() : ''; var currentFrame = this.comp.renderedFrame; var keyframes = this.keyframes; var lastKeyFrame = keyframes[keyframes.length - 1].t; if (currentFrame <= lastKeyFrame) { return this.pv; } var cycleDuration; var firstKeyFrame; if (!durationFlag) { if (!duration || duration > keyframes.length - 1) { duration = keyframes.length - 1; } firstKeyFrame = keyframes[keyframes.length - 1 - duration].t; cycleDuration = lastKeyFrame - firstKeyFrame; } else { if (!duration) { cycleDuration = Math.max(0, lastKeyFrame - this.elem.data.ip); } else { cycleDuration = Math.abs(lastKeyFrame - this.elem.comp.globalData.frameRate * duration); } firstKeyFrame = lastKeyFrame - cycleDuration; } var i; var len; var ret; if (type === 'pingpong') { var iterations = Math.floor((currentFrame - firstKeyFrame) / cycleDuration); if (iterations % 2 !== 0) { return this.getValueAtTime(((cycleDuration - (currentFrame - firstKeyFrame) % cycleDuration + firstKeyFrame)) / this.comp.globalData.frameRate, 0); // eslint-disable-line } } else if (type === 'offset') { var initV = this.getValueAtTime(firstKeyFrame / this.comp.globalData.frameRate, 0); var endV = this.getValueAtTime(lastKeyFrame / this.comp.globalData.frameRate, 0); var current = this.getValueAtTime(((currentFrame - firstKeyFrame) % cycleDuration + firstKeyFrame) / this.comp.globalData.frameRate, 0); // eslint-disable-line var repeats = Math.floor((currentFrame - firstKeyFrame) / cycleDuration); if (this.pv.length) { ret = new Array(initV.length); len = ret.length; for (i = 0; i < len; i += 1) { ret[i] = (endV[i] - initV[i]) * repeats + current[i]; } return ret; } return (endV - initV) * repeats + current; } else if (type === 'continue') { var lastValue = this.getValueAtTime(lastKeyFrame / this.comp.globalData.frameRate, 0); var nextLastValue = this.getValueAtTime((lastKeyFrame - 0.001) / this.comp.globalData.frameRate, 0); if (this.pv.length) { ret = new Array(lastValue.length); len = ret.length; for (i = 0; i < len; i += 1) { ret[i] = lastValue[i] + (lastValue[i] - nextLastValue[i]) * ((currentFrame - lastKeyFrame) / this.comp.globalData.frameRate) / 0.0005; // eslint-disable-line } return ret; } return lastValue + (lastValue - nextLastValue) * (((currentFrame - lastKeyFrame)) / 0.001); } return this.getValueAtTime((((currentFrame - firstKeyFrame) % cycleDuration + firstKeyFrame)) / this.comp.globalData.frameRate, 0); // eslint-disable-line } function loopIn(type, duration, durationFlag) { if (!this.k) { return this.pv; } type = type ? type.toLowerCase() : ''; var currentFrame = this.comp.renderedFrame; var keyframes = this.keyframes; var firstKeyFrame = keyframes[0].t; if (currentFrame >= firstKeyFrame) { return this.pv; } var cycleDuration; var lastKeyFrame; if (!durationFlag) { if (!duration || duration > keyframes.length - 1) { duration = keyframes.length - 1; } lastKeyFrame = keyframes[duration].t; cycleDuration = lastKeyFrame - firstKeyFrame; } else { if (!duration) { cycleDuration = Math.max(0, this.elem.data.op - firstKeyFrame); } else { cycleDuration = Math.abs(this.elem.comp.globalData.frameRate * duration); } lastKeyFrame = firstKeyFrame + cycleDuration; } var i; var len; var ret; if (type === 'pingpong') { var iterations = Math.floor((firstKeyFrame - currentFrame) / cycleDuration); if (iterations % 2 === 0) { return this.getValueAtTime((((firstKeyFrame - currentFrame) % cycleDuration + firstKeyFrame)) / this.comp.globalData.frameRate, 0); // eslint-disable-line } } else if (type === 'offset') { var initV = this.getValueAtTime(firstKeyFrame / this.comp.globalData.frameRate, 0); var endV = this.getValueAtTime(lastKeyFrame / this.comp.globalData.frameRate, 0); var current = this.getValueAtTime((cycleDuration - ((firstKeyFrame - currentFrame) % cycleDuration) + firstKeyFrame) / this.comp.globalData.frameRate, 0); var repeats = Math.floor((firstKeyFrame - currentFrame) / cycleDuration) + 1; if (this.pv.length) { ret = new Array(initV.length); len = ret.length; for (i = 0; i < len; i += 1) { ret[i] = current[i] - (endV[i] - initV[i]) * repeats; } return ret; } return current - (endV - initV) * repeats; } else if (type === 'continue') { var firstValue = this.getValueAtTime(firstKeyFrame / this.comp.globalData.frameRate, 0); var nextFirstValue = this.getValueAtTime((firstKeyFrame + 0.001) / this.comp.globalData.frameRate, 0); if (this.pv.length) { ret = new Array(firstValue.length); len = ret.length; for (i = 0; i < len; i += 1) { ret[i] = firstValue[i] + ((firstValue[i] - nextFirstValue[i]) * (firstKeyFrame - currentFrame)) / 0.001; } return ret; } return firstValue + ((firstValue - nextFirstValue) * (firstKeyFrame - currentFrame)) / 0.001; } return this.getValueAtTime(((cycleDuration - ((firstKeyFrame - currentFrame) % cycleDuration + firstKeyFrame))) / this.comp.globalData.frameRate, 0); // eslint-disable-line } function smooth(width, samples) { if (!this.k) { return this.pv; } width = (width || 0.4) * 0.5; samples = Math.floor(samples || 5); if (samples <= 1) { return this.pv; } var currentTime = this.comp.renderedFrame / this.comp.globalData.frameRate; var initFrame = currentTime - width; var endFrame = currentTime + width; var sampleFrequency = samples > 1 ? (endFrame - initFrame) / (samples - 1) : 1; var i = 0; var j = 0; var value; if (this.pv.length) { value = createTypedArray('float32', this.pv.length); } else { value = 0; } var sampleValue; while (i < samples) { sampleValue = this.getValueAtTime(initFrame + i * sampleFrequency); if (this.pv.length) { for (j = 0; j < this.pv.length; j += 1) { value[j] += sampleValue[j]; } } else { value += sampleValue; } i += 1; } if (this.pv.length) { for (j = 0; j < this.pv.length; j += 1) { value[j] /= samples; } } else { value /= samples; } return value; } function getTransformValueAtTime(time) { if (!this._transformCachingAtTime) { this._transformCachingAtTime = { v: new Matrix(), }; } /// / var matrix = this._transformCachingAtTime.v; matrix.cloneFromProps(this.pre.props); if (this.appliedTransformations < 1) { var anchor = this.a.getValueAtTime(time); matrix.translate( -anchor[0] * this.a.mult, -anchor[1] * this.a.mult, anchor[2] * this.a.mult ); } if (this.appliedTransformations < 2) { var scale = this.s.getValueAtTime(time); matrix.scale( scale[0] * this.s.mult, scale[1] * this.s.mult, scale[2] * this.s.mult ); } if (this.sk && this.appliedTransformations < 3) { var skew = this.sk.getValueAtTime(time); var skewAxis = this.sa.getValueAtTime(time); matrix.skewFromAxis(-skew * this.sk.mult, skewAxis * this.sa.mult); } if (this.r && this.appliedTransformations < 4) { var rotation = this.r.getValueAtTime(time); matrix.rotate(-rotation * this.r.mult); } else if (!this.r && this.appliedTransformations < 4) { var rotationZ = this.rz.getValueAtTime(time); var rotationY = this.ry.getValueAtTime(time); var rotationX = this.rx.getValueAtTime(time); var orientation = this.or.getValueAtTime(time); matrix.rotateZ(-rotationZ * this.rz.mult) .rotateY(rotationY * this.ry.mult) .rotateX(rotationX * this.rx.mult) .rotateZ(-orientation[2] * this.or.mult) .rotateY(orientation[1] * this.or.mult) .rotateX(orientation[0] * this.or.mult); } if (this.data.p && this.data.p.s) { var positionX = this.px.getValueAtTime(time); var positionY = this.py.getValueAtTime(time); if (this.data.p.z) { var positionZ = this.pz.getValueAtTime(time); matrix.translate( positionX * this.px.mult, positionY * this.py.mult, -positionZ * this.pz.mult ); } else { matrix.translate(positionX * this.px.mult, positionY * this.py.mult, 0); } } else { var position = this.p.getValueAtTime(time); matrix.translate( position[0] * this.p.mult, position[1] * this.p.mult, -position[2] * this.p.mult ); } return matrix; /// / } function getTransformStaticValueAtTime() { return this.v.clone(new Matrix()); } var getTransformProperty = TransformPropertyFactory.getTransformProperty; TransformPropertyFactory.getTransformProperty = function (elem, data, container) { var prop = getTransformProperty(elem, data, container); if (prop.dynamicProperties.length) { prop.getValueAtTime = getTransformValueAtTime.bind(prop); } else { prop.getValueAtTime = getTransformStaticValueAtTime.bind(prop); } prop.setGroupProperty = expressionHelpers.setGroupProperty; return prop; }; var propertyGetProp = PropertyFactory.getProp; PropertyFactory.getProp = function (elem, data, type, mult, container) { var prop = propertyGetProp(elem, data, type, mult, container); // prop.getVelocityAtTime = getVelocityAtTime; // prop.loopOut = loopOut; // prop.loopIn = loopIn; if (prop.kf) { prop.getValueAtTime = expressionHelpers.getValueAtTime.bind(prop); } else { prop.getValueAtTime = expressionHelpers.getStaticValueAtTime.bind(prop); } prop.setGroupProperty = expressionHelpers.setGroupProperty; prop.loopOut = loopOut; prop.loopIn = loopIn; prop.smooth = smooth; prop.getVelocityAtTime = expressionHelpers.getVelocityAtTime.bind(prop); prop.getSpeedAtTime = expressionHelpers.getSpeedAtTime.bind(prop); prop.numKeys = data.a === 1 ? data.k.length : 0; prop.propertyIndex = data.ix; var value = 0; if (type !== 0) { value = createTypedArray('float32', data.a === 1 ? data.k[0].s.length : data.k.length); } prop._cachingAtTime = { lastFrame: initialDefaultFrame, lastIndex: 0, value: value, }; expressionHelpers.searchExpressions(elem, data, prop); if (prop.k) { container.addDynamicProperty(prop); } return prop; }; function getShapeValueAtTime(frameNum) { // For now this caching object is created only when needed instead of creating it when the shape is initialized. if (!this._cachingAtTime) { this._cachingAtTime = { shapeValue: shapePool.clone(this.pv), lastIndex: 0, lastTime: initialDefaultFrame, }; } frameNum *= this.elem.globalData.frameRate; frameNum -= this.offsetTime; if (frameNum !== this._cachingAtTime.lastTime) { this._cachingAtTime.lastIndex = this._cachingAtTime.lastTime < frameNum ? this._caching.lastIndex : 0; this._cachingAtTime.lastTime = frameNum; this.interpolateShape(frameNum, this._cachingAtTime.shapeValue, this._cachingAtTime); } return this._cachingAtTime.shapeValue; } var ShapePropertyConstructorFunction = ShapePropertyFactory.getConstructorFunction(); var KeyframedShapePropertyConstructorFunction = ShapePropertyFactory.getKeyframedConstructorFunction(); function ShapeExpressions() {} ShapeExpressions.prototype = { vertices: function (prop, time) { if (this.k) { this.getValue(); } var shapePath = this.v; if (time !== undefined) { shapePath = this.getValueAtTime(time, 0); } var i; var len = shapePath._length; var vertices = shapePath[prop]; var points = shapePath.v; var arr = createSizedArray(len); for (i = 0; i < len; i += 1) { if (prop === 'i' || prop === 'o') { arr[i] = [vertices[i][0] - points[i][0], vertices[i][1] - points[i][1]]; } else { arr[i] = [vertices[i][0], vertices[i][1]]; } } return arr; }, points: function (time) { return this.vertices('v', time); }, inTangents: function (time) { return this.vertices('i', time); }, outTangents: function (time) { return this.vertices('o', time); }, isClosed: function () { return this.v.c; }, pointOnPath: function (perc, time) { var shapePath = this.v; if (time !== undefined) { shapePath = this.getValueAtTime(time, 0); } if (!this._segmentsLength) { this._segmentsLength = bez.getSegmentsLength(shapePath); } var segmentsLength = this._segmentsLength; var lengths = segmentsLength.lengths; var lengthPos = segmentsLength.totalLength * perc; var i = 0; var len = lengths.length; var accumulatedLength = 0; var pt; while (i < len) { if (accumulatedLength + lengths[i].addedLength > lengthPos) { var initIndex = i; var endIndex = (shapePath.c && i === len - 1) ? 0 : i + 1; var segmentPerc = (lengthPos - accumulatedLength) / lengths[i].addedLength; pt = bez.getPointInSegment(shapePath.v[initIndex], shapePath.v[endIndex], shapePath.o[initIndex], shapePath.i[endIndex], segmentPerc, lengths[i]); break; } else { accumulatedLength += lengths[i].addedLength; } i += 1; } if (!pt) { pt = shapePath.c ? [shapePath.v[0][0], shapePath.v[0][1]] : [shapePath.v[shapePath._length - 1][0], shapePath.v[shapePath._length - 1][1]]; } return pt; }, vectorOnPath: function (perc, time, vectorType) { // perc doesn't use triple equality because it can be a Number object as well as a primitive. if (perc == 1) { // eslint-disable-line eqeqeq perc = this.v.c; } else if (perc == 0) { // eslint-disable-line eqeqeq perc = 0.999; } var pt1 = this.pointOnPath(perc, time); var pt2 = this.pointOnPath(perc + 0.001, time); var xLength = pt2[0] - pt1[0]; var yLength = pt2[1] - pt1[1]; var magnitude = Math.sqrt(Math.pow(xLength, 2) + Math.pow(yLength, 2)); if (magnitude === 0) { return [0, 0]; } var unitVector = vectorType === 'tangent' ? [xLength / magnitude, yLength / magnitude] : [-yLength / magnitude, xLength / magnitude]; return unitVector; }, tangentOnPath: function (perc, time) { return this.vectorOnPath(perc, time, 'tangent'); }, normalOnPath: function (perc, time) { return this.vectorOnPath(perc, time, 'normal'); }, setGroupProperty: expressionHelpers.setGroupProperty, getValueAtTime: expressionHelpers.getStaticValueAtTime, }; extendPrototype([ShapeExpressions], ShapePropertyConstructorFunction); extendPrototype([ShapeExpressions], KeyframedShapePropertyConstructorFunction); KeyframedShapePropertyConstructorFunction.prototype.getValueAtTime = getShapeValueAtTime; KeyframedShapePropertyConstructorFunction.prototype.initiateExpression = ExpressionManager.initiateExpression; var propertyGetShapeProp = ShapePropertyFactory.getShapeProp; ShapePropertyFactory.getShapeProp = function (elem, data, type, arr, trims) { var prop = propertyGetShapeProp(elem, data, type, arr, trims); prop.propertyIndex = data.ix; prop.lock = false; if (type === 3) { expressionHelpers.searchExpressions(elem, data.pt, prop); } else if (type === 4) { expressionHelpers.searchExpressions(elem, data.ks, prop); } if (prop.k) { elem.addDynamicProperty(prop); } return prop; }; }()); /* global ExpressionManager, TextProperty */ (function addDecorator() { function searchExpressions() { if (this.data.d.x) { this.calculateExpression = ExpressionManager.initiateExpression.bind(this)(this.elem, this.data.d, this); this.addEffect(this.getExpressionValue.bind(this)); return true; } return null; } TextProperty.prototype.getExpressionValue = function (currentValue, text) { var newValue = this.calculateExpression(text); if (currentValue.t !== newValue) { var newData = {}; this.copyData(newData, currentValue); newData.t = newValue.toString(); newData.__complete = false; return newData; } return currentValue; }; TextProperty.prototype.searchProperty = function () { var isKeyframed = this.searchKeyframes(); var hasExpressions = this.searchExpressions(); this.kf = isKeyframed || hasExpressions; return this.kf; }; TextProperty.prototype.searchExpressions = searchExpressions; }()); /* global propertyGroupFactory, PropertyInterface */ /* exported ShapePathInterface */ var ShapePathInterface = ( function () { return function pathInterfaceFactory(shape, view, propertyGroup) { var prop = view.sh; function interfaceFunction(val) { if (val === 'Shape' || val === 'shape' || val === 'Path' || val === 'path' || val === 'ADBE Vector Shape' || val === 2) { return interfaceFunction.path; } return null; } var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); prop.setGroupProperty(PropertyInterface('Path', _propertyGroup)); Object.defineProperties(interfaceFunction, { path: { get: function () { if (prop.k) { prop.getValue(); } return prop; }, }, shape: { get: function () { if (prop.k) { prop.getValue(); } return prop; }, }, _name: { value: shape.nm }, ix: { value: shape.ix }, propertyIndex: { value: shape.ix }, mn: { value: shape.mn }, propertyGroup: { value: propertyGroup }, }); return interfaceFunction; }; }() ); /* exported propertyGroupFactory */ var propertyGroupFactory = (function () { return function (interfaceFunction, parentPropertyGroup) { return function (val) { val = val === undefined ? 1 : val; if (val <= 0) { return interfaceFunction; } return parentPropertyGroup(val - 1); }; }; }()); /* exported PropertyInterface */ var PropertyInterface = (function () { return function (propertyName, propertyGroup) { var interfaceFunction = { _name: propertyName, }; function _propertyGroup(val) { val = val === undefined ? 1 : val; if (val <= 0) { return interfaceFunction; } return propertyGroup(val - 1); } return _propertyGroup; }; }()); /* global ExpressionPropertyInterface, PropertyInterface, propertyGroupFactory, ShapePathInterface */ /* exported ShapeExpressionInterface */ var ShapeExpressionInterface = (function () { function iterateElements(shapes, view, propertyGroup) { var arr = []; var i; var len = shapes ? shapes.length : 0; for (i = 0; i < len; i += 1) { if (shapes[i].ty === 'gr') { arr.push(groupInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'fl') { arr.push(fillInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'st') { arr.push(strokeInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'tm') { arr.push(trimInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'tr') { // arr.push(transformInterfaceFactory(shapes[i],view[i],propertyGroup)); } else if (shapes[i].ty === 'el') { arr.push(ellipseInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'sr') { arr.push(starInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'sh') { arr.push(ShapePathInterface(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'rc') { arr.push(rectInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'rd') { arr.push(roundedInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'rp') { arr.push(repeaterInterfaceFactory(shapes[i], view[i], propertyGroup)); } else if (shapes[i].ty === 'gf') { arr.push(gradientFillInterfaceFactory(shapes[i], view[i], propertyGroup)); } else { arr.push(defaultInterfaceFactory(shapes[i], view[i], propertyGroup)); } } return arr; } function contentsInterfaceFactory(shape, view, propertyGroup) { var interfaces; var interfaceFunction = function _interfaceFunction(value) { var i = 0; var len = interfaces.length; while (i < len) { if (interfaces[i]._name === value || interfaces[i].mn === value || interfaces[i].propertyIndex === value || interfaces[i].ix === value || interfaces[i].ind === value) { return interfaces[i]; } i += 1; } if (typeof value === 'number') { return interfaces[value - 1]; } return null; }; interfaceFunction.propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); interfaces = iterateElements(shape.it, view.it, interfaceFunction.propertyGroup); interfaceFunction.numProperties = interfaces.length; var transformInterface = transformInterfaceFactory(shape.it[shape.it.length - 1], view.it[view.it.length - 1], interfaceFunction.propertyGroup); interfaceFunction.transform = transformInterface; interfaceFunction.propertyIndex = shape.cix; interfaceFunction._name = shape.nm; return interfaceFunction; } function groupInterfaceFactory(shape, view, propertyGroup) { var interfaceFunction = function _interfaceFunction(value) { switch (value) { case 'ADBE Vectors Group': case 'Contents': case 2: return interfaceFunction.content; // Not necessary for now. Keeping them here in case a new case appears // case 'ADBE Vector Transform Group': // case 3: default: return interfaceFunction.transform; } }; interfaceFunction.propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); var content = contentsInterfaceFactory(shape, view, interfaceFunction.propertyGroup); var transformInterface = transformInterfaceFactory(shape.it[shape.it.length - 1], view.it[view.it.length - 1], interfaceFunction.propertyGroup); interfaceFunction.content = content; interfaceFunction.transform = transformInterface; Object.defineProperty(interfaceFunction, '_name', { get: function () { return shape.nm; }, }); // interfaceFunction.content = interfaceFunction; interfaceFunction.numProperties = shape.np; interfaceFunction.propertyIndex = shape.ix; interfaceFunction.nm = shape.nm; interfaceFunction.mn = shape.mn; return interfaceFunction; } function fillInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(val) { if (val === 'Color' || val === 'color') { return interfaceFunction.color; } if (val === 'Opacity' || val === 'opacity') { return interfaceFunction.opacity; } return null; } Object.defineProperties(interfaceFunction, { color: { get: ExpressionPropertyInterface(view.c), }, opacity: { get: ExpressionPropertyInterface(view.o), }, _name: { value: shape.nm }, mn: { value: shape.mn }, }); view.c.setGroupProperty(PropertyInterface('Color', propertyGroup)); view.o.setGroupProperty(PropertyInterface('Opacity', propertyGroup)); return interfaceFunction; } function gradientFillInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(val) { if (val === 'Start Point' || val === 'start point') { return interfaceFunction.startPoint; } if (val === 'End Point' || val === 'end point') { return interfaceFunction.endPoint; } if (val === 'Opacity' || val === 'opacity') { return interfaceFunction.opacity; } return null; } Object.defineProperties(interfaceFunction, { startPoint: { get: ExpressionPropertyInterface(view.s), }, endPoint: { get: ExpressionPropertyInterface(view.e), }, opacity: { get: ExpressionPropertyInterface(view.o), }, type: { get: function () { return 'a'; }, }, _name: { value: shape.nm }, mn: { value: shape.mn }, }); view.s.setGroupProperty(PropertyInterface('Start Point', propertyGroup)); view.e.setGroupProperty(PropertyInterface('End Point', propertyGroup)); view.o.setGroupProperty(PropertyInterface('Opacity', propertyGroup)); return interfaceFunction; } function defaultInterfaceFactory() { function interfaceFunction() { return null; } return interfaceFunction; } function strokeInterfaceFactory(shape, view, propertyGroup) { var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); var _dashPropertyGroup = propertyGroupFactory(dashOb, _propertyGroup); function addPropertyToDashOb(i) { Object.defineProperty(dashOb, shape.d[i].nm, { get: ExpressionPropertyInterface(view.d.dataProps[i].p), }); } var i; var len = shape.d ? shape.d.length : 0; var dashOb = {}; for (i = 0; i < len; i += 1) { addPropertyToDashOb(i); view.d.dataProps[i].p.setGroupProperty(_dashPropertyGroup); } function interfaceFunction(val) { if (val === 'Color' || val === 'color') { return interfaceFunction.color; } if (val === 'Opacity' || val === 'opacity') { return interfaceFunction.opacity; } if (val === 'Stroke Width' || val === 'stroke width') { return interfaceFunction.strokeWidth; } return null; } Object.defineProperties(interfaceFunction, { color: { get: ExpressionPropertyInterface(view.c), }, opacity: { get: ExpressionPropertyInterface(view.o), }, strokeWidth: { get: ExpressionPropertyInterface(view.w), }, dash: { get: function () { return dashOb; }, }, _name: { value: shape.nm }, mn: { value: shape.mn }, }); view.c.setGroupProperty(PropertyInterface('Color', _propertyGroup)); view.o.setGroupProperty(PropertyInterface('Opacity', _propertyGroup)); view.w.setGroupProperty(PropertyInterface('Stroke Width', _propertyGroup)); return interfaceFunction; } function trimInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(val) { if (val === shape.e.ix || val === 'End' || val === 'end') { return interfaceFunction.end; } if (val === shape.s.ix) { return interfaceFunction.start; } if (val === shape.o.ix) { return interfaceFunction.offset; } return null; } var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); interfaceFunction.propertyIndex = shape.ix; view.s.setGroupProperty(PropertyInterface('Start', _propertyGroup)); view.e.setGroupProperty(PropertyInterface('End', _propertyGroup)); view.o.setGroupProperty(PropertyInterface('Offset', _propertyGroup)); interfaceFunction.propertyIndex = shape.ix; interfaceFunction.propertyGroup = propertyGroup; Object.defineProperties(interfaceFunction, { start: { get: ExpressionPropertyInterface(view.s), }, end: { get: ExpressionPropertyInterface(view.e), }, offset: { get: ExpressionPropertyInterface(view.o), }, _name: { value: shape.nm }, }); interfaceFunction.mn = shape.mn; return interfaceFunction; } function transformInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(value) { if (shape.a.ix === value || value === 'Anchor Point') { return interfaceFunction.anchorPoint; } if (shape.o.ix === value || value === 'Opacity') { return interfaceFunction.opacity; } if (shape.p.ix === value || value === 'Position') { return interfaceFunction.position; } if (shape.r.ix === value || value === 'Rotation' || value === 'ADBE Vector Rotation') { return interfaceFunction.rotation; } if (shape.s.ix === value || value === 'Scale') { return interfaceFunction.scale; } if ((shape.sk && shape.sk.ix === value) || value === 'Skew') { return interfaceFunction.skew; } if ((shape.sa && shape.sa.ix === value) || value === 'Skew Axis') { return interfaceFunction.skewAxis; } return null; } var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); view.transform.mProps.o.setGroupProperty(PropertyInterface('Opacity', _propertyGroup)); view.transform.mProps.p.setGroupProperty(PropertyInterface('Position', _propertyGroup)); view.transform.mProps.a.setGroupProperty(PropertyInterface('Anchor Point', _propertyGroup)); view.transform.mProps.s.setGroupProperty(PropertyInterface('Scale', _propertyGroup)); view.transform.mProps.r.setGroupProperty(PropertyInterface('Rotation', _propertyGroup)); if (view.transform.mProps.sk) { view.transform.mProps.sk.setGroupProperty(PropertyInterface('Skew', _propertyGroup)); view.transform.mProps.sa.setGroupProperty(PropertyInterface('Skew Angle', _propertyGroup)); } view.transform.op.setGroupProperty(PropertyInterface('Opacity', _propertyGroup)); Object.defineProperties(interfaceFunction, { opacity: { get: ExpressionPropertyInterface(view.transform.mProps.o), }, position: { get: ExpressionPropertyInterface(view.transform.mProps.p), }, anchorPoint: { get: ExpressionPropertyInterface(view.transform.mProps.a), }, scale: { get: ExpressionPropertyInterface(view.transform.mProps.s), }, rotation: { get: ExpressionPropertyInterface(view.transform.mProps.r), }, skew: { get: ExpressionPropertyInterface(view.transform.mProps.sk), }, skewAxis: { get: ExpressionPropertyInterface(view.transform.mProps.sa), }, _name: { value: shape.nm }, }); interfaceFunction.ty = 'tr'; interfaceFunction.mn = shape.mn; interfaceFunction.propertyGroup = propertyGroup; return interfaceFunction; } function ellipseInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(value) { if (shape.p.ix === value) { return interfaceFunction.position; } if (shape.s.ix === value) { return interfaceFunction.size; } return null; } var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); interfaceFunction.propertyIndex = shape.ix; var prop = view.sh.ty === 'tm' ? view.sh.prop : view.sh; prop.s.setGroupProperty(PropertyInterface('Size', _propertyGroup)); prop.p.setGroupProperty(PropertyInterface('Position', _propertyGroup)); Object.defineProperties(interfaceFunction, { size: { get: ExpressionPropertyInterface(prop.s), }, position: { get: ExpressionPropertyInterface(prop.p), }, _name: { value: shape.nm }, }); interfaceFunction.mn = shape.mn; return interfaceFunction; } function starInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(value) { if (shape.p.ix === value) { return interfaceFunction.position; } if (shape.r.ix === value) { return interfaceFunction.rotation; } if (shape.pt.ix === value) { return interfaceFunction.points; } if (shape.or.ix === value || value === 'ADBE Vector Star Outer Radius') { return interfaceFunction.outerRadius; } if (shape.os.ix === value) { return interfaceFunction.outerRoundness; } if (shape.ir && (shape.ir.ix === value || value === 'ADBE Vector Star Inner Radius')) { return interfaceFunction.innerRadius; } if (shape.is && shape.is.ix === value) { return interfaceFunction.innerRoundness; } return null; } var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); var prop = view.sh.ty === 'tm' ? view.sh.prop : view.sh; interfaceFunction.propertyIndex = shape.ix; prop.or.setGroupProperty(PropertyInterface('Outer Radius', _propertyGroup)); prop.os.setGroupProperty(PropertyInterface('Outer Roundness', _propertyGroup)); prop.pt.setGroupProperty(PropertyInterface('Points', _propertyGroup)); prop.p.setGroupProperty(PropertyInterface('Position', _propertyGroup)); prop.r.setGroupProperty(PropertyInterface('Rotation', _propertyGroup)); if (shape.ir) { prop.ir.setGroupProperty(PropertyInterface('Inner Radius', _propertyGroup)); prop.is.setGroupProperty(PropertyInterface('Inner Roundness', _propertyGroup)); } Object.defineProperties(interfaceFunction, { position: { get: ExpressionPropertyInterface(prop.p), }, rotation: { get: ExpressionPropertyInterface(prop.r), }, points: { get: ExpressionPropertyInterface(prop.pt), }, outerRadius: { get: ExpressionPropertyInterface(prop.or), }, outerRoundness: { get: ExpressionPropertyInterface(prop.os), }, innerRadius: { get: ExpressionPropertyInterface(prop.ir), }, innerRoundness: { get: ExpressionPropertyInterface(prop.is), }, _name: { value: shape.nm }, }); interfaceFunction.mn = shape.mn; return interfaceFunction; } function rectInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(value) { if (shape.p.ix === value) { return interfaceFunction.position; } if (shape.r.ix === value) { return interfaceFunction.roundness; } if (shape.s.ix === value || value === 'Size' || value === 'ADBE Vector Rect Size') { return interfaceFunction.size; } return null; } var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); var prop = view.sh.ty === 'tm' ? view.sh.prop : view.sh; interfaceFunction.propertyIndex = shape.ix; prop.p.setGroupProperty(PropertyInterface('Position', _propertyGroup)); prop.s.setGroupProperty(PropertyInterface('Size', _propertyGroup)); prop.r.setGroupProperty(PropertyInterface('Rotation', _propertyGroup)); Object.defineProperties(interfaceFunction, { position: { get: ExpressionPropertyInterface(prop.p), }, roundness: { get: ExpressionPropertyInterface(prop.r), }, size: { get: ExpressionPropertyInterface(prop.s), }, _name: { value: shape.nm }, }); interfaceFunction.mn = shape.mn; return interfaceFunction; } function roundedInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(value) { if (shape.r.ix === value || value === 'Round Corners 1') { return interfaceFunction.radius; } return null; } var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); var prop = view; interfaceFunction.propertyIndex = shape.ix; prop.rd.setGroupProperty(PropertyInterface('Radius', _propertyGroup)); Object.defineProperties(interfaceFunction, { radius: { get: ExpressionPropertyInterface(prop.rd), }, _name: { value: shape.nm }, }); interfaceFunction.mn = shape.mn; return interfaceFunction; } function repeaterInterfaceFactory(shape, view, propertyGroup) { function interfaceFunction(value) { if (shape.c.ix === value || value === 'Copies') { return interfaceFunction.copies; } if (shape.o.ix === value || value === 'Offset') { return interfaceFunction.offset; } return null; } var _propertyGroup = propertyGroupFactory(interfaceFunction, propertyGroup); var prop = view; interfaceFunction.propertyIndex = shape.ix; prop.c.setGroupProperty(PropertyInterface('Copies', _propertyGroup)); prop.o.setGroupProperty(PropertyInterface('Offset', _propertyGroup)); Object.defineProperties(interfaceFunction, { copies: { get: ExpressionPropertyInterface(prop.c), }, offset: { get: ExpressionPropertyInterface(prop.o), }, _name: { value: shape.nm }, }); interfaceFunction.mn = shape.mn; return interfaceFunction; } return function (shapes, view, propertyGroup) { var interfaces; function _interfaceFunction(value) { if (typeof value === 'number') { value = value === undefined ? 1 : value; if (value === 0) { return propertyGroup; } return interfaces[value - 1]; } var i = 0; var len = interfaces.length; while (i < len) { if (interfaces[i]._name === value) { return interfaces[i]; } i += 1; } return null; } function parentGroupWrapper() { return propertyGroup; } _interfaceFunction.propertyGroup = propertyGroupFactory(_interfaceFunction, parentGroupWrapper); interfaces = iterateElements(shapes, view, _interfaceFunction.propertyGroup); _interfaceFunction.numProperties = interfaces.length; _interfaceFunction._name = 'Contents'; return _interfaceFunction; }; }()); /* exported TextExpressionInterface */ var TextExpressionInterface = (function () { return function (elem) { var _prevValue; var _sourceText; function _thisLayerFunction(name) { switch (name) { case 'ADBE Text Document': return _thisLayerFunction.sourceText; default: return null; } } Object.defineProperty(_thisLayerFunction, 'sourceText', { get: function () { elem.textProperty.getValue(); var stringValue = elem.textProperty.currentData.t; if (stringValue !== _prevValue) { elem.textProperty.currentData.t = _prevValue; _sourceText = new String(stringValue); // eslint-disable-line no-new-wrappers // If stringValue is an empty string, eval returns undefined, so it has to be returned as a String primitive _sourceText.value = stringValue || new String(stringValue); // eslint-disable-line no-new-wrappers } return _sourceText; }, }); return _thisLayerFunction; }; }()); /* global Matrix, MaskManagerInterface, TransformExpressionInterface, getDescriptor */ /* exported LayerExpressionInterface */ var LayerExpressionInterface = (function () { function getMatrix(time) { var toWorldMat = new Matrix(); if (time !== undefined) { var propMatrix = this._elem.finalTransform.mProp.getValueAtTime(time); propMatrix.clone(toWorldMat); } else { var transformMat = this._elem.finalTransform.mProp; transformMat.applyToMatrix(toWorldMat); } return toWorldMat; } function toWorldVec(arr, time) { var toWorldMat = this.getMatrix(time); toWorldMat.props[12] = 0; toWorldMat.props[13] = 0; toWorldMat.props[14] = 0; return this.applyPoint(toWorldMat, arr); } function toWorld(arr, time) { var toWorldMat = this.getMatrix(time); return this.applyPoint(toWorldMat, arr); } function fromWorldVec(arr, time) { var toWorldMat = this.getMatrix(time); toWorldMat.props[12] = 0; toWorldMat.props[13] = 0; toWorldMat.props[14] = 0; return this.invertPoint(toWorldMat, arr); } function fromWorld(arr, time) { var toWorldMat = this.getMatrix(time); return this.invertPoint(toWorldMat, arr); } function applyPoint(matrix, arr) { if (this._elem.hierarchy && this._elem.hierarchy.length) { var i; var len = this._elem.hierarchy.length; for (i = 0; i < len; i += 1) { this._elem.hierarchy[i].finalTransform.mProp.applyToMatrix(matrix); } } return matrix.applyToPointArray(arr[0], arr[1], arr[2] || 0); } function invertPoint(matrix, arr) { if (this._elem.hierarchy && this._elem.hierarchy.length) { var i; var len = this._elem.hierarchy.length; for (i = 0; i < len; i += 1) { this._elem.hierarchy[i].finalTransform.mProp.applyToMatrix(matrix); } } return matrix.inversePoint(arr); } function fromComp(arr) { var toWorldMat = new Matrix(); toWorldMat.reset(); this._elem.finalTransform.mProp.applyToMatrix(toWorldMat); if (this._elem.hierarchy && this._elem.hierarchy.length) { var i; var len = this._elem.hierarchy.length; for (i = 0; i < len; i += 1) { this._elem.hierarchy[i].finalTransform.mProp.applyToMatrix(toWorldMat); } return toWorldMat.inversePoint(arr); } return toWorldMat.inversePoint(arr); } function sampleImage() { return [1, 1, 1, 1]; } return function (elem) { var transformInterface; function _registerMaskInterface(maskManager) { _thisLayerFunction.mask = new MaskManagerInterface(maskManager, elem); } function _registerEffectsInterface(effects) { _thisLayerFunction.effect = effects; } function _thisLayerFunction(name) { switch (name) { case 'ADBE Root Vectors Group': case 'Contents': case 2: return _thisLayerFunction.shapeInterface; case 1: case 6: case 'Transform': case 'transform': case 'ADBE Transform Group': return transformInterface; case 4: case 'ADBE Effect Parade': case 'effects': case 'Effects': return _thisLayerFunction.effect; case 'ADBE Text Properties': return _thisLayerFunction.textInterface; default: return null; } } _thisLayerFunction.getMatrix = getMatrix; _thisLayerFunction.invertPoint = invertPoint; _thisLayerFunction.applyPoint = applyPoint; _thisLayerFunction.toWorld = toWorld; _thisLayerFunction.toWorldVec = toWorldVec; _thisLayerFunction.fromWorld = fromWorld; _thisLayerFunction.fromWorldVec = fromWorldVec; _thisLayerFunction.toComp = toWorld; _thisLayerFunction.fromComp = fromComp; _thisLayerFunction.sampleImage = sampleImage; _thisLayerFunction.sourceRectAtTime = elem.sourceRectAtTime.bind(elem); _thisLayerFunction._elem = elem; transformInterface = TransformExpressionInterface(elem.finalTransform.mProp); var anchorPointDescriptor = getDescriptor(transformInterface, 'anchorPoint'); Object.defineProperties(_thisLayerFunction, { hasParent: { get: function () { return elem.hierarchy.length; }, }, parent: { get: function () { return elem.hierarchy[0].layerInterface; }, }, rotation: getDescriptor(transformInterface, 'rotation'), scale: getDescriptor(transformInterface, 'scale'), position: getDescriptor(transformInterface, 'position'), opacity: getDescriptor(transformInterface, 'opacity'), anchorPoint: anchorPointDescriptor, anchor_point: anchorPointDescriptor, transform: { get: function () { return transformInterface; }, }, active: { get: function () { return elem.isInRange; }, }, }); _thisLayerFunction.startTime = elem.data.st; _thisLayerFunction.index = elem.data.ind; _thisLayerFunction.source = elem.data.refId; _thisLayerFunction.height = elem.data.ty === 0 ? elem.data.h : 100; _thisLayerFunction.width = elem.data.ty === 0 ? elem.data.w : 100; _thisLayerFunction.inPoint = elem.data.ip / elem.comp.globalData.frameRate; _thisLayerFunction.outPoint = elem.data.op / elem.comp.globalData.frameRate; _thisLayerFunction._name = elem.data.nm; _thisLayerFunction.registerMaskInterface = _registerMaskInterface; _thisLayerFunction.registerEffectsInterface = _registerEffectsInterface; return _thisLayerFunction; }; }()); /* global */ /* exported FootageInterface */ var FootageInterface = (function () { var outlineInterfaceFactory = (function (elem) { var currentPropertyName = ''; var currentProperty = elem.getFootageData(); function init() { currentPropertyName = ''; currentProperty = elem.getFootageData(); return searchProperty; } function searchProperty(value) { if (currentProperty[value]) { currentPropertyName = value; currentProperty = currentProperty[value]; if (typeof currentProperty === 'object') { return searchProperty; } return currentProperty; } var propertyNameIndex = value.indexOf(currentPropertyName); if (propertyNameIndex !== -1) { var index = parseInt(value.substr(propertyNameIndex + currentPropertyName.length), 10); currentProperty = currentProperty[index]; if (typeof currentProperty === 'object') { return searchProperty; } return currentProperty; } return ''; } return init; }); var dataInterfaceFactory = function (elem) { function interfaceFunction(value) { if (value === 'Outline') { return interfaceFunction.outlineInterface(); } return null; } interfaceFunction._name = 'Outline'; interfaceFunction.outlineInterface = outlineInterfaceFactory(elem); return interfaceFunction; }; return function (elem) { function _interfaceFunction(value) { if (value === 'Data') { return _interfaceFunction.dataInterface; } return null; } _interfaceFunction._name = 'Data'; _interfaceFunction.dataInterface = dataInterfaceFactory(elem); return _interfaceFunction; }; }()); /* exported CompExpressionInterface */ var CompExpressionInterface = (function () { return function (comp) { function _thisLayerFunction(name) { var i = 0; var len = comp.layers.length; while (i < len) { if (comp.layers[i].nm === name || comp.layers[i].ind === name) { return comp.elements[i].layerInterface; } i += 1; } return null; // return {active:false}; } Object.defineProperty(_thisLayerFunction, '_name', { value: comp.data.nm }); _thisLayerFunction.layer = _thisLayerFunction; _thisLayerFunction.pixelAspect = 1; _thisLayerFunction.height = comp.data.h || comp.globalData.compSize.h; _thisLayerFunction.width = comp.data.w || comp.globalData.compSize.w; _thisLayerFunction.pixelAspect = 1; _thisLayerFunction.frameDuration = 1 / comp.globalData.frameRate; _thisLayerFunction.displayStartTime = 0; _thisLayerFunction.numLayers = comp.layers.length; return _thisLayerFunction; }; }()); /* global ExpressionPropertyInterface */ /* exported TransformExpressionInterface */ var TransformExpressionInterface = (function () { return function (transform) { function _thisFunction(name) { switch (name) { case 'scale': case 'Scale': case 'ADBE Scale': case 6: return _thisFunction.scale; case 'rotation': case 'Rotation': case 'ADBE Rotation': case 'ADBE Rotate Z': case 10: return _thisFunction.rotation; case 'ADBE Rotate X': return _thisFunction.xRotation; case 'ADBE Rotate Y': return _thisFunction.yRotation; case 'position': case 'Position': case 'ADBE Position': case 2: return _thisFunction.position; case 'ADBE Position_0': return _thisFunction.xPosition; case 'ADBE Position_1': return _thisFunction.yPosition; case 'ADBE Position_2': return _thisFunction.zPosition; case 'anchorPoint': case 'AnchorPoint': case 'Anchor Point': case 'ADBE AnchorPoint': case 1: return _thisFunction.anchorPoint; case 'opacity': case 'Opacity': case 11: return _thisFunction.opacity; default: return null; } } Object.defineProperty(_thisFunction, 'rotation', { get: ExpressionPropertyInterface(transform.r || transform.rz), }); Object.defineProperty(_thisFunction, 'zRotation', { get: ExpressionPropertyInterface(transform.rz || transform.r), }); Object.defineProperty(_thisFunction, 'xRotation', { get: ExpressionPropertyInterface(transform.rx), }); Object.defineProperty(_thisFunction, 'yRotation', { get: ExpressionPropertyInterface(transform.ry), }); Object.defineProperty(_thisFunction, 'scale', { get: ExpressionPropertyInterface(transform.s), }); var _px; var _py; var _pz; var _transformFactory; if (transform.p) { _transformFactory = ExpressionPropertyInterface(transform.p); } else { _px = ExpressionPropertyInterface(transform.px); _py = ExpressionPropertyInterface(transform.py); if (transform.pz) { _pz = ExpressionPropertyInterface(transform.pz); } } Object.defineProperty(_thisFunction, 'position', { get: function () { if (transform.p) { return _transformFactory(); } return [ _px(), _py(), _pz ? _pz() : 0]; }, }); Object.defineProperty(_thisFunction, 'xPosition', { get: ExpressionPropertyInterface(transform.px), }); Object.defineProperty(_thisFunction, 'yPosition', { get: ExpressionPropertyInterface(transform.py), }); Object.defineProperty(_thisFunction, 'zPosition', { get: ExpressionPropertyInterface(transform.pz), }); Object.defineProperty(_thisFunction, 'anchorPoint', { get: ExpressionPropertyInterface(transform.a), }); Object.defineProperty(_thisFunction, 'opacity', { get: ExpressionPropertyInterface(transform.o), }); Object.defineProperty(_thisFunction, 'skew', { get: ExpressionPropertyInterface(transform.sk), }); Object.defineProperty(_thisFunction, 'skewAxis', { get: ExpressionPropertyInterface(transform.sa), }); Object.defineProperty(_thisFunction, 'orientation', { get: ExpressionPropertyInterface(transform.or), }); return _thisFunction; }; }()); /* exported ProjectInterface */ var ProjectInterface = (function () { function registerComposition(comp) { this.compositions.push(comp); } return function () { function _thisProjectFunction(name) { var i = 0; var len = this.compositions.length; while (i < len) { if (this.compositions[i].data && this.compositions[i].data.nm === name) { if (this.compositions[i].prepareFrame && this.compositions[i].data.xt) { this.compositions[i].prepareFrame(this.currentFrame); } return this.compositions[i].compInterface; } i += 1; } return null; } _thisProjectFunction.compositions = []; _thisProjectFunction.currentFrame = 0; _thisProjectFunction.registerComposition = registerComposition; return _thisProjectFunction; }; }()); /* global propertyGroupFactory, ExpressionPropertyInterface, PropertyInterface */ /* exported EffectsExpressionInterface */ var EffectsExpressionInterface = (function () { var ob = { createEffectsInterface: createEffectsInterface, }; function createEffectsInterface(elem, propertyGroup) { if (elem.effectsManager) { var effectElements = []; var effectsData = elem.data.ef; var i; var len = elem.effectsManager.effectElements.length; for (i = 0; i < len; i += 1) { effectElements.push(createGroupInterface(effectsData[i], elem.effectsManager.effectElements[i], propertyGroup, elem)); } var effects = elem.data.ef || []; var groupInterface = function (name) { i = 0; len = effects.length; while (i < len) { if (name === effects[i].nm || name === effects[i].mn || name === effects[i].ix) { return effectElements[i]; } i += 1; } return null; }; Object.defineProperty(groupInterface, 'numProperties', { get: function () { return effects.length; }, }); return groupInterface; } return null; } function createGroupInterface(data, elements, propertyGroup, elem) { function groupInterface(name) { var effects = data.ef; var i = 0; var len = effects.length; while (i < len) { if (name === effects[i].nm || name === effects[i].mn || name === effects[i].ix) { if (effects[i].ty === 5) { return effectElements[i]; } return effectElements[i](); } i += 1; } throw new Error(); } var _propertyGroup = propertyGroupFactory(groupInterface, propertyGroup); var effectElements = []; var i; var len = data.ef.length; for (i = 0; i < len; i += 1) { if (data.ef[i].ty === 5) { effectElements.push(createGroupInterface(data.ef[i], elements.effectElements[i], elements.effectElements[i].propertyGroup, elem)); } else { effectElements.push(createValueInterface(elements.effectElements[i], data.ef[i].ty, elem, _propertyGroup)); } } if (data.mn === 'ADBE Color Control') { Object.defineProperty(groupInterface, 'color', { get: function () { return effectElements[0](); }, }); } Object.defineProperties(groupInterface, { numProperties: { get: function () { return data.np; }, }, _name: { value: data.nm }, propertyGroup: { value: _propertyGroup }, }); groupInterface.enabled = data.en !== 0; groupInterface.active = groupInterface.enabled; return groupInterface; } function createValueInterface(element, type, elem, propertyGroup) { var expressionProperty = ExpressionPropertyInterface(element.p); function interfaceFunction() { if (type === 10) { return elem.comp.compInterface(element.p.v); } return expressionProperty(); } if (element.p.setGroupProperty) { element.p.setGroupProperty(PropertyInterface('', propertyGroup)); } return interfaceFunction; } return ob; }()); /* global createSizedArray */ /* exported MaskManagerInterface */ var MaskManagerInterface = (function () { function MaskInterface(mask, data) { this._mask = mask; this._data = data; } Object.defineProperty(MaskInterface.prototype, 'maskPath', { get: function () { if (this._mask.prop.k) { this._mask.prop.getValue(); } return this._mask.prop; }, }); Object.defineProperty(MaskInterface.prototype, 'maskOpacity', { get: function () { if (this._mask.op.k) { this._mask.op.getValue(); } return this._mask.op.v * 100; }, }); var MaskManager = function (maskManager) { var _masksInterfaces = createSizedArray(maskManager.viewData.length); var i; var len = maskManager.viewData.length; for (i = 0; i < len; i += 1) { _masksInterfaces[i] = new MaskInterface(maskManager.viewData[i], maskManager.masksProperties[i]); } var maskFunction = function (name) { i = 0; while (i < len) { if (maskManager.masksProperties[i].nm === name) { return _masksInterfaces[i]; } i += 1; } return null; }; return maskFunction; }; return MaskManager; }()); /* global createTypedArray */ /* exported ExpressionPropertyInterface */ var ExpressionPropertyInterface = (function () { var defaultUnidimensionalValue = { pv: 0, v: 0, mult: 1 }; var defaultMultidimensionalValue = { pv: [0, 0, 0], v: [0, 0, 0], mult: 1 }; function completeProperty(expressionValue, property, type) { Object.defineProperty(expressionValue, 'velocity', { get: function () { return property.getVelocityAtTime(property.comp.currentFrame); }, }); expressionValue.numKeys = property.keyframes ? property.keyframes.length : 0; expressionValue.key = function (pos) { if (!expressionValue.numKeys) { return 0; } var value = ''; if ('s' in property.keyframes[pos - 1]) { value = property.keyframes[pos - 1].s; } else if ('e' in property.keyframes[pos - 2]) { value = property.keyframes[pos - 2].e; } else { value = property.keyframes[pos - 2].s; } var valueProp = type === 'unidimensional' ? new Number(value) : Object.assign({}, value); // eslint-disable-line no-new-wrappers valueProp.time = property.keyframes[pos - 1].t / property.elem.comp.globalData.frameRate; valueProp.value = type === 'unidimensional' ? value[0] : value; return valueProp; }; expressionValue.valueAtTime = property.getValueAtTime; expressionValue.speedAtTime = property.getSpeedAtTime; expressionValue.velocityAtTime = property.getVelocityAtTime; expressionValue.propertyGroup = property.propertyGroup; } function UnidimensionalPropertyInterface(property) { if (!property || !('pv' in property)) { property = defaultUnidimensionalValue; } var mult = 1 / property.mult; var val = property.pv * mult; var expressionValue = new Number(val); // eslint-disable-line no-new-wrappers expressionValue.value = val; completeProperty(expressionValue, property, 'unidimensional'); return function () { if (property.k) { property.getValue(); } val = property.v * mult; if (expressionValue.value !== val) { expressionValue = new Number(val); // eslint-disable-line no-new-wrappers expressionValue.value = val; completeProperty(expressionValue, property, 'unidimensional'); } return expressionValue; }; } function MultidimensionalPropertyInterface(property) { if (!property || !('pv' in property)) { property = defaultMultidimensionalValue; } var mult = 1 / property.mult; var len = (property.data && property.data.l) || property.pv.length; var expressionValue = createTypedArray('float32', len); var arrValue = createTypedArray('float32', len); expressionValue.value = arrValue; completeProperty(expressionValue, property, 'multidimensional'); return function () { if (property.k) { property.getValue(); } for (var i = 0; i < len; i += 1) { arrValue[i] = property.v[i] * mult; expressionValue[i] = arrValue[i]; } return expressionValue; }; } // TODO: try to avoid using this getter function defaultGetter() { return defaultUnidimensionalValue; } return function (property) { if (!property) { return defaultGetter; } if (property.propType === 'unidimensional') { return UnidimensionalPropertyInterface(property); } return MultidimensionalPropertyInterface(property); }; }()); /* global expressionHelpers, TextSelectorProp, ExpressionManager */ /* exported TextExpressionSelectorPropFactory */ var TextExpressionSelectorPropFactory = (function () { // eslint-disable-line no-unused-vars function getValueProxy(index, total) { this.textIndex = index + 1; this.textTotal = total; this.v = this.getValue() * this.mult; return this.v; } return function (elem, data) { this.pv = 1; this.comp = elem.comp; this.elem = elem; this.mult = 0.01; this.propType = 'textSelector'; this.textTotal = data.totalChars; this.selectorValue = 100; this.lastValue = [1, 1, 1]; this.k = true; this.x = true; this.getValue = ExpressionManager.initiateExpression.bind(this)(elem, data, this); this.getMult = getValueProxy; this.getVelocityAtTime = expressionHelpers.getVelocityAtTime; if (this.kf) { this.getValueAtTime = expressionHelpers.getValueAtTime.bind(this); } else { this.getValueAtTime = expressionHelpers.getStaticValueAtTime.bind(this); } this.setGroupProperty = expressionHelpers.setGroupProperty; }; }()); var propertyGetTextProp = TextSelectorProp.getTextSelectorProp; TextSelectorProp.getTextSelectorProp = function (elem, data, arr) { if (data.t === 1) { return new TextExpressionSelectorPropFactory(elem, data, arr); // eslint-disable-line no-undef } return propertyGetTextProp(elem, data, arr); }; /* global PropertyFactory */ /* exported SliderEffect, AngleEffect, ColorEffect, PointEffect, LayerIndexEffect, MaskIndexEffect, CheckboxEffect, NoValueEffect */ function SliderEffect(data, elem, container) { this.p = PropertyFactory.getProp(elem, data.v, 0, 0, container); } function AngleEffect(data, elem, container) { this.p = PropertyFactory.getProp(elem, data.v, 0, 0, container); } function ColorEffect(data, elem, container) { this.p = PropertyFactory.getProp(elem, data.v, 1, 0, container); } function PointEffect(data, elem, container) { this.p = PropertyFactory.getProp(elem, data.v, 1, 0, container); } function LayerIndexEffect(data, elem, container) { this.p = PropertyFactory.getProp(elem, data.v, 0, 0, container); } function MaskIndexEffect(data, elem, container) { this.p = PropertyFactory.getProp(elem, data.v, 0, 0, container); } function CheckboxEffect(data, elem, container) { this.p = PropertyFactory.getProp(elem, data.v, 0, 0, container); } function NoValueEffect() { this.p = {}; } /* global extendPrototype, SliderEffect, AngleEffect, ColorEffect, PointEffect, CheckboxEffect, LayerIndexEffect, MaskIndexEffect, NoValueEffect, DynamicPropertyContainer */ function EffectsManager(data, element) { var effects = data.ef || []; this.effectElements = []; var i; var len = effects.length; var effectItem; for (i = 0; i < len; i += 1) { effectItem = new GroupEffect(effects[i], element); this.effectElements.push(effectItem); } } function GroupEffect(data, element) { this.init(data, element); } extendPrototype([DynamicPropertyContainer], GroupEffect); GroupEffect.prototype.getValue = GroupEffect.prototype.iterateDynamicProperties; GroupEffect.prototype.init = function (data, element) { this.data = data; this.effectElements = []; this.initDynamicPropertyContainer(element); var i; var len = this.data.ef.length; var eff; var effects = this.data.ef; for (i = 0; i < len; i += 1) { eff = null; switch (effects[i].ty) { case 0: eff = new SliderEffect(effects[i], element, this); break; case 1: eff = new AngleEffect(effects[i], element, this); break; case 2: eff = new ColorEffect(effects[i], element, this); break; case 3: eff = new PointEffect(effects[i], element, this); break; case 4: case 7: eff = new CheckboxEffect(effects[i], element, this); break; case 10: eff = new LayerIndexEffect(effects[i], element, this); break; case 11: eff = new MaskIndexEffect(effects[i], element, this); break; case 5: eff = new EffectsManager(effects[i], element, this); break; // case 6: default: eff = new NoValueEffect(effects[i], element, this); break; } if (eff) { this.effectElements.push(eff); } } }; var lottie = {}; function setLocationHref(href) { locationHref = href; } function searchAnimations() { if (standalone === true) { animationManager.searchAnimations(animationData, standalone, renderer); } else { animationManager.searchAnimations(); } } function setSubframeRendering(flag) { subframeEnabled = flag; } function setIDPrefix(prefix) { idPrefix = prefix; } function loadAnimation(params) { if (standalone === true) { params.animationData = JSON.parse(animationData); } return animationManager.loadAnimation(params); } function setQuality(value) { if (typeof value === 'string') { switch (value) { case 'high': defaultCurveSegments = 200; break; default: case 'medium': defaultCurveSegments = 50; break; case 'low': defaultCurveSegments = 10; break; } } else if (!isNaN(value) && value > 1) { defaultCurveSegments = value; } if (defaultCurveSegments >= 50) { roundValues(false); } else { roundValues(true); } } function inBrowser() { return typeof navigator !== 'undefined'; } function installPlugin(type, plugin) { if (type === 'expressions') { expressionsPlugin = plugin; } } function getFactory(name) { switch (name) { case 'propertyFactory': return PropertyFactory; case 'shapePropertyFactory': return ShapePropertyFactory; case 'matrix': return Matrix; default: return null; } } lottie.play = animationManager.play; lottie.pause = animationManager.pause; lottie.setLocationHref = setLocationHref; lottie.togglePause = animationManager.togglePause; lottie.setSpeed = animationManager.setSpeed; lottie.setDirection = animationManager.setDirection; lottie.stop = animationManager.stop; lottie.searchAnimations = searchAnimations; lottie.registerAnimation = animationManager.registerAnimation; lottie.loadAnimation = loadAnimation; lottie.setSubframeRendering = setSubframeRendering; lottie.resize = animationManager.resize; // lottie.start = start; lottie.goToAndStop = animationManager.goToAndStop; lottie.destroy = animationManager.destroy; lottie.setQuality = setQuality; lottie.inBrowser = inBrowser; lottie.installPlugin = installPlugin; lottie.freeze = animationManager.freeze; lottie.unfreeze = animationManager.unfreeze; lottie.setVolume = animationManager.setVolume; lottie.mute = animationManager.mute; lottie.unmute = animationManager.unmute; lottie.getRegisteredAnimations = animationManager.getRegisteredAnimations; lottie.useWebWorker = function (flag) { _useWebWorker = flag; }; lottie.setIDPrefix = setIDPrefix; lottie.__getFactory = getFactory; lottie.version = '5.8.1'; function checkReady() { if (document.readyState === 'complete') { clearInterval(readyStateCheckInterval); searchAnimations(); } } function getQueryVariable(variable) { var vars = queryString.split('&'); for (var i = 0; i < vars.length; i += 1) { var pair = vars[i].split('='); if (decodeURIComponent(pair[0]) == variable) { // eslint-disable-line eqeqeq return decodeURIComponent(pair[1]); } } return null; } var standalone = '__[STANDALONE]__'; var animationData = '__[ANIMATIONDATA]__'; var renderer = ''; var queryString; if (standalone) { var scripts = document.getElementsByTagName('script'); var index = scripts.length - 1; var myScript = scripts[index] || { src: '', }; queryString = myScript.src.replace(/^[^\?]+\??/, ''); // eslint-disable-line no-useless-escape renderer = getQueryVariable('renderer'); } var readyStateCheckInterval = setInterval(checkReady, 100); return lottie; })); /***/ }) /******/ }); /************************************************************************/ /******/ // The module cache /******/ var __webpack_module_cache__ = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ // Check if module is in cache /******/ var cachedModule = __webpack_module_cache__[moduleId]; /******/ if (cachedModule !== undefined) { /******/ return cachedModule.exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = __webpack_module_cache__[moduleId] = { /******/ // no module.id needed /******/ // no module.loaded needed /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /************************************************************************/ /******/ /* webpack/runtime/compat get default export */ /******/ (() => { /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = (module) => { /******/ var getter = module && module.__esModule ? /******/ () => (module['default']) : /******/ () => (module); /******/ __webpack_require__.d(getter, { a: getter }); /******/ return getter; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/define property getters */ /******/ (() => { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = (exports, definition) => { /******/ for(var key in definition) { /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) /******/ })(); /******/ /************************************************************************/ var __webpack_exports__ = {}; // This entry need to be wrapped in an IIFE because it need to be in strict mode. (() => { "use strict"; ;// CONCATENATED MODULE: external "gsap" const external_gsap_namespaceObject = gsap; var external_gsap_default = /*#__PURE__*/__webpack_require__.n(external_gsap_namespaceObject); ;// CONCATENATED MODULE: external "window" const external_window_namespaceObject = window; // EXTERNAL MODULE: ./node_modules/lottie-web/build/player/lottie.js var lottie = __webpack_require__(1248); var lottie_default = /*#__PURE__*/__webpack_require__.n(lottie); ;// CONCATENATED MODULE: external "Swiper" const external_Swiper_namespaceObject = Swiper; var external_Swiper_default = /*#__PURE__*/__webpack_require__.n(external_Swiper_namespaceObject); ;// CONCATENATED MODULE: ./src/components/global/global-home-brand-slide/clientlibs/js/main.js function main() { let tabIdx = 0; let isLottie = false; let $thisTabCont = $('.ghbs__display .display').eq(tabIdx); let $thisTabMenu = $('.ghbs__item').eq(tabIdx); let userClick = false; function init() { initLottie(); initSwiper(); addEvents(); } function initSwiper() { const breakpoint = window.matchMedia('(max-width: 1366px)'); let brandSwiper; const breakpointChecker = function() { if ( breakpoint.matches === true ) { return (function() { brandSwiper = new (external_Swiper_default())('.ghbs__container', { slidesPerView: 'auto', // speed: 800, centeredSlides: true, loop:true, slideToClickedSlide: true, on: { slideChangeTransitionEnd: function(){ const targetSlide = $('.ghbs__item:nth-of-type('+(this.activeIndex + 1)+') a') if(!userClick) targetSlide.trigger('click') userClick = false } } }); })() } else if ( breakpoint.matches === false ) { if ( brandSwiper !== undefined ) brandSwiper.destroy( true, true ); return; } }; breakpoint.onchange = (e) => { breakpointChecker() } breakpointChecker(); } function initLottie() { $('.ghbs__display .display').each(function(i) { const thisTab = $('.ghbs__item').eq(i).find('span').text(); lottie_default().loadAnimation({ container: $(this).find('.display__lottie')[0], autoplay: false, loop: false, path: `/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/img/main/${thisTab}/data.json` }); }) } function addEvents() { $(document).on('click', '.ghbs__item a', function(e) { const id = $(this).attr('href').slice(1); userClick = true tabIdx = $(this).parent().index(); $thisTabCont = $(`.ghbs__display .display[data-id="${id}"]`); $thisTabMenu = $('.ghbs__item').eq(tabIdx); $thisTabCont.addClass('no-animation'); if (!$thisTabCont.hasClass('is-active')) { stopAnimation(); playAnimation(); } e.preventDefault(); e.stopPropagation(); }) } function playAnimation() { $('.ghbs__display .display').removeClass('is-active').removeClass('is-animation'); $('.ghbs__item').removeClass('is-active'); $thisTabCont.addClass('is-active').addClass('is-animation'); $thisTabMenu.addClass('is-active').addClass('is-animation'); lottie_default().stop(); lottie_default().play(); isLottie = true; } function stopAnimation() { if ((lottie_default()) === undefined) return; $('.ghbs__display .display').removeClass('is-animation').removeClass('no-animation'); lottie_default().stop(); isLottie = false; } external_gsap_default().registerPlugin(external_window_namespaceObject.ScrollTrigger); external_window_namespaceObject.ScrollTrigger.scrollerProxy('[data-scroll-container]', { scrollTop(value) { return arguments.length ? window.locomotive.scrollTo(value, 0, 0) : window.locomotive.scroll.instance.scroll.y; }, getBoundingClientRect() { return { top: 0, left: 0, width: window.innerWidth, height: window.innerHeight }; }, pinType: document.querySelector('[data-scroll-container]').style.transform ? "transform" : "fixed" }); external_window_namespaceObject.ScrollTrigger.addEventListener("refresh", () => window.locomotive.update()); external_window_namespaceObject.ScrollTrigger.refresh(); window.locomotive.on('scroll', (args) => { external_window_namespaceObject.ScrollTrigger.update() }); external_window_namespaceObject.ScrollTrigger.create({ trigger: '.ghbs', scroller: '[data-scroll-container]', start: 'top 70%', end: 'bottom bottom', // markers: true, invalidateOnRefresh: true, onEnter: () => playAnimation(), onLeaveBack: () => stopAnimation() }); init(); } window.addEventListener('compFuncRun', main); })(); // This entry need to be wrapped in an IIFE because it need to be in strict mode. (() => { "use strict"; // extracted by mini-css-extract-plugin })(); /******/ })() ; </script> </section> </div> </div> <div class="global-newsletter-subscription parbase"> <div> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/components/content/global/global-newsletter-subscription/clientlibs.min.css" type="text/css"> <section id="globalNewsLetterSubscriptionSection" data-success-msg="Thank you!" data-duplicate-msg="You are already subscribed with your email address." data-systemerror-msg="Your request has not been completed due to system error. Please try again." data-share-url="https://www.hankooktire.com/global/en/home.html" class="gns mgt mgb en"> <div class="section--full"> <h2 class="title">Subscribe Now</h2> <p class="description">Receive the latest news from Hankook Tire & Technology</p> <form> <div class="gns-input"> <input type="text" name="emailAddr" id="emailAddr" placeholder="Your email address"/> <label for="emailAddr">Your email address</label> <button class="btn btn--arrow btn--bg" onclick="doSubscribeNext();" data-contents="Subscribe_Start" type="button"> Subscribe </button> </div> </form> </div> <div class="popup_wrapper"> <div class="popup_base Subscribe_pop" id="Subscribe_pop" data-sitecd="go-en"> <div class="dim"></div> <div class="pop_inner"> <div class="top"> <button class="close_pop">CLOSE</button> </div> <div class="pop_con"> <div class="pop_title"> <h3 class="font_contents_title_2"> Subscribe to Hankook Tire News </h3> </div> <p class="font_body_2 txt-center description"> Be the first to receive stories from Hankook Tire & Technology, latest news on tires, motorsports, brand, high-tech and more. </p> <form name="newsletter_form" id="newsletter_form"> <div class="popup_email_box"> <input type="text" id="popup_emailAddr" name="popup_emailAddr" required/> <label for="popup_emailAddr">Enter your email address</label> </div> <p class="Validation emailValidation1"><span id="emailValidationInputValue" style="padding-right:3px;"></span>is not a valid email address in the basic format account@hostname.</p> <p class="Validation emailValidation2">Value is required.</p> <div class="select-wrap"> <div class="select-box"> <button class="btn" id="country" type="button" data-value="">Your Location</button> <div class="drop-box" id="ContryDropdown"> <div class="drop-search-box"> <input type="text" placeholder="Search your location" id="ContrySearch"/> </div> <button data-value="AF" type="button">Afghanistan</button> <button data-value="AX" type="button">Aland Islands</button> <button data-value="AL" type="button">Albania</button> <button data-value="DZ" type="button">Algeria</button> <button data-value="AS" type="button">American Samoa</button> <button data-value="AD" type="button">Andorra</button> <button data-value="AO" type="button">Angola</button> <button data-value="AI" type="button">Anguilla</button> <button data-value="AQ" type="button">Antarctica</button> <button data-value="AG" type="button">Antigua and Barbuda</button> <button data-value="AR" type="button">Argentina</button> <button data-value="AM" type="button">Armenia</button> <button data-value="AW" type="button">Aruba</button> <button data-value="AU" type="button">Australia</button> <button data-value="AT" type="button">Austria</button> <button data-value="AZ" type="button">Azerbaijan</button> <button data-value="BS" type="button">Bahamas</button> <button data-value="BH" type="button">Bahrain</button> <button data-value="BD" type="button">Bangladesh</button> <button data-value="BB" type="button">Barbados</button> <button data-value="BY" type="button">Belarus</button> <button data-value="BE" type="button">Belgium</button> <button data-value="BZ" type="button">Belize</button> <button data-value="BJ" type="button">Benin</button> <button data-value="BM" type="button">Bermuda</button> <button data-value="BT" type="button">Bhutan</button> <button data-value="BO" type="button">Bolivia</button> <button data-value="BQ" type="button">Bonaire, Sint Eustatius and Saba</button> <button data-value="BA" type="button">Bosnia and Herzegovina</button> <button data-value="BW" type="button">Botswana</button> <button data-value="BV" type="button">Bouvet Island</button> <button data-value="BR" type="button">Brazil</button> <button data-value="IO" type="button">British Indian Ocean Territory</button> <button data-value="BN" type="button">Brunei Darussalam</button> <button data-value="BG" type="button">Bulgaria</button> <button data-value="BF" type="button">Burkina Faso</button> <button data-value="BI" type="button">Burundi</button> <button data-value="KH" type="button">Cambodia</button> <button data-value="CM" type="button">Cameroon</button> <button data-value="CA" type="button">Canada</button> <button data-value="CV" type="button">Cape Verde</button> <button data-value="KY" type="button">Cayman Islands</button> <button data-value="CF" type="button">Central African Republic</button> <button data-value="TD" type="button">Chad</button> <button data-value="CL" type="button">Chile</button> <button data-value="CN" type="button">China</button> <button data-value="CX" type="button">Christmas Island</button> <button data-value="CC" type="button">Cocos (Keeling) Islands</button> <button data-value="CO" type="button">Colombia</button> <button data-value="KM" type="button">Comoros</button> <button data-value="CG" type="button">Congo</button> <button data-value="CD" type="button">Congo, Democratic Republic of the Congo</button> <button data-value="CK" type="button">Cook Islands</button> <button data-value="CR" type="button">Costa Rica</button> <button data-value="CI" type="button">Cote D'Ivoire</button> <button data-value="HR" type="button">Croatia</button> <button data-value="CU" type="button">Cuba</button> <button data-value="CW" type="button">Curacao</button> <button data-value="CY" type="button">Cyprus</button> <button data-value="CZ" type="button">Czech Republic</button> <button data-value="DK" type="button">Denmark</button> <button data-value="DJ" type="button">Djibouti</button> <button data-value="DM" type="button">Dominica</button> <button data-value="DO" type="button">Dominican Republic</button> <button data-value="EC" type="button">Ecuador</button> <button data-value="EG" type="button">Egypt</button> <button data-value="SV" type="button">El Salvador</button> <button data-value="GQ" type="button">Equatorial Guinea</button> <button data-value="ER" type="button">Eritrea</button> <button data-value="EE" type="button">Estonia</button> <button data-value="ET" type="button">Ethiopia</button> <button data-value="FK" type="button">Falkland Islands (Malvinas)</button> <button data-value="FO" type="button">Faroe Islands</button> <button data-value="FJ" type="button">Fiji</button> <button data-value="FI" type="button">Finland</button> <button data-value="FR" type="button">France</button> <button data-value="GF" type="button">French Guiana</button> <button data-value="PF" type="button">French Polynesia</button> <button data-value="TF" type="button">French Southern Territories</button> <button data-value="GA" type="button">Gabon</button> <button data-value="GM" type="button">Gambia</button> <button data-value="GE" type="button">Georgia</button> <button data-value="DE" type="button">Germany</button> <button data-value="GH" type="button">Ghana</button> <button data-value="GI" type="button">Gibraltar</button> <button data-value="GR" type="button">Greece</button> <button data-value="GL" type="button">Greenland</button> <button data-value="GD" type="button">Grenada</button> <button data-value="GP" type="button">Guadeloupe</button> <button data-value="GU" type="button">Guam</button> <button data-value="GT" type="button">Guatemala</button> <button data-value="GG" type="button">Guernsey</button> <button data-value="GN" type="button">Guinea</button> <button data-value="GW" type="button">Guinea-Bissau</button> <button data-value="GY" type="button">Guyana</button> <button data-value="HT" type="button">Haiti</button> <button data-value="HM" type="button">Heard Island and Mcdonald Islands</button> <button data-value="VA" type="button">Holy See (Vatican City State)</button> <button data-value="HN" type="button">Honduras</button> <button data-value="HK" type="button">Hong Kong</button> <button data-value="HU" type="button">Hungary</button> <button data-value="IS" type="button">Iceland</button> <button data-value="IN" type="button">India</button> <button data-value="ID" type="button">Indonesia</button> <button data-value="IR" type="button">Iran, Islamic Republic of</button> <button data-value="IQ" type="button">Iraq</button> <button data-value="IE" type="button">Ireland</button> <button data-value="IM" type="button">Isle of Man</button> <button data-value="IL" type="button">Israel</button> <button data-value="IT" type="button">Italy</button> <button data-value="JM" type="button">Jamaica</button> <button data-value="JP" type="button">Japan</button> <button data-value="JE" type="button">Jersey</button> <button data-value="JO" type="button">Jordan</button> <button data-value="KZ" type="button">Kazakhstan</button> <button data-value="KE" type="button">Kenya</button> <button data-value="KI" type="button">Kiribati</button> <button data-value="KP" type="button">Korea, Democratic People's Republic of</button> <button data-value="KR" type="button">Korea, Republic of</button> <button data-value="XK" type="button">Kosovo</button> <button data-value="KW" type="button">Kuwait</button> <button data-value="KG" type="button">Kyrgyzstan</button> <button data-value="LA" type="button">Lao People's Democratic Republic</button> <button data-value="LV" type="button">Latvia</button> <button data-value="LB" type="button">Lebanon</button> <button data-value="LS" type="button">Lesotho</button> <button data-value="LR" type="button">Liberia</button> <button data-value="LY" type="button">Libyan Arab Jamahiriya</button> <button data-value="LI" type="button">Liechtenstein</button> <button data-value="LT" type="button">Lithuania</button> <button data-value="LU" type="button">Luxembourg</button> <button data-value="MO" type="button">Macao</button> <button data-value="MK" type="button">Macedonia, the Former Yugoslav Republic of</button> <button data-value="MG" type="button">Madagascar</button> <button data-value="MW" type="button">Malawi</button> <button data-value="MY" type="button">Malaysia</button> <button data-value="MV" type="button">Maldives</button> <button data-value="ML" type="button">Mali</button> <button data-value="MT" type="button">Malta</button> <button data-value="MH" type="button">Marshall Islands</button> <button data-value="MQ" type="button">Martinique</button> <button data-value="MR" type="button">Mauritania</button> <button data-value="MU" type="button">Mauritius</button> <button data-value="YT" type="button">Mayotte</button> <button data-value="MX" type="button">Mexico</button> <button data-value="FM" type="button">Micronesia, Federated States of</button> <button data-value="MD" type="button">Moldova, Republic of</button> <button data-value="MC" type="button">Monaco</button> <button data-value="MN" type="button">Mongolia</button> <button data-value="ME" type="button">Montenegro</button> <button data-value="MS" type="button">Montserrat</button> <button data-value="MA" type="button">Morocco</button> <button data-value="MZ" type="button">Mozambique</button> <button data-value="MM" type="button">Myanmar</button> <button data-value="NA" type="button">Namibia</button> <button data-value="NR" type="button">Nauru</button> <button data-value="NP" type="button">Nepal</button> <button data-value="NL" type="button">Netherlands</button> <button data-value="AN" type="button">Netherlands Antilles</button> <button data-value="NC" type="button">New Caledonia</button> <button data-value="NZ" type="button">New Zealand</button> <button data-value="NI" type="button">Nicaragua</button> <button data-value="NE" type="button">Niger</button> <button data-value="NG" type="button">Nigeria</button> <button data-value="NU" type="button">Niue</button> <button data-value="NF" type="button">Norfolk Island</button> <button data-value="MP" type="button">Northern Mariana Islands</button> <button data-value="NO" type="button">Norway</button> <button data-value="OM" type="button">Oman</button> <button data-value="PK" type="button">Pakistan</button> <button data-value="PW" type="button">Palau</button> <button data-value="PS" type="button">Palestinian Territory, Occupied</button> <button data-value="PA" type="button">Panama</button> <button data-value="PG" type="button">Papua New Guinea</button> <button data-value="PY" type="button">Paraguay</button> <button data-value="PE" type="button">Peru</button> <button data-value="PH" type="button">Philippines</button> <button data-value="PN" type="button">Pitcairn</button> <button data-value="PL" type="button">Poland</button> <button data-value="PT" type="button">Portugal</button> <button data-value="PR" type="button">Puerto Rico</button> <button data-value="QA" type="button">Qatar</button> <button data-value="RE" type="button">Reunion</button> <button data-value="RO" type="button">Romania</button> <button data-value="RU" type="button">Russian Federation</button> <button data-value="RW" type="button">Rwanda</button> <button data-value="BL" type="button">Saint Barthelemy</button> <button data-value="SH" type="button">Saint Helena</button> <button data-value="KN" type="button">Saint Kitts and Nevis</button> <button data-value="LC" type="button">Saint Lucia</button> <button data-value="MF" type="button">Saint Martin</button> <button data-value="PM" type="button">Saint Pierre and Miquelon</button> <button data-value="VC" type="button">Saint Vincent and the Grenadines</button> <button data-value="WS" type="button">Samoa</button> <button data-value="SM" type="button">San Marino</button> <button data-value="ST" type="button">Sao Tome and Principe</button> <button data-value="SA" type="button">Saudi Arabia</button> <button data-value="SN" type="button">Senegal</button> <button data-value="RS" type="button">Serbia</button> <button data-value="CS" type="button">Serbia and Montenegro</button> <button data-value="SC" type="button">Seychelles</button> <button data-value="SL" type="button">Sierra Leone</button> <button data-value="SG" type="button">Singapore</button> <button data-value="SX" type="button">Sint Maarten</button> <button data-value="SK" type="button">Slovakia</button> <button data-value="SI" type="button">Slovenia</button> <button data-value="SB" type="button">Solomon Islands</button> <button data-value="SO" type="button">Somalia</button> <button data-value="ZA" type="button">South Africa</button> <button data-value="GS" type="button">South Georgia and the South Sandwich Islands</button> <button data-value="SS" type="button">South Sudan</button> <button data-value="ES" type="button">Spain</button> <button data-value="LK" type="button">Sri Lanka</button> <button data-value="SD" type="button">Sudan</button> <button data-value="SR" type="button">Suriname</button> <button data-value="SJ" type="button">Svalbard and Jan Mayen</button> <button data-value="SZ" type="button">Swaziland</button> <button data-value="SE" type="button">Sweden</button> <button data-value="CH" type="button">Switzerland</button> <button data-value="SY" type="button">Syrian Arab Republic</button> <button data-value="TW" type="button">Taiwan, Province of China</button> <button data-value="TJ" type="button">Tajikistan</button> <button data-value="TZ" type="button">Tanzania, United Republic of</button> <button data-value="TH" type="button">Thailand</button> <button data-value="TL" type="button">Timor-Leste</button> <button data-value="TG" type="button">Togo</button> <button data-value="TK" type="button">Tokelau</button> <button data-value="TO" type="button">Tonga</button> <button data-value="TT" type="button">Trinidad and Tobago</button> <button data-value="TN" type="button">Tunisia</button> <button data-value="TR" type="button">Turkey</button> <button data-value="TM" type="button">Turkmenistan</button> <button data-value="TC" type="button">Turks and Caicos Islands</button> <button data-value="TV" type="button">Tuvalu</button> <button data-value="UG" type="button">Uganda</button> <button data-value="UA" type="button">Ukraine</button> <button data-value="AE" type="button">United Arab Emirates</button> <button data-value="GB" type="button">United Kingdom</button> <button data-value="US" type="button">United States</button> <button data-value="UM" type="button">United States Minor Outlying Islands</button> <button data-value="UY" type="button">Uruguay</button> <button data-value="UZ" type="button">Uzbekistan</button> <button data-value="VU" type="button">Vanuatu</button> <button data-value="VE" type="button">Venezuela</button> <button data-value="VN" type="button">Viet Nam</button> <button data-value="VG" type="button">Virgin Islands, British</button> <button data-value="VI" type="button">Virgin Islands, U.s.</button> <button data-value="WF" type="button">Wallis and Futuna</button> <button data-value="EH" type="button">Western Sahara</button> <button data-value="YE" type="button">Yemen</button> <button data-value="ZM" type="button">Zambia</button> <button data-value="ZW" type="button">Zimbabwe</button> <div class="drop-search-noresult">No results found</div> </div> </div> <p class="Validation countryValidation">Value is required.</p> <p class="Validation langValidation"></p> </div> <div class="check-wrap"> <span class="checkbox input-block"> <input type="checkbox" id="popup_agree" name="popup_agree"/> <label for="popup_agree"><span> By clicking or tapping the 'Subscribe' button, I acknowledge that I have read and agree to the <b><u><a href="https://www.hankooktire.com/global/en/footer/privacy-policy.html" target="_blank">Privacy Policy</a></u></b><u></u>. </span></label> </span> <p class="Validation checkValidation">Value is required.</p> </div> <a href="javascript:void(0);" class="btn btn--arrow btn--bg sub-btn" onclick="doSubscribe();">Subscribe</a> <!-- ���̾˷α� Popup Contents - Subscribe Button Text --> <button type="button" id="hiddenSubscribeBtn" style="display:none;"></button> </form> </div> </div> </div> <div class="popup_base popup_submitted" id="popup_submitted" data-parent="Subscribe_pop"> <div class="dim"></div> <div class="pop_inner"> <div class="top"> <button class="all_close close_pop" data-contents="subscribe_completed_close_right">Close</button> </div> <div class="pop_con"> <div class="pop_title"> <h3 class="font_contents_title_2">Thank you!</h3> <h3 class="font_contents_title_2">Your request has been submitted.</h3> </div> <p class="font_body_2 txt-center descriptiodn" style="padding-bottom:32px;"> You'll receive a welcome email.<br /> If you can’t receive the email,<br /> please check your <strong>spam</strong> folder. </p> <p class="share_btn font_body_3" data-contents="subscribe_completed_share" onclick="doShare('popup_submitted');">Share</p> <p class="share_txt">Please share this link with your friends!</p> <p class="share_txt_complete">Copied to clipboard.</p> <a href="javascript:void(0);" data-contents="subscribe_completed_close" class="btn btn--bg all_close close_pop">Close</a> </div> </div> </div> <div class="popup_base popup_duplicate_submission" id="popup_duplicate_submission" data-parent="Subscribe_pop"> <div class="pop_inner"> <div class="top"> <button class="all_close close_pop" data-contents="already_subscribed_close_right">Close</button> </div> <div class="pop_con"> <div class="pop_title"> <h3 class="font_contents_title_2">You are already subscribed with your email address.</h3> </div> <p class="share_btn font_body_3" data-contents="already_subscribed_share" onclick="doShare('popup_duplicate_submission');">Share</p> <p class="share_txt">Please share this link with your friends!</p> <p class="share_txt_complete">Copied to clipboard.</p> <a href="javascript:void(0);" data-contents="already_subscribed_close" class="btn btn--bg all_close close_pop">Close</a> </div> </div> </div> <div class="popup_base popup_submission_failed" id="popup_submission_failed"> <div class="pop_inner"> <div class="top"> <button class="close_pop" data-contents="error pop-up_close_right">Back</button> </div> <div class="pop_con"> <div class="pop_title"> <h3 class="font_contents_title_2">Your request has not been completed due to system error. Please try again.</h3> </div> <a href="javascript:void(0);" data-contents="error pop-up_go_back" class="btn btn--bg close_pop">Back</a> </div> </div> </div> </div> </section> <script src="/etc.clientlibs/hankooktire/components/content/global/global-newsletter-subscription/clientlibs.min.js"></script> </div> </div> <div class="global-home-media-slide-a parbase"> <div class="bg-black " data-dark-theme> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/components/content/global/global-home-media-slide-a/clientlibs.min.css" type="text/css"> <section class="ghma"> <div class="section--full"> <div class="content-container"> <div class="content"> <h2 class="h3 title font_headline_1">Hankook Technoring</h2> <p class="desc font_body_2_main"> Hankook Technoring is the largest tire test track in Asia which tests the extreme tire technology. To develop the innovative tires, Hankook Tire intensely researches and rigorously tests the tire performance in various road surfaces and extreme environments. </p> <div class="btn-wrap"> <a href="/global/ko/innovation/technoring.html" target="_self" class="btn btn--round">Learn More</a> <a href="https://www.hankooktire.com/global/en/innovation/technoring-webgl.html" target="_blank" rel="noopener noreferrer" class="btn btn--round">Virtual Experience</a> </div> </div> <div class="video-wrap"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/DADE_main_1104.mp4" poster="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/global_main_1104.jpg" muted="" playsinline="" autoplay></video> </div> <div class="progress"><div class="thumb"></div><div class="thumb-prev"></div></div> </div> </div> </section> <script src="/etc.clientlibs/hankooktire/components/content/global/global-home-media-slide-a/clientlibs.min.js"></script> </div> </div> <div class="global-home-media-slide-b parbase"> <div> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/components/content/global/global-home-media-slide-b/clientlibs.min.css" type="text/css"> <section class="ghmb"> <div class="content"> <h2 class="h3 title font_headline_1">Motorsports</h2> <p class="desc font_body_2"> As a sponsor for a host of motorsports competitions and teams in Korea and abroad, we stand behind drivers the world over to push their limits and explore new possibilities. </p> <div class="btn-wrap"> <a href="https://www.hankook-motorsports.com/en/main.html" target="_blank" class="btn btn--round">Learn More</a> </div> </div> <div class="section--full"> <div class="ghmb__swiper"> <ul class="ghmb__list swiper-wrapper"> <li class="ghmb__item swiper-slide sm" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/IM_HK_FE_Mexico_City_5657_233021_2.jpg);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/IM_HK_FE_Mexico_City_5657_233021_2.jpg" alt="HK_FE_Mexico_City_5657_233021" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide md" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/Portland_7972_2.jpg);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/Portland_7972_2.jpg" alt="Portland_7972" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide lg" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/IM_HK_MOTORSPORT_FE_Portland_241015_2.jpg);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/IM_HK_MOTORSPORT_FE_Portland_241015_2.jpg" alt="HK_MOTORSPORT_FE_Portland_241015" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide sm" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/20230116_1.png);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/20230116_1.png" alt="home-motorsport-img1" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide md" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/20230116_2.png);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/20230116_2.png" alt="home-motorsport-img2" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide lg" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/20230116_3.png);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/20230116_3.png" alt="home-motorsport-img3" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide sm" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/01.jpg);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/01.jpg" alt="home-motorsport-img4" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide lg" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/03.jpg);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/03.jpg" alt="home-motorsport-img5" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide sm" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/02.jpg);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/02.jpg" alt="home-motorsport-img6" data-type="img"/> </a> </li> <li class="ghmb__item swiper-slide md" style="background-image: url(https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/04.jpg);"> <a href="#"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/global/images/home/motorsports/04.jpg" alt="home-motorsport-img7" data-type="img"/> </a> </li> </ul> <div class="section--full"> <div class="swiper-scrollbar"></div> </div> </div> </div> </section> <script src="/etc.clientlibs/hankooktire/components/content/global/global-home-media-slide-b/clientlibs.min.js"></script> </div> </div> <div class="global-home-video parbase"> <div> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/components/content/global/global-home-video/clientlibs.min.css" type="text/css"> <section class="ghv"> <div class="section--full"> <a class="video-container" href="/global/en/inside-hankook.html" target="_self"> <video src="https://asset.hankooktire.com/content/dam/hankooktire/global/video/main/main_company_overview_0627.mp4" muted="" playsinline="" autoplay loop></video> </a> <h2 class="title font_headline_2">Inside Hankook</h2> <p class="desc font_body_2_main">In ceaseless pursuit of innovation, Hankook Tire reaches new heights as a global top-tier company that shapes the future of driving. </p> <div class="progress"> <div class="thumb"></div> <div class="thumb-prev"></div> </div> <a class="btn btn--round btn--invert" href="/global/en/inside-hankook.html" target="_self">Learn More</a> </div> </section> <script src="/etc.clientlibs/hankooktire/components/content/global/global-home-video/clientlibs.min.js"></script> </div> </div> <div class="global-home-social parbase"> <div> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/components/content/global/global-home-social/clientlibs.min.css" type="text/css"> <section class="ghs"> <div class="section--full"> <h2 class="title font_body_1_main"><span>#Hankooktire </span> in Social Media</h2> </div> <div class="ghs__swiper w_show"> <ul class="ghs__list swiper-wrapper"> <li class="ghs__item swiper-slide" data-social-type="instagram"> <a href="https://www.instagram.com/p/DHAkZ62Bnzs/" target="_blank" rel="noopener noreferrer" style="background-image:url('https:\2f\2f asset.hankooktire.com\2f content\2f dam\2fhankooktire\2flocal\2fimg\2fmain\2fsns\2f 2025\2f 03\2f 3\2f 0317_IG_GL.jpg')"></a> </li> <li class="ghs__item swiper-slide" data-social-type="facebook"> <a href="https://www.facebook.com/hankooktire.global/videos/945549870710065/" target="_blank" rel="noopener noreferrer" style="background-image:url('https:\2f\2f asset.hankooktire.com\2f content\2f dam\2fhankooktire\2flocal\2fimg\2fmain\2fsns\2f 2025\2f 03\2f 3\2f 0317_FB_GL.jpg')"></a> </li> <li class="ghs__item swiper-slide" data-social-type="tiktok"> <a href="https://www.tiktok.com/@hankooktire.official/video/7481577417341996289" target="_blank" rel="noopener noreferrer" style="background-image:url('https:\2f\2f asset.hankooktire.com\2f content\2f dam\2fhankooktire\2flocal\2fimg\2fmain\2fsns\2f 2025\2f 03\2f 3\2f 0317_TT_GL.jpg')"></a> </li> <li class="ghs__item swiper-slide" data-social-type="youtube"> <a href="https://www.youtube.com/shorts/00nxlPLZs4k" target="_blank" rel="noopener noreferrer" style="background-image:url('https:\2f\2f asset.hankooktire.com\2f content\2f dam\2fhankooktire\2flocal\2fimg\2fmain\2fsns\2f 2025\2f 03\2f 3\2f 0317_YT_GL.jpg')"></a> </li> <li class="ghs__item swiper-slide" data-social-type="instagram"> <a href="https://www.instagram.com/p/DG2UYSWPklC/?img_index=1" target="_blank" rel="noopener noreferrer" style="background-image:url('https:\2f\2f asset.hankooktire.com\2f content\2f dam\2fhankooktire\2flocal\2fimg\2fmain\2fsns\2f 2025\2f 03\2f 2\2fGL_Mar_W2_INSTRA_01.jpg')"></a> </li> <li class="ghs__item swiper-slide" data-social-type="facebook"> <a href="https://www.facebook.com/share/p/1BM9wi7e9q/" target="_blank" rel="noopener noreferrer" style="background-image:url('https:\2f\2f asset.hankooktire.com\2f content\2f dam\2fhankooktire\2flocal\2fimg\2fmain\2fsns\2f 2025\2f 03\2f 2\2fGL_Mar_W2_FB_02.jpg')"></a> </li> </ul> </div> <div class="ghs__mobile_list m_show"> <ul> <li class="ghs__item swiper-slide" data-social-type="instagram"> <a href="https://www.instagram.com/p/DHAkZ62Bnzs/" target="_blank" rel="noopener noreferrer"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/local/img/main/sns/2025/03/3/0317_IG_GL.jpg" alt="home-social-01"/> </a> </li> <li class="ghs__item swiper-slide" data-social-type="facebook"> <a href="https://www.facebook.com/hankooktire.global/videos/945549870710065/" target="_blank" rel="noopener noreferrer"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/local/img/main/sns/2025/03/3/0317_FB_GL.jpg" alt="home-social-02"/> </a> </li> <li class="ghs__item swiper-slide" data-social-type="tiktok"> <a href="https://www.tiktok.com/@hankooktire.official/video/7481577417341996289" target="_blank" rel="noopener noreferrer"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/local/img/main/sns/2025/03/3/0317_TT_GL.jpg" alt="home-social-03"/> </a> </li> <li class="ghs__item swiper-slide" data-social-type="youtube"> <a href="https://www.youtube.com/shorts/00nxlPLZs4k" target="_blank" rel="noopener noreferrer"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/local/img/main/sns/2025/03/3/0317_YT_GL.jpg" alt="home-social-05"/> </a> </li> <li class="ghs__item swiper-slide" data-social-type="instagram"> <a href="https://www.instagram.com/p/DG2UYSWPklC/?img_index=1" target="_blank" rel="noopener noreferrer"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/local/img/main/sns/2025/03/2/GL_Mar_W2_INSTRA_01.jpg" alt="home-social-01"/> </a> </li> <li class="ghs__item swiper-slide" data-social-type="facebook"> <a href="https://www.facebook.com/share/p/1BM9wi7e9q/" target="_blank" rel="noopener noreferrer"> <img src="https://asset.hankooktire.com/content/dam/hankooktire/local/img/main/sns/2025/03/2/GL_Mar_W2_FB_02.jpg" alt="home-social-04"/> </a> </li> </ul> </div> </section> <script src="/etc.clientlibs/hankooktire/components/content/global/global-home-social/clientlibs.min.js"></script> </div> </div> </div> </main> <link rel="stylesheet" href="/etc.clientlibs/hankooktire/components/content/global/common/footer/clientlibs.min.css" type="text/css"> <footer class="footer footer--global"> <div class="menu"> <ul class="d1"> <li class="d1__menu"> <a>Company</a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu "> <a href="/global/en/company/company-overview.html">Company Overview</a> </li> <li class="d2__menu "> <a href="/global/en/career/job-announcement.html" target="_self">Careers</a> </li> <li class="d2__menu "> <a href="/global/en/company/media-list.html" target="_self">Media Center</a> </li> <li class="d2__menu "> <a href="/global/en/company/awards/design-award.html" target="_self">Award</a> </li> <li class="d2__menu "> <a href="/global/en/company/global-network.html">Global Network</a> </li> <li class="d2__menu "> <a href="/global/en/footer/contact.html">Contact</a> </li> <li class="d2__menu "> <a href="javascript:void(0);" onclick="doSubscribeFooterShow();">Newsletter</a> </li> </ul> </div> </li> <li class="d1__menu"> <a target="_self">ESG</a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu "> <a href="/global/en/esg/hankook-tire-esg/esg-overview.html" target="_self">ESG Overview</a> </li> <li class="d2__menu "> <a href="/global/en/esg/governance.html" target="_self">Governance</a> </li> <li class="d2__menu "> <a href="/global/en/esg/eco-value-chain.html" target="_self">Eco Value Chain</a> </li> <li class="d2__menu "> <a href="/global/en/esg/sustainable-product.html" target="_self">Sustainable Product</a> </li> <li class="d2__menu "> <a href="/global/en/esg/responsible-engagement.html" target="_self">Responsible Engagement</a> </li> <li class="d2__menu "> <a href="/global/en/esg/esg-report.html" target="_self">ESG Report</a> </li> <li class="d2__menu "> <a href="/global/en/misconduct-reporting/misconduct-reporting-guide.html" target="_self">Misconduct Reporting</a> </li> </ul> </div> </li> <li class="d1__menu"> <a target="_self">Investors</a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu "> <a href="/global/en/investors/financial-information-results/key-figures.html" target="_self">Financial Information</a> </li> <li class="d2__menu "> <a href="/global/en/investors/financial-information-results/credit-ratings.html" target="_self">Financial Results</a> </li> <li class="d2__menu "> <a href="/global/en/investors/shares-shareholders/distribution-shares.html" target="_self">Shares & Shareholders</a> </li> <li class="d2__menu "> <a href="/global/en/investors/financial-reports/annual-reports.html" target="_self">Financial Reports</a> </li> <li class="d2__menu "> <a href="/global/en/investors/financial-reports/krx-disclosure.html" target="_self">KRX Disclosure</a> </li> </ul> </div> </li> <li class="d1__menu"> <a>Our Brands</a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu "> <a href="/global/en/tires/ion.html">iON</a> </li> <li class="d2__menu "> <a href="/global/en/tires/ventus.html">Ventus</a> </li> <li class="d2__menu "> <a href="/global/en/tires/dynapro.html">Dynapro</a> </li> <li class="d2__menu "> <a href="/global/en/tires/weatherflex.html">Weatherflex</a> </li> <li class="d2__menu "> <a href="/global/en/tires/kinergy.html">Kinergy</a> </li> <li class="d2__menu "> <a href="/global/en/tires/winter-i-cept-winter-i-pike.html">Winter i*cept & Winter i*pike</a> </li> <li class="d2__menu "> <a href="/global/en/tires/vantra.html">Vantra</a> </li> <li class="d2__menu "> <a href="/global/en/tires/smart.html">Smart</a> </li> </ul> </div> </li> <li class="d1__menu"> <a>Motorsports</a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu "> <a href="https://www.hankook-motorsports.com/en/main.html" target="_blank">Hankook Motorsports</a> </li> <li class="d2__menu "> <a href="https://www.hankook-motorsports.com/en/formula-e/about-formula-e.html" target="_blank">Formula E</a> </li> <li class="d2__menu "> <a href="https://www.hankook-motorsports.com/en/wrc/about-wrc.html" target="_blank">WRC</a> </li> <li class="d2__menu "> <a href="https://www.hankook-motorsports.com/en/lamborghini/super_trofeo_europe.html" target="_blank">Partnerships</a> </li> <li class="d2__menu "> <a href="https://www.hankook-motorsports.com/en/tires/tires/circuit.html" target="_blank">Competition Tires</a> </li> </ul> </div> </li> <li class="d1__menu"> <a>Family Site</a> <div class="d2-wrap"> <ul class="d2"> <li class="d2__menu "> <a href="https://www.hankook-motorsports.com/en/main.html" target="_blank">Hankook Motorsports</a> </li> <li class="d2__menu "> <a href="https://www.laufenn.com/" target="_blank">Laufenn</a> </li> <li class="d2__menu "> <a href="https://www.hankookandcompany.com/ko?lang=ko" target="_blank"> Hankook & Company</a> </li> <li class="d2__menu "> <a href="https://www.hankook-atlasbx.com/en/" target="_blank">ES Business HQ</a> </li> <li class="d2__menu "> <a href="https://www.hankook-networks.com/ko" target="_blank">Hankook Networks</a> </li> <li class="d2__menu "> <a href="https://www.hankook-engineeringworks.com/ko" target="_blank">Hankook Engineering Works</a> </li> <li class="d2__menu "> <a href="https://www.hankook-precisionworks.com/ko" target="_blank">Hankook Precision Works</a> </li> <li class="d2__menu "> <a href="https://www.hanonsystems.com/en/" target="_blank">Hanon Systems</a> </li> <li class="d2__menu "> <a href="https://www.model-solution.com/en/main" target="_blank">Model Solution</a> </li> <li class="d2__menu "> <a href="https://preciseley.com/" target="_blank">Preciseley Microtechnology Corp.</a> </li> </ul> </div> </li> <li class="d1__menu"> <a href="javascript:;">Official Partner of</a> <div class="d2-wrap"> <ul class="d2 sponsor-list"> <li class="d2__menu sponsor formulae"> <a href="https://www.hankook-motorsports.com/en/formula-e/about-formula-e.html" target="_blank"></a> </li> <li class="d2__menu sponsor wrc"> <a href="https://www.hankook-motorsports.com/en/wrc/about-wrc.html" target="_blank"></a> </li> <li class="d2__menu sponsor lamborghini"> <a href="https://www.hankook-motorsports.com/en/lamborghini/super_trofeo_europe.html" target="_blank"></a> </li> <li class="d2__menu sponsor uefa"> <a href="/global/en/the-uefa-europa-league-sponsorship.html"></a> </li> </ul> </div> </li> </ul> </div> <div class="outlink"> <div class="link__find"> <a href="/global/en/hankook-in-your-location.html" target="_self" class="btn btn--round btn--invert"> <span> Hankook in Your Location<br/> <small>Croatia</small> </span> </a> </div> <ul class="language"> <li class="on">English</li> <li><a href="/global/ko/home.html">Korean </a></li> </ul> </div> <div class="info info1"> <ul class="info__list sponsor-list"> <li class="info__item">Official Partner of</li> <li class="sponsor info__item formulae"> <a href="https://www.hankook-motorsports.com/en/formula-e/about-formula-e.html" target="_blank"></a> </li> <li class="sponsor info__item wrc"> <a href="https://www.hankook-motorsports.com/en/wrc/about-wrc.html" target="_blank"></a> </li> <li class="sponsor info__item lamborghini"> <a href="https://www.hankook-motorsports.com/en/lamborghini/super_trofeo_europe.html" target="_blank"></a> </li> <li class="sponsor info__item uefa"> <a href="/global/en/the-uefa-europa-league-sponsorship.html"></a> </li> </ul> <ul class="info__list"> <li class="info__item">Family Site :</li> <li class="info__item"><a href="https://www.hankook-motorsports.com/en/main.html" target="_blank">Hankook Motorsports</a></li> <li class="info__item"><a href="https://www.laufenn.com/" target="_blank">Laufenn</a></li> <li class="info__item"><a href="https://www.hankookandcompany.com/en.do?lang=en" target="_blank">Hankook & Company</a></li> <li class="info__item"><a href="https://www.hankook-atlasbx.com/en/" target="_blank">ES Business HQ</a></li> <li class="info__item"><a href="https://www.hankook-networks.com/en?lang=en" target="_blank">Hankook Networks</a></li> <li class="info__item"><a href="https://www.hankook-engineeringworks.com/en?lang=en" target="_blank">Hankook Engineering Works</a></li> <li class="info__item"><a href="https://www.hankook-precisionworks.com/en.do?lang=en" target="_blank">Hankook Precision Works</a></li> <li class="info__item"><a href="https://www.hanonsystems.com/en/" target="_blank">Hanon Systems</a></li> <li class="info__item"><a href="https://www.model-solution.com/en/main" target="_blank">Model Solution</a></li> <li class="info__item"><a href="https://preciseley.com/" target="_blank">Preciseley Microtechnology Corp.</a></li> </ul> <ul class="social"> <li class="social__item"> <a href="https://ko-kr.facebook.com/hankooktire.global/" target="_blank" class="icon icon--facebook"> <span class="a11y">facebook</span> </a> </li> <li class="social__item"> <a href="https://www.youtube.com/user/hankooktireglobal" target="_blank" class="icon icon--youtube"> <span class="a11y">youtube</span> </a> </li> <li class="social__item"> <a href="https://www.instagram.com/hankooktire.global/" target="_blank" class="icon icon--instagram"> <span class="a11y">Instagram</span> </a> </li> <li class="social__item"> <a href="https://www.linkedin.com/company/hankook-tire-global/" target="_blank" class="icon icon--linkedin"> <span class="a11y">Linkedin</span> </a> </li> <li class="social__item"> <a href="https://www.tiktok.com/@hankooktire.official" target="_blank" class="icon icon--tiktok"> <span class="a11y">TikTok</span> </a> </li> </ul> </div> <div class="info info2"> <ul class="info__list"> <li class="info__item"> <a href="/global/en/footer/privacy-policy.html" target="_self"> Privacy Policy </a> </li> <li class="info__item"> <a href="/global/en/suppliers.html" target="_self"> Supplier </a> </li> <li class="info__item"> <a href="https://heps.hankooktech.com/login_e.jsp" target="_blank"> Supplier Portal <img src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global/resources/svg/icon_outlink.svg" alt=""/> </a> </li> <li class="info__item"> <a href="/global/en/sitemap.html" target="_self"> Sitemap </a> </li> <li class="info__item"> <a href="/global/en/misconduct-reporting/misconduct-reporting-guide.html" target="_self"> Misconduct Reporting </a> </li> </ul> <div class="copyright">Copyright © 2025 Hankook Tire & Technology. All Rights Reserved.</div> </div> <div class="popup_wrapper"> <div class="popup_base Subscribe_popFooter" id="Subscribe_popFooter" data-success-msg="Thank you!" data-duplicate-msg="You are already subscribed with your email address." data-systemerror-msg="Your request has not been completed due to system error. Please try again." data-share-url="https://www.hankooktire.com/global/en/home.html" data-sitecd="go-en"> <div class="dim"></div> <div class="pop_inner"> <div class="top"> <button class="close_pop">CLOSE</button> </div> <div class="pop_con"> <div class="pop_title"> <h3 class="font_contents_title_2"> Subscribe to Hankook Tire News </h3> </div> <p class="font_body_2 txt-center description"> Be the first to receive stories from Hankook Tire & Technology, latest news on tires, motorsports, brand, high-tech and more. </p> <form name="newsletter_formFooter" id="newsletter_formFooter"> <div class="popup_email_box"> <input type="text" id="popup_emailAddrFooter" name="popup_emailAddrFooter" required/> <label for="popup_emailAddrFooter">Enter your email address</label> </div> <p class="Validation emailValidation1Footer"><span id="emailValidationInputValueFooter" style="padding-right:3px;"></span>is not a valid email address in the basic format account@hostname.</p> <p class="Validation emailValidation2Footer">Value is required.</p> <div class="select-wrap"> <div class="select-box"> <button class="btn" id="countryFooter" type="button" data-value="">Your Location</button> <div class="drop-box" id="ContryDropdownFooter"> <div class="drop-search-box"> <input type="text" placeholder="Search your location" id="ContrySearchFooter"/> </div> <button data-value="AF" type="button">Afghanistan</button> <button data-value="AX" type="button">Aland Islands</button> <button data-value="AL" type="button">Albania</button> <button data-value="DZ" type="button">Algeria</button> <button data-value="AS" type="button">American Samoa</button> <button data-value="AD" type="button">Andorra</button> <button data-value="AO" type="button">Angola</button> <button data-value="AI" type="button">Anguilla</button> <button data-value="AQ" type="button">Antarctica</button> <button data-value="AG" type="button">Antigua and Barbuda</button> <button data-value="AR" type="button">Argentina</button> <button data-value="AM" type="button">Armenia</button> <button data-value="AW" type="button">Aruba</button> <button data-value="AU" type="button">Australia</button> <button data-value="AT" type="button">Austria</button> <button data-value="AZ" type="button">Azerbaijan</button> <button data-value="BS" type="button">Bahamas</button> <button data-value="BH" type="button">Bahrain</button> <button data-value="BD" type="button">Bangladesh</button> <button data-value="BB" type="button">Barbados</button> <button data-value="BY" type="button">Belarus</button> <button data-value="BE" type="button">Belgium</button> <button data-value="BZ" type="button">Belize</button> <button data-value="BJ" type="button">Benin</button> <button data-value="BM" type="button">Bermuda</button> <button data-value="BT" type="button">Bhutan</button> <button data-value="BO" type="button">Bolivia</button> <button data-value="BQ" type="button">Bonaire, Sint Eustatius and Saba</button> <button data-value="BA" type="button">Bosnia and Herzegovina</button> <button data-value="BW" type="button">Botswana</button> <button data-value="BV" type="button">Bouvet Island</button> <button data-value="BR" type="button">Brazil</button> <button data-value="IO" type="button">British Indian Ocean Territory</button> <button data-value="BN" type="button">Brunei Darussalam</button> <button data-value="BG" type="button">Bulgaria</button> <button data-value="BF" type="button">Burkina Faso</button> <button data-value="BI" type="button">Burundi</button> <button data-value="KH" type="button">Cambodia</button> <button data-value="CM" type="button">Cameroon</button> <button data-value="CA" type="button">Canada</button> <button data-value="CV" type="button">Cape Verde</button> <button data-value="KY" type="button">Cayman Islands</button> <button data-value="CF" type="button">Central African Republic</button> <button data-value="TD" type="button">Chad</button> <button data-value="CL" type="button">Chile</button> <button data-value="CN" type="button">China</button> <button data-value="CX" type="button">Christmas Island</button> <button data-value="CC" type="button">Cocos (Keeling) Islands</button> <button data-value="CO" type="button">Colombia</button> <button data-value="KM" type="button">Comoros</button> <button data-value="CG" type="button">Congo</button> <button data-value="CD" type="button">Congo, Democratic Republic of the Congo</button> <button data-value="CK" type="button">Cook Islands</button> <button data-value="CR" type="button">Costa Rica</button> <button data-value="CI" type="button">Cote D'Ivoire</button> <button data-value="HR" type="button">Croatia</button> <button data-value="CU" type="button">Cuba</button> <button data-value="CW" type="button">Curacao</button> <button data-value="CY" type="button">Cyprus</button> <button data-value="CZ" type="button">Czech Republic</button> <button data-value="DK" type="button">Denmark</button> <button data-value="DJ" type="button">Djibouti</button> <button data-value="DM" type="button">Dominica</button> <button data-value="DO" type="button">Dominican Republic</button> <button data-value="EC" type="button">Ecuador</button> <button data-value="EG" type="button">Egypt</button> <button data-value="SV" type="button">El Salvador</button> <button data-value="GQ" type="button">Equatorial Guinea</button> <button data-value="ER" type="button">Eritrea</button> <button data-value="EE" type="button">Estonia</button> <button data-value="ET" type="button">Ethiopia</button> <button data-value="FK" type="button">Falkland Islands (Malvinas)</button> <button data-value="FO" type="button">Faroe Islands</button> <button data-value="FJ" type="button">Fiji</button> <button data-value="FI" type="button">Finland</button> <button data-value="FR" type="button">France</button> <button data-value="GF" type="button">French Guiana</button> <button data-value="PF" type="button">French Polynesia</button> <button data-value="TF" type="button">French Southern Territories</button> <button data-value="GA" type="button">Gabon</button> <button data-value="GM" type="button">Gambia</button> <button data-value="GE" type="button">Georgia</button> <button data-value="DE" type="button">Germany</button> <button data-value="GH" type="button">Ghana</button> <button data-value="GI" type="button">Gibraltar</button> <button data-value="GR" type="button">Greece</button> <button data-value="GL" type="button">Greenland</button> <button data-value="GD" type="button">Grenada</button> <button data-value="GP" type="button">Guadeloupe</button> <button data-value="GU" type="button">Guam</button> <button data-value="GT" type="button">Guatemala</button> <button data-value="GG" type="button">Guernsey</button> <button data-value="GN" type="button">Guinea</button> <button data-value="GW" type="button">Guinea-Bissau</button> <button data-value="GY" type="button">Guyana</button> <button data-value="HT" type="button">Haiti</button> <button data-value="HM" type="button">Heard Island and Mcdonald Islands</button> <button data-value="VA" type="button">Holy See (Vatican City State)</button> <button data-value="HN" type="button">Honduras</button> <button data-value="HK" type="button">Hong Kong</button> <button data-value="HU" type="button">Hungary</button> <button data-value="IS" type="button">Iceland</button> <button data-value="IN" type="button">India</button> <button data-value="ID" type="button">Indonesia</button> <button data-value="IR" type="button">Iran, Islamic Republic of</button> <button data-value="IQ" type="button">Iraq</button> <button data-value="IE" type="button">Ireland</button> <button data-value="IM" type="button">Isle of Man</button> <button data-value="IL" type="button">Israel</button> <button data-value="IT" type="button">Italy</button> <button data-value="JM" type="button">Jamaica</button> <button data-value="JP" type="button">Japan</button> <button data-value="JE" type="button">Jersey</button> <button data-value="JO" type="button">Jordan</button> <button data-value="KZ" type="button">Kazakhstan</button> <button data-value="KE" type="button">Kenya</button> <button data-value="KI" type="button">Kiribati</button> <button data-value="KP" type="button">Korea, Democratic People's Republic of</button> <button data-value="KR" type="button">Korea, Republic of</button> <button data-value="XK" type="button">Kosovo</button> <button data-value="KW" type="button">Kuwait</button> <button data-value="KG" type="button">Kyrgyzstan</button> <button data-value="LA" type="button">Lao People's Democratic Republic</button> <button data-value="LV" type="button">Latvia</button> <button data-value="LB" type="button">Lebanon</button> <button data-value="LS" type="button">Lesotho</button> <button data-value="LR" type="button">Liberia</button> <button data-value="LY" type="button">Libyan Arab Jamahiriya</button> <button data-value="LI" type="button">Liechtenstein</button> <button data-value="LT" type="button">Lithuania</button> <button data-value="LU" type="button">Luxembourg</button> <button data-value="MO" type="button">Macao</button> <button data-value="MK" type="button">Macedonia, the Former Yugoslav Republic of</button> <button data-value="MG" type="button">Madagascar</button> <button data-value="MW" type="button">Malawi</button> <button data-value="MY" type="button">Malaysia</button> <button data-value="MV" type="button">Maldives</button> <button data-value="ML" type="button">Mali</button> <button data-value="MT" type="button">Malta</button> <button data-value="MH" type="button">Marshall Islands</button> <button data-value="MQ" type="button">Martinique</button> <button data-value="MR" type="button">Mauritania</button> <button data-value="MU" type="button">Mauritius</button> <button data-value="YT" type="button">Mayotte</button> <button data-value="MX" type="button">Mexico</button> <button data-value="FM" type="button">Micronesia, Federated States of</button> <button data-value="MD" type="button">Moldova, Republic of</button> <button data-value="MC" type="button">Monaco</button> <button data-value="MN" type="button">Mongolia</button> <button data-value="ME" type="button">Montenegro</button> <button data-value="MS" type="button">Montserrat</button> <button data-value="MA" type="button">Morocco</button> <button data-value="MZ" type="button">Mozambique</button> <button data-value="MM" type="button">Myanmar</button> <button data-value="NA" type="button">Namibia</button> <button data-value="NR" type="button">Nauru</button> <button data-value="NP" type="button">Nepal</button> <button data-value="NL" type="button">Netherlands</button> <button data-value="AN" type="button">Netherlands Antilles</button> <button data-value="NC" type="button">New Caledonia</button> <button data-value="NZ" type="button">New Zealand</button> <button data-value="NI" type="button">Nicaragua</button> <button data-value="NE" type="button">Niger</button> <button data-value="NG" type="button">Nigeria</button> <button data-value="NU" type="button">Niue</button> <button data-value="NF" type="button">Norfolk Island</button> <button data-value="MP" type="button">Northern Mariana Islands</button> <button data-value="NO" type="button">Norway</button> <button data-value="OM" type="button">Oman</button> <button data-value="PK" type="button">Pakistan</button> <button data-value="PW" type="button">Palau</button> <button data-value="PS" type="button">Palestinian Territory, Occupied</button> <button data-value="PA" type="button">Panama</button> <button data-value="PG" type="button">Papua New Guinea</button> <button data-value="PY" type="button">Paraguay</button> <button data-value="PE" type="button">Peru</button> <button data-value="PH" type="button">Philippines</button> <button data-value="PN" type="button">Pitcairn</button> <button data-value="PL" type="button">Poland</button> <button data-value="PT" type="button">Portugal</button> <button data-value="PR" type="button">Puerto Rico</button> <button data-value="QA" type="button">Qatar</button> <button data-value="RE" type="button">Reunion</button> <button data-value="RO" type="button">Romania</button> <button data-value="RU" type="button">Russian Federation</button> <button data-value="RW" type="button">Rwanda</button> <button data-value="BL" type="button">Saint Barthelemy</button> <button data-value="SH" type="button">Saint Helena</button> <button data-value="KN" type="button">Saint Kitts and Nevis</button> <button data-value="LC" type="button">Saint Lucia</button> <button data-value="MF" type="button">Saint Martin</button> <button data-value="PM" type="button">Saint Pierre and Miquelon</button> <button data-value="VC" type="button">Saint Vincent and the Grenadines</button> <button data-value="WS" type="button">Samoa</button> <button data-value="SM" type="button">San Marino</button> <button data-value="ST" type="button">Sao Tome and Principe</button> <button data-value="SA" type="button">Saudi Arabia</button> <button data-value="SN" type="button">Senegal</button> <button data-value="RS" type="button">Serbia</button> <button data-value="CS" type="button">Serbia and Montenegro</button> <button data-value="SC" type="button">Seychelles</button> <button data-value="SL" type="button">Sierra Leone</button> <button data-value="SG" type="button">Singapore</button> <button data-value="SX" type="button">Sint Maarten</button> <button data-value="SK" type="button">Slovakia</button> <button data-value="SI" type="button">Slovenia</button> <button data-value="SB" type="button">Solomon Islands</button> <button data-value="SO" type="button">Somalia</button> <button data-value="ZA" type="button">South Africa</button> <button data-value="GS" type="button">South Georgia and the South Sandwich Islands</button> <button data-value="SS" type="button">South Sudan</button> <button data-value="ES" type="button">Spain</button> <button data-value="LK" type="button">Sri Lanka</button> <button data-value="SD" type="button">Sudan</button> <button data-value="SR" type="button">Suriname</button> <button data-value="SJ" type="button">Svalbard and Jan Mayen</button> <button data-value="SZ" type="button">Swaziland</button> <button data-value="SE" type="button">Sweden</button> <button data-value="CH" type="button">Switzerland</button> <button data-value="SY" type="button">Syrian Arab Republic</button> <button data-value="TW" type="button">Taiwan, Province of China</button> <button data-value="TJ" type="button">Tajikistan</button> <button data-value="TZ" type="button">Tanzania, United Republic of</button> <button data-value="TH" type="button">Thailand</button> <button data-value="TL" type="button">Timor-Leste</button> <button data-value="TG" type="button">Togo</button> <button data-value="TK" type="button">Tokelau</button> <button data-value="TO" type="button">Tonga</button> <button data-value="TT" type="button">Trinidad and Tobago</button> <button data-value="TN" type="button">Tunisia</button> <button data-value="TR" type="button">Turkey</button> <button data-value="TM" type="button">Turkmenistan</button> <button data-value="TC" type="button">Turks and Caicos Islands</button> <button data-value="TV" type="button">Tuvalu</button> <button data-value="UG" type="button">Uganda</button> <button data-value="UA" type="button">Ukraine</button> <button data-value="AE" type="button">United Arab Emirates</button> <button data-value="GB" type="button">United Kingdom</button> <button data-value="US" type="button">United States</button> <button data-value="UM" type="button">United States Minor Outlying Islands</button> <button data-value="UY" type="button">Uruguay</button> <button data-value="UZ" type="button">Uzbekistan</button> <button data-value="VU" type="button">Vanuatu</button> <button data-value="VE" type="button">Venezuela</button> <button data-value="VN" type="button">Viet Nam</button> <button data-value="VG" type="button">Virgin Islands, British</button> <button data-value="VI" type="button">Virgin Islands, U.s.</button> <button data-value="WF" type="button">Wallis and Futuna</button> <button data-value="EH" type="button">Western Sahara</button> <button data-value="YE" type="button">Yemen</button> <button data-value="ZM" type="button">Zambia</button> <button data-value="ZW" type="button">Zimbabwe</button> <div class="drop-search-noresultFooter">No results found</div> </div> </div> <p class="Validation countryValidationFooter">Value is required.</p> <p class="Validation langValidationFooter"></p> </div> <div class="check-wrap"> <span class="checkbox input-block"> <input type="checkbox" id="popup_agreeFooter" name="popup_agreeFooter"/> <label for="popup_agreeFooter"><span> By clicking or tapping the 'Subscribe' button, I acknowledge that I have read and agree to the <b><u><a href="https://www.hankooktire.com/global/en/footer/privacy-policy.html" target="_blank">Privacy Policy</a></u></b><u></u>. </span></label> </span> <p class="Validation checkValidationFooter">Value is required.</p> </div> <a href="javascript:void(0);" class="btn btn--arrow btn--bg sub-btn" onclick="doSubscribeFooter();">Subscribe</a> <!-- ���̾˷α� Popup Contents - Subscribe Button Text --> <button type="button" id="hiddenSubscribeBtnFooter" style="display:none;"></button> </form> </div> </div> </div> <div class="popup_base popup_submittedFooter" id="popup_submittedFooter" data-parent="Subscribe_popFooter"> <div class="dim"></div> <div class="pop_inner"> <div class="top"> <button class="all_close close_pop" data-contents="subscribe_completed_close_right">Close</button> </div> <div class="pop_con"> <div class="pop_title"> <h3 class="font_contents_title_2">Thank you!</h3> <h3 class="font_contents_title_2">Your request has been submitted.</h3> </div> <p class="font_body_2 txt-center descriptiodn" style="padding-bottom:32px;"> You'll receive a welcome email.<br /> If you can’t receive the email,<br /> please check your <strong>spam</strong> folder. </p> <p class="share_btn font_body_3 share_btnFooter" data-contents="subscribe_completed_share" onclick="doShareFooter('popup_submittedFooter');">Share</p> <p class="share_txt">Please share this link with your friends!</p> <p class="share_txt_complete">Copied to clipboard.</p> <a href="javascript:void(0);" data-contents="subscribe_completed_close" class="btn btn--bg all_close close_pop">Close</a> </div> </div> </div> <div class="popup_base popup_duplicate_submissionFooter" id="popup_duplicate_submissionFooter" data-parent="Subscribe_popFooter"> <div class="pop_inner"> <div class="top"> <button class="all_close close_pop" data-contents="already_subscribed_close_right">Close</button> </div> <div class="pop_con"> <div class="pop_title"> <h3 class="font_contents_title_2">You are already subscribed with your email address.</h3> </div> <p class="share_btn font_body_3 share_btnFooter" data-contents="already_subscribed_share" onclick="doShareFooter('popup_duplicate_submissionFooter');">Share</p> <p class="share_txt">Please share this link with your friends!</p> <p class="share_txt_complete">Copied to clipboard.</p> <a href="javascript:void(0);" data-contents="already_subscribed_close" class="btn btn--bg all_close close_pop">Close</a> </div> </div> </div> <div class="popup_base popup_submission_failedFooter" id="popup_submission_failedFooter"> <div class="pop_inner"> <div class="top"> <button class="close_pop" data-contents="error pop-up_close_right">Back</button> </div> <div class="pop_con"> <div class="pop_title"> <h3 class="font_contents_title_2">Your request has not been completed due to system error. Please try again.</h3> </div> <a href="javascript:void(0);" data-contents="error pop-up_go_back" class="btn btn--bg close_pop">Back</a> </div> </div> </div> </div> </footer> <script src="/etc.clientlibs/hankooktire/components/content/global/common/footer/clientlibs.min.js"></script> <script src="/etc.clientlibs/hankooktire/clientlibs/clientlib-global.min.js"></script> <div class="popup_wrapper"> <div class="popup_base newsletter_pop" id="newsletter_pop"> <div class="dim"></div> <div class="pop_inner"> <div class="pop_con"> <p class="tit">News from Hankook Tire</p> <p class="font_body_2">Be the first to receive stories from Hankook Tire, latest news on tires, motorsports, green business and more.</p> <form action="" method="post" id="nslt_regist"> <input type="hidden" name="siteCd" id="siteCd" value="GO-EN"/> <div class="select-search-box"> <div class="search-wrap"> <input type="text" id="searchText" name="search" placeholder="Enter the e-mail."/> <label for="searchText">E-mail Address</label> </div> </div> <div class="check-wrap"> <span class="checkbox input-block"> <input type="checkbox" id="c1" name="checkbox"/> <label for="c1"><span>I wish to receive direct marketing emails/communications from Hankook Tire in accordance with the <a href="#" target="_blank">Privacy Policy.</a></span></label> </span> </div> <a href="#" class="btn btn--arrow btn--bg disabled" id="d_form_btn">Send</a> </form> </div> <button class="close_pop">Close</button> </div> </div> </div> <script src="/etc.clientlibs/hankooktire/components/content/global/common/newsletter/clientlibs.min.js"></script> </div> <script async defer src="https://widget.driverreviews.com/script.min.js?version=manufacturer" id="dr-script" data-pubkey="27bb98f34a83dab46d0bf6f2bee68ffc7618b223" data-lang="en"></script> </body> </html>