SlideShare ist ein Scribd-Unternehmen logo
1 von 88
ARコンテンツ作成勉強会
HoloLens2とOculusQuestではじめるWebXR
サンプルのダウンロード
http://arfukuoka.lolipop.jp/WebXR2021/Sample.zip
自己紹介
氏名:吉永崇(Takashi Yoshinaga)
専門:ARを用いた医療支援や運動計測
Volumetric Video (3Dビデオ)
コミュニティ:ARコンテンツ作成勉強会 主催
ARコンテンツ作成勉強会の紹介
 2013年5月に勉強会をスタート。
 ARコンテンツの作り方をハンズオン形式で学ぶ
 人数は5~10名程度の少人数で実施
 参加条件はAR/VRに興味がある人(知識不要)
 各地で開催 (福岡、熊本、宮崎、長崎、大分、 鹿児島、山口、広島、札幌、関東)
Twitterと勉強会ページで情報を発信しています
@AR_Fukuoka Googleで「AR勉強会」で検索
#AR_Fukuoka
ハッシュタグ
本題に入ります
本日のゴール
HoloLens2やOculus Questを使ったハンドトラッキングをWebXRでやってみよう
https://youtu.be/y4WD2wgzKYQ
開発ツール:A-Frameの概要
 Webブラウザ上でVRなどの3D表現を簡単に実現するフレームワーク
 HTMLのタグを書くだけで3Dオブジェクトを配置できる
 Firefox、Chrome、Edgeなど主要なブラウザがWebVR対応を表明
 HoloLens2やOculus Quest、HTC Viveなどの各種HMDに対応
 上記Webブラウザやデバイスで動くのでコンテンツの公開・共有が容易
必要なもの
 Webブラウザ → コンテンツの体験や動作確認
 テキストエディタ → HTMLやjavascriptの記述
 Webサーバー → コンテンツの公開
サーバーに関して今回は・・・
 Glitchを利用 https://glitch.com/
 FacebookかGitHubのアカウントがあればOK
 サーバーとエディタの両方を無料で提供
この資料ではGlitch使用を前提に説明します
テンプレートコードの複製
https://glitch.com/~webxr-hand-template
GET STARTED
テンプレートコードの複製
下にスクロール
テンプレートコードの複製
Remix Your Own
テンプレートの確認
index.htmlをクリックし、コードが表示されることを確認
index.html
テンプレートの確認
index.htmlをクリックし、コードが表示されることを確認
エディタ プレビュー
コンテンツ名(URL)の変更
画面左上の文字列(コンテンツ名)をクリック
ここをクリック
コンテンツ名(URL)の変更
文字列を各自、分かりやすい名称(半角英数)に変更
シンプルで分かり易く変更
URLの確認
プレビュー画面の上方にある[Change URL]からURLを確認
Change URL
これがURL
※実機での動作確認に使用
実機で動作確認
WebブラウザのアドレスバーにコンテンツのURLを入力後、AR/VRボタンをクリック
URLを入力
ARボタン
URLを入力
VRボタン
HoloLens2 Quest
動作の様子 (HoloLens2)
今回はこれを編集しながらハンドトラッキングを用いたコンテンツを作っていきます
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
テンプレートの確認
Lesson01
テンプレートの確認
A-Frameの読み込み
3D空間に描画する内容を記述
テンプレートの確認
<a-scene background="color: #ECECEC">
<a-box position="0 1.5 -2" scale="0.5 0.5 0.5" rotation="0 45 0"
color="#4CC3D9" shadow></a-box>
</a-scene>
a-box
position
0 1.5 -2
位置 大きさ 色
向き
テンプレートの確認
手の挙動に
ついて記述(予定)
テンプレートの確認
<script>
window.onload = function() {
initRightHand(); //右手の初期化
initLeftHand(); //左手の初期化
};
//右手の初期化を行う関数
function initRightHand(){
};
//左手の初期化を行う関数
function initLeftHand(){
};
</script>
読み込みが終わったら
自動的に実行される
右手の挙動を記述
するために用意した関数
左手の挙動を記述
するために用意した関数
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
手のオブジェクトを表示
ここを編集
手のオブジェクトを表示
<a-scene background="color: #ECECEC">
<a-box position="0 1.5 -2" scale="0.5 0.5 0.5" rotation="0 45 0"
color="#4CC3D9" shadow></a-box>
<!--左手の描画-->
<a-entity id="leftHand"
hand-tracking-controls="hand: left; modelStyle: dots;"></a-entity>
<!--右手の描画-->
<a-entity id="rightHand"
hand-tracking-controls="hand: right; modelStyle: dots;"></a-entity>
</a-scene>
【hand-tracking-controlsの詳細]】
hand: left または right
modelStyle: mesh または dots
(meshはうまく働かず)
modelColor: 手のモデルの色
(今回はデフォルト色) Lesson02
実機で動作確認
必ず再読み込みボタンをクリック
再読み込み
再読み込み
動作確認
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
javascriptで手の情報を使用する準備
ここを編集
javascriptで手の情報を使用する準備
<script>
window.onload = function() {
initRightHand(); //右手の初期化
initLeftHand(); //左手の初期化
};
//右手の初期化を行う関数
function initRightHand(){
};
//左手の初期化を行う関数
function initLeftHand(){
};
</script>
ここに変数を追加
javascriptで手の情報を使用する準備
var scene; //描画する3D空間
var rightHand; //右手の情報を保持する変数
var leftHand; //左手の情報を保持する変数
window.onload = function() {
initRightHand(); //右手の初期化
initLeftHand(); //左手の初期化
};
//右手の初期化を行う関数
function initRightHand(){
};
//左手の初期化を行う関数
function initLeftHand(){
}; Lesson03
javascriptで3D空間を操作する準備
var scene; //描画する3D空間
var rightHand; //右手
var leftHand; //左手
window.onload = function() {
//3D空間を変数として保持
scene = document.querySelector('a-scene');
initRightHand(); //右手の初期化
initLeftHand(); //左手の初期化
};
//右手の初期化を行う関数
function initRightHand(){
};
//左手の初期化を行う関数
function initLeftHand(){ }; Lesson04
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
右手の操作で空間にオブジェクトを生成
var scene; //描画する3D空間
var rightHand; //右手
var leftHand; //左手
window.onload = function() {
//3D空間を変数として保持
scene = document.querySelector('a-scene');
initRightHand(); //右手の初期化
initLeftHand(); //左手の初期化
};
//右手の初期化を行う関数
function initRightHand(){
};
//左手の初期化を行う関数
function initLeftHand(){ };
ここを編集
右手の操作で空間にオブジェクトを生成
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
});
//ピンチしながら手を移動
rightHand.addEventListener('pinchmoved', function (e) {
});
}; Lesson05
ピンチ開始の取得
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
});
//ピンチしながら手を移動
rightHand.addEventListener('pinchmoved', function (e) {
});
};
ここを編集
ピンチ開始の取得
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
var position = e.detail.position;
//BOX生成関数を呼び出す (次のページ以降で解説)
addBox(position);
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
});
//ピンチしながら手を移動
rightHand.addEventListener('pinchmoved', function (e) {
});
}; Lesson06
Boxの生成
ここに関数を追加
Boxの生成
//左手の初期化を行う関数
function initLeftHand(){
};
function addBox(position){
//a-boxという要素を作る
var box = document.createElement('a-box');
//位置や大きさ、色を設定
box.setAttribute('position', position);
box.setAttribute('scale', '0.02 0.02 0.02');
box.setAttribute('color', '#0062C6');
//あとで一括削除しやすいようにクラス名設定
box.setAttribute('class', 'box');
//3次元空間にboxを追加
scene.appendChild(box);
}
</script>
Lesson07
動作確認
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
手の移動に追従
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
/*中略*/
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
});
//ピンチしながら手を移動
rightHand.addEventListener('pinchmoved', function (e) {
});
};
ここを編集
手の移動に追従
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
/*中略*/
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
});
//ピンチしながら手を移動
rightHand.addEventListener('pinchmoved', function (e) {
var position = e.detail.position;
//BOXを生成
addBox(position);
}); Lesson08
動作確認
問題点
あまり密にboxを生成するとすぐにメモリを消費して動きが遅くなる
描画するBoxを間引く(1/6)
<script>
var scene; //描画する3D空間
var rightHand; //右手
var leftHand; //左手
var prev;//最後にBox置いた位置を記憶する変数
window.onload = function() {
//3D空間を変数として保持
scene = document.querySelector('a-scene');
initRightHand(); //右手の初期化
initLeftHand(); //左手の初期化
};
//右手の初期化を行う関数
function initRightHand(){
/*以下省略*/
Lesson09
描画するBoxを間引く(2/6)
var prev;//最後にBox置いた位置を記憶
window.onload = function() {
/*省略*/
};
//右手の初期化を行う関数
function initRightHand(){
/*省略*/
};
//左手の初期化を行う関数
function initLeftHand(){
};
//Boxの追加を行う関数
function addBox(position){
}
ここを編集
描画するBoxを間引く(3/6)
function addBox(position){
//a-boxという要素を作る
var box = document.createElement('a-box');
//位置や大きさ、色を設定
box.setAttribute('position', position);
box.setAttribute('scale', '0.02 0.02 0.02');
box.setAttribute('color', '#0062C6');
//あとで一括削除するためにクラス名設定
box.setAttribute('class', 'box');
//3次元空間にboxを追加
scene.appendChild(box);
//最後にBox置いた位置を記憶
prev=box.object3D.position;
}
Lesson09
描画するBoxを間引く(4/6)
var prev;//最後にBox置いた位置を記憶
window.onload = function() {
/*省略*/
};
//右手の初期化を行う関数
function initRightHand(){
/*省略*/
};
//左手の初期化を行う関数
function initLeftHand(){
};
//Boxの追加を行う関数
function addBox(position){
}
ここを編集
描画するBoxを間引く(5/6)
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
/*中略*/
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
});
//ピンチしながら手を移動
rightHand.addEventListener('pinchmoved', function (e) {
});
};
ここを編集
描画するBoxを間引く(6/6)
rightHand.addEventListener('pinchmoved', function (e) {
var position = e.detail.position;
//最後にboxを置いた位置と現在の手の位置との距離
var length= prev.distanceTo(position);
//一定距離以上ならboxを置く
if(length>=0.02){
//BOXを生成
addBox(position);
}
});
Lesson10
prev
position
一定距離以上
動作確認
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
色を切り替える
var scene; //描画する3D空間
var rightHand; //右手
var leftHand; //左手
var prev;//最後にBox置いた位置を記憶
//Cubeに割り当てる色の配列
var colors = ['#0062C6', '#00AB00', '#FFCF00', '#7F00FF',
'#FFFFFF', '#FF2000', '#F52394', '#593110'];
//利用する色の番号
var index=0;
window.onload = function() {
//3D空間を変数として保持
scene = document.querySelector('a-scene');
initRightHand(); //右手の初期化
initLeftHand(); //左手の初期化
}; Lesson11
色を切り替える
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
/*中略*/
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
});
//ピンチしながら手を移動
rightHand.addEventListener('pinchmoved', function (e) {
/*中略*/
});
};
ここを編集
色を切り替える
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
var position = e.detail.position;
//BOX生成関数を呼び出す
addBox(position);
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
//色の番号を加算して、あとでboxの色に反映
index++;
index%=colors.length;
}); Lesson12
色を切り替える
window.onload = function() {
/*省略*/
};
//右手の初期化を行う関数
function initRightHand(){
/*省略*/
};
//左手の初期化を行う関数
function initLeftHand(){
};
//Boxの追加を行う関数
function addBox(position){
}
ここを編集
色を切り替える
function addBox(position){
//a-boxという要素を作る
var box = document.createElement('a-box');
//位置や大きさ、色を設定
box.setAttribute('position', position);
box.setAttribute('scale', '0.02 0.02 0.02’);
box.setAttribute('color', '#0062C6');
box.setAttribute('color', colors[index]);
//あとで一括削除するためにクラス名設定
box.setAttribute('class', 'box');
//3次元空間にboxを追加
scene.appendChild(box);
//最後にBox置いた位置を記憶
prev=box.object3D.position;
} Lesson13
box.setAttribute('color', '#0062C6');
動作確認
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
描画したBoxを削除
var prev;//最後にBox置いた位置を記憶
window.onload = function() {
/*省略*/
};
//右手の初期化を行う関数
function initRightHand(){
/*省略*/
};
//左手の初期化を行う関数
function initLeftHand(){
};
//Boxの追加を行う関数
function addBox(position){
/*省略*/
}
ここを編集
描画したBoxを削除
function initLeftHand(){
//左手のオブジェクトを取得
leftHand = document.getElementById("leftHand");
//ピンチ開始時の挙動
leftHand.addEventListener('pinchstarted', function (e) {
//boxクラスが割り当てられているオブジェクトを全て取得
var els = document.querySelectorAll('.box’);
//一つ一つ削除していく
for (var i = 0; i < els.length; i++) {
els[i].parentNode.removeChild(els[i]);
}
});
};
Lesson14
動作確認
完成
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
ハンズオンの手順
1.サンプルの概要を解説
2.ハンドトラッキング機能を追加 (手の表示)
3.javascriptでハンドトラッキングと連携する準備
4.右手のアクションを記述
a) ピンチ(つまみ操作)開始時のオブジェクト追加
b) ピンチしながらの移動に追従してオブジェクト追加
c) ピンチ終了時に次回追加するオブジェクトの色を設定
5.左手のアクションを記述
a) ピンチ開始時に全てのオブジェクトを削除
6.おまけ
a) 常に人差し指の位置を追跡
指の先の位置を取得する方法
a-sceneを編集
指の先の位置を取得する方法
<a-scene background="color: #ECECEC">
<a-box position="0 1.5 -2" scale="0.5 0.5 0.5"
rotation="0 45 0" color="#4CC3D9" shadow></a-box>
<a-entity id="leftHand" hand-tracking-controls="hand: left;
modelStyle: dots;"></a-entity>
<a-entity id="rightHand" hand-tracking-controls="hand: right;
modelStyle: dots;"></a-entity>
<!--指先に表示する球-->
<a-sphere id="tip" position="0 0 0" radius="0.015"
color="#0062C6"></a-sphere>
</a-scene>
Lesson15
テンプレートの確認
Javascript
の記述に戻る
指の先の位置を取得する方法
//Cubeに割り当てる色の配列
var colors = ['#0062C6', '#00AB00', '#FFCF00', '#7F00FF',
'#FFFFFF', '#FF2000', '#F52394', '#593110'];
//利用する色の番号
var index=0;
//指の先端を表す球
var tip;
window.onload = function() {
//3D空間を変数として保持
scene = document.querySelector('a-scene');
//指先の位置を表す球を取得
tip = document.getElementById("tip");
initRightHand(); //右手の初期化
initLeftHand(); //左手の初期化
};
Lesson16
指の先の位置を取得する方法
var prev;//最後にBox置いた位置を記憶
window.onload = function() {
/*省略*/
};
//右手の初期化を行う関数
function initRightHand(){
/*省略*/
};
//左手の初期化を行う関数
function initLeftHand(){
/*省略*/
};
//Boxの追加を行う関数
function addBox(position){
/*省略*/
}
ここを編集
指の先の位置を取得する方法
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//リアルタイムに指の先端を追跡(この後記述)
tipTracking(rightHand.components['hand-tracking-controls']);
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
/*省略*/
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
/*省略*/
});
Lesson17
指の先の位置を取得する方法
window.onload = function() {
/*省略*/
};
function initRightHand(){
/*省略(右手の初期化を行う関数)*/
};
function initLeftHand(){
/*省略(左手の初期化を行う関数)*/
};
function addBox(position){
/*省略(Boxの追加を行う関数)*/
}
ここに指の位置追跡の
関数を追加
指の先の位置を取得する方法
function initLeftHand(){
/*省略(左手の初期化を行う関数)*/
};
function addBox(position){
/*省略(Boxの追加を行う関数)*/
}
function tipTracking(ctrl){
//指の先端の位置
var position = ctrl.indexTipPosition;
//指の位置を球に反映
tip.setAttribute('position', position);
//30ms後にtipTrackingを再度呼ぶ
setTimeout(function(){tipTracking(ctrl);}, 30);
}; Lesson18
次のBoxの色を指先の球に反映
function initRightHand(){
//右手のオブジェクト(id=rightHand)を取得
rightHand = document.getElementById("rightHand");
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
/*中略*/
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
});
//ピンチしながら手を移動
rightHand.addEventListener('pinchmoved', function (e) {
/*中略*/
});
};
ここを編集
次のBoxの色を指先の球に反映
//ピンチ開始
rightHand.addEventListener('pinchstarted', function (e) {
var position = e.detail.position;
//BOX生成関数を呼び出す
addBox(position);
});
//ピンチ終了
rightHand.addEventListener('pinchended', function (e) {
//色の番号を加算してboxの色に反映
index++;
index%=colors.length;
//指の先端の球にも色を反映
tip.setAttribute('color', colors[index]);
});
Lesson19
参考資料
• A-Frame公式
https://aframe.io
• A-Frameハンズオン
https://www.slideshare.net/ssuserc0d7fb/arframe-
x-arjs
• WebVRハンズオン
https://www.slideshare.net/ssuserc0d7fb/oculus-
quest-12-with-aframe-webvr-239362153
• A-Frameでハンドトラッキング
https://www.jyuko49.com/entry/2020/12/14/2147
15

Weitere ähnliche Inhalte

Was ist angesagt?

ピクサー USD 入門 新たなコンテンツパイプラインを構築する
ピクサー USD 入門 新たなコンテンツパイプラインを構築するピクサー USD 入門 新たなコンテンツパイプラインを構築する
ピクサー USD 入門 新たなコンテンツパイプラインを構築する
Takahito Tejima
 

Was ist angesagt? (20)

OpenCV/ARCore/Unityで作る塗り絵AR
OpenCV/ARCore/Unityで作る塗り絵AROpenCV/ARCore/Unityで作る塗り絵AR
OpenCV/ARCore/Unityで作る塗り絵AR
 
AI x OpenCV x WebAR: Selfie Segmentationを使ってみよう
AI x OpenCV x WebAR: Selfie Segmentationを使ってみようAI x OpenCV x WebAR: Selfie Segmentationを使ってみよう
AI x OpenCV x WebAR: Selfie Segmentationを使ってみよう
 
MRTKをNreal Lightに対応させてみた
MRTKをNreal Lightに対応させてみたMRTKをNreal Lightに対応させてみた
MRTKをNreal Lightに対応させてみた
 
【準備編!】HoloLens 2/Oculus Quest対応WebXRハンズオン
【準備編!】HoloLens 2/Oculus Quest対応WebXRハンズオン【準備編!】HoloLens 2/Oculus Quest対応WebXRハンズオン
【準備編!】HoloLens 2/Oculus Quest対応WebXRハンズオン
 
点群を使いこなせ! 可視化なんて当たり前、xRと点群を組み合わせたUnityの世界 【Interact , Stipple】
点群を使いこなせ! 可視化なんて当たり前、xRと点群を組み合わせたUnityの世界 【Interact , Stipple】点群を使いこなせ! 可視化なんて当たり前、xRと点群を組み合わせたUnityの世界 【Interact , Stipple】
点群を使いこなせ! 可視化なんて当たり前、xRと点群を組み合わせたUnityの世界 【Interact , Stipple】
 
見よう見まねでやってみる2D流体シミュレーション
見よう見まねでやってみる2D流体シミュレーション見よう見まねでやってみる2D流体シミュレーション
見よう見まねでやってみる2D流体シミュレーション
 
Oculus Quest 1&2 開発のはじめの一歩 with A-Frame WebVR
Oculus Quest 1&2 開発のはじめの一歩 with A-Frame WebVROculus Quest 1&2 開発のはじめの一歩 with A-Frame WebVR
Oculus Quest 1&2 開発のはじめの一歩 with A-Frame WebVR
 
5分でわかる Unity点群
5分でわかる Unity点群5分でわかる Unity点群
5分でわかる Unity点群
 
Unityによるリアルタイム通信とMagicOnionによるC#大統一理論の実現
Unityによるリアルタイム通信とMagicOnionによるC#大統一理論の実現Unityによるリアルタイム通信とMagicOnionによるC#大統一理論の実現
Unityによるリアルタイム通信とMagicOnionによるC#大統一理論の実現
 
OpenCVでつくろうARスタンプアプリ in 熊本
OpenCVでつくろうARスタンプアプリ in 熊本OpenCVでつくろうARスタンプアプリ in 熊本
OpenCVでつくろうARスタンプアプリ in 熊本
 
UnityとVuforiaで始めるAR開発
UnityとVuforiaで始めるAR開発UnityとVuforiaで始めるAR開発
UnityとVuforiaで始めるAR開発
 
Nreal Lightハンズオン
Nreal LightハンズオンNreal Lightハンズオン
Nreal Lightハンズオン
 
Azure kinect DKハンズオン
Azure kinect DKハンズオンAzure kinect DKハンズオン
Azure kinect DKハンズオン
 
バーチャルライブ配信アプリREALITYの3Dアバターシステムの全容について
バーチャルライブ配信アプリREALITYの3Dアバターシステムの全容についてバーチャルライブ配信アプリREALITYの3Dアバターシステムの全容について
バーチャルライブ配信アプリREALITYの3Dアバターシステムの全容について
 
OpenCVで作るスタンプAR
OpenCVで作るスタンプAROpenCVで作るスタンプAR
OpenCVで作るスタンプAR
 
OpenVRやOpenXRの基本的なことを調べてみた
OpenVRやOpenXRの基本的なことを調べてみたOpenVRやOpenXRの基本的なことを調べてみた
OpenVRやOpenXRの基本的なことを調べてみた
 
ノンプログラミングで始めるAR (HoloLens 2 / ARCore / ARKit) 開発 with MRTK
ノンプログラミングで始めるAR (HoloLens 2 / ARCore / ARKit) 開発 with MRTK ノンプログラミングで始めるAR (HoloLens 2 / ARCore / ARKit) 開発 with MRTK
ノンプログラミングで始めるAR (HoloLens 2 / ARCore / ARKit) 開発 with MRTK
 
ピクサー USD 入門 新たなコンテンツパイプラインを構築する
ピクサー USD 入門 新たなコンテンツパイプラインを構築するピクサー USD 入門 新たなコンテンツパイプラインを構築する
ピクサー USD 入門 新たなコンテンツパイプラインを構築する
 
はじめようARCore: Motion Tracking & Image Tracking編
はじめようARCore: Motion Tracking & Image Tracking編はじめようARCore: Motion Tracking & Image Tracking編
はじめようARCore: Motion Tracking & Image Tracking編
 
CEDEC 2020 - 高品質かつ低負荷な3Dライブを実現するシェーダー開発 ~『ラブライブ!スクールアイドルフェスティバル ALL STARS』(スク...
CEDEC 2020 - 高品質かつ低負荷な3Dライブを実現するシェーダー開発 ~『ラブライブ!スクールアイドルフェスティバル ALL STARS』(スク...CEDEC 2020 - 高品質かつ低負荷な3Dライブを実現するシェーダー開発 ~『ラブライブ!スクールアイドルフェスティバル ALL STARS』(スク...
CEDEC 2020 - 高品質かつ低負荷な3Dライブを実現するシェーダー開発 ~『ラブライブ!スクールアイドルフェスティバル ALL STARS』(スク...
 

Ähnlich wie A-Frameで始めるWebXRとハンドトラッキング (HoloLens2/Oculus Quest対応)

Unity道場京都スペシャル トゥーンシェーディングとノンフォトリアリスティック風絵づくり入門_
 Unity道場京都スペシャル トゥーンシェーディングとノンフォトリアリスティック風絵づくり入門_ Unity道場京都スペシャル トゥーンシェーディングとノンフォトリアリスティック風絵づくり入門_
Unity道場京都スペシャル トゥーンシェーディングとノンフォトリアリスティック風絵づくり入門_
Unity Technologies Japan K.K.
 

Ähnlich wie A-Frameで始めるWebXRとハンドトラッキング (HoloLens2/Oculus Quest対応) (20)

ARコンテンツ作成勉強会 in 宮崎: はじめようARCore
ARコンテンツ作成勉強会 in 宮崎: はじめようARCoreARコンテンツ作成勉強会 in 宮崎: はじめようARCore
ARコンテンツ作成勉強会 in 宮崎: はじめようARCore
 
HoloLensハンズオン@ももち浜TECHカフェ vol.2
HoloLensハンズオン@ももち浜TECHカフェ vol.2HoloLensハンズオン@ももち浜TECHカフェ vol.2
HoloLensハンズオン@ももち浜TECHカフェ vol.2
 
はじめようArcore (修正版)
はじめようArcore (修正版)はじめようArcore (修正版)
はじめようArcore (修正版)
 
エンジニアカフェ1周年イベント:WebAR/VR開発入門
エンジニアカフェ1周年イベント:WebAR/VR開発入門エンジニアカフェ1周年イベント:WebAR/VR開発入門
エンジニアカフェ1周年イベント:WebAR/VR開発入門
 
はじめようARCore
はじめようARCoreはじめようARCore
はじめようARCore
 
第19回SOIL水曜セミナー:RGB-DカメラでAR空間に入り込もう
第19回SOIL水曜セミナー:RGB-DカメラでAR空間に入り込もう第19回SOIL水曜セミナー:RGB-DカメラでAR空間に入り込もう
第19回SOIL水曜セミナー:RGB-DカメラでAR空間に入り込もう
 
Holo-SDKハンズオン:はじめようヘッドトラッキングを用いた3D表現
Holo-SDKハンズオン:はじめようヘッドトラッキングを用いた3D表現Holo-SDKハンズオン:はじめようヘッドトラッキングを用いた3D表現
Holo-SDKハンズオン:はじめようヘッドトラッキングを用いた3D表現
 
ノンプログラミングで始める AR 開発入門
ノンプログラミングで始める AR 開発入門ノンプログラミングで始める AR 開発入門
ノンプログラミングで始める AR 開発入門
 
KinectでAR空間に入り込もう
KinectでAR空間に入り込もうKinectでAR空間に入り込もう
KinectでAR空間に入り込もう
 
20131210 QZSS Ideathon 2013
20131210 QZSS Ideathon 201320131210 QZSS Ideathon 2013
20131210 QZSS Ideathon 2013
 
20160723 unibook lt大会_発表資料(HoloLensのアプリ開発)
20160723 unibook lt大会_発表資料(HoloLensのアプリ開発)20160723 unibook lt大会_発表資料(HoloLensのアプリ開発)
20160723 unibook lt大会_発表資料(HoloLensのアプリ開発)
 
Unity道場京都スペシャル トゥーンシェーディングとノンフォトリアリスティック風絵づくり入門_
 Unity道場京都スペシャル トゥーンシェーディングとノンフォトリアリスティック風絵づくり入門_ Unity道場京都スペシャル トゥーンシェーディングとノンフォトリアリスティック風絵づくり入門_
Unity道場京都スペシャル トゥーンシェーディングとノンフォトリアリスティック風絵づくり入門_
 
Tokyo MotionControl Network tech cafe 「誰もがつまづく3D認識の世界」
Tokyo MotionControl Network tech cafe 「誰もがつまづく3D認識の世界」Tokyo MotionControl Network tech cafe 「誰もがつまづく3D認識の世界」
Tokyo MotionControl Network tech cafe 「誰もがつまづく3D認識の世界」
 
UnityとBlenderハンズオン第1章
UnityとBlenderハンズオン第1章UnityとBlenderハンズオン第1章
UnityとBlenderハンズオン第1章
 
Holoニュースとか(2019_09)
Holoニュースとか(2019_09)Holoニュースとか(2019_09)
Holoニュースとか(2019_09)
 
はじめようRGB-Dセンシングと画像処理
はじめようRGB-Dセンシングと画像処理はじめようRGB-Dセンシングと画像処理
はじめようRGB-Dセンシングと画像処理
 
ARコンテンツ作成勉強会( #AR_Fukuoka )紹介
ARコンテンツ作成勉強会( #AR_Fukuoka )紹介ARコンテンツ作成勉強会( #AR_Fukuoka )紹介
ARコンテンツ作成勉強会( #AR_Fukuoka )紹介
 
Googlemaps tutorial
Googlemaps tutorialGooglemaps tutorial
Googlemaps tutorial
 
OpenXR + XR Interaction Toolkit使ったHoloLensコンテンツ開発検証 ~ (私が)完全に理解できたらちゃんと作れて、いろ...
OpenXR + XR Interaction Toolkit使ったHoloLensコンテンツ開発検証 ~ (私が)完全に理解できたらちゃんと作れて、いろ...OpenXR + XR Interaction Toolkit使ったHoloLensコンテンツ開発検証 ~ (私が)完全に理解できたらちゃんと作れて、いろ...
OpenXR + XR Interaction Toolkit使ったHoloLensコンテンツ開発検証 ~ (私が)完全に理解できたらちゃんと作れて、いろ...
 
PUN2 × OculusQuest でハンドトラッキング同期実装(プロジェクト公開しました)
PUN2 × OculusQuest でハンドトラッキング同期実装(プロジェクト公開しました)PUN2 × OculusQuest でハンドトラッキング同期実装(プロジェクト公開しました)
PUN2 × OculusQuest でハンドトラッキング同期実装(プロジェクト公開しました)
 

Mehr von Takashi Yoshinaga

Mehr von Takashi Yoshinaga (16)

iPad LiDARで エンジニアカフェを3Dスキャン
iPad LiDARでエンジニアカフェを3DスキャンiPad LiDARでエンジニアカフェを3Dスキャン
iPad LiDARで エンジニアカフェを3Dスキャン
 
Web技術ではじめようAR/VRアプリ開発
Web技術ではじめようAR/VRアプリ開発Web技術ではじめようAR/VRアプリ開発
Web技術ではじめようAR/VRアプリ開発
 
FUKUOKA Engineers Day 2021 発表資料:AR Fukuoka & HoloBox紹介
FUKUOKA Engineers Day 2021 発表資料:AR Fukuoka & HoloBox紹介FUKUOKA Engineers Day 2021 発表資料:AR Fukuoka & HoloBox紹介
FUKUOKA Engineers Day 2021 発表資料:AR Fukuoka & HoloBox紹介
 
Voxon Photonics VX1 で遊んでみた
Voxon Photonics VX1で遊んでみたVoxon Photonics VX1で遊んでみた
Voxon Photonics VX1 で遊んでみた
 
コロナ禍中のコミュニティ活動
コロナ禍中のコミュニティ活動コロナ禍中のコミュニティ活動
コロナ禍中のコミュニティ活動
 
Project HoloBox
Project HoloBoxProject HoloBox
Project HoloBox
 
AR Fukuoka紹介2020
AR Fukuoka紹介2020AR Fukuoka紹介2020
AR Fukuoka紹介2020
 
iPad LiDARで作ってみた in AR Fukuoka 忘年会2020
iPad LiDARで作ってみた in AR Fukuoka 忘年会2020iPad LiDARで作ってみた in AR Fukuoka 忘年会2020
iPad LiDARで作ってみた in AR Fukuoka 忘年会2020
 
MRTKで始めるAR開発 (HoloLens 1 and 2, ARCore, ARkit)
MRTKで始めるAR開発 (HoloLens 1 and 2, ARCore, ARkit)MRTKで始めるAR開発 (HoloLens 1 and 2, ARCore, ARkit)
MRTKで始めるAR開発 (HoloLens 1 and 2, ARCore, ARkit)
 
OSC2020 Fukuoka: インストールいらず、WebAR入門
OSC2020 Fukuoka: インストールいらず、WebAR入門OSC2020 Fukuoka: インストールいらず、WebAR入門
OSC2020 Fukuoka: インストールいらず、WebAR入門
 
AI x WebAR MediaPipeの顔認識を使ってみよう! in 織りなすラボ
AI x WebAR MediaPipeの顔認識を使ってみよう! in 織りなすラボAI x WebAR MediaPipeの顔認識を使ってみよう! in 織りなすラボ
AI x WebAR MediaPipeの顔認識を使ってみよう! in 織りなすラボ
 
Spatial Copy & Paste @HoloLensゆるっとLT会
Spatial Copy & Paste @HoloLensゆるっとLT会Spatial Copy & Paste @HoloLensゆるっとLT会
Spatial Copy & Paste @HoloLensゆるっとLT会
 
AI x WebAR! MediaPipeの顔認識を使ってみよう!
AI x WebAR! MediaPipeの顔認識を使ってみよう!AI x WebAR! MediaPipeの顔認識を使ってみよう!
AI x WebAR! MediaPipeの顔認識を使ってみよう!
 
[Netlify版] 0から始めようWebAR/VR入門ハンズオン with 織りなすラボ
[Netlify版] 0から始めようWebAR/VR入門ハンズオン with 織りなすラボ[Netlify版] 0から始めようWebAR/VR入門ハンズオン with 織りなすラボ
[Netlify版] 0から始めようWebAR/VR入門ハンズオン with 織りなすラボ
 
[Glitch版] 0から始めようWebAR/VR入門ハンズオン with 織りなすラボ
[Glitch版] 0から始めようWebAR/VR入門ハンズオン with 織りなすラボ[Glitch版] 0から始めようWebAR/VR入門ハンズオン with 織りなすラボ
[Glitch版] 0から始めようWebAR/VR入門ハンズオン with 織りなすラボ
 
0から始めようWebAR/VR入門ハンズオン
0から始めようWebAR/VR入門ハンズオン0から始めようWebAR/VR入門ハンズオン
0から始めようWebAR/VR入門ハンズオン
 

Kürzlich hochgeladen

Kürzlich hochgeladen (12)

新人研修 後半 2024/04/26の勉強会で発表されたものです。
新人研修 後半        2024/04/26の勉強会で発表されたものです。新人研修 後半        2024/04/26の勉強会で発表されたものです。
新人研修 後半 2024/04/26の勉強会で発表されたものです。
 
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
 
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
 
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
 
Utilizing Ballerina for Cloud Native Integrations
Utilizing Ballerina for Cloud Native IntegrationsUtilizing Ballerina for Cloud Native Integrations
Utilizing Ballerina for Cloud Native Integrations
 
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
 
LoRaWANスマート距離検出センサー DS20L カタログ LiDARデバイス
LoRaWANスマート距離検出センサー  DS20L  カタログ  LiDARデバイスLoRaWANスマート距離検出センサー  DS20L  カタログ  LiDARデバイス
LoRaWANスマート距離検出センサー DS20L カタログ LiDARデバイス
 
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
 
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
 
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
 
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアルLoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
 
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
 

A-Frameで始めるWebXRとハンドトラッキング (HoloLens2/Oculus Quest対応)