123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207 |
- {
- "metadata": {
- "type": "App"
- },
- "project": {
- "shadows": true,
- "vr": false
- },
- "camera": {
- "metadata": {
- "version": 4.4,
- "type": "Object",
- "generator": "Object3D.toJSON"
- },
- "object": {
- "uuid": "E41E9F54-8B31-4D1F-8D09-AF5E802E9A22",
- "type": "PerspectiveCamera",
- "name": "Camera",
- "matrix": [0.9392361044883728,-2.8092810300250903e-9,-0.3432718515396118,0,-0.14778217673301697,0.902585506439209,-0.404351145029068,0,0.3098321855068207,0.43051064014434814,0.847740888595581,0,142.32125854492188,202.75485229492188,389.40936279296875,1],
- "fov": 50,
- "aspect": 1.536388140161725,
- "near": 0.1,
- "far": 100000
- }
- },
- "scene": {
- "metadata": {
- "version": 4.4,
- "type": "Object",
- "generator": "Object3D.toJSON"
- },
- "geometries": [
- {
- "uuid": "8F05A1F2-3877-478B-8DFC-F572AC61AB3A",
- "type": "PlaneGeometry",
- "width": 300,
- "height": 400,
- "widthSegments": 1,
- "heightSegments": 1
- },
- {
- "uuid": "EEDF0A9A-D174-44E4-9C2F-A2F5BB8BE7F5",
- "type": "CylinderGeometry",
- "radiusTop": 5,
- "radiusBottom": 5,
- "height": 20,
- "radialSegments": 32,
- "heightSegments": 1,
- "openEnded": false
- },
- {
- "uuid": "7149652B-DBD7-4CB7-A600-27A9AC005C95",
- "type": "BoxGeometry",
- "width": 20,
- "height": 10,
- "depth": 10,
- "widthSegments": 1,
- "heightSegments": 1,
- "depthSegments": 1
- },
- {
- "uuid": "CABCC711-1331-4D4C-9FF6-409299F10C68",
- "type": "SphereGeometry",
- "radius": 5,
- "widthSegments": 32,
- "heightSegments": 16,
- "phiStart": 0,
- "phiLength": 6.28,
- "thetaStart": 0,
- "thetaLength": 3.14
- },
- {
- "uuid": "EFBF641D-F092-462E-B7FB-0BFAD1591EFC",
- "type": "BoxGeometry",
- "width": 20,
- "height": 10,
- "depth": 10,
- "widthSegments": 1,
- "heightSegments": 1,
- "depthSegments": 1
- }],
- "materials": [
- {
- "uuid": "2F69AF3A-DDF5-4BBA-87B5-80159F90DDBF",
- "type": "MeshPhongMaterial",
- "color": 86015,
- "emissive": 0,
- "specular": 1118481,
- "shininess": 30
- },
- {
- "uuid": "3B9DE64D-E1C8-4C24-9F73-3A9E10E3E655",
- "type": "MeshPhongMaterial",
- "color": 16777215,
- "emissive": 0,
- "specular": 1118481,
- "shininess": 30
- },
- {
- "uuid": "D98FC4D1-169E-420A-92EA-20E55009A46D",
- "type": "MeshBasicMaterial",
- "wireframe": true,
- "color": 63744
- },
- {
- "uuid": "043B208C-1F83-42C6-802C-E0E35621C27C",
- "type": "MeshPhongMaterial",
- "color": 16777215,
- "emissive": 0,
- "specular": 1118481,
- "shininess": 30
- },
- {
- "uuid": "40EC9BDA-91C0-4671-937A-2BCB6DA7EEBB",
- "type": "MeshBasicMaterial",
- "wireframe": true,
- "color": 63744
- }],
- "object": {
- "uuid": "31517222-A9A7-4EAF-B5F6-60751C0BABA3",
- "type": "Scene",
- "name": "Scene",
- "matrix": [1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],
- "children": [
- {
- "uuid": "EBBB1E63-6318-4752-AE2E-440A4E0B3EF3",
- "type": "Mesh",
- "name": "Ground",
- "matrix": [1,0,0,0,0,0.0007960614748299122,-0.9999997019767761,0,0,0.9999997019767761,0.0007960614748299122,0,0,0,0,1],
- "geometry": "8F05A1F2-3877-478B-8DFC-F572AC61AB3A",
- "material": "2F69AF3A-DDF5-4BBA-87B5-80159F90DDBF"
- },
- {
- "uuid": "6EE2E764-43E0-48E0-85F2-E0C8823C20DC",
- "type": "DirectionalLight",
- "name": "DirectionalLight 1",
- "matrix": [1,0,0,0,0,1,0,0,0,0,1,0,100,200,150,1],
- "color": 16777215,
- "intensity": 1
- },
- {
- "uuid": "38219749-1E67-45F2-AB15-E64BA0940CAD",
- "type": "Mesh",
- "name": "Brick",
- "matrix": [1,0,0,0,0,1,0,0,0,0,1,0,0,5,0,1],
- "children": [
- {
- "uuid": "711A5955-8F17-4A8B-991A-7604D27E6FA0",
- "type": "Mesh",
- "name": "Cylinder",
- "matrix": [0.0007962009985931218,0.0007962677045725286,0.9999995231628418,0,-0.9999997615814209,3.462185702574061e-7,0.0007962677045725286,0,2.210134084634774e-7,-0.9999997615814209,0.0007962008821777999,0,0,0,0,1],
- "geometry": "EEDF0A9A-D174-44E4-9C2F-A2F5BB8BE7F5",
- "material": "3B9DE64D-E1C8-4C24-9F73-3A9E10E3E655"
- }],
- "geometry": "7149652B-DBD7-4CB7-A600-27A9AC005C95",
- "material": "D98FC4D1-169E-420A-92EA-20E55009A46D"
- },
- {
- "uuid": "18FFA67C-F893-4E7A-8A76-8D996DEBE0C6",
- "type": "Mesh",
- "name": "Ball",
- "matrix": [1,0,0,0,0,1,0,0,0,0,1,0,0,5,35.54999923706055,1],
- "geometry": "CABCC711-1331-4D4C-9FF6-409299F10C68",
- "material": "043B208C-1F83-42C6-802C-E0E35621C27C"
- },
- {
- "uuid": "6D660D49-39B8-40C3-95F6-E4E007AA8D79",
- "type": "Mesh",
- "name": "Paddle",
- "matrix": [2,0,0,0,0,1,0,0,0,0,1,0,0,5,159.5399932861328,1],
- "children": [
- {
- "uuid": "4F5F884C-9E1B-45E6-8F1E-4D538A46D8CB",
- "type": "Mesh",
- "name": "Cylinder",
- "matrix": [0.0007962009985931218,0.0007962677045725286,0.9999995231628418,0,-0.9999997615814209,3.462185702574061e-7,0.0007962677045725286,0,2.210134084634774e-7,-0.9999997615814209,0.0007962008821777999,0,0,0,0,1],
- "geometry": "EEDF0A9A-D174-44E4-9C2F-A2F5BB8BE7F5",
- "material": "3B9DE64D-E1C8-4C24-9F73-3A9E10E3E655"
- }],
- "geometry": "EFBF641D-F092-462E-B7FB-0BFAD1591EFC",
- "material": "40EC9BDA-91C0-4671-937A-2BCB6DA7EEBB"
- },
- {
- "uuid": "B0BEAF69-8B5D-4D87-ADCA-FDE83A02762D",
- "type": "PointLight",
- "name": "PointLight 2",
- "matrix": [1,0,0,0,0,1,0,0,0,0,1,0,-116.54356384277344,69.48957061767578,-206.8248291015625,1],
- "color": 16777215,
- "intensity": 1,
- "distance": 0,
- "decay": 1
- }]
- }
- },
- "scripts": {
- "6D660D49-39B8-40C3-95F6-E4E007AA8D79": [
- {
- "name": "User",
- "source": "function mousemove( event ) {\n\n\tthis.position.x = ( event.clientX / player.width ) * 300 - 150;\n\n}\n\n// function update( event ) {}"
- }],
- "31517222-A9A7-4EAF-B5F6-60751C0BABA3": [
- {
- "name": "Game Logic",
- "source": "var ball = this.getObjectByName( 'Ball' );\n\nvar direction = new THREE.Vector3();\ndirection.x = Math.random() - 0.5;\ndirection.z = - 0.5;\ndirection.normalize();\n\nvar speed = new THREE.Vector3();\n\n//\n\nvar group = new THREE.Group();\nthis.add( group );\n\nvar paddle = this.getObjectByName( 'Paddle' );\npaddle.material.visible = false;\ngroup.add( paddle );\n\nvar brick = this.getObjectByName( 'Brick' );\n\nfor ( var j = 0; j < 8; j ++ ) {\n\n\tvar material = new THREE.MeshPhongMaterial( { color: Math.random() * 0xffffff } );\n\n\tfor ( var i = 0; i < 12; i ++ ) {\n\t\t\n\t\tvar object = brick.clone();\n\t\tobject.position.x = i * 22 - 120;\n\t\tobject.position.z = j * 14 - 120;\n\t\tgroup.add( object );\n\n\t\tvar cylinder = object.getObjectByName( 'Cylinder' );\n\t\tcylinder.material = material;\n\n\t}\n\t\n}\n\nbrick.visible = false;\nbrick.material.visible = false;\n\n//\n\nvar raycaster = new THREE.Raycaster();\n\nfunction update( event ) {\n\t\n\tif ( ball.position.x < - 150 || ball.position.x > 150 ) direction.x = - direction.x;\n\tif ( ball.position.z < - 200 || ball.position.z > 200 ) direction.z = - direction.z;\n\n\tball.position.x = Math.max( - 150, Math.min( 150, ball.position.x ) );\n\tball.position.z = Math.max( - 200, Math.min( 200, ball.position.z ) );\n\t\n\tball.position.add( speed.copy( direction ).multiplyScalar( event.delta / 4 ) );\n\t\n\traycaster.set( ball.position, direction );\n\t\n\tvar intersections = raycaster.intersectObjects( group.children );\n\t\n\tif ( intersections.length > 0 ) {\n\t\n\t\tvar intersection = intersections[ 0 ];\n\t\t\n\t\tif ( intersection.distance < 5 ) {\n\t\t\t\n\t\t\tif ( intersection.object !== paddle ) {\n\n\t\t\t\tgroup.remove( intersection.object );\n\t\t\t\t\n\t\t\t}\n\t\t\t\n\t\t\tdirection.reflect( intersection.face.normal );\n\t\t\t\n\t\t}\n\t\t\n\t}\n\n}"
- }]
- }
- }
|