A-Frame: https://aframe.io
AR.js: https://github.com/jeromeetienne/AR.js
謝辞:ここで紹介するソフトウェアの作者に感謝します.
参考Webページ
https://medium.com/@akashkuttappa/using-3d-models-with-ar-js-and-a-frame-84d462efe498
【サイト内の関連ページ】
【関連する外部ページ】
Python の公式ページ: https://www.python.org/
ここで行うこと:hiro マーカーにより,箱(Box)を表示する Web ページを作る.Web サーバを稼働させ,Web ブラウザでこの Web ページが動くようにする.
名前は何でもよいが,日本語を含まないものがよい.
次のページに記載のサンプルプログラムのうち,マーカーベースの AR のものを使う.(タイプミスと思われる部分を修正,a-box を使うように変更,URLを最新にものに修正など).
https://ar-js-org.github.io/AR.js-Docs/#getting-started
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="initial-scale=1.0,user-scalable=no,maximum-scale=1,width=device-width"> <title>marker AR</title> <script src="https://aframe.io/releases/1.0.4/aframe.min.js"></script> <!-- we import arjs version without NFT but with marker + location based support --> <script src="https://raw.githack.com/AR-js-org/AR.js/master/aframe/build/aframe-ar.js"></script> </head> <body style="margin:0px; overflow:hidden;"> <a-scene embedded arjs> <a-marker preset="hiro"> <a-box position="0 0.5 0" wireframe="true"></a-box> </a-marker> <a-entity camera></a-entity> </a-scene> </body> </html>
http://localhost/a.html
※ カメラの使用の許可についての表示が出た場合には許可する.
https://github.com/AR-js-org/AR.js/blob/master/data/images/hiro.png
カメラで,マーカー画像 hiro.pngを撮影すると,箱が現れるので確認する.
.obj 形式ファイル,.mtl 形式ファイルを準備する. できたファイルは次のとおりである.
ここでは,Blender を用いる.
Windows でのBlender のインストールは,別ページ »で説明している.
Blender の使い方については,別ページ »にまとめ
いま作成した作業用のフォルダ(ディレクトリ)に, b.html のようなファイル名で保存する.
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="initial-scale=1.0,user-scalable=no,maximum-scale=1,width=device-width"> <title>marker AR</title> <script src="https://aframe.io/releases/1.0.4/aframe.min.js"></script> <!-- we import arjs version without NFT but with marker + location based support --> <script src="https://raw.githack.com/AR-js-org/AR.js/master/aframe/build/aframe-ar.js"></script> </head> <body style="margin:0px; overflow:hidden;"> <a-scene embedded arjs> <a-marker preset="hiro"> <a-entity position="0 0 0" scale="0.5 0.5 0.5" obj-model="obj:url(./a.obj); mtl:url(./a.mtl)"> </a-entity> </a-marker> <a-entity camera></a-entity> </a-scene> </body> </html>
もし,Web サーバが稼働していなければ,次の手順で稼働させる.
http://localhost/b.html
https://github.com/AR-js-org/AR.js/blob/master/data/images/hiro.png
カメラで,マーカー画像 hiro.pngを撮影すると,3次元オブジェクトが現れるので確認する.
マーカーの場所,大きさ,傾きの応じて3次元オブジェクトが表示される.