{"id":14519,"date":"2024-01-04T10:59:32","date_gmt":"2024-01-04T01:59:32","guid":{"rendered":"http:\/\/www.gisdeveloper.co.kr\/?p=14519"},"modified":"2024-02-04T11:03:54","modified_gmt":"2024-02-04T02:03:54","slug":"three-js%eb%a5%bc-%ec%9d%b4%ec%9a%a9%ed%95%9c-vrvitrual-reality-%ec%bb%a8%ed%85%90%ec%b8%a0-%ec%a0%9c%ec%9e%91","status":"publish","type":"post","link":"http:\/\/www.gisdeveloper.co.kr\/?p=14519","title":{"rendered":"three.js\ub97c \uc774\uc6a9\ud55c VR(Vitrual Reality) \ucee8\ud150\uce20 \uc81c\uc791"},"content":{"rendered":"<p>\uc774 \ud3ec\uc2a4\ud2b8\ub294 three.js\ub97c \uc774\uc6a9\ud574\uc11c \uc6f9 \uae30\ubc18\uc758 VR \uc5b4\ud50c\ub9ac\ucf00\uc774\uc158\uc744 \ub9cc\ub4dc\ub294 \uae30\ubcf8 \uc694\uc18c\uc5d0 \ub300\ud55c \uac1c\ub7b5\uc801\uc778 \ub0b4\uc6a9\uc744 \uc5b8\uae09\ud569\ub2c8\ub2e4.<\/p>\n<h3>\uc791\uc5c5 \ud750\ub984<\/h3>\n<p>\uba3c\uc800, \ud504\ub85c\uc81d\ud2b8\uc5d0 VRButton.js\ub97c import \ud574\uc57c \ud569\ub2c8\ub2e4.<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"js\">\r\nimport { VRButton } from 'three\/addons\/webxr\/VRButton.js';\r\n<\/pre>\n<p>VRButton.createButton()\uc740 2\uac00\uc9c0 \uc911\uc694\ud55c \uac83\uc744 \uc218\ud589\ud569\ub2c8\ub2e4: VR \ud638\ud658\uc131\uc744 \uac00\uc9c0\ub294 \ubc84\ud2bc\uc744 \uc0dd\uc131\ud558\uba70 \uc0ac\uc6a9\uc790\uac00 \uadf8 \ubc84\ud2bc\uc744 \ud65c\uc131\ud654\ud558\uba74 VR \uc138\uc158\uc744 \uac1c\uc2dc\ud569\ub2c8\ub2e4. \uc774\ub97c \uc704\ud574 \ub2e8\uc9c0 \ub2e4\uc74c \ucf54\ub4dc\ub97c \uc791\uc131\ud558\uba74 \ub429\ub2c8\ub2e4.<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"js\">\r\ndocument.body.appendChild( VRButton.createButton( renderer ) );\r\n<\/pre>\n<p>\ub2e4\uc74c\uc73c\ub85c\ub294, WebGLRenderer \uac1d\uccb4\uc758 XR \ub80c\ub354\ub9c1\uc744 \ud65c\uc131\ud654\uc2dc\ud0b5\ub2c8\ub2e4. <\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"js\">\r\nrenderer.xr.enabled = true;\r\n<\/pre>\n<p>\ub9c8\uc9c0\ub9c9\uc73c\ub85c, \uc560\ub2c8\uba54\uc774\uc158 \ub8e8\ud504(Animation Loop)\uc5d0 \ub300\ud55c \ucf54\ub4dc\ub85c \uc790\uc8fc \uc0ac\uc6a9\ub418\ub294 requestAnimationFrame \ud568\uc218 \ub300\uc2e0\uc5d0 setAnimationLoop\ub97c \ub300\uc2e0 \uc0ac\uc6a9\ud558\ub3c4\ub85d \ud569\ub2c8\ub2e4. \ucf54\ub4dc\ub294 \ub2e4\uc74c\uacfc \uac19\uc2b5\ub2c8\ub2e4.<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"js\">\r\nrenderer.setAnimationLoop( function () {\r\n    renderer.render( scene, camera );\r\n} );\r\n<\/pre>\n<h3>\ub2e4\uc74c \ub2e8\uacc4<\/h3>\n<p>3D \uc7a5\uba74\uc5d0 \ub300\ud55c \uad6c\uc131\uc740 \uc77c\ubc18\uc801\uc778 three.js API\ub85c \uac1c\ubc1c\ud558\uba74 \ub418\uace0 VR\uc640 \uad00\ub828\ub41c UI\uc801\uc778 \uae30\ub2a5\uc740 three.js\uc5d0\uc11c \uc81c\uacf5\ud558\ub294 VR\uc5d0 \ud2b9\ud654\ub41c \ucd94\uac00\uc801\uc778 API\ub97c \uc0ac\uc6a9\ud574 \uac1c\ubc1c\ud558\uba74 \ub429\ub2c8\ub2e4.<\/p>\n<p><a href='https:\/\/threejs.org\/docs\/index.html#manual\/en\/introduction\/How-to-create-VR-content'>\uc774 \uae00\uc758 \uc6d0\ubb38\uc785\ub2c8\ub2e4.<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\uc774 \ud3ec\uc2a4\ud2b8\ub294 three.js\ub97c \uc774\uc6a9\ud574\uc11c \uc6f9 \uae30\ubc18\uc758 VR \uc5b4\ud50c\ub9ac\ucf00\uc774\uc158\uc744 \ub9cc\ub4dc\ub294 \uae30\ubcf8 \uc694\uc18c\uc5d0 \ub300\ud55c \uac1c\ub7b5\uc801\uc778 \ub0b4\uc6a9\uc744 \uc5b8\uae09\ud569\ub2c8\ub2e4. \uc791\uc5c5 \ud750\ub984 \uba3c\uc800, \ud504\ub85c\uc81d\ud2b8\uc5d0 VRButton.js\ub97c import \ud574\uc57c \ud569\ub2c8\ub2e4. import { VRButton } from &#8216;three\/addons\/webxr\/VRButton.js&#8217;; VRButton.createButton()\uc740 2\uac00\uc9c0 \uc911\uc694\ud55c \uac83\uc744 \uc218\ud589\ud569\ub2c8\ub2e4: VR \ud638\ud658\uc131\uc744 \uac00\uc9c0\ub294 \ubc84\ud2bc\uc744 \uc0dd\uc131\ud558\uba70 \uc0ac\uc6a9\uc790\uac00 \uadf8 \ubc84\ud2bc\uc744 \ud65c\uc131\ud654\ud558\uba74 VR \uc138\uc158\uc744 \uac1c\uc2dc\ud569\ub2c8\ub2e4. \uc774\ub97c \uc704\ud574 \ub2e8\uc9c0 \ub2e4\uc74c \ucf54\ub4dc\ub97c \uc791\uc131\ud558\uba74 \ub429\ub2c8\ub2e4. document.body.appendChild( VRButton.createButton( &hellip; <\/p>\n<p class=\"link-more\"><a href=\"http:\/\/www.gisdeveloper.co.kr\/?p=14519\" class=\"more-link\">\ub354 \ubcf4\uae30<span class=\"screen-reader-text\"> &#8220;three.js\ub97c \uc774\uc6a9\ud55c VR(Vitrual Reality) \ucee8\ud150\uce20 \uc81c\uc791&#8221;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[145],"tags":[],"class_list":["post-14519","post","type-post","status-publish","format-standard","hentry","category-three-js"],"_links":{"self":[{"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=\/wp\/v2\/posts\/14519","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=14519"}],"version-history":[{"count":5,"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=\/wp\/v2\/posts\/14519\/revisions"}],"predecessor-version":[{"id":14524,"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=\/wp\/v2\/posts\/14519\/revisions\/14524"}],"wp:attachment":[{"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=14519"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=14519"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.gisdeveloper.co.kr\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=14519"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}