{"id":750,"date":"2019-05-15T15:45:00","date_gmt":"2019-05-15T06:45:00","guid":{"rendered":"https:\/\/virtualcast.jp\/blog\/?p=750"},"modified":"2024-10-22T19:23:55","modified_gmt":"2024-10-22T10:23:55","slug":"oss-browser-vrm-vci-viewer","status":"publish","type":"post","link":"https:\/\/blog.virtualcast.jp\/blog\/2019\/05\/oss-browser-vrm-vci-viewer\/","title":{"rendered":"VRM \u306f Unity \u5c02\u7528\u3058\u3083\u306a\u3044\uff01\u30d6\u30e9\u30a6\u30b6\u3067 VRM \u8868\u793a\u51fa\u6765\u308b\u3082\u306e\u3092\u4f5c\u308a\u307e\u3057\u305f\uff01"},"content":{"rendered":"\n<p><a href=\"https:\/\/seed.online\">\u30b6\u30fb\u30b7\u30fc\u30c9\u30aa\u30f3\u30e9\u30a4\u30f3<\/a> \u306b\u306f\u3001 glTF \u898f\u683c\u306e\u62e1\u5f35\u3067\u3042\u308b VR \u5229\u7528\u60f3\u5b9a\u306e\u30d2\u30e5\u30fc\u30de\u30ce\u30a4\u30c9\u30e2\u30c7\u30eb\u62e1\u5f35\u306e <a href=\"https:\/\/vrm.dev\">VRM<\/a> \u53ca\u3073\u3001 <a href=\"https:\/\/virtualcast.jp\">VirtualCast<\/a> \u4e0a\u3067\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u30a2\u30a4\u30c6\u30e0\u3092\u81ea\u7531\u306b\u4f5c\u6210\u51fa\u6765\u308b <a href=\"https:\/\/github.com\/virtual-cast\/VCI\">VCI<\/a> \u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u3053\u3068\u304c\u51fa\u6765\u307e\u3059\u3002<\/p>\n\n\n<p>\u4ee5\u524d\u306f\u305d\u308c\u3089\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067\u95b2\u89a7\u3059\u308b\u306e\u306b\u3001 <a href=\"https:\/\/docs.unity3d.com\/ja\/current\/Manual\/webgl-gettingstarted.html\">Unity \u306e WebGL \u30d3\u30eb\u30c9<\/a>\u3092\u7528\u3044\u3066\u3044\u307e\u3057\u305f\u3002<\/p>\n\n\n<p>\u3057\u304b\u3057\u30012019\u5e745\u6708\u73fe\u5728\u306e Unity \u306e WebGL \u30d3\u30eb\u30c9(\u3068 Web Assembly)\u306f\u3001\u6570 MB \u306e\u30e9\u30f3\u30bf\u30a4\u30e0\u306e\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3068\u3001\u8d77\u52d5\u51e6\u7406\u306b\u6570\u79d2\u304b\u304b\u308b\u306a\u3069\u306e\u96e3\u70b9\u304c\u5b58\u5728\u3057\u3066\u3044\u3066\u3001\u30cd\u30a4\u30c6\u30a3\u30d6(JavaScript)\u5b9f\u88c5\u306b\u7f6e\u304d\u63db\u3048\u305f\u3044\u3068\u3044\u3046\u8981\u671b\u304c\u51fa\u3066\u3044\u307e\u3057\u305f\u3002\u4e00\u90e8\u7aef\u672b\u3067\u6b63\u5e38\u306b\u8868\u793a\u51fa\u6765\u306a\u3044\u3068\u3044\u3046\u554f\u984c\u3082\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n<p>\u305d\u3053\u3067\u3001\u79c1\u5c71\u5cb8\u306e\u8abf\u67fb\u306e\u7d50\u679c\u3001 <a href=\"https:\/\/www.babylonjs.com\/\">babylon.js<\/a> \u3092\u63a1\u7528\u3057\u3001\u81ea\u524d\u3067 VRM\/VCI \u3092\u51fa\u6765\u308b\u3060\u3051\u6b63\u3057\u304f porting \u3059\u308b\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3092\u7a3c\u50cd\u3057\u307e\u3057\u305f\u3002<\/p>\n\n\n<figure class=\"wp-block-image\"><a href=\"https:\/\/seed.online\/items\/d73d522ac8da78f8f84ac1e0e69e5c730325a03e6bcb733197077ed5e38c56b8\/\" target=\"_blank\" rel=\"noreferrer noopener\"><img src=\"https:\/\/qiita-image-store.s3.ap-northeast-1.amazonaws.com\/0\/332028\/017729ec-10d0-5c95-08a8-2ac6d5332031.png\" alt=\"image.png\"\/><\/a><figcaption><a href=\"https:\/\/seed.online\/items\/d73d522ac8da78f8f84ac1e0e69e5c730325a03e6bcb733197077ed5e38c56b8\/\">\u3080\u30fc\u3093\u3061\u3083\u3093\uff01 - \u516c\u958b\u30a2\u30a4\u30c6\u30e0\u60c5\u5831 - THE SEED ONLINE(\u03b1)<\/a> <\/figcaption><\/figure>\n\n\n<p>\u305d\u306e\u6210\u679c\u7269\u306f <a href=\"https:\/\/github.com\/virtual-cast\/babylon-mtoon-material\">virtual-cast\/babylon-mtoon-material<\/a> \u53ca\u3073 <a href=\"https:\/\/github.com\/virtual-cast\/babylon-vrm-loader\">virtual-cast\/babylon-vrm-loader<\/a> \u3068\u3057\u3066 MIT \u30e9\u30a4\u30bb\u30f3\u30b9\u3067 OSS \u516c\u958b\u3057\u3066\u3044\u307e\u3059\u3002\u8ab0\u3067\u3082\u5229\u7528\u53ef\u80fd\u3067\u3059\u3057\u3001\u30b3\u30f3\u30c8\u30ea\u30d3\u30e5\u30fc\u30c8\u3082\u6b53\u8fce\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n<!--more-->\n\n\n<h2>\u4f55\u6545 babylon.js \u304b\uff1f<\/h2>\n\n\n<p>\u65e2\u5b58\u306e VRM \u30d6\u30e9\u30a6\u30b6\u5b9f\u88c5\u3067\u306f\u3001 <a href=\"https:\/\/github.com\/rdrgn\/three-vrm\">rdrgn\/three-vrm<\/a> \u304c\u6700\u3082\u6709\u529b\u306a OSS \u30e9\u30a4\u30d6\u30e9\u30ea\u3060\u3068\u601d\u3044\u307e\u3059\u3002<br>\n\u3053\u308c\u306f three.js \u306e examples \u5185\u306b\u3042\u308b <a href=\"https:\/\/github.com\/mrdoob\/three.js\/blob\/dev\/examples\/js\/loaders\/GLTFLoader.js\">GLTFLoader<\/a> \u3092\u62e1\u5f35\u3057\u3001 BlendShape \u3084 SpringBone, MToonMaterial \u306a\u3069\u306e\u6a5f\u80fd\u3092\u79fb\u690d\u3057\u305f\u3082\u306e\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<br>\n<a href=\"https:\/\/threejs.org\/examples\/#webgl_loader_gltf\">three.js examples webgl_loader_gltf<\/a> \u3092\u898b\u308b\u901a\u308a\u3001 PBR glTF \u30e2\u30c7\u30eb\u306e\u8aad\u307f\u8fbc\u307f\u901f\u5ea6\u3084\u30e9\u30f3\u30bf\u30a4\u30e0\u52d5\u4f5c\u901f\u5ea6\u306f\u7533\u3057\u5206\u306a\u304f\u3001\u300c\u3053\u308c\u3067\u5341\u5206\u3067\u306f\u300d\u3068\u3044\u3046\u898b\u65b9\u304c\u51fa\u6765\u308b\u304b\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n\n\n<p>\u307e\u305f\u3001 Google \u304c\u516c\u958b\u3057\u305f <a href=\"https:\/\/googlewebcomponents.github.io\/model-viewer\/\">Web Custom Component \u306b\u3088\u308b <code>&lt;model-viewer&gt;<\/code> \u30bf\u30b0\u5b9f\u88c5<\/a> \u3082\u3001\u5185\u90e8\u3067\u306f three.js \u3092\u7528\u3044\u3066\u3044\u307e\u3059\u3002<br>\n\u73fe\u5728\u306e WebGL \u696d\u754c\u3092\u898b\u308b\u3068\u3001 three.js \u304c\u5727\u5012\u7684\u306a\u30b7\u30a7\u30a2\u3092\u8a87\u3063\u3066\u3044\u308b\u306e\u306f\u8a00\u3046\u307e\u3067\u3082\u3042\u308a\u307e\u305b\u3093\u3002<br>\n\u3057\u304b\u3057\u3001\u79c1\u306f\u6570\u5e74\u5f8c\u3092\u898b\u636e\u3048\u3066\u8003\u3048\u307e\u3057\u305f\u3002<\/p>\n\n\n<h3>What is babylon.js?<\/h3>\n\n\n<figure class=\"wp-block-image\"><img src=\"https:\/\/cdn-images-1.medium.com\/max\/800\/1*q3xKmgKpjaqC5_uwN3i4rQ.png\" alt=\"\"\/><\/figure>\n\n\n<p>\u305d\u3082\u305d\u3082 babylon.js \u3068\u3044\u3046 WebGL \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3092\u3001\u30d6\u30e9\u30a6\u30b6\u754c\u9688\u306e\u4eba\u3067\u3082\u805e\u3044\u305f\u3053\u3068\u304c\u306a\u3044\u5834\u5408\u304c\u591a\u3044\u306e\u3067\u306f\u306a\u3044\u304b\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n\n\n<figure class=\"wp-block-image\"><img src=\"https:\/\/qiita-image-store.s3.ap-northeast-1.amazonaws.com\/0\/332028\/a8b2c933-4f35-f59b-66eb-74b0503f00a0.png\" alt=\"babylon.js vs three.js\"\/><figcaption>Google Trend: Babylon.js vs three.js<\/figcaption><\/figure>\n\n\n<p>Google Trend \u3092\u4f7f\u3063\u3066\u4e16\u754c\u306e\u4eba\u6c17\u5ea6\u3092\u898b\u3066\u3082\u3001 three.js \u3068\u306f\u6bd4\u3079\u7269\u306b\u306a\u3089\u306a\u3044\u307b\u3069\u8a71\u984c\u306b\u4e0a\u304c\u3063\u3066\u3044\u306a\u3044\u3067\u3059\u3002 Qiita \u306e\u8a18\u4e8b\u3068\u3057\u3066\u3082\u3001 <a href=\"https:\/\/qiita.com\/tags\/three.js\">three.js<\/a> \u306f 400 \u8a18\u4e8b\u8fd1\u304f\u3042\u308b\u306e\u306b\u5bfe\u3057\u3001 <a href=\"https:\/\/qiita.com\/tags\/babylon.js\">Babylon.js<\/a> \u306f 14 \u8a18\u4e8b\u2026\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u306e\u60c5\u5831\u91cf\u3068\u3057\u3066\u306f\u304b\u306a\u308a\u5fc3\u3082\u3068\u306a\u3044\u6570\u5024\u3067\u3059\u3002<\/p>\n\n\n<p>\u305d\u308c\u3067\u3082\u9078\u3076\u7406\u7531\u304c\u3044\u304f\u3064\u304b\u3042\u308a\u307e\u3057\u305f\u3002<\/p>\n\n\n<h3>Created by Microsoft<\/h3>\n\n\n<p>three.js \u3068\u6bd4\u3079\u308b\u3068\u4eba\u6c17\u5ea6\u3068\u3057\u3066\u306f\u898b\u52a3\u308a\u3057\u307e\u3059\u304c\u3001 WebGL 3D \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306e\u4e2d\u3067\u306f\u6050\u3089\u304f <strong>2 \u4f4d\u306e\u77e5\u540d\u5ea6<\/strong> \u3067\u3042\u308a\u3001\u30e1\u30a4\u30f3\u30b3\u30f3\u30c8\u30ea\u30d3\u30e5\u30fc\u30bf\u306f <strong>Microsoft \u306e\u4eba<\/strong> \u3067\u3059\u3002 <\/p>\n\n\n<figure class=\"wp-block-embed-twitter wp-block-embed is-type-rich is-provider-twitter\"><div class=\"wp-block-embed__wrapper\">\n<blockquote class=\"twitter-tweet\" data-width=\"500\" data-dnt=\"true\"><p lang=\"en\" dir=\"ltr\"><a href=\"https:\/\/twitter.com\/hashtag\/Paint3D?src=hash&amp;ref_src=twsrc%5Etfw\">#Paint3D<\/a> now supports <a href=\"https:\/\/twitter.com\/glTF3D?ref_src=twsrc%5Etfw\">@glTF3D<\/a> <a href=\"https:\/\/t.co\/V7KOdeFdUa\">https:\/\/t.co\/V7KOdeFdUa<\/a><\/p>&mdash; Saurabh Bhatia (@iamSBTron) <a href=\"https:\/\/twitter.com\/iamSBTron\/status\/885189708803854336?ref_src=twsrc%5Etfw\">July 12, 2017<\/a><\/blockquote><script async src=\"https:\/\/platform.twitter.com\/widgets.js\" charset=\"utf-8\"><\/script>\n<\/div><\/figure>\n\n\n<p>Windows 10 \u306b\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u5165\u3063\u3066\u3044\u308b Paint 3D \u3082\u30cd\u30a4\u30c6\u30a3\u30d6\u3067 glTF \u3092\u30b5\u30dd\u30fc\u30c8\u3057\u3066\u3044\u307e\u3059\u3057\u3001 <strong>Microsoft \u306f glTF \u306b\u5f37\u3044\u610f\u6b32\u3092\u6301\u3063\u3066\u3044\u308b<\/strong> \u3053\u3068\u304c\u4f3a\u3048\u308b\u305f\u3081\u3001\u305d\u3053\u306b\u4fe1\u983c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n<h3>glTF, PBR-based<\/h3>\n\n\n<p>babylon.js \u306f\u3001\u73fe\u5728\u6d41\u884c\u306e glTF \u898f\u683c\u53ca\u3073\u7269\u7406\u30d9\u30fc\u30b9\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u3092\u4e3b\u8981\u306a\u8981\u7d20\u3068\u3057\u3066\u5b9f\u88c5\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n<p>three.js \u306f\u5143\u3005\u306f\u666e\u901a\u306e WebGL \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3067\u3001\u8ffd\u52a0\u3068\u3057\u3066 glTF \u3084\u7269\u7406\u30d9\u30fc\u30b9\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u3092\u30b5\u30dd\u30fc\u30c8\u51fa\u6765\u308b\u3088\u3046\u306b\u3057\u305f\u306e\u3067\u3001\u305d\u306e\u5206\u7121\u99c4\u304c\u3042\u308b\u90e8\u5206\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n<h3>Created with TypeScript<\/h3>\n\n\n<p>Microsoft \u88fd\u306a\u306e\u3067\u4e2d\u8eab\u306f\u5168\u3066 <code>TypeScript<\/code> \u3067\u3059\u3002\u898b\u3084\u3059\u3044\u3002\u578b\u304c\u5b09\u3057\u3044\u3002<\/p>\n\n\n<h3>v4.0 Is Here!<\/h3>\n\n\n<figure class=\"wp-block-embed-youtube wp-block-embed is-type-video is-provider-youtube wp-embed-aspect-16-9 wp-has-aspect-ratio video\"><div class=\"wp-block-embed__wrapper\">\n<iframe loading=\"lazy\" title=\"Babylon.js 4.0 Announcement Video\" width=\"500\" height=\"281\" src=\"https:\/\/www.youtube.com\/embed\/RlPAOT9v-s0?feature=oembed\" frameborder=\"0\" allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share\" referrerpolicy=\"strict-origin-when-cross-origin\" allowfullscreen><\/iframe>\n<\/div><\/figure>\n\n\n<p><a href=\"https:\/\/medium.com\/@babylonjs\/babylon-js-4-0-is-here-d725b5b02e9b\">Babylon.js 4.0 Is Here! \u2013 Babylon.js \u2013 Medium<\/a><\/p>\n\n\n<p>\u3064\u3044\u5148\u65e5\u3001 babylon.js v4 \u306e\u30e1\u30b8\u30e3\u30fc\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u304c\u3042\u308a\u307e\u3057\u305f\u3002\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6539\u5584\u3084 <code>ES Module<\/code> \u5bfe\u5fdc\u306a\u3069\u3001\u529b\u5f37\u3044\u5909\u66f4\u304c\u884c\u308f\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n<p>three.js \u3068\u306f\u7570\u306a\u308a\u3001 API \u306e\u7834\u58ca\u7684\u5909\u66f4\u306f\u57fa\u672c\u7684\u306b\u30e1\u30b8\u30e3\u30fc\u30d0\u30fc\u30b8\u30e7\u30f3\u30a2\u30c3\u30d7\u3067\u3057\u304b\u884c\u308f\u308c\u306a\u3044\u305f\u3081\u3001 v4 \u306e API \u3092\u5b89\u5fc3\u3057\u3066\u6d3b\u7528\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n<h3>three.js \u306e\u6280\u8853\u7684\u8ca0\u50b5\u3068\u30ad\u30e3\u30c3\u30c1\u30a2\u30c3\u30d7\u96e3\u5ea6<\/h3>\n\n\n<p>three.js \u306f\u767b\u5834\u304b\u3089\u9577\u304f\u7d4c\u3061\u3001\u6280\u8853\u7684\u306a\u8ca0\u50b5\u304c\u6e9c\u307e\u3063\u3066\u304d\u3066\u3044\u308b\u3088\u3046\u306b\u898b\u3048\u307e\u3059\u3002<\/p>\n\n\n<ul><li>\u72ec\u7279\u306a\u30b3\u30fc\u30c9\u30d5\u30a9\u30fc\u30de\u30c3\u30c8(\u60aa\u3044\u308f\u3051\u3067\u306f\u306a\u3044\u3067\u3059\u304c\u3001\u30b3\u30df\u30c3\u30c8\u3057\u3066\u3044\u304f\u3068\u8003\u3048\u308b\u3068\u5c11\u3057\u62b5\u6297\u304c\u3042\u308b)<\/li><li>\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u81ea\u4f53\u304c <code>ECMAScript 5<\/code> \u76f8\u5f53\u3067\u66f8\u304d\u3065\u3089\u3044\u3001\u898b\u3065\u3089\u3044<ul><li><a href=\"https:\/\/webpack.js.org\/guides\/tree-shaking\/\">tree shaking<\/a> \u306e\u305f\u3081\u306e <code>ES Module<\/code> \u5bfe\u5fdc\u306f\u9032\u3093\u3067\u3044\u308b\u69d8\u5b50<\/li><li>TypeScript \u3067\u66f8\u304b\u308c\u3066\u3044\u306a\u3044\u3068\u3044\u3046\u3053\u3068\u306e\u30c7\u30e1\u30ea\u30c3\u30c8\u306f\u500b\u4eba\u7684\u306b\u306f\u5927\u304d\u3044\u3067\u3059<\/li><\/ul><\/li><li>\u7834\u58ca\u7684\u5909\u66f4\u304c\u591a\u3081<ul><li><a href=\"https:\/\/github.com\/mrdoob\/three.js\/wiki\/Migration-Guide\">Migration Guide<\/a> \u306b\u3042\u308b\u901a\u308a\u3001\u5404\u30d0\u30fc\u30b8\u30e7\u30f3\u30a2\u30c3\u30d7\u3067\u4e92\u63db\u6027\u306e\u306a\u3044\u5909\u66f4\u304c\u5165\u308b<\/li><\/ul><\/li><li>\u30d0\u30fc\u30b8\u30e7\u30f3\u30a2\u30c3\u30d7\u304c\u5927\u898f\u6a21\u304b\u3064\u983b\u7e41<ul><li>\u69d8\u3005\u306a\u30d5\u30a9\u30fc\u30de\u30c3\u30c8\u3084\u30b5\u30f3\u30d7\u30eb\u3078\u306e\u5bfe\u5fdc\u3092\u5168\u3066 1 \u30ea\u30dd\u30b8\u30c8\u30ea\u306b\u683c\u7d0d\u3057\u3066\u3044\u308b\u306e\u3067\u3001\u66f4\u65b0\u3092\u30c8\u30e9\u30c3\u30af\u3059\u308b\u306e\u304c\u672c\u5f53\u306b\u5927\u5909<\/li><li>Issue \/ Pull Requests \u306e\u6570\u304c\u30e4\u30d0\u3044<\/li><li>(\u3088\u304f\u7ba1\u7406\u51fa\u6765\u308b\u306a\u3068\u611f\u5fc3)<\/li><\/ul><\/li><\/ul>\n\n\n<p>\u81ea\u5206\u304c 3 \u5e74\u5f8c\u306b\u4eca\u66f8\u304f\u30b9\u30af\u30ea\u30d7\u30c8\u3092\u4fdd\u5b88\u3057\u3088\u3046\u3001\u3068\u601d\u3063\u305f\u6642\u3001\u4eca\u3068 3 \u5e74\u5f8c\u3067\u3069\u308c\u307b\u3069\u306e\u9055\u3044\u304c\u751f\u307e\u308c\u308b\u304b\u3092\u8003\u3048\u307e\u3057\u305f\u3002\u305d\u306e\u6642\u3001 three.js \u306f\u6050\u3089\u304f\u5225\u306e\u5316\u3051\u7269\u306b\u5909\u308f\u3063\u3066\u3044\u308b\u3053\u3068\u3067\u3057\u3087\u3046\u3002<\/p>\n\n\n<p>\u305d\u308c\u3068\u6bd4\u3079\u3001 babylon.js \u306f\u30e1\u30b8\u30e3\u30fc\u30d0\u30fc\u30b8\u30e7\u30f3\u30a2\u30c3\u30d7\u3092\u9664\u304d\u7834\u58ca\u7684\u5909\u66f4\u304c\u306a\u3044\u306e\u3067\u3001\u4fdd\u5b88\u30b3\u30b9\u30c8\u306f\u304b\u306a\u308a\u4f4e\u304f\u6291\u3048\u3089\u308c\u308b\u3068\u8003\u3048\u3089\u308c\u307e\u3059\u3002<\/p>\n\n\n<p>\u305d\u308c\u3067\u3082\u5185\u90e8\u3067\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u3084 API \u8ffd\u52a0\u5bfe\u5fdc\u306a\u3069\u306f\u884c\u308f\u308c\u308b\u306e\u3067\u3001\u6700\u65b0\u6280\u8853\u3092\u3059\u3050\u306b\u5229\u7528\u3059\u308b\u3053\u3068\u306f\u53ef\u80fd\u3067\u3059\u3002<\/p>\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n<p>\u3053\u308c\u3089\u3092\u8e0f\u307e\u3048\u3001 3 \u5e74\u5f8c\u306f babylon.js \u304c\u305d\u306e\u52e2\u3044\u3092\u5897\u3057\u3001\u591a\u304f\u306e WebGL \u5b9f\u88c5\u306b babylon.js \u3001\u305d\u3057\u3066 <a href=\"https:\/\/github.com\/virtual-cast\/babylon-vrm-loader\">virtual-cast\/babylon-vrm-loader<\/a> \u3092\u4f7f\u3063\u3066\u304f\u308c\u308b\u3060\u308d\u3046\u3068\u3044\u3046\u63a8\u6e2c\u3092\u5143\u306b\u3001 babylon.js \u3092\u63a1\u7528\u3057\u307e\u3057\u305f\u3002<\/p>\n\n\n<h2>\u4f55\u3092\u4f5c\u3063\u305f\u304b<\/h2>\n\n\n<p>\u3053\u3053\u304b\u3089\u306f\u30a8\u30f3\u30b8\u30cb\u30a2\u7684\u306a\u8a71\u3067\u3059\u3002\u5b9f\u88c5\u3057\u305f\u611f\u60f3\u3092\u5148\u306b\u8ff0\u3079\u3066\u304a\u304f\u3068\u3001 <strong>\u300c babylon.js \u306e API \u306f\u7d50\u69cb\u5206\u304b\u308a\u3084\u3059\u3044\u3057\u3001\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u304c\u304b\u306a\u308a\u5145\u5b9f\u3057\u3066\u3044\u308b\u306e\u3067\u7406\u89e3\u3057\u3084\u3059\u3044\u300d<\/strong> \u3068\u3044\u3046\u611f\u3058\u3067\u3059\u3002 babylon.js \u306b\u3057\u3066\u6b63\u89e3\u3060\u3063\u305f\u6c17\u6301\u3061\u3002<\/p>\n\n\n<h3>babylon-mtoon-material<\/h3>\n\n\n<figure class=\"wp-block-image\"><img loading=\"lazy\" width=\"936\" height=\"238\" src=\"https:\/\/virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image-8.png\" alt=\"babylon-mtoon-material\" class=\"wp-image-751\" srcset=\"https:\/\/blog.virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image-8.png 936w, https:\/\/blog.virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image-8-300x76.png 300w, https:\/\/blog.virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image-8-768x195.png 768w\" sizes=\"(max-width: 936px) 100vw, 936px\" \/><\/figure>\n\n\n<p>2 \u30ab\u6708\u307b\u3069\u5c02\u4efb\u3067\u3053\u306e\u958b\u767a\u3092\u884c\u3063\u3066\u3044\u307e\u3057\u305f\u304c\u3001\u307b\u3068\u3093\u3069\u306f <a href=\"https:\/\/github.com\/Santarh\/MToon\">MToon \u30de\u30c6\u30ea\u30a2\u30eb<\/a> \u3092 Unity(ShaderLab) \u304b\u3089 WebGL(GLSL) \u306b\u79fb\u690d\u3059\u308b\u4f5c\u696d\u306b\u8cbb\u3084\u3055\u308c\u307e\u3057\u305f\u3002<\/p>\n\n\n<p>babylon.js \u3067\u306f\u3001\u8ffd\u52a0\u306e Material \u5b9f\u88c5\u3068\u3057\u3066 <a href=\"https:\/\/github.com\/BabylonJS\/Babylon.js\/tree\/master\/materialsLibrary\">materialsLibrary<\/a> \u304c\u5225\u30d1\u30c3\u30b1\u30fc\u30b8\u3067\u7528\u610f\u3055\u308c\u3066\u3044\u307e\u3059\u3002\u3053\u306e<a href=\"https:\/\/doc.babylonjs.com\/how_to\/how_to_create_a_material_for_materialslibrary\">\u30ea\u30d5\u30a1\u30ec\u30f3\u30b9<\/a>\u3092\u53c2\u8003\u306b\u3057\u3066\u3001\u65b0\u3057\u3044\u30de\u30c6\u30ea\u30a2\u30eb(\u30b7\u30a7\u30fc\u30c0)\u3092\u4f5c\u6210\u3059\u308b\u3053\u3068\u304c\u51fa\u6765\u307e\u3059\u3002<\/p>\n\n\n<p>OSS \u3068\u3057\u3066\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u304c\u516c\u958b\u3057\u3066\u3044\u308b Material \u5b9f\u88c5\u304c\u306a\u304b\u3063\u305f\u306e\u3067\u3001\u3053\u306e\u3042\u305f\u308a\u306f\u304b\u306a\u308a\u624b\u63a2\u308a\u72b6\u614b\u3067\u3057\u305f\u3002<\/p>\n\n\n<p>babylon.js \u81ea\u4f53\u304c\u30b5\u30dd\u30fc\u30c8\u3059\u308b\u4e00\u822c\u7684\u306a\u6a5f\u80fd\u306f\u3001 <code>StandardMaterial<\/code> \u3068\u3044\u3046\u5b9f\u88c5\u306b\u3042\u308a\u307e\u3059\u3002\u5177\u4f53\u7684\u306b\u306f\u4e0b\u8a18\u306e\u3088\u3046\u306a\u3082\u306e\u3067\u3059\u3002<\/p>\n\n\n<ul><li>\u8907\u6570\u500b\u306e\u5149\u6e90<\/li><li><code>Multiview<\/code>: VR \u5411\u3051<\/li><li><code>LogarithmicDepth<\/code>: \u6df1\u5ea6\u3092 log \u3067\u8868\u73fe<\/li><li><code>Fog<\/code>: \u9060\u304f\u306b\u884c\u304f\u3068\u9727\u304c\u304b\u304b\u3063\u305f\u3088\u3046\u306b\u306a\u308b<\/li><li><code>Bones in shader<\/code>: \u30dc\u30fc\u30f3\u64cd\u4f5c\u3092 GPU \u3067\u51e6\u7406<\/li><li><code>MorphTargets in shader<\/code>: \u30e2\u30fc\u30d5\u30bf\u30fc\u30b2\u30c3\u30c8\u64cd\u4f5c\u3092 GPU \u3067\u51e6\u7406<\/li><li><code>Shadow<\/code>: \u30e1\u30c3\u30b7\u30e5\u304b\u3089\u843d\u3061\u308b\u5f71<\/li><li><code>EffectFallback<\/code>: \u901f\u5ea6\u304c\u8db3\u308a\u306a\u3044\u5834\u5408\u306b\u81ea\u52d5\u3067\u7279\u5b9a\u306e\u6a5f\u80fd\u3092 OFF \u306b\u3059\u308b\u30d5\u30a9\u30fc\u30eb\u30d0\u30c3\u30af<\/li><li><code>Instances<\/code>: GPU \u30a4\u30f3\u30b9\u30bf\u30f3\u30b7\u30f3\u30b0<\/li><li><code>ClipPlane<\/code>: \u898b\u3048\u306a\u3044\u30e1\u30c3\u30b7\u30e5\u3092\u8868\u793a\u3057\u306a\u3044\u3088\u3046\u306b\u3059\u308b<\/li><li><code>AmbientColor<\/code>: \u30b7\u30fc\u30f3\u5168\u4f53\u306e\u74b0\u5883\u5149<\/li><li><code>Alpha CutOff<\/code>: \u7279\u5b9a\u306e\u30a2\u30eb\u30d5\u30a1\u5024\u4ee5\u4e0b\u3092\u5168\u304f\u8868\u793a\u3057\u306a\u3044\u3088\u3046\u306b\u3059\u308b<\/li><li><code>Diffuse<\/code>: \u57fa\u672c\u30c6\u30af\u30b9\u30c1\u30e3\u30ab\u30e9\u30fc<\/li><li><code>Emissive<\/code>: \u81ea\u5df1\u767a\u5149\u30c6\u30af\u30b9\u30c1\u30e3\u30ab\u30e9\u30fc<\/li><li><code>Bump<\/code>: \u51f9\u51f8\u8868\u73fe\u306e\u30c6\u30af\u30b9\u30c1\u30e3<\/li><\/ul>\n\n\n<p>\u4ed6\u306b\u3082\u53cd\u5c04\u30fb\u5c48\u6298\u306a\u3069\u306e\u6a5f\u80fd\u304c\u642d\u8f09\u3055\u308c\u3066\u3044\u307e\u3059\u304c\u3001 <code>MToonMaterial<\/code> \u306f\u4e0a\u8a18\u6a5f\u80fd\u3092\u305d\u306e\u307e\u307e\u5f15\u304d\u7d99\u3044\u3067\u5229\u7528\u51fa\u6765\u308b\u3088\u3046\u306b\u5b9f\u88c5\u3059\u308b\u3053\u3068\u306b\u3057\u307e\u3057\u305f\u3002\u307b\u3068\u3093\u3069\u306f <code>StandardMaterial<\/code> \u306e\u30b3\u30d4\u30da\u3067\u3059\u3002<\/p>\n\n\n<p>Material \u306e\u5b9f\u88c5\u306f\u3001\u30b3\u30f3\u30d1\u30a4\u30eb\u3057\u3066\u30b7\u30a7\u30fc\u30c0\u3092\u5229\u7528\u51fa\u6765\u308b\u72b6\u614b\u306b\u3059\u308b <code>isReady<\/code> \u30e1\u30bd\u30c3\u30c9\u3068\u3001\u6bce\u30d5\u30ec\u30fc\u30e0\u30b7\u30a7\u30fc\u30c0\u306b\u73fe\u5728\u306e\u5024\u3092\u6e21\u3059 <code>bind<\/code> \u30e1\u30bd\u30c3\u30c9\u306e\u4e8c\u3064\u304c\u30e1\u30a4\u30f3\u3068\u306a\u3063\u3066\u3044\u308b\u3088\u3046\u3067\u3059\u3002\u305d\u308c\u3068\u8ffd\u52a0\u3057\u3066\u3001 <code>GLSL<\/code> \u30b3\u30fc\u30c9\u3092\u7528\u610f\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n<p>\u305d\u3053\u306b\u3001 MToon \u72ec\u81ea\u306e\u30c6\u30af\u30b9\u30c1\u30e3\u3084\u30d1\u30e9\u30e1\u30fc\u30bf\u3092\u8a2d\u5b9a\u51fa\u6765\u308b\u3088\u3046\u306b\u3057\u307e\u3057\u305f\u3002<\/p>\n\n\n<p>MToon \u306f\u30e9\u30a4\u30c6\u30a3\u30f3\u30b0\u306e\u3046\u3061 <strong>\u300c\u9670\u300d<\/strong> \u306e\u8a08\u7b97\u3092\u72ec\u81ea\u5f62\u5f0f\u306b\u5909\u3048\u308b\u5fc5\u8981\u304c\u3042\u308b\u306e\u3067\u3001 <a href=\"https:\/\/github.com\/BabylonJS\/Babylon.js\/blob\/master\/src\/Shaders\/ShadersInclude\/lightFragment.fx\">lightFragment.fx<\/a> \u3092\u7f6e\u304d\u63db\u3048\u308b\u3088\u3046\u306b\u3057\u307e\u3057\u305f\u3002<\/p>\n\n\n<p>\u307e\u305f\u3001\u30a2\u30a6\u30c8\u30e9\u30a4\u30f3\u3092\u63cf\u753b\u3059\u308b\u305f\u3081\u3001 <a href=\"https:\/\/doc.babylonjs.com\/how_to\/how_to_use_edgesrenderer\">EdgesRenderer<\/a> \u3084 <a href=\"https:\/\/doc.babylonjs.com\/api\/classes\/babylon.outlinerenderer\">OutlineRenderer<\/a> \u5b9f\u88c5\u3092\u53c2\u8003\u306b\u3057\u3066\u3001\u8ffd\u52a0\u3067\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u3092\u5b9f\u884c\u51fa\u6765\u308b\u3088\u3046\u306b\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n<p>\u73fe\u5728 VRM \u304c\u51fa\u529b\u3059\u308b MToon \u306e\u30d7\u30ed\u30d1\u30c6\u30a3\u60c5\u5831\u306f Unity \u306e\u30de\u30c6\u30ea\u30a2\u30eb\u6a5f\u80fd\u306b\u4f9d\u5b58\u3057\u3066\u3044\u308b\u3082\u306e\u3082\u3042\u308b\u306e\u3067\u3001\u305d\u306e\u3042\u305f\u308a\u3092\u8003\u616e\u3057\u3066\u8abf\u6574\u3059\u308b\u306e\u306b\u6642\u9593\u304c\u304b\u304b\u308a\u307e\u3057\u305f\u3002<\/p>\n\n\n<h3>babylon-vrm-loader<\/h3>\n\n\n<figure class=\"wp-block-image\"><img loading=\"lazy\" width=\"761\" height=\"399\" src=\"https:\/\/virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image-9.png\" alt=\"babylon-vrm-loader\" class=\"wp-image-752\" srcset=\"https:\/\/blog.virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image-9.png 761w, https:\/\/blog.virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image-9-300x157.png 300w\" sizes=\"(max-width: 761px) 100vw, 761px\" \/><\/figure>\n\n\n<p>babylon.js \u3067 VRM \/ VCI \u30d5\u30a1\u30a4\u30eb\u3092\u8aad\u307f\u8fbc\u3081\u308b\u3088\u3046\u306b\u3059\u308b\u305f\u3081\u3001 <a href=\"https:\/\/github.com\/BabylonJS\/Babylon.js\/blob\/master\/loaders\/src\/glTF\/2.0\/glTFLoader.ts\">glTFLoader<\/a> \u306e\u62e1\u5f35\u3092\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/p>\n\n\n<p>\u3068\u3044\u3063\u3066\u3082\u3001 VRM \/ VCI \u30d5\u30a1\u30a4\u30eb\u306e\u4e2d\u8eab\u306f glTF \u306e\u307e\u307e\u306a\u306e\u3067\u3001\u62e1\u5f35\u5b50\u3068\u3057\u3066 <code>.vrm<\/code> <code>.vci<\/code> \u3092\u8a31\u53ef\u3059\u308b\u3088\u3046\u306b\u5909\u66f4\u3059\u308b\u3060\u3051\u3067\u3059\u307f\u307e\u3057\u305f\u3002\u8d85\u697d\u3002<\/p>\n\n\n<p>\u3082\u3061\u308d\u3093\u3001\u305d\u308c\u3060\u3051\u3060\u3068\u4ed6\u306e\u62e1\u5f35\u6a5f\u80fd\u304c\u5229\u7528\u51fa\u6765\u306a\u3044\u306e\u3067\u3001 <code>VRMManager<\/code> \u30af\u30e9\u30b9\u3092\u30b7\u30fc\u30f3\u306e metadata \u3068\u3057\u3066\u8ffd\u52a0\u5b9f\u88c5\u3057\u3066\u3001 <code>BlendShape(\u8868\u60c5)<\/code> \u6a5f\u80fd\u3068 <code>Unity Humanoid \u306e\u30dc\u30fc\u30f3\u540d\u304b\u3089\u30dc\u30fc\u30f3\u3092\u53d6\u5f97<\/code> \u3059\u308b\u6a5f\u80fd\u3092\u5b9f\u88c5\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n<p>\u3057\u304b\u3057\u3001 <code>BlendShape<\/code> \u6a5f\u80fd\u306f glTF \u306e <code>MorphTarget<\/code> \u3068\u3044\u3046\u3082\u306e\u3092\u7528\u3044\u3066\u5b9f\u88c5\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u3059\u304c\u3001 babylon.js \u5b9f\u88c5\u3068\u306e\u76f8\u6027\u306e\u554f\u984c\u304b\u3001\u30d0\u30b0\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n<p><a href=\"https:\/\/github.com\/virtual-cast\/babylon-vrm-loader\/issues\/1\">BlendShape(with MorphTarget) is broken \u00b7 Issue #1 \u00b7 virtual-cast\/babylon-vrm-loader<\/a> \u306b\u307e\u3068\u3081\u3066\u3044\u307e\u3059\u304c\u3001 <code>MorphTarget<\/code> \u3092\u64cd\u4f5c\u3059\u308b\u3068\u30e1\u30c3\u30b7\u30e5\u304c\u7834\u7dbb\u3057\u307e\u3059\u3002\u57f7\u7b46\u73fe\u5728\u3067\u3082\u539f\u56e0\u304c\u660e\u3089\u304b\u306b\u306a\u3063\u3066\u3044\u306a\u3044\u306e\u3067\u3001\u3082\u3057\u3069\u306a\u305f\u304b\u539f\u56e0\u304c\u308f\u304b\u308b\u65b9\u304c\u3044\u3089\u3063\u3057\u3083\u3044\u307e\u3057\u305f\u3089\u3054\u6559\u6388\u9858\u3044\u305f\u3044\u3067\u3059\u3002<\/p>\n\n\n<h3>tso-vrm-viewer<\/h3>\n\n\n<p>\u30b6\u30fb\u30b7\u30fc\u30c9\u30aa\u30f3\u30e9\u30a4\u30f3\u306e\u30ea\u30dd\u30b8\u30c8\u30ea\u4e0a\u306b\u3001\u4e0a\u8a18\u4e8c\u3064\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u5229\u7528\u3057\u3066\u30d3\u30e5\u30fc\u30a2\u3092\u8868\u793a\u3059\u308b\u6a5f\u80fd\u3092\u8a2d\u3051\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n<p>\u30dc\u30fc\u30f3\u3092\u53d6\u5f97\u3057\u3066\u5f85\u6a5f\u30e2\u30fc\u30b7\u30e7\u30f3\u3092\u30ad\u30fc\u30d5\u30ec\u30fc\u30e0\u6307\u5b9a\u3067\u518d\u751f\u3057\u305f\u308a\u3001\u30ab\u30e1\u30e9\u3092\u8abf\u6574\u3057\u305f\u308a\u3001\u30a2\u30a4\u30b3\u30f3\u3092\u64ae\u5f71\u3067\u304d\u308b\u306a\u3069\u306e\u8ffd\u52a0\u6a5f\u80fd\u3092\u5b9f\u88c5\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n<p>\u4eca\u56de\u306e\u5b9f\u88c5\u3067\u3001\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067 VRM \u3092\u6c17\u8efd\u306b\u6271\u3048\u308b\u3088\u3046\u306b\u306a\u3063\u305f\u306e\u3067\u3001\u30d6\u30e9\u30a6\u30b6 VRM \u30b2\u30fc\u30e0\u306a\u3069\u3092\u5b9f\u88c5\u3057\u3066\u3044\u304f\u3053\u3068\u3082\u53ef\u80fd\u306b\u306a\u308a\u307e\u3057\u305f\u3002\u79c1\u500b\u4eba\u3068\u3057\u3066\u3082\u3001\u30c1\u30fc\u30e0\u3068\u3057\u3066\u3082\u4f55\u304b\u3057\u3089\u306e\u30b5\u30f3\u30d7\u30eb\u30b2\u30fc\u30e0\u3092\u4f5c\u3063\u3066\u307f\u305f\u3044\u3068\u3044\u3046\u8a71\u306b\u306a\u3063\u3066\u3044\u308b\u306e\u3067\u3001\u3053\u3046\u3054\u671f\u5f85\u3002<\/p>\n\n\n<p>\u3053\u308c\u307e\u3067\u306f WebGL 3D \u3068\u3044\u3048\u3070 three.js \u4e00\u5f37\u306e\u6642\u4ee3\u3067\u3057\u305f\u304c\u3001\u3053\u308c\u304b\u3089\u306f babylon.js \u3082\u540c\u3058\u304b\u3001\u305d\u308c\u4ee5\u4e0a\u306e\u5f37\u307f\u3092\u6301\u3063\u3066\u7af6\u4e89\u306b\u52a0\u308f\u3063\u3066\u304f\u308b\u306f\u305a\u3067\u3059\u3002 babylon.js \u306f\u3044\u3044\u305e\u3002<\/p>\n\n\n<figure class=\"wp-block-image\"><a href=\"https:\/\/www.ospn.jp\/osc2019-do\/\" target=\"_blank\" rel=\"noreferrer noopener\"><img loading=\"lazy\" width=\"471\" height=\"122\" src=\"https:\/\/virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image.png\" alt=\"\" class=\"wp-image-754\" srcset=\"https:\/\/blog.virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image.png 471w, https:\/\/blog.virtualcast.jp\/blog\/wp-content\/uploads\/2019\/05\/image-300x78.png 300w\" sizes=\"(max-width: 471px) 100vw, 471px\" \/><\/a><\/figure>\n\n\n<p>\u307e\u305f\u30012019\u5e745\u670831, 6\u67081\u65e5\u306b\u958b\u50ac\u3055\u308c\u308b<a href=\"https:\/\/www.ospn.jp\/osc2019-do\/\">OSC Hokkaido 2019<\/a> \u306b\u304a\u3044\u3066\u3001 6\/1 11:00 \u304b\u3089 <a href=\"https:\/\/www.ospn.jp\/osc2019-do\/modules\/eguide\/event.php?eid=38\">\u697d\u3057\u3044VR\u7a7a\u9593\u3092\u4f5c\u308b\u6280\u8853\u3068\u652f\u3048\u308b\u6280\u8853<\/a>\u3068\u3044\u3046\u304a\u984c\u76ee\u3067\u8b1b\u6f14\u3092\u884c\u308f\u305b\u3066\u3044\u305f\u3060\u304d\u307e\u3059\u3002<br>\n\u3053\u306e babylon.js \u542b\u3081\u30b6\u30fb\u30b7\u30fc\u30c9\u30aa\u30f3\u30e9\u30a4\u30f3\u3067\u5229\u7528\u3055\u308c\u3066\u3044\u308b Laravel, nuxt.js \u306a\u3069\u306e OSS \u6280\u8853\u30b9\u30bf\u30c3\u30af\u3092\u307e\u3068\u3081\u3066\u7d39\u4ecb\u3057\u3088\u3046\u3068\u601d\u3044\u307e\u3059\u306e\u3067\u3001\u662f\u975e\u304a\u8d8a\u3057\u304f\u3060\u3055\u3044\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u30b6\u30fb\u30b7\u30fc\u30c9\u30aa\u30f3\u30e9\u30a4\u30f3 \u306b\u306f\u3001 glTF \u898f\u683c\u306e\u62e1\u5f35\u3067\u3042\u308b VR \u5229\u7528\u60f3\u5b9a\u306e\u30d2\u30e5\u30fc\u30de\u30ce\u30a4\u30c9\u30e2\u30c7\u30eb\u62e1\u5f35\u306e VRM \u53ca\u3073\u3001 VirtualCast \u4e0a\u3067\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u30a2\u30a4\u30c6\u30e0\u3092\u81ea\u7531\u306b\u4f5c\u6210\u51fa\u6765\u308b VCI \u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u3053...<\/p>\n","protected":false},"author":3,"featured_media":752,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[20,238,31,26],"tags":[],"_links":{"self":[{"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/posts\/750"}],"collection":[{"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/comments?post=750"}],"version-history":[{"count":15,"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/posts\/750\/revisions"}],"predecessor-version":[{"id":14468,"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/posts\/750\/revisions\/14468"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/media\/752"}],"wp:attachment":[{"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/media?parent=750"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/categories?post=750"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.virtualcast.jp\/blog\/wp-json\/wp\/v2\/tags?post=750"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}