Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
楽しいVR空間を作る技術と支える技術 #osc19do
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Infiniteloop
October 17, 2023
Programming
130
1
Share
楽しいVR空間を作る技術と支える技術 #osc19do
オープンソースカンファレンス2019北海道の登壇資料です
Infiniteloop
October 17, 2023
More Decks by Infiniteloop
See All by Infiniteloop
[新卒向け研修資料] テスト文字列に「うんこ」と入れるな(2025年版)
infiniteloop_inc
18
83k
俺の PHP プロファイラの話 PHP スクリプトで PHP 処理系のメモリをのぞき込む
infiniteloop_inc
1
700
心理的安全性を学び直し、 「いい組織とは何か?」を考えてみる
infiniteloop_inc
1
1k
ゼロからつくる 2D物理シミュレーション ~物理現象をコードに落とし込む方法~
infiniteloop_inc
1
1.5k
詫び石の裏側
infiniteloop_inc
0
950
[新卒向け研修資料] テスト文字列に「うんこ」と入れるな(2024年版)
infiniteloop_inc
7
36k
リファクタリングで実装が○○分短縮した話
infiniteloop_inc
0
300
ADRという考えを取り入れてみて
infiniteloop_inc
0
310
500万行のPHPプロジェクトにおけるログ出力の歩み
infiniteloop_inc
0
230
Other Decks in Programming
See All in Programming
Old Dog, New Tricks: The Java 25 Reinvention - JNation
bazlur_rahman
0
140
Why Laravel apps break—Mastering the fundamentals to keep them maintainable
kentaroutakeda
1
340
AI駆動開発で崩れていくコードベースを立て直す
kyoko_nr_nr
1
430
技術記事、AIに書かせるか、自分で書くか? 〜それでも私が自分の手で書く理由〜 / #QiitaConference
jnchito
2
1.3k
メソッドのジェネリクスでGoの夢は広がるか? / Kyoto.go #65
utgwkk
3
540
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
350
Language Server 使ってる? 〜VSCode と Zed の場合〜 / Are you using a Language Server? ~For VS Code and Zed~
handlename
0
750
LLM本来の能力を解き放つサンドボックス技術とAI民主化への適用
yukukotani
3
2.8k
Copilot CLI の継戦能力を高める コンテキスト管理
nozomutu
1
1.2k
AIチームを指揮するOSS「TAKT」活用術 / How to Use “TAKT,” an OSS Tool for Orchestrating AI Teams
nrslib
6
830
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
4k
密結合なバックエンドから TypeScript のコードを生成する
kemuridama
1
730
Featured
See All Featured
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
240
svc-hook: hooking system calls on ARM64 by binary rewriting
retrage
2
290
Embracing the Ebb and Flow
colly
88
5.1k
Speed Design
sergeychernyshev
33
1.8k
Effective software design: The role of men in debugging patriarchy in IT @ Voxxed Days AMS
baasie
0
390
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
520
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.3k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
320
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
360
Statistics for Hackers
jakevdp
799
230k
Heart Work Chapter 1 - Part 1
lfama
PRO
7
36k
Transcript
楽しいVR空間を 作る技術と支える技術 2019/06/01 OSC 2019 Hokkaido 株式会社インフィニットループ 後藤 大宗・山岸 大
自己紹介 ・後藤大宗 / Taishu Goto ・3Dモデラー ・スマブラはプリン使い 仙台→山形→千葉→北海道 イマココ スープカリーがおいしい!
https://hagurumaheigen.booth.pm/ BOOTH 歯車平原
VCIとVRMとは違うのか?
基本的にはどちらも glTF2.0ベースの3Dフォーマット 人型アバターのフォーマット さまざまなプラットフォーム上で同じデータを 使うことを想定して作られた 人型である必要がない 家具、武器、背景 など プラットフォーム側でなく、 VCI自体にLuaスク リプトを記述して動きを制御することができる
VRM VCI
VCI Object と VCI Sub Item VCIの構造
VCI Object SubItem SubItem SubItem
アメリカンクラッカーVCIの場合 VCI Object VCI Sub Item
SubItemの所有権
所有権 同期の基準になるユーザー
SubItem所有権の基本ルール 2・SubItemを掴んだ人に所有権が移る 3・同じGroupIDはまとめて移る 1・はじめはアイテムを出した人が持つ
SubItem所有権の基本ルール1 ・はじめはアイテムを出した人が持つ
SubItem所有権の基本ルール2 SubItemを掴んだ人に所有権が移る SubItem 現状「掴む」以外で 所有権を移す方法は ありません そのため、 コライダが無いなどで 掴めない場合は 所有権が移せません
注意
SubItem所有権の基本ルール3 同じGroupIDはまとめて移る ただしGroupIDが0のものは掴んだものしか移らない
VCIの重要な仕様に関しては 特にこの「所有権」まわりを 理解しておけば大丈夫だと思います あとはLuaスクリプト次第!
VCIの機能について なにができるの?
・Luaスクリプト無しで できること ・Luaスクリプト有りで できること ・(現状)できないこと VCIの機能について UniVCI v0.17時点
Luaスクリプト無しで できること ・物理挙動の設定 ・掴める/掴めないの設定 ・大きさを変えられるかの設定
Luaスクリプト無しで できること Unity上のコンポーネント で設定 VCI Sub Itemで 掴み、拡縮の設定 Collider Rigidbodyで
物理挙動を設定
Luaスクリプト有りで できること ・移動させる ・回転させる ・拡縮させる ・音を鳴らす ・衝突検知 ・アニメーションさせる ・マテリアルの色、UVの変更 ・他のVCIからメッセージを受け取る
etc できないこと以外はだいたいできる!
(現状)できないこと ・オブジェクトの表示非表示切り替え ・マテリアルを別のものに変更 ・他のVCIやキャラクターを直接制御 ・アニメーションのブレンドや同時再生 etc
Luaスクリプトについて イベント関数
イベント関数 update updateAll onUse onUnuse onTriggerEnter onTriggerExit onCollisionEnter onCollisionExit onGrab
onUngrab 毎フレーム処理 コントローラのボタン検出 コライダによる衝突判定 アイテムを掴んだ際の処理
回転翼のスクリプト onGrab() onUngrab() アニメーションファイル名
回転翼のスクリプト コライダ アニメーションコンポーネント 参照
ポジションリセットのスクリプト onUse()
ポジションリセットのスクリプト
ドラムのスクリプト onCollisionEnter()
ドラムのスクリプト ドラムとスティックにコライダとrigidbodyをつけておく
ドラムのスクリプト イベント関数内に条件文を追記することで どのSubItemとコライダの衝突なのか判別 自動で代入される
ドラムのスクリプト コンポーネント VCI Objectにアタッチした Audio Source 、Animation を名称指定する
Luaスクリプトについて 共有変数
共有変数 変数をユーザー間で同期することができる 途中からネットワークに参加したユーザーにもアイ テムの状態を共有できる vci.state.Set("STATE",state) vci.state.Get("STATE") stateの値を”STATE”という 共有変数に保存 共有変数”STATE”から
値を取得
共有変数 ネットワーク上にすでに変数が 保存されてるかのチェック 値があれば取得し、 なければ初期化 現在の状態を共有変数に 代入 ライトのスクリプト
Luaスクリプトについて メッセージシステム
メッセージシステム メッセージを送受信することで同じスタジオ内 にある別のVCIと変数のやり取りができる ↓ 例 スイッチのVCI と 爆弾のVCI データを管理するVCI と 掲示板のVCI vci.message.Emit("MSG_NAME",1) vci.message.On("MSG_NAME", onMessage)
送信側 受信側
メッセージシステム vci.message.Emit("MSG_NAME",1) 送信側のスクリプト メッセージ格納する名前 string型で”addforce_on”という メッセージの中身になる メッセージは投げっぱなし 過去のログの読み取りなどはできない
メッセージシステム vci.message.On("MSG_NAME", onMessage) 受信側のスクリプト 受信側はonMessage関数とセットで使おう 送信側を判定する条件式
アップデートで配信のコメントも 取得できるようになりました
コメントの取得 name部分が”comment”でシステムからの コメントメッセージを取得可能 例 「www」で画面に草が生える 「クッキー」でクッキーのカウントが増える
VCI学習 調べ方など
VirtualCast Wiki
関数別や、用途で別れている VCI取り込みのリンクや Unitypackageファイルもあるので 参考にして作りやすい
VCI Developers Discord https://discord.gg/jtsXVVA ↓どなたでも自由に参加できます VCIの質問やバグ報告 作ったVCIの宣伝など THE SEED ONLINEの質問も
こちらで受け付けています 公式VCIの開発者コミュニティです
THE SEED ONLINE
自己紹介 - 山岸 “@akai_inu” Masaru - OSC 2016 Hokkaido, OSC
2016 Tokyo/Fall - THE SEED ONLINE エンジニア ポートフォリオサイト https://il-m-yamagishi.github.io
VCI の使い方 1.VCIを作成 2.アップロード 4.遊ぶ アイテムボックス 3.連携 することで TSOのアイテムボックスから VCIを持ってこられる
THE SEED ONLINE 構成図
Microsoft 製 WebGL フレームワーク
個人初 OSS! virtual-cast/babylon-mtoon-material virtual-cast/babylon-vrm-loader
Vue.js のフレームワーク - 最新技術の塊 - デザイナー・コーダー責務分離 - TypeScript - Vetur
OAuth Login OAuth Provider - Twitter - Facebook - niconico
OpenAPI 3 OpenAPI 3
ありがとうございました。