プログラミングとイラストレーション » マウスダウン、イベントタッチでオブジェクトを選択|WebGL|three.js
プログラミングとイラストレーション > HTML5 > マウスダウン、イベントタッチでオブジェクトを選択|WebGL|three.js

マウスダウン、イベントタッチでオブジェクトを選択|WebGL|three.js

マウスダウン、イベントタッチでオブジェクトを選択|WebGL|three.js

マウスダウン、イベントタッチでオブジェクトを選択|WebGL|three.js(HTML5, JavaScript, CSS3) : デモ

three.jsのダウンロード:threejs.org

1.HTML

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
<meta name="apple-mobile-web-app-capable" content="yes"/>
<title>マウスイベント</title>
<script src="build/devicecheck.js"></script>
<script src="build/three.min.js"></script>
<script>


window.addEventListener("load", function()
{
	threestart();
});

function threestart()
{	
	var renderer,
	scene,
	camera,
	axis,
	cube,
	raycaster,
	rayReceiveObjects = [],
	mouse,
	vector = new THREE.Vector3(),
	buttonStart = null,
	buttonMove = null,
	buttonEnd = null;
		
	 if(Sandbox.prototype.g_mobiledevice === true)
	{
		buttonStart = 'touchstart';
		buttonMove = 'touchmove';
		buttonEnd = 'touchend';
	}
	else //Sandbox.prototype.g_mobiledeviceがtrueでないなら、パーソナルコンピュータ用にマウスイベントに変更します
	{
		buttonStart = 'mousedown';
		buttonMove = 'mousemove';
		buttonEnd = 'mouseup';
	}
	
	document.getElementById('canvas-frame').addEventListener('touchstart', function() 
    {
        event.preventDefault();
    });
    document.getElementById('canvas-frame').addEventListener('touchmove', function() 
    {
        event.preventDefault();
    });
    document.getElementById('canvas-frame').addEventListener('touchend', function() 
    {
        event.preventDefault();
    });
		
	raycaster = new THREE.Raycaster();
	mouse = new THREE.Vector2();
	
	initThree();
	initObject();
	initEvent();
	initCamera();
	draw();
	
	function initThree()
	{
		canvasFrame = document.getElementById("canvas-frame");
		renderer = new THREE.WebGLRenderer();
		renderer.setSize(	window.innerWidth, window.innerHeight);
		canvasFrame.appendChild(renderer.domElement);
		renderer.setClearColor(0x000000,1.0);
		scene = new THREE.Scene();
	}
	
	function initCamera()
	{
		camera = new THREE.PerspectiveCamera(45,window.innerWidth/window.innerHeight,1,10000);
		camera.aspect = window.innerWidth / window.innerHeight;
		camera.position.set(50,50,100);
		camera.up.set(0,0,1);
		camera.lookAt({x:0,y:0,z:0});	
	}
	
	function initObject()
	{
		var geometry = new THREE.BoxGeometry(50,50,50);
		var material = new THREE.MeshNormalMaterial();
		cube = new THREE.Mesh(	geometry, material);
		cube.name = "box1";
		cube.position.set(0,0,0);
		scene.add(cube); //
		rayReceiveObjects[0]=cube;
		
	}
	
	function initEvent()
	{
		document.addEventListener( buttonEnd, onDocumentMouseDown, false );
		function onDocumentMouseDown(e)
		{
			e.preventDefault();
			mouse.x = ( (e.pageX-e.target.offsetParent.offsetLeft) / window.innerWidth ) * 2 - 1;
			mouse.y = - ( (e.pageY-e.target.offsetParent.offsetTop) / window.innerHeight ) * 2 + 1;
			var vector = new THREE.Vector3( mouse.x, mouse.y, 0.5 ).unproject( camera );
			raycaster.ray.set( camera.position, vector.sub( camera.position ).normalize() );
	
			var intersects = raycaster.intersectObjects( rayReceiveObjects );
			
			if ( intersects.length > 0 ) 
			{
				alert(intersects[0].object.name + "が選択された");
				console.log("箱の名前:" + intersects[0].object.name);
				console.log("カメラ位置座標からの距離:" + intersects[0].distance);
				console.log("光線との交差座標("+intersects[0].point.x+", "+ intersects[0].point.y+", "+intersects[0].point.z+")");
			}
		}
	}
	
	function draw()
	{
		renderer.clear();
		renderer.render(scene,camera);
	}
}


</script>
<style>
*{padding:0; margin:0}
div#canvas-frame
{
	width:512px;
	height:512px;
}
</style>
</head>
<body>
<div id="canvas-frame"></div>
</body>
</html>

2.JavaScript

devicecheck.js

function Sandbox()
{
}
	
Sandbox.prototype = 
{
	/*name : "My App",
	version : "1.0",
	getName : function()
	{
		return this.name;
	}*/
};

Sandbox.prototype.g_mobiledevice = false;
Sandbox.prototype.g_browsername = "unknown";
Sandbox.prototype.g_browserver = -1;

if(checkUserAgent() == false)
{
	window.alert('このブラウザは対象外です');
}

function checkUserAgent()
{
	var ua = navigator.userAgent;

	//iPhoneか?	
	var mstr = ua.match(/iPhone OS \d+/);
	if(mstr != null){
		var vstr = mstr[0].match(/\d+/);
		if(parseInt(vstr[0]) >= 3) 
		{
			Sandbox.prototype.g_mobiledevice = true;
			Sandbox.prototype.g_browsername = 'iPhone';
			//alert('major-version ' + vstr);
			return true;
		}
	}
	//iPadか?
	if(ua.indexOf('iPad') > -1)
	{
		mstr = ua.match(/CPU OS \d+/);
		if(mstr != null)
		{
			var vstr = mstr[0].match(/\d+/);
			if(parseInt(vstr[0]) >= 3) {
				Sandbox.prototype.g_mobiledevice = true;
				Sandbox.prototype.g_browsername = 'iPad';
				//alert('major-version ' + vstr);
				return true;
			}		
		}		
	}	
	//Androidか?	
	var mstr = ua.match(/Android \d+\.\d+/);
	if(mstr != null)
	{
		Sandbox.prototype.g_browsername = 'Android';
		var vstr = mstr[0].match(/\d+\.\d+/);
		Sandbox.prototype.g_browserver = parseFloat(vstr[0]);
		Sandbox.prototype.g_mobiledevice = true;
		if(Sandbox.prototype.g_browserver > 2.1) 
		{
			//alert('version ' + vstr);
			return true;
		}
	}
	//Chromeか?
	mstr = ua.match(/Chrome\/\d+/);
	if(mstr != null)
	{
		Sandbox.prototype.g_browsername = 'Chrome';
		var vstr = mstr[0].match(/\d+/);
		Sandbox.prototype.g_browserver = parseInt(vstr[0]);
		if(Sandbox.prototype.g_browserver >= 9) 
		{
			//alert('major-version ' + vstr);
			
			return true;
		}		
	}
	//Safariか?
	if(ua.indexOf('Safari') > -1)
	{
		mstr = ua.match(/Version\/\d+/);
		if(mstr != null){
			var vstr = mstr[0].match(/\d+/);
			if(parseInt(vstr[0]) >= 5) 
			{
				Sandbox.prototype.g_browsername = 'Safari';
				//alert('major-version ' + vstr);
				return true;
			}		
		}		
	}
	//Internet Explorerか?
	mstr = ua.match(/MSIE \d+/);
	if(mstr != null)
	{
		var vstr = mstr[0].match(/\d+/);
		if(parseInt(vstr[0]) >= 9) 
		{
			Sandbox.prototype.g_browsername = 'MSIE';
			//alert('major-version ' + vstr);
			return true;
		}		
	}
	//Firefoxか?
	mstr = ua.match(/Firefox\/\d+/);
	if(mstr != null){
		var vstr = mstr[0].match(/\d+/);
		if(parseInt(vstr[0]) >= 4) 
		{
			Sandbox.prototype.g_browsername = 'Firefox';
			//alert('major-version ' + vstr);
			return true;
		}		
	}
	//Operaか?
	if(ua.indexOf('Opera') > -1)
	{
		mstr = ua.match(/Version\/\d+/);
		if(mstr != null){
			var vstr = mstr[0].match(/\d+/);
			if(parseInt(vstr[0]) >= 11) 
			{
				Sandbox.prototype.g_browsername = 'Opera';
				//alert('major-version ' + vstr);
				return true;
			}		
		}		
	}
	
	return false;
}

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

コメントフィード

トラックバック URL : http://www.htmlcode.jp/%e3%83%9e%e3%82%a6%e3%82%b9%e3%83%80%e3%82%a6%e3%83%b3%e3%81%a7%e3%82%aa%e3%83%96%e3%82%b8%e3%82%a7%e3%82%af%e3%83%88%e3%82%92%e9%81%b8%e6%8a%9e%ef%bd%9cwebgl%ef%bd%9cthree-js/trackback/