jax 1.1.1 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +4 -0
- data/.rvmrc +2 -3
- data/.travis.yml +8 -22
- data/README.md +2 -2
- data/Rakefile +128 -96
- data/app/assets/javascripts/jax/controller-list.js.coffee +22 -0
- data/app/assets/javascripts/jax/dom-helpers.js.coffee +17 -0
- data/app/assets/javascripts/jax/jasmine_runner.js +177 -0
- data/app/assets/javascripts/jax/runtime.js +6 -0
- data/app/assets/javascripts/jax/shader_editor.js.coffee +33 -0
- data/app/assets/stylesheets/jax/controller-list.css +5 -0
- data/app/assets/stylesheets/jax/jasmine.css +16 -0
- data/app/assets/stylesheets/jax/nav.css +41 -0
- data/app/assets/stylesheets/jax/runtime.css +47 -0
- data/app/assets/stylesheets/jax/shader_editor.css +3 -0
- data/app/assets/stylesheets/jax/suite.css +82 -0
- data/app/controllers/jax/suite_controller.rb +48 -0
- data/app/views/jax/suite/jasmine.html.erb +38 -0
- data/app/views/jax/suite/run_webgl.html.erb +49 -0
- data/app/views/jax/suite/shader_editor.html.erb +24 -0
- data/app/views/layouts/jax.html.erb +40 -0
- data/bin/jax +8 -4
- data/config/routes.rb +2 -0
- data/config.ru +5 -0
- data/features/rails/resources.feature +45 -0
- data/features/rails/shaders.feature +13 -0
- data/features/rails/specs.feature +24 -0
- data/features/runtime.feature +15 -0
- data/features/step_definitions/environment_steps.rb +15 -0
- data/features/step_definitions/response_steps.rb +13 -0
- data/features/step_definitions/runtime.rb +11 -0
- data/features/step_definitions/web_steps.rb +223 -0
- data/features/support/env.rb +75 -0
- data/features/support/paths.rb +30 -0
- data/features/support/rails_environment.rb +3 -0
- data/features/support/selectors.rb +39 -0
- data/features/support/setup.rb +17 -0
- data/jax.gemspec +22 -16
- data/lib/assets/javascripts/jax/anim_frame.js +64 -0
- data/lib/assets/javascripts/jax/application.js +16 -0
- data/lib/assets/javascripts/jax/builtin/all.js +21 -0
- data/lib/assets/javascripts/jax/builtin/meshes/cube.js +83 -0
- data/lib/assets/javascripts/jax/builtin/meshes/plane.js +67 -0
- data/lib/assets/javascripts/jax/builtin/meshes/quad.js +89 -0
- data/lib/assets/javascripts/jax/builtin/meshes/sphere.js +65 -0
- data/lib/assets/javascripts/jax/builtin/meshes/teapot.js +48 -0
- data/lib/assets/javascripts/jax/builtin/meshes/torus.js +64 -0
- data/lib/assets/javascripts/jax/compatibility.js +312 -0
- data/lib/assets/javascripts/jax/context.js +741 -0
- data/lib/assets/javascripts/jax/core/base.js +69 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/mat3.js +20 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/mat4.js +10 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/quat4.js +148 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec2.js +25 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec3.js +86 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec4.js +28 -0
- data/lib/assets/javascripts/jax/core/helper.js +44 -0
- data/lib/assets/javascripts/jax/core/math.js +61 -0
- data/lib/assets/javascripts/jax/core/matrix_stack.js +310 -0
- data/lib/assets/javascripts/jax/core/util.js +271 -0
- data/lib/assets/javascripts/jax/core.js +43 -0
- data/lib/assets/javascripts/jax/events.js +304 -0
- data/lib/assets/javascripts/jax/geometry/line.js +185 -0
- data/lib/assets/javascripts/jax/geometry/plane.js +371 -0
- data/lib/assets/javascripts/jax/geometry/triangle/inliner.rb +94 -0
- data/lib/assets/javascripts/jax/geometry/triangle/slow_tri_tri_intersect.js +20 -0
- data/lib/assets/javascripts/jax/geometry/triangle/tri_tri_intersect.js +281 -0
- data/lib/assets/javascripts/jax/geometry/triangle/tri_tri_intersect_optimized.js +564 -0
- data/lib/assets/javascripts/jax/geometry/triangle.js +311 -0
- data/lib/assets/javascripts/jax/geometry.js +14 -0
- data/lib/assets/javascripts/jax/mvc/controller.js +188 -0
- data/lib/assets/javascripts/jax/mvc/model.js +302 -0
- data/lib/assets/javascripts/jax/mvc/route_set.js +148 -0
- data/lib/assets/javascripts/jax/mvc/view.js +43 -0
- data/lib/assets/javascripts/jax/mvc/view_manager.js +65 -0
- data/lib/assets/javascripts/jax/noise.js +251 -0
- data/lib/assets/javascripts/jax/prototype/class.js +81 -0
- data/lib/assets/javascripts/jax/prototype/core.js +112 -0
- data/lib/assets/javascripts/jax/prototype/extensions.js +142 -0
- data/lib/assets/javascripts/jax/vendor/ejs.js +1 -0
- data/lib/assets/javascripts/jax/vendor/glMatrix.js +7 -0
- data/lib/assets/javascripts/jax/webgl/camera.js +697 -0
- data/lib/assets/javascripts/jax/webgl/cleanup.js +1 -0
- data/lib/assets/javascripts/jax/webgl/core/buffer.js +292 -0
- data/lib/assets/javascripts/jax/webgl/core/data_region.js +184 -0
- data/lib/assets/javascripts/jax/webgl/core/data_segment.js +255 -0
- data/lib/assets/javascripts/jax/webgl/core/events.js +99 -0
- data/lib/assets/javascripts/jax/webgl/core/framebuffer.js +316 -0
- data/lib/assets/javascripts/jax/webgl/core.js +6 -0
- data/lib/assets/javascripts/jax/webgl/material.js +381 -0
- data/lib/assets/javascripts/jax/webgl/mesh/normals.js +37 -0
- data/lib/assets/javascripts/jax/webgl/mesh/support.js +104 -0
- data/lib/assets/javascripts/jax/webgl/mesh/tangent_space.js +111 -0
- data/lib/assets/javascripts/jax/webgl/mesh.js +440 -0
- data/lib/assets/javascripts/jax/webgl/scene/frustum.js +422 -0
- data/lib/assets/javascripts/jax/webgl/scene/light_manager.js +141 -0
- data/lib/assets/javascripts/jax/webgl/scene/light_source.js +300 -0
- data/lib/assets/javascripts/jax/webgl/scene.js +16 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator/attribute.js +53 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator/uniform.js +71 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator.js +13 -0
- data/lib/assets/javascripts/jax/webgl/shader/manifest.js +70 -0
- data/lib/assets/javascripts/jax/webgl/shader/program.js +138 -0
- data/lib/assets/javascripts/jax/webgl/shader.js +299 -0
- data/lib/assets/javascripts/jax/webgl/shader_chain.js +267 -0
- data/lib/assets/javascripts/jax/webgl/texture.js +506 -0
- data/lib/assets/javascripts/jax/webgl/world.js +279 -0
- data/lib/assets/javascripts/jax/webgl.js +109 -0
- data/lib/assets/javascripts/jax.js +136 -0
- data/{builtin/app/shaders/basic/common.ejs → lib/assets/javascripts/shaders/basic/common.glsl} +0 -0
- data/{builtin/app/shaders/basic/fragment.ejs → lib/assets/javascripts/shaders/basic/fragment.glsl} +0 -0
- data/{builtin/app/shaders/basic/vertex.ejs → lib/assets/javascripts/shaders/basic/vertex.glsl} +1 -1
- data/{builtin/app/shaders/depthmap/common.ejs → lib/assets/javascripts/shaders/depthmap/common.glsl} +0 -0
- data/{builtin/app/shaders/depthmap/fragment.ejs → lib/assets/javascripts/shaders/depthmap/fragment.glsl} +1 -1
- data/{builtin/app → lib/assets/javascripts}/shaders/depthmap/material.js +0 -0
- data/{builtin/app/shaders/depthmap/vertex.ejs → lib/assets/javascripts/shaders/depthmap/vertex.glsl} +0 -0
- data/{builtin/app/shaders/fog/common.ejs → lib/assets/javascripts/shaders/fog/common.glsl} +0 -0
- data/{builtin/app/shaders/fog/fragment.ejs → lib/assets/javascripts/shaders/fog/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/fog/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/fog/material.js +6 -8
- data/{builtin/app/shaders/fog/vertex.ejs → lib/assets/javascripts/shaders/fog/vertex.glsl} +0 -0
- data/{builtin/app/shaders/functions/depth_map.ejs → lib/assets/javascripts/shaders/functions/depth_map.glsl} +0 -0
- data/{builtin/app/shaders/functions/lights.ejs → lib/assets/javascripts/shaders/functions/lights.glsl} +0 -0
- data/{builtin/app/shaders/functions/noise.ejs → lib/assets/javascripts/shaders/functions/noise.glsl} +0 -0
- data/lib/assets/javascripts/shaders/lighting/common.glsl +5 -0
- data/{builtin/app/shaders/lighting/fragment.ejs → lib/assets/javascripts/shaders/lighting/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/lighting/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/lighting/material.js +2 -4
- data/{builtin/app/shaders/lighting/vertex.ejs → lib/assets/javascripts/shaders/lighting/vertex.glsl} +0 -0
- data/{builtin/app/shaders/normal_map/common.ejs → lib/assets/javascripts/shaders/normal_map/common.glsl} +1 -1
- data/{builtin/app/shaders/normal_map/fragment.ejs → lib/assets/javascripts/shaders/normal_map/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/normal_map/manifest.yml +0 -0
- data/lib/assets/javascripts/shaders/normal_map/material.js +11 -0
- data/{builtin/app/shaders/normal_map/vertex.ejs → lib/assets/javascripts/shaders/normal_map/vertex.glsl} +0 -0
- data/{builtin/app/shaders/paraboloid/common.ejs → lib/assets/javascripts/shaders/paraboloid/common.glsl} +0 -0
- data/{builtin/app/shaders/paraboloid/fragment.ejs → lib/assets/javascripts/shaders/paraboloid/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/paraboloid/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/paraboloid/material.js +2 -4
- data/{builtin/app/shaders/paraboloid/vertex.ejs → lib/assets/javascripts/shaders/paraboloid/vertex.glsl} +0 -0
- data/{builtin/app/shaders/picking/common.ejs → lib/assets/javascripts/shaders/picking/common.glsl} +0 -0
- data/{builtin/app/shaders/picking/fragment.ejs → lib/assets/javascripts/shaders/picking/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/picking/material.js +2 -4
- data/{builtin/app/shaders/picking/vertex.ejs → lib/assets/javascripts/shaders/picking/vertex.glsl} +0 -0
- data/{builtin/app/shaders/shadow_map/common.ejs → lib/assets/javascripts/shaders/shadow_map/common.glsl} +2 -1
- data/{builtin/app/shaders/shadow_map/fragment.ejs → lib/assets/javascripts/shaders/shadow_map/fragment.glsl} +1 -1
- data/{builtin/app → lib/assets/javascripts}/shaders/shadow_map/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/shadow_map/material.js +4 -6
- data/{builtin/app/shaders/shadow_map/vertex.ejs → lib/assets/javascripts/shaders/shadow_map/vertex.glsl} +0 -0
- data/{builtin/app/shaders/texture/common.ejs → lib/assets/javascripts/shaders/texture/common.glsl} +0 -0
- data/{builtin/app/shaders/texture/fragment.ejs → lib/assets/javascripts/shaders/texture/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/texture/manifest.yml +0 -0
- data/lib/assets/javascripts/shaders/texture/material.js +17 -0
- data/{builtin/app/shaders/texture/vertex.ejs → lib/assets/javascripts/shaders/texture/vertex.glsl} +0 -0
- data/lib/generators/jax/all.rb +16 -0
- data/lib/generators/jax/application/application_generator.rb +48 -0
- data/lib/generators/jax/base/actions.rb +52 -0
- data/lib/generators/jax/base/coffee_generator.rb +30 -0
- data/lib/generators/jax/base/named_base.rb +17 -0
- data/lib/generators/jax/base/plugin_base.rb +108 -0
- data/lib/generators/jax/base/plugin_credentials.rb +99 -0
- data/lib/generators/jax/base/plugin_manifest.rb +75 -0
- data/lib/generators/jax/base/rails_base.rb +30 -0
- data/lib/generators/jax/base/source_root.rb +5 -0
- data/lib/generators/jax/controller/controller_generator.rb +37 -0
- data/lib/generators/jax/helper/helper_generator.rb +30 -0
- data/lib/generators/jax/install/install_generator.rb +27 -0
- data/lib/generators/jax/jax_generator.rb +13 -0
- data/lib/generators/jax/light/light_generator.rb +23 -0
- data/lib/{jax/generators → generators/jax}/material/USAGE +4 -8
- data/lib/generators/jax/material/material_generator.rb +112 -0
- data/lib/generators/jax/model/model_generator.rb +24 -0
- data/lib/generators/jax/plugin/plugin_generator.rb +72 -0
- data/lib/generators/jax/scaffold/scaffold_generator.rb +35 -0
- data/lib/generators/jax/shader/shader_generator.rb +38 -0
- data/lib/jax/commands/plugin_manager.rb +240 -0
- data/lib/jax/commands.rb +69 -0
- data/lib/jax/configuration.rb +64 -0
- data/lib/jax/directive_processor.rb +53 -0
- data/lib/jax/engine.rb +38 -54
- data/lib/jax/helper_methods.rb +3 -0
- data/lib/jax/rails/application.rb +34 -0
- data/lib/jax/resource_file.rb +29 -0
- data/lib/jax/script_loader.rb +68 -0
- data/lib/jax/server.rb +87 -0
- data/lib/jax/shader.rb +70 -172
- data/lib/jax/testing/rails_environment.rb +94 -0
- data/lib/jax/util/tar.rb +75 -0
- data/lib/jax/util.rb +3 -0
- data/lib/jax/version.rb +7 -8
- data/lib/jax.rb +23 -41
- data/spec/bin/jax_spec.rb +149 -0
- data/{lib/jax/generators/app/templates/app/models/.empty_directory → spec/fixtures/public/favicon.ico} +0 -0
- data/spec/fixtures/public/textures/brickwall.jpg +0 -0
- data/spec/fixtures/public/textures/jacks.jpg +0 -0
- data/spec/fixtures/public/textures/normal_map.jpg +0 -0
- data/spec/fixtures/public/textures/rock.png +0 -0
- data/spec/fixtures/public/textures/rock_normal.png +0 -0
- data/spec/fixtures/public/textures/rss.png +0 -0
- data/spec/generators/jax/application_generator_spec.rb +18 -0
- data/spec/generators/jax/controller_generator_spec.rb +102 -0
- data/spec/generators/jax/helper_generator_spec.rb +55 -0
- data/spec/generators/jax/install_generator_spec.rb +30 -0
- data/spec/generators/jax/jax_generator_spec.rb +21 -0
- data/spec/generators/jax/light_generator_spec.rb +27 -0
- data/spec/generators/jax/material_generator_spec.rb +62 -0
- data/spec/generators/jax/model_generator_spec.rb +72 -0
- data/spec/generators/jax/plugin_generator_spec.rb +143 -0
- data/spec/generators/jax/scaffold_generator_spec.rb +35 -0
- data/spec/generators/jax/shader_generator_spec.rb +37 -0
- data/spec/javascripts/helpers/jasmine_webgl_helper.js +13 -0
- data/{lib/jax/generators/app/templates/spec/javascripts/support/spec_helpers → spec/javascripts/helpers}/jax_spec_environment_helper.js +7 -2
- data/{lib/jax/generators/app/templates/spec/javascripts/support/spec_helpers → spec/javascripts/helpers}/jax_spec_helper.js +0 -0
- data/spec/javascripts/jax/builtin/meshes/cube_spec.js +10 -0
- data/spec/javascripts/jax/builtin/meshes/plane_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/quad_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/sphere_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/teapot_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/torus_spec.js +8 -0
- data/spec/javascripts/jax/compatibility_spec.js +46 -0
- data/spec/javascripts/jax/context_events_spec.js +212 -0
- data/spec/javascripts/jax/context_spec.js +305 -0
- data/spec/javascripts/jax/core/data_region_spec.js +118 -0
- data/spec/javascripts/jax/core/data_segment_spec.js +96 -0
- data/spec/javascripts/jax/core/delegation_spec.js +48 -0
- data/spec/javascripts/jax/core/events_spec.js +17 -0
- data/spec/javascripts/jax/core/glMatrix_extensions_spec.js +8 -0
- data/spec/javascripts/jax/core/helper_spec.js +61 -0
- data/spec/javascripts/jax/core/matrix_stack_spec.js +28 -0
- data/spec/javascripts/jax/core/utils_spec.js +275 -0
- data/spec/javascripts/jax/geometry/line_spec.js +20 -0
- data/spec/javascripts/jax/geometry/plane_spec.js +181 -0
- data/spec/javascripts/jax/geometry/triangle_spec.js +105 -0
- data/spec/javascripts/jax/mvc/controller_spec.js +156 -0
- data/spec/javascripts/jax/mvc/model_spec.js +93 -0
- data/spec/javascripts/jax/mvc/route_set_spec.js +49 -0
- data/spec/javascripts/jax/mvc/view_manager_spec.js +17 -0
- data/spec/javascripts/jax/noise_spec.js +50 -0
- data/spec/javascripts/jax/optimizations/material_limitations_spec.js +85 -0
- data/spec/javascripts/jax/optimizations/shaders/basic_spec.js +65 -0
- data/spec/javascripts/jax/prototype/extensions_spec.js +34 -0
- data/spec/javascripts/jax/webgl/camera_spec.js +237 -0
- data/spec/javascripts/jax/webgl/core/events_spec.js +47 -0
- data/spec/javascripts/jax/webgl/framebuffer_spec.js +44 -0
- data/spec/javascripts/jax/webgl/lighting_spec.js +108 -0
- data/spec/javascripts/jax/webgl/material_spec.js +117 -0
- data/spec/javascripts/jax/webgl/mesh_spec.js +228 -0
- data/spec/javascripts/jax/webgl/shader/manifest_spec.js +57 -0
- data/spec/javascripts/jax/webgl/shader_chain_spec.js +211 -0
- data/spec/javascripts/jax/webgl/shader_spec.js +276 -0
- data/spec/javascripts/jax/webgl/tangent_space_spec.js +142 -0
- data/spec/javascripts/jax/webgl/texture_spec.js +159 -0
- data/spec/javascripts/jax/webgl_spec.js +5 -0
- data/spec/javascripts/jax/world_spec.js +175 -0
- data/spec/javascripts/jax_spec.js +14 -0
- data/spec/javascripts/node/mocks/webgl.js +159 -0
- data/spec/javascripts/node_helper.js +51 -0
- data/spec/javascripts/shaders/core_materials_spec.js +38 -0
- data/spec/javascripts/shaders/fog_spec.js +15 -0
- data/spec/javascripts/shaders/lighting_spec.js +15 -0
- data/spec/javascripts/shaders/normal_map_spec.js +15 -0
- data/spec/javascripts/shaders/paraboloid_spec.js +33 -0
- data/spec/javascripts/shaders/preprocessor_spec.js +45 -0
- data/spec/javascripts/shaders/shadow_map_spec.js +15 -0
- data/spec/javascripts/shaders/texture_spec.js +37 -0
- data/spec/javascripts/suite/controller_select_spec.js.coffee +24 -0
- data/spec/lib/jax/commands/plugin_manager/credentials_spec.rb +56 -0
- data/spec/lib/jax/commands/plugin_manager/push_spec.rb +62 -0
- data/spec/lib/jax/commands/plugin_manager_spec.rb +204 -0
- data/spec/lib/jax/rails/application_spec.rb +23 -0
- data/spec/lib/jax/shader_spec.rb +67 -0
- data/spec/lib/jax/util/tar_spec.rb +26 -0
- data/spec/{test_helper.rb → spec_helper.rb} +37 -28
- data/spec/support/test_model_generator.rb +14 -0
- data/templates/app/Gemfile.tt +17 -0
- data/templates/app/Rakefile +4 -0
- data/templates/app/config/application.rb +16 -0
- data/{lib/jax/generators/app/templates → templates/app}/config/boot.rb +0 -0
- data/templates/app/config/environment.rb +5 -0
- data/templates/app/config/environments/production.rb +4 -0
- data/templates/app/config.ru +6 -0
- data/{lib/jax/generators/app/templates/app/resources → templates/app/public}/.empty_directory +0 -0
- data/templates/app/script/jax +8 -0
- data/{lib/jax/generators/app/templates/app/views → templates/app/spec}/.empty_directory +0 -0
- data/templates/application_controller.js.coffee.erb +3 -0
- data/templates/application_controller.js.erb +6 -0
- data/templates/application_helper.js.coffee.erb +3 -0
- data/templates/application_helper.js.erb +3 -0
- data/templates/controller.js.coffee.erb +9 -0
- data/templates/controller.js.erb +15 -0
- data/templates/controller_spec.js.coffee.erb +9 -0
- data/templates/controller_spec.js.erb +12 -0
- data/templates/helper.js.coffee.erb +2 -0
- data/templates/helper.js.erb +3 -0
- data/templates/helper_spec.js.coffee.erb +8 -0
- data/templates/helper_spec.js.erb +12 -0
- data/{lib/jax/generators/light_source/templates/light.yml.tt → templates/light_source.resource.erb} +3 -3
- data/{lib/jax/generators/material/templates/material.yml.tt → templates/material.resource.erb} +0 -9
- data/templates/model.js.coffee.erb +3 -0
- data/templates/model.js.erb +5 -0
- data/templates/model_defaults.resource.erb +5 -0
- data/templates/model_spec.js.coffee.erb +16 -0
- data/templates/model_spec.js.erb +18 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/controllers/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/helpers/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/models/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/resources/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/views/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/init.rb +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/install.rb +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/public → templates/new_plugin/spec}/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/uninstall.rb +0 -0
- data/{lib/jax/generators/shader/templates/common.ejs.tt → templates/shader_common.glsl.erb} +0 -0
- data/{lib/jax/generators/shader/templates/fragment.ejs.tt → templates/shader_fragment.glsl.erb} +0 -0
- data/{lib/jax/generators/shader/templates/manifest.yml.tt → templates/shader_manifest.yml.erb} +0 -0
- data/templates/shader_material.js.coffee.erb +22 -0
- data/{lib/jax/generators/shader/templates/material.js.tt → templates/shader_material.js.erb} +0 -0
- data/templates/shader_spec.js.coffee.erb +16 -0
- data/{lib/jax/generators/shader/templates/spec.js.tt → templates/shader_spec.js.erb} +1 -1
- data/{lib/jax/generators/shader/templates/vertex.ejs.tt → templates/shader_vertex.glsl.erb} +0 -0
- data/templates/view.js.coffee.erb +3 -0
- data/{lib/jax/generators/controller/templates/view.js.tt → templates/view.js.erb} +1 -1
- data/vendor/assets/javascripts/ejs.js +505 -0
- data/vendor/assets/javascripts/glMatrix.js +1772 -0
- data/vendor/assets/javascripts/jasmine.js +2476 -0
- data/vendor/assets/stylesheets/jasmine.css +166 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/alias.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/constant.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/constructor.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/description.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/information.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/instance_method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/instance_property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/method_deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/mixin.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/namespace.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/related_to.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/search-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/section-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/section.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/selected-section-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/subclass.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/superclass.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/utility.png +0 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/application.js +478 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/prototype.js +4874 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/tabs.js +506 -0
- data/vendor/pdoc_template/html/assets/stylesheets/jax.css +30 -0
- data/vendor/pdoc_template/html/assets/stylesheets/pdoc/api.css +681 -0
- data/vendor/pdoc_template/html/assets/stylesheets/pdoc/pygments.css +62 -0
- data/vendor/pdoc_template/html/helpers.rb +35 -0
- data/vendor/pdoc_template/html/index.erb +18 -0
- data/vendor/pdoc_template/html/item_index.js.erb +6 -0
- data/vendor/pdoc_template/html/layout.erb +67 -0
- data/vendor/pdoc_template/html/leaf.erb +22 -0
- data/vendor/pdoc_template/html/node.erb +30 -0
- data/vendor/pdoc_template/html/partials/class_relationships.erb +19 -0
- data/vendor/pdoc_template/html/partials/classes.erb +7 -0
- data/vendor/pdoc_template/html/partials/constructor.erb +5 -0
- data/vendor/pdoc_template/html/partials/description.erb +5 -0
- data/vendor/pdoc_template/html/partials/link_list.erb +1 -0
- data/vendor/pdoc_template/html/partials/method_signatures.erb +14 -0
- data/vendor/pdoc_template/html/partials/methodized_note.erb +9 -0
- data/vendor/pdoc_template/html/partials/mixins.erb +7 -0
- data/vendor/pdoc_template/html/partials/namespaces.erb +7 -0
- data/vendor/pdoc_template/html/partials/related_utilities.erb +5 -0
- data/vendor/pdoc_template/html/partials/relationships.erb +11 -0
- data/vendor/pdoc_template/html/partials/short_description_list.erb +7 -0
- data/vendor/pdoc_template/html/partials/title.erb +24 -0
- data/vendor/pdoc_template/html/section.erb +18 -0
- metadata +635 -332
- data/builtin/app/shaders/lighting/common.ejs +0 -5
- data/builtin/app/shaders/normal_map/material.js +0 -16
- data/builtin/app/shaders/texture/material.js +0 -18
- data/jax.gems +0 -1
- data/lib/jax/application/builtin/configurable.rb +0 -5
- data/lib/jax/application/builtin/configuration.rb +0 -5
- data/lib/jax/application/builtin.rb +0 -12
- data/lib/jax/application/configurable.rb +0 -19
- data/lib/jax/application/configuration.rb +0 -60
- data/lib/jax/application/railties.rb +0 -26
- data/lib/jax/application.rb +0 -149
- data/lib/jax/core_ext/kernel.rb +0 -7
- data/lib/jax/engine/configurable.rb +0 -19
- data/lib/jax/engine/configuration.rb +0 -49
- data/lib/jax/generators/app/app_generator.rb +0 -96
- data/lib/jax/generators/app/templates/Gemfile.tt +0 -3
- data/lib/jax/generators/app/templates/Rakefile +0 -6
- data/lib/jax/generators/app/templates/app/controllers/application_controller.js.tt +0 -5
- data/lib/jax/generators/app/templates/app/helpers/application_helper.js.tt +0 -3
- data/lib/jax/generators/app/templates/config/application.rb.tt +0 -6
- data/lib/jax/generators/app/templates/config/environment.rb.tt +0 -5
- data/lib/jax/generators/app/templates/config/routes.rb.tt +0 -5
- data/lib/jax/generators/app/templates/public/index.html.tt +0 -26
- data/lib/jax/generators/app/templates/public/javascripts/jax.js +0 -9462
- data/lib/jax/generators/app/templates/public/stylesheets/%file_name%.css.tt +0 -11
- data/lib/jax/generators/app/templates/public/webgl_not_supported.html +0 -26
- data/lib/jax/generators/app/templates/script/jax +0 -7
- data/lib/jax/generators/app/templates/spec/javascripts/controllers/application_controller_spec.js +0 -11
- data/lib/jax/generators/app/templates/spec/javascripts/helpers/application_helper_spec.js +0 -12
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine.yml +0 -91
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine_config.rb +0 -23
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine_runner.rb +0 -32
- data/lib/jax/generators/app/templates/spec/javascripts/support/spec_layout.html.erb +0 -104
- data/lib/jax/generators/app.rb +0 -18
- data/lib/jax/generators/commands.rb +0 -220
- data/lib/jax/generators/controller/USAGE +0 -9
- data/lib/jax/generators/controller/controller_generator.rb +0 -66
- data/lib/jax/generators/controller/templates/controller_source.js.tt +0 -16
- data/lib/jax/generators/controller/templates/controller_test.js.tt +0 -11
- data/lib/jax/generators/controller/templates/helper.js.tt +0 -3
- data/lib/jax/generators/controller/templates/helper_test.js.tt +0 -12
- data/lib/jax/generators/interactions.rb +0 -56
- data/lib/jax/generators/light_source/USAGE +0 -14
- data/lib/jax/generators/light_source/light_source_generator.rb +0 -46
- data/lib/jax/generators/material/material_generator.rb +0 -80
- data/lib/jax/generators/material/templates/append.yml.tt +0 -7
- data/lib/jax/generators/model/USAGE +0 -5
- data/lib/jax/generators/model/model_generator.rb +0 -40
- data/lib/jax/generators/model/templates/model.js.tt +0 -11
- data/lib/jax/generators/model/templates/test.js.tt +0 -11
- data/lib/jax/generators/packager/package_generator.rb +0 -32
- data/lib/jax/generators/plugin/USAGE +0 -4
- data/lib/jax/generators/plugin/all.rb +0 -113
- data/lib/jax/generators/plugin/credentials.rb +0 -108
- data/lib/jax/generators/plugin/plugin_generator.rb +0 -72
- data/lib/jax/generators/plugin/plugin_manager.rb +0 -254
- data/lib/jax/generators/plugin/templates/new_plugin/config/routes.rb +0 -3
- data/lib/jax/generators/plugin/templates/new_plugin/spec/.empty_directory +0 -0
- data/lib/jax/generators/script_jax_loader.rb +0 -49
- data/lib/jax/generators/shader/USAGE +0 -4
- data/lib/jax/generators/shader/shader_generator.rb +0 -70
- data/lib/jax/monkeypatch/jasmine/config.rb +0 -45
- data/lib/jax/monkeypatch/jasmine/server.rb +0 -50
- data/lib/jax/monkeypatch/jasmine.rb +0 -3
- data/lib/jax/packager/sprockets_template.rb +0 -77
- data/lib/jax/packager.rb +0 -59
- data/lib/jax/plugin/manifest.rb +0 -71
- data/lib/jax/plugin.rb +0 -49
- data/lib/jax/resource_compiler.rb +0 -60
- data/lib/jax/routes.rb +0 -62
- data/lib/jax/tasks/rake.rb +0 -38
- data/spec/benchmark.htm +0 -93
- data/spec/generators/app_generator_test.rb +0 -42
- data/spec/generators/controller_generator_test.rb +0 -47
- data/spec/generators/light_generator_test.rb +0 -37
- data/spec/generators/material_generator_test.rb +0 -22
- data/spec/generators/model_generator_test.rb +0 -26
- data/spec/generators/plugin_generator_test.rb +0 -114
- data/spec/generators/plugin_manager/push_test.rb +0 -59
- data/spec/generators/plugin_manager_test.rb +0 -192
- data/spec/generators/shader_generator_test.rb +0 -38
- data/spec/javascripts/support/jasmine.yml +0 -85
- data/spec/javascripts/support/jasmine_runner.rb +0 -32
- data/spec/lib/jax/application_test.rb +0 -18
- data/spec/lib/jax/generators/plugin/credentials_test.rb +0 -72
- data/spec/lib/jax/packager_test.rb +0 -87
- data/spec/lib/jax/plugin_test.rb +0 -27
- data/spec/lib/jax/reloading_test.rb +0 -23
- data/spec/lib/jax/routes_test.rb +0 -28
- data/spec/lib/jax/shader_test.rb +0 -29
- data/spec/lib/jax/tasks/jax_rake_test.rb +0 -85
- data/spec/support/bases/generator_test_case.rb +0 -108
- data/spec/support/bases/isolated_test_case.rb +0 -148
- data/spec/support/file_exist_matcher.rb +0 -23
- data/spec/support/spec_shell.rb +0 -110
- data/spec/test_app.rb +0 -3
@@ -0,0 +1,304 @@
|
|
1
|
+
/**
|
2
|
+
* Jax.EVENT_METHODS -> Object
|
3
|
+
* Contains event handling methods which are added to +Jax.Context+.
|
4
|
+
**/
|
5
|
+
Jax.EVENT_METHODS = (function() {
|
6
|
+
function getCumulativeOffset(element) {
|
7
|
+
var valueT = 0, valueL = 0;
|
8
|
+
do {
|
9
|
+
valueT += element.offsetTop || 0;
|
10
|
+
valueL += element.offsetLeft || 0;
|
11
|
+
valueT += Jax.Compatibility.offsetTop;
|
12
|
+
valueL += Jax.Compatibility.offsetLeft;
|
13
|
+
element = element.offsetParent;
|
14
|
+
} while (element);
|
15
|
+
|
16
|
+
var result = [valueL, valueT];
|
17
|
+
result.left = valueL;
|
18
|
+
result.top = valueT;
|
19
|
+
return result;
|
20
|
+
}
|
21
|
+
|
22
|
+
function buildKeyEvent(self, evt) {
|
23
|
+
var keyboard = self.keyboard;
|
24
|
+
evt = evt || window.event || {};
|
25
|
+
keyboard.last = evt;
|
26
|
+
return evt;
|
27
|
+
}
|
28
|
+
|
29
|
+
function fixEvent(event) {
|
30
|
+
// this borrowed from jQuery
|
31
|
+
// store a copy of the original event object
|
32
|
+
// and "clone" to set read-only properties
|
33
|
+
var originalEvent = event;
|
34
|
+
event = {type:originalEvent.type};
|
35
|
+
var props = "altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" ");
|
36
|
+
|
37
|
+
for ( var i = props.length, prop; i; ) {
|
38
|
+
prop = props[ --i ];
|
39
|
+
event[ prop ] = originalEvent[ prop ];
|
40
|
+
}
|
41
|
+
|
42
|
+
// Fix target property, if necessary
|
43
|
+
if ( !event.target ) {
|
44
|
+
// Fixes #1925 where srcElement might not be defined either
|
45
|
+
event.target = event.srcElement || document;
|
46
|
+
}
|
47
|
+
|
48
|
+
// check if target is a textnode (safari)
|
49
|
+
if ( event.target.nodeType === 3 ) {
|
50
|
+
event.target = event.target.parentNode;
|
51
|
+
}
|
52
|
+
|
53
|
+
// Add relatedTarget, if necessary
|
54
|
+
if ( !event.relatedTarget && event.fromElement ) {
|
55
|
+
event.relatedTarget = event.fromElement === event.target ? event.toElement : event.fromElement;
|
56
|
+
}
|
57
|
+
|
58
|
+
// Calculate pageX/Y if missing and clientX/Y available
|
59
|
+
if ( event.pageX == null && event.clientX != null ) {
|
60
|
+
var eventDocument = event.target.ownerDocument || document,
|
61
|
+
doc = eventDocument.documentElement,
|
62
|
+
body = eventDocument.body;
|
63
|
+
|
64
|
+
event.pageX = event.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc && doc.clientLeft || body && body.clientLeft || 0);
|
65
|
+
event.pageY = event.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc && doc.clientTop || body && body.clientTop || 0);
|
66
|
+
}
|
67
|
+
|
68
|
+
// Add which for key events
|
69
|
+
if ( event.which == null && (event.charCode != null || event.keyCode != null) ) {
|
70
|
+
event.which = event.charCode != null ? event.charCode : event.keyCode;
|
71
|
+
}
|
72
|
+
|
73
|
+
// Add metaKey to non-Mac browsers (use ctrl for PC's and Meta for Macs)
|
74
|
+
if ( !event.metaKey && event.ctrlKey ) {
|
75
|
+
event.metaKey = event.ctrlKey;
|
76
|
+
}
|
77
|
+
|
78
|
+
// Add which for click: 1 === left; 2 === middle; 3 === right
|
79
|
+
// Note: button is not normalized, so don't use it
|
80
|
+
if ( !event.which && event.button !== undefined ) {
|
81
|
+
event.which = (event.button & 1 ? 1 : ( event.button & 2 ? 3 : ( event.button & 4 ? 2 : 0 ) ));
|
82
|
+
}
|
83
|
+
|
84
|
+
return event;
|
85
|
+
}
|
86
|
+
|
87
|
+
function buildMouseEvent(self, evt) {
|
88
|
+
var mouse = self.mouse;
|
89
|
+
|
90
|
+
evt = fixEvent(evt || window.event);
|
91
|
+
evt.context = self;
|
92
|
+
evt.canvas = self.canvas;
|
93
|
+
evt.offsetx = mouse.x;
|
94
|
+
evt.offsety = mouse.y;
|
95
|
+
evt.mouse = mouse;
|
96
|
+
|
97
|
+
mouse.offsetx = evt.offsetx || 0;
|
98
|
+
mouse.offsety = evt.offsety || 0;
|
99
|
+
|
100
|
+
var cumulativeOffset = getCumulativeOffset(self.canvas);
|
101
|
+
mouse.x = evt.pageX - cumulativeOffset[0];
|
102
|
+
mouse.y = evt.pageY - cumulativeOffset[1];
|
103
|
+
|
104
|
+
if (self.canvas) {
|
105
|
+
if (self.canvas.offsetWidth) mouse.x = mouse.x / self.canvas.offsetWidth * self.canvas.width;
|
106
|
+
if (self.canvas.offsetHeight) mouse.y = mouse.y / self.canvas.offsetHeight * self.canvas.height;
|
107
|
+
}
|
108
|
+
|
109
|
+
mouse.y = self.canvas.height - mouse.y; // invert y
|
110
|
+
|
111
|
+
// calculate differences, useful for checking movement relative to last position
|
112
|
+
if (evt.type == 'mouseover') {
|
113
|
+
// don't count 'mouseover' or we'll inadvertently cancel out long movements
|
114
|
+
mouse.diffx = mouse.diffy = 0;
|
115
|
+
} else {
|
116
|
+
mouse.diffx = mouse.x - mouse.offsetx;
|
117
|
+
mouse.diffy = mouse.y - mouse.offsety;
|
118
|
+
}
|
119
|
+
|
120
|
+
// check button state special cases
|
121
|
+
if (evt.type == "mousedown" || evt.type == "onmousedown") {
|
122
|
+
// begin dragging, and possibly click
|
123
|
+
mouse.down = mouse.down || {count:0};
|
124
|
+
mouse.down["button"+evt.which] = {at:[mouse.x,mouse.y],time:Jax.uptime};
|
125
|
+
mouse.down.count++;
|
126
|
+
} else if (evt.type == "click" || evt.type == "onclick") {
|
127
|
+
// complete click
|
128
|
+
evt.cancel = false;
|
129
|
+
if (mouse.down && mouse.down["button"+evt.which]) {
|
130
|
+
evt.cancel = !!Jax.click_speed && (Jax.uptime - mouse.down["button"+evt.which].time) > Jax.click_speed;
|
131
|
+
}
|
132
|
+
} else if (evt.type == "mouseup" || evt.type == "onmouseup") {
|
133
|
+
// stop dragging
|
134
|
+
if (mouse.down)
|
135
|
+
{
|
136
|
+
mouse.down.count--;
|
137
|
+
// mouse.down = null;
|
138
|
+
if (mouse.down.count < 0) mouse.down.count = 0;
|
139
|
+
}
|
140
|
+
} else if (evt.type == "mouseout" || evt.type == "onmouseout") {
|
141
|
+
// reset all mousedown state so when mouse re-enters we won't be dragging
|
142
|
+
// in practice, this behavior is accurate more often than the opposite
|
143
|
+
// (e.g. drag out and then back in without releasing).
|
144
|
+
// Requiring an extra mouse-up in this opposite instance is harmless and
|
145
|
+
// relatively unobtrusive.
|
146
|
+
mouse.down = null;
|
147
|
+
}
|
148
|
+
|
149
|
+
evt.x = mouse.x;
|
150
|
+
evt.y = mouse.y;
|
151
|
+
evt.diffx = mouse.diffx;
|
152
|
+
evt.diffy = mouse.diffy;
|
153
|
+
evt.down = mouse.down;
|
154
|
+
|
155
|
+
return evt;
|
156
|
+
}
|
157
|
+
|
158
|
+
function dispatchEvent(self, evt) {
|
159
|
+
if (evt.cancel) return;
|
160
|
+
var type = evt.type.toString();
|
161
|
+
if (type.indexOf("on") == 0) type = type.substring(2, type.length);
|
162
|
+
type = type.toLowerCase();
|
163
|
+
var target;
|
164
|
+
switch(type) {
|
165
|
+
case "click": target = "mouse_clicked"; break;
|
166
|
+
case "mousemove":
|
167
|
+
if (evt.move_type == 'mousemove') target = "mouse_moved";
|
168
|
+
else target = "mouse_dragged";
|
169
|
+
break;
|
170
|
+
case "mousedown": target = "mouse_pressed"; break;
|
171
|
+
case "mouseout": target = "mouse_exited"; break;
|
172
|
+
case "mouseover": target = "mouse_entered"; break;
|
173
|
+
case "mouseup": target = "mouse_released";break;
|
174
|
+
case "keydown": target = "key_pressed"; break;
|
175
|
+
case "keypress": target = "key_typed"; break;
|
176
|
+
case "keyup": target = "key_released"; break;
|
177
|
+
default: return true; // don't dispatch this event to the controller
|
178
|
+
}
|
179
|
+
|
180
|
+
if (self.current_controller[target]) {
|
181
|
+
var result = self.current_controller[target](evt);
|
182
|
+
if (result != undefined) return result;
|
183
|
+
}
|
184
|
+
return true;
|
185
|
+
}
|
186
|
+
|
187
|
+
// Tag names which, when active, should cause key input to be IGNORED. The implication is that while
|
188
|
+
// one of these tags has focus, the user doesn't want to be controlling his character because s/he is
|
189
|
+
// trying to type something.
|
190
|
+
var ignoreKeyTagNames = [
|
191
|
+
'input', 'form', 'textarea', 'label', 'fieldset', 'legend', 'select', 'optgroup', 'option', 'button'
|
192
|
+
];
|
193
|
+
|
194
|
+
function registerListener(self, type, func) {
|
195
|
+
if (self.canvas.addEventListener) {
|
196
|
+
/* W3 */
|
197
|
+
self.canvas.addEventListener(type, func, false);
|
198
|
+
} else {
|
199
|
+
/* IE */
|
200
|
+
self.canvas.attachEvent("on"+type, func);
|
201
|
+
}
|
202
|
+
}
|
203
|
+
|
204
|
+
return {
|
205
|
+
disposeEventListeners: function() {
|
206
|
+
this.unregisterMouseListeners();
|
207
|
+
this.unregisterKeyListeners();
|
208
|
+
},
|
209
|
+
|
210
|
+
registerMouseListeners: function(receiver) {
|
211
|
+
// we have to watch over/out to avoid problematic 'jittering' on mousemove
|
212
|
+
var register = {mouseover:1,mouseout:1}, name;
|
213
|
+
for (name in receiver) {
|
214
|
+
switch(name) {
|
215
|
+
case 'mouse_pressed' : register['mousedown'] = 1; break;
|
216
|
+
case 'mouse_released': register['mouseup'] = 1; break;
|
217
|
+
case 'mouse_dragged' : // same as mouse_moved
|
218
|
+
case 'mouse_moved' : register['mousedown'] = register['mouseup'] = register['mousemove'] = 1; break;
|
219
|
+
case 'mouse_clicked' : register['click'] = register['mousedown'] = 1; break;
|
220
|
+
case 'mouse_exited' : register['mouseout'] = 1; break;
|
221
|
+
case 'mouse_entered' : register['mouseover'] = 1; break;
|
222
|
+
};
|
223
|
+
}
|
224
|
+
|
225
|
+
for (name in register) {
|
226
|
+
if (name == 'mousemove')
|
227
|
+
registerListener(this, name, this._evt_mousemovefunc);
|
228
|
+
else
|
229
|
+
registerListener(this, name, this._evt_mousefunc);
|
230
|
+
}
|
231
|
+
},
|
232
|
+
|
233
|
+
unregisterMouseListeners: function() {
|
234
|
+
if (this._evt_mousefunc) this.canvas.removeEventListener(this._evt_mousefunc);
|
235
|
+
if (this._evt_mousemovefunc) this.canvas.removeEventListener(this._evt_mousemovefunc);
|
236
|
+
},
|
237
|
+
|
238
|
+
registerKeyListeners: function() {
|
239
|
+
if (this.canvas.addEventListener) {
|
240
|
+
/* W3 */
|
241
|
+
document.addEventListener('keydown', this._evt_keyfunc, false);
|
242
|
+
document.addEventListener('keypress', this._evt_keyfunc, false);
|
243
|
+
document.addEventListener('keyup', this._evt_keyfunc, false);
|
244
|
+
} else {
|
245
|
+
/* IE */
|
246
|
+
document.attachEvent('onkeydown', this._evt_keyfunc);
|
247
|
+
document.attachEvent('onkeypress', this._evt_keyfunc);
|
248
|
+
document.attachEvent('onkeyup', this._evt_keyfunc);
|
249
|
+
}
|
250
|
+
},
|
251
|
+
|
252
|
+
unregisterKeyListeners: function() {
|
253
|
+
if (!this._evt_keyfunc) return;
|
254
|
+
|
255
|
+
this.canvas.removeEventListener(this._evt_keyfunc);
|
256
|
+
document.removeEventListener('keydown', this._evt_keyfunc, false);
|
257
|
+
document.removeEventListener('keyup', this._evt_keyfunc, false);
|
258
|
+
document.removeEventListener('keypress', this._evt_keyfunc, false);
|
259
|
+
document.removeEventListener('onkeydown', this._evt_keyfunc, false);
|
260
|
+
document.removeEventListener('onkeyup', this._evt_keyfunc, false);
|
261
|
+
document.removeEventListener('onkeypress', this._evt_keyfunc, false);
|
262
|
+
},
|
263
|
+
|
264
|
+
setupEventListeners: function() {
|
265
|
+
this.keyboard = {};
|
266
|
+
this.mouse = {};
|
267
|
+
|
268
|
+
var canvas = this.canvas;
|
269
|
+
var self = this;
|
270
|
+
|
271
|
+
this._evt_mousefunc = function(evt) {
|
272
|
+
if (!self.current_controller) return;
|
273
|
+
evt = buildMouseEvent(self, evt);
|
274
|
+
return dispatchEvent(self, evt);
|
275
|
+
};
|
276
|
+
this._evt_mousemovefunc = function(evt) {
|
277
|
+
if (!self.current_controller) return;
|
278
|
+
evt = buildMouseEvent(self, evt);
|
279
|
+
if (self.mouse && (!self.mouse.down || self.mouse.down.count <= 0)) // mouse is not being dragged
|
280
|
+
evt.move_type = "mousemove";
|
281
|
+
else
|
282
|
+
evt.move_type = "mousedrag";
|
283
|
+
return dispatchEvent(self, evt);
|
284
|
+
};
|
285
|
+
this._evt_keyfunc = function(evt) {
|
286
|
+
if (evt.which) evt.str = String.fromCharCode(evt.which);
|
287
|
+
if (document.activeElement) {
|
288
|
+
if (ignoreKeyTagNames.indexOf(document.activeElement.tagName) != -1)
|
289
|
+
{ // user is probably trying to type, so don't capture this input
|
290
|
+
return;
|
291
|
+
}
|
292
|
+
}
|
293
|
+
if (!self.current_controller) return;
|
294
|
+
evt = buildKeyEvent(self, evt);
|
295
|
+
return dispatchEvent(self, evt);
|
296
|
+
};
|
297
|
+
|
298
|
+
this.registerKeyListeners();
|
299
|
+
|
300
|
+
// this is now done by the context
|
301
|
+
// this.registerMouseListeners();
|
302
|
+
}
|
303
|
+
};
|
304
|
+
})();
|
@@ -0,0 +1,185 @@
|
|
1
|
+
/**
|
2
|
+
* class Jax.Geometry.Line
|
3
|
+
*
|
4
|
+
**/
|
5
|
+
Jax.Geometry.Line = (function() {
|
6
|
+
var Line = Jax.Class.create({
|
7
|
+
/**
|
8
|
+
* new Jax.Geometry.Line([a[, b]])
|
9
|
+
* - a (vec3): point A (optional)
|
10
|
+
* - b (vec3): point B (optional)
|
11
|
+
*
|
12
|
+
* Creates a new line. If point A and B are given, they are
|
13
|
+
* passed into #set to initialize the line. If they are not
|
14
|
+
* given, all values default to 0.
|
15
|
+
**/
|
16
|
+
initialize: function(a, b) {
|
17
|
+
/**
|
18
|
+
* Jax.Geometry.Line#a -> vec3
|
19
|
+
*
|
20
|
+
* the starting point of this line
|
21
|
+
**/
|
22
|
+
|
23
|
+
this.a = vec3.create();
|
24
|
+
|
25
|
+
/**
|
26
|
+
* Jax.Geometry.Line#b -> vec3
|
27
|
+
*
|
28
|
+
* the ending point of this line
|
29
|
+
**/
|
30
|
+
this.b = vec3.create();
|
31
|
+
|
32
|
+
/**
|
33
|
+
* Jax.Geometry.Line#normal -> vec3
|
34
|
+
*
|
35
|
+
* the normal for this line, pointing from A towards B.
|
36
|
+
**/
|
37
|
+
this.normal = vec3.create();
|
38
|
+
|
39
|
+
/**
|
40
|
+
* Jax.Geometry.Line#length -> Number
|
41
|
+
*
|
42
|
+
* the length of this line
|
43
|
+
**/
|
44
|
+
this.length = 0;
|
45
|
+
|
46
|
+
if (arguments.length) this.set(a, b);
|
47
|
+
},
|
48
|
+
|
49
|
+
/**
|
50
|
+
* Jax.Geometry.Line#set(a, b) -> Jax.Geometry.Line
|
51
|
+
* - a (vec3): point A
|
52
|
+
* - b (vec3): point B
|
53
|
+
*
|
54
|
+
* Sets this line to span from point A to point B.
|
55
|
+
* Also recalculates the length and normal for this line.
|
56
|
+
**/
|
57
|
+
set: function(a, b) {
|
58
|
+
vec3.set(a, this.a);
|
59
|
+
vec3.set(b, this.b);
|
60
|
+
|
61
|
+
vec3.subtract(b, a, this.normal);
|
62
|
+
this.length = vec3.length(this.normal);
|
63
|
+
vec3.normalize(this.normal);
|
64
|
+
|
65
|
+
return this;
|
66
|
+
},
|
67
|
+
|
68
|
+
/**
|
69
|
+
* Jax.Geometry.Line#intersectLineSegment(line[, dest]) -> Boolean
|
70
|
+
* - line (Jax.Geometry.Line): the line to test for intersection
|
71
|
+
* - dest (Jax.Geometry.Line): an optional receiving line
|
72
|
+
*
|
73
|
+
* Tests the two lines for intersection. If +dest+ is given, the overlap is stored
|
74
|
+
* within it. (If the lines intersect at a single point, but do not overlap, then
|
75
|
+
* only the A point in +dest+ will be set.) If +dest+ is
|
76
|
+
* omitted, this information is ignored.
|
77
|
+
*
|
78
|
+
* If the lines do not interesct, Jax.Geometry.DISJOINT (which is equal to 0) is returned.
|
79
|
+
* If they intersect in a single unique point, Jax.Geometry.INTERSECT is returned.
|
80
|
+
* If they intersect in a sub-segment, Jax.Geometry.COINCIDE is returned.
|
81
|
+
**/
|
82
|
+
intersectLineSegment: function(line, dest) {
|
83
|
+
var u = vec3.subtract(this.b, this.a, vec3.create());
|
84
|
+
var v = vec3.subtract(line.b, line.a, vec3.create());
|
85
|
+
var w = vec3.subtract(this.a, line.a, vec3.create());
|
86
|
+
var D = (u[0] * v[1] - u[1] * v[0]);
|
87
|
+
if (Math.abs(D) < Math.EPSILON) { // S1 and S2 are parallel
|
88
|
+
if ((u[0] * w[1] - u[1] * w[0]) != 0 || (v[0] * w[1] - v[1] * w[0]) != 0) {
|
89
|
+
return Jax.Geometry.DISJOINT; // they are NOT colinear
|
90
|
+
}
|
91
|
+
// they are colinear or degenerate
|
92
|
+
// check if they are degenerate points
|
93
|
+
var du = vec3.dot(u, u);
|
94
|
+
var dv = vec3.dot(v, v);
|
95
|
+
if (du == 0 && dv == 0) { // both segments are points
|
96
|
+
if (!Math.equalish(this.a, line.a)) // they are distinct points
|
97
|
+
return Jax.Geometry.DISJOINT;
|
98
|
+
// they are the same point
|
99
|
+
if (dest) vec3.set(line.a, dest.a);
|
100
|
+
// vec3.set(line.a, dest.b);
|
101
|
+
return Jax.Geometry.INTERSECT;
|
102
|
+
}
|
103
|
+
if (du == 0) { // +this+ is a single point
|
104
|
+
if (!line.contains(this.a)) // but is not in S2
|
105
|
+
return Jax.Geometry.DISJOINT;
|
106
|
+
if (dest) vec3.set(this.a, dest.a);
|
107
|
+
// vec3.set(this.b, dest.b);
|
108
|
+
return Jax.Geometry.INTERSECT;
|
109
|
+
}
|
110
|
+
if (dv == 0) { // +line+ is a single point
|
111
|
+
if (!this.contains(line.a)) // but is not in this line
|
112
|
+
return Jax.Geometry.DISJOINT;
|
113
|
+
if (dest) vec3.set(line.a, dest.a);
|
114
|
+
// vec3.set(line.b, dest.b);
|
115
|
+
return Jax.Geometry.INTERSECT;
|
116
|
+
}
|
117
|
+
// they are colinear segments - get overlap (or not)
|
118
|
+
var t0, t1; // endpoints of +this+ in eqn for +line+
|
119
|
+
var w2 = vec3.subtract(this.a, line.a, vec3.create());
|
120
|
+
if (v[0] != 0) {
|
121
|
+
t0 = w[0] / v[0];
|
122
|
+
t1 = w2[0] / v[0];
|
123
|
+
} else {
|
124
|
+
t0 = w[1] / v[1];
|
125
|
+
t1 = w2[1] / v[1];
|
126
|
+
}
|
127
|
+
if (t0 > t1) { // must have t0 smaller than t1
|
128
|
+
var t = t0; t0 = t1; t1 = t;
|
129
|
+
}
|
130
|
+
if (t0 > 1 || t1 < 0) // NO overlap
|
131
|
+
return Jax.Geometry.DISJOINT;
|
132
|
+
t0 = t0 < 0 ? 0 : t0; // clamp to min 0
|
133
|
+
t1 = t1 > 1 ? 1 : t1; // clamp to max 1
|
134
|
+
if (t0 == t1) {
|
135
|
+
// intersect is a point
|
136
|
+
if (line) {
|
137
|
+
vec3.add(line.a, vec3.scale(v, t0, dest.a), dest.a);
|
138
|
+
return Jax.Geometry.INTERSECT;
|
139
|
+
}
|
140
|
+
}
|
141
|
+
|
142
|
+
// they overlap in a valid subsegment
|
143
|
+
if (dest) {
|
144
|
+
vec3.add(line.a, vec3.scale(v, t0, dest.a), dest);
|
145
|
+
vec3.add(line.b, vec3.scale(v, t1, dest.b), dest);
|
146
|
+
}
|
147
|
+
return Jax.Geometry.COINCIDENT;
|
148
|
+
}
|
149
|
+
|
150
|
+
// the segments are askew and may intersect in a point
|
151
|
+
// get the intersect parameter for +this+
|
152
|
+
var sI = (v[0] * w[1] - v[1] * w[0]) / D;
|
153
|
+
if (sI < 0 || sI > 1) // no intersect with +this+
|
154
|
+
return Jax.Geometry.DISJOINT;
|
155
|
+
// get the intersect parameter for +line+
|
156
|
+
var tI = (u[0] * w[1] - u[1] * w[0]) / D;
|
157
|
+
if (tI < 0 || tI > 1) // no intersect with +line+
|
158
|
+
return Jax.Geometry.DISJOINT;
|
159
|
+
|
160
|
+
if (dest) vec3.add(this.a, vec3.scale(u, sI, dest), dest);
|
161
|
+
return Jax.Geometry.INTERSECT;
|
162
|
+
},
|
163
|
+
|
164
|
+
toString: function() {
|
165
|
+
return "[Line a:"+this.a+", b:"+this.b+"]";
|
166
|
+
}
|
167
|
+
});
|
168
|
+
|
169
|
+
// array-style accessors
|
170
|
+
Object.defineProperty(Line.prototype, 0, {
|
171
|
+
get: function() { return this.a; },
|
172
|
+
set: function(v) { return this.a = v; },
|
173
|
+
enumerable: false,
|
174
|
+
configurable: false
|
175
|
+
});
|
176
|
+
|
177
|
+
Object.defineProperty(Line.prototype, 1, {
|
178
|
+
get: function() { return this.b; },
|
179
|
+
set: function(v) { return this.b = v; },
|
180
|
+
enumerable: false,
|
181
|
+
configurable: false
|
182
|
+
});
|
183
|
+
|
184
|
+
return Line;
|
185
|
+
})();
|