opal-js_wrap-three 0.1.1 → 0.1.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -0
- data/Gemfile.lock +4 -4
- data/lib/opal/js_wrap/three/version.rb +1 -1
- data/lib-opal/js_wrap/three/WebGL.js +102 -0
- data/lib-opal/js_wrap/three/animation/AnimationClipCreator.js +116 -0
- data/lib-opal/js_wrap/three/animation/CCDIKSolver.js +436 -0
- data/lib-opal/js_wrap/three/animation/MMDAnimationHelper.js +941 -0
- data/lib-opal/js_wrap/three/animation/MMDPhysics.js +1183 -0
- data/lib-opal/js_wrap/three/cameras/CinematicCamera.js +204 -0
- data/lib-opal/js_wrap/three/controls/ArcballControls.js +2649 -0
- data/lib-opal/js_wrap/three/controls/DragControls.js +234 -0
- data/lib-opal/js_wrap/three/controls/FirstPersonControls.js +301 -0
- data/lib-opal/js_wrap/three/controls/FlyControls.js +357 -0
- data/lib-opal/js_wrap/three/controls/OrbitControls.js +908 -0
- data/lib-opal/js_wrap/three/controls/PointerLockControls.js +173 -0
- data/lib-opal/js_wrap/three/controls/TrackballControls.js +666 -0
- data/lib-opal/js_wrap/three/controls/TransformControls.js +1210 -0
- data/lib-opal/js_wrap/three/controls/experimental/CameraControls.js +860 -0
- data/lib-opal/js_wrap/three/csm/CSM.js +346 -0
- data/lib-opal/js_wrap/three/csm/CSMFrustum.js +123 -0
- data/lib-opal/js_wrap/three/csm/CSMHelper.js +197 -0
- data/lib-opal/js_wrap/three/csm/CSMShader.js +29 -0
- data/lib-opal/js_wrap/three/curves/CurveExtras.js +544 -0
- data/lib-opal/js_wrap/three/curves/NURBSCurve.js +122 -0
- data/lib-opal/js_wrap/three/curves/NURBSSurface.js +78 -0
- data/lib-opal/js_wrap/three/curves/NURBSUtils.js +413 -0
- data/lib-opal/js_wrap/three/deprecated/Geometry.js +1373 -0
- data/lib-opal/js_wrap/three/effects/AnaglyphEffect.js +113 -0
- data/lib-opal/js_wrap/three/effects/AsciiEffect.js +267 -0
- data/lib-opal/js_wrap/three/effects/OutlineEffect.js +400 -0
- data/lib-opal/js_wrap/three/effects/ParallaxBarrierEffect.js +90 -0
- data/lib-opal/js_wrap/three/effects/PeppersGhostEffect.js +160 -0
- data/lib-opal/js_wrap/three/effects/StereoEffect.js +63 -0
- data/lib-opal/js_wrap/three/environments/DebugEnvironment.js +107 -0
- data/lib-opal/js_wrap/three/environments/RoomEnvironment.js +166 -0
- data/lib-opal/js_wrap/three/exporters/ColladaExporter.js +442 -0
- data/lib-opal/js_wrap/three/exporters/DRACOExporter.js +205 -0
- data/lib-opal/js_wrap/three/exporters/GLTFExporter.js +2042 -0
- data/lib-opal/js_wrap/three/exporters/MMDExporter.js +189 -0
- data/lib-opal/js_wrap/three/exporters/OBJExporter.js +241 -0
- data/lib-opal/js_wrap/three/exporters/PLYExporter.js +370 -0
- data/lib-opal/js_wrap/three/exporters/STLExporter.js +186 -0
- data/lib-opal/js_wrap/three/exporters/USDZExporter.js +402 -0
- data/lib-opal/js_wrap/three/geometries/BoxLineGeometry.js +106 -0
- data/lib-opal/js_wrap/three/geometries/ConvexGeometry.js +88 -0
- data/lib-opal/js_wrap/three/geometries/DecalGeometry.js +302 -0
- data/lib-opal/js_wrap/three/geometries/LightningStrike.js +817 -0
- data/lib-opal/js_wrap/three/geometries/ParametricGeometries.js +280 -0
- data/lib-opal/js_wrap/three/geometries/ParametricGeometry.js +146 -0
- data/lib-opal/js_wrap/three/geometries/RoundedBoxGeometry.js +183 -0
- data/lib-opal/js_wrap/three/geometries/TeapotGeometry.js +352 -0
- data/lib-opal/js_wrap/three/geometries/TextGeometry.js +76 -0
- data/lib-opal/js_wrap/three/helpers/LightProbeHelper.js +95 -0
- data/lib-opal/js_wrap/three/helpers/PositionalAudioHelper.js +138 -0
- data/lib-opal/js_wrap/three/helpers/RectAreaLightHelper.js +115 -0
- data/lib-opal/js_wrap/three/helpers/VertexNormalsHelper.js +131 -0
- data/lib-opal/js_wrap/three/helpers/VertexTangentsHelper.js +118 -0
- data/lib-opal/js_wrap/three/interactive/HTMLMesh.js +307 -0
- data/lib-opal/js_wrap/three/interactive/InteractiveGroup.js +138 -0
- data/lib-opal/js_wrap/three/interactive/SelectionBox.js +264 -0
- data/lib-opal/js_wrap/three/interactive/SelectionHelper.js +88 -0
- data/lib-opal/js_wrap/three/libs/OimoPhysics/OimoPhysics.js +46059 -0
- data/lib-opal/js_wrap/three/libs/OimoPhysics/index.js +92 -0
- data/lib-opal/js_wrap/three/libs/chevrotain.module.min.js +6947 -0
- data/lib-opal/js_wrap/three/libs/ecsy.module.js +1999 -0
- data/lib-opal/js_wrap/three/libs/fflate.module.js +3002 -0
- data/lib-opal/js_wrap/three/libs/flow.module.js +3033 -0
- data/lib-opal/js_wrap/three/libs/ktx-parse.module.js +392 -0
- data/lib-opal/js_wrap/three/libs/lil-gui.module.min.js +821 -0
- data/lib-opal/js_wrap/three/libs/meshopt_decoder.module.js +136 -0
- data/lib-opal/js_wrap/three/libs/mmdparser.module.js +11022 -0
- data/lib-opal/js_wrap/three/libs/motion-controllers.module.js +589 -0
- data/lib-opal/js_wrap/three/libs/opentype.module.min.js +6132 -0
- data/lib-opal/js_wrap/three/libs/potpack.module.js +171 -0
- data/lib-opal/js_wrap/three/libs/rhino3dm/rhino3dm.js +6781 -0
- data/lib-opal/js_wrap/three/libs/rhino3dm/rhino3dm.module.js +6783 -0
- data/lib-opal/js_wrap/three/libs/stats.module.js +139 -0
- data/lib-opal/js_wrap/three/libs/tween.module.min.js +349 -0
- data/lib-opal/js_wrap/three/lights/LightProbeGenerator.js +233 -0
- data/lib-opal/js_wrap/three/lights/RectAreaLightUniformsLib.js +75 -0
- data/lib-opal/js_wrap/three/lines/Line2.js +66 -0
- data/lib-opal/js_wrap/three/lines/LineGeometry.js +122 -0
- data/lib-opal/js_wrap/three/lines/LineMaterial.js +227 -0
- data/lib-opal/js_wrap/three/lines/LineSegments2.js +312 -0
- data/lib-opal/js_wrap/three/lines/LineSegmentsGeometry.js +238 -0
- data/lib-opal/js_wrap/three/lines/Wireframe.js +98 -0
- data/lib-opal/js_wrap/three/lines/WireframeGeometry2.js +65 -0
- data/lib-opal/js_wrap/three/loaders/3DMLoader.js +1230 -0
- data/lib-opal/js_wrap/three/loaders/3MFLoader.js +1123 -0
- data/lib-opal/js_wrap/three/loaders/AMFLoader.js +445 -0
- data/lib-opal/js_wrap/three/loaders/BVHLoader.js +365 -0
- data/lib-opal/js_wrap/three/loaders/BasisTextureLoader.js +692 -0
- data/lib-opal/js_wrap/three/loaders/ColladaLoader.js +3046 -0
- data/lib-opal/js_wrap/three/loaders/DDSLoader.js +264 -0
- data/lib-opal/js_wrap/three/loaders/DRACOLoader.js +531 -0
- data/lib-opal/js_wrap/three/loaders/EXRLoader.js +1834 -0
- data/lib-opal/js_wrap/three/loaders/FBXLoader.js +3125 -0
- data/lib-opal/js_wrap/three/loaders/FontLoader.js +201 -0
- data/lib-opal/js_wrap/three/loaders/GCodeLoader.js +248 -0
- data/lib-opal/js_wrap/three/loaders/GLTFLoader.js +3334 -0
- data/lib-opal/js_wrap/three/loaders/HDRCubeTextureLoader.js +144 -0
- data/lib-opal/js_wrap/three/loaders/IFCLoader.js +2395 -0
- data/lib-opal/js_wrap/three/loaders/KMZLoader.js +142 -0
- data/lib-opal/js_wrap/three/loaders/KTX2Loader.js +535 -0
- data/lib-opal/js_wrap/three/loaders/KTXLoader.js +202 -0
- data/lib-opal/js_wrap/three/loaders/LDrawLoader.js +1737 -0
- data/lib-opal/js_wrap/three/loaders/LUT3dlLoader.js +163 -0
- data/lib-opal/js_wrap/three/loaders/LUTCubeLoader.js +171 -0
- data/lib-opal/js_wrap/three/loaders/LWOLoader.js +831 -0
- data/lib-opal/js_wrap/three/loaders/LogLuvLoader.js +713 -0
- data/lib-opal/js_wrap/three/loaders/LottieLoader.js +103 -0
- data/lib-opal/js_wrap/three/loaders/MD2Loader.js +258 -0
- data/lib-opal/js_wrap/three/loaders/MDDLoader.js +116 -0
- data/lib-opal/js_wrap/three/loaders/MMDLoader.js +1687 -0
- data/lib-opal/js_wrap/three/loaders/MTLLoader.js +465 -0
- data/lib-opal/js_wrap/three/loaders/NRRDLoader.js +554 -0
- data/lib-opal/js_wrap/three/loaders/NodeMaterialLoader.js +248 -0
- data/lib-opal/js_wrap/three/loaders/OBJLoader.js +673 -0
- data/lib-opal/js_wrap/three/loaders/PCDLoader.js +322 -0
- data/lib-opal/js_wrap/three/loaders/PDBLoader.js +318 -0
- data/lib-opal/js_wrap/three/loaders/PLYLoader.js +489 -0
- data/lib-opal/js_wrap/three/loaders/PRWMLoader.js +247 -0
- data/lib-opal/js_wrap/three/loaders/PVRLoader.js +240 -0
- data/lib-opal/js_wrap/three/loaders/RGBELoader.js +462 -0
- data/lib-opal/js_wrap/three/loaders/RGBMLoader.js +1169 -0
- data/lib-opal/js_wrap/three/loaders/STLLoader.js +345 -0
- data/lib-opal/js_wrap/three/loaders/SVGLoader.js +2162 -0
- data/lib-opal/js_wrap/three/loaders/TDSLoader.js +982 -0
- data/lib-opal/js_wrap/three/loaders/TGALoader.js +444 -0
- data/lib-opal/js_wrap/three/loaders/TTFLoader.js +210 -0
- data/lib-opal/js_wrap/three/loaders/TiltLoader.js +391 -0
- data/lib-opal/js_wrap/three/loaders/VOXLoader.js +272 -0
- data/lib-opal/js_wrap/three/loaders/VRMLLoader.js +2685 -0
- data/lib-opal/js_wrap/three/loaders/VRMLoader.js +103 -0
- data/lib-opal/js_wrap/three/loaders/VTKLoader.js +894 -0
- data/lib-opal/js_wrap/three/loaders/XYZLoader.js +136 -0
- data/lib-opal/js_wrap/three/loaders/ifc/web-ifc-api.js +60504 -0
- data/lib-opal/js_wrap/three/loaders/lwo/IFFParser.js +931 -0
- data/lib-opal/js_wrap/three/loaders/lwo/LWO2Parser.js +450 -0
- data/lib-opal/js_wrap/three/loaders/lwo/LWO3Parser.js +406 -0
- data/lib-opal/js_wrap/three/math/Capsule.js +133 -0
- data/lib-opal/js_wrap/three/math/ColorConverter.js +104 -0
- data/lib-opal/js_wrap/three/math/ConvexHull.js +924 -0
- data/lib-opal/js_wrap/three/math/ImprovedNoise.js +86 -0
- data/lib-opal/js_wrap/three/math/Lut.js +170 -0
- data/lib-opal/js_wrap/three/math/MeshSurfaceSampler.js +187 -0
- data/lib-opal/js_wrap/three/math/OBB.js +345 -0
- data/lib-opal/js_wrap/three/math/Octree.js +409 -0
- data/lib-opal/js_wrap/three/math/SimplexNoise.js +425 -0
- data/lib-opal/js_wrap/three/misc/ConvexObjectBreaker.js +447 -0
- data/lib-opal/js_wrap/three/misc/GPUComputationRenderer.js +322 -0
- data/lib-opal/js_wrap/three/misc/Gyroscope.js +94 -0
- data/lib-opal/js_wrap/three/misc/MD2Character.js +225 -0
- data/lib-opal/js_wrap/three/misc/MD2CharacterComplex.js +424 -0
- data/lib-opal/js_wrap/three/misc/MorphAnimMesh.js +109 -0
- data/lib-opal/js_wrap/three/misc/MorphBlendMesh.js +283 -0
- data/lib-opal/js_wrap/three/misc/ProgressiveLightMap.js +324 -0
- data/lib-opal/js_wrap/three/misc/RollerCoaster.js +489 -0
- data/lib-opal/js_wrap/three/misc/TubePainter.js +158 -0
- data/lib-opal/js_wrap/three/misc/Volume.js +427 -0
- data/lib-opal/js_wrap/three/misc/VolumeSlice.js +210 -0
- data/lib-opal/js_wrap/three/modifiers/CurveModifier.js +291 -0
- data/lib-opal/js_wrap/three/modifiers/EdgeSplitModifier.js +308 -0
- data/lib-opal/js_wrap/three/modifiers/SimplifyModifier.js +435 -0
- data/lib-opal/js_wrap/three/modifiers/TessellateModifier.js +264 -0
- data/lib-opal/js_wrap/three/node-editor/NodeEditor.js +402 -0
- data/lib-opal/js_wrap/three/node-editor/accessors/NormalEditor.js +80 -0
- data/lib-opal/js_wrap/three/node-editor/accessors/PositionEditor.js +80 -0
- data/lib-opal/js_wrap/three/node-editor/accessors/UVEditor.js +71 -0
- data/lib-opal/js_wrap/three/node-editor/display/BlendEditor.js +78 -0
- data/lib-opal/js_wrap/three/node-editor/inputs/ColorEditor.js +111 -0
- data/lib-opal/js_wrap/three/node-editor/inputs/FloatEditor.js +69 -0
- data/lib-opal/js_wrap/three/node-editor/inputs/SliderEditor.js +97 -0
- data/lib-opal/js_wrap/three/node-editor/inputs/Vector2Editor.js +73 -0
- data/lib-opal/js_wrap/three/node-editor/inputs/Vector3Editor.js +75 -0
- data/lib-opal/js_wrap/three/node-editor/inputs/Vector4Editor.js +77 -0
- data/lib-opal/js_wrap/three/node-editor/materials/StandardMaterialEditor.js +121 -0
- data/lib-opal/js_wrap/three/node-editor/math/DotEditor.js +76 -0
- data/lib-opal/js_wrap/three/node-editor/math/InvertEditor.js +80 -0
- data/lib-opal/js_wrap/three/node-editor/math/LimiterEditor.js +85 -0
- data/lib-opal/js_wrap/three/node-editor/math/NormalizeEditor.js +69 -0
- data/lib-opal/js_wrap/three/node-editor/math/OperatorEditor.js +91 -0
- data/lib-opal/js_wrap/three/node-editor/math/PowerEditor.js +73 -0
- data/lib-opal/js_wrap/three/node-editor/math/TrigonometryEditor.js +83 -0
- data/lib-opal/js_wrap/three/node-editor/procedural/CheckerEditor.js +69 -0
- data/lib-opal/js_wrap/three/node-editor/utils/OscillatorEditor.js +87 -0
- data/lib-opal/js_wrap/three/node-editor/utils/TimerEditor.js +89 -0
- data/lib-opal/js_wrap/three/nodes/Nodes.js +481 -0
- data/lib-opal/js_wrap/three/nodes/accessors/CameraNode.js +222 -0
- data/lib-opal/js_wrap/three/nodes/accessors/ColorsNode.js +99 -0
- data/lib-opal/js_wrap/three/nodes/accessors/LightNode.js +100 -0
- data/lib-opal/js_wrap/three/nodes/accessors/NormalNode.js +152 -0
- data/lib-opal/js_wrap/three/nodes/accessors/PositionNode.js +163 -0
- data/lib-opal/js_wrap/three/nodes/accessors/ReflectNode.js +161 -0
- data/lib-opal/js_wrap/three/nodes/accessors/ResolutionNode.js +99 -0
- data/lib-opal/js_wrap/three/nodes/accessors/ScreenUVNode.js +101 -0
- data/lib-opal/js_wrap/three/nodes/accessors/UVNode.js +105 -0
- data/lib-opal/js_wrap/three/nodes/core/AttributeNode.js +106 -0
- data/lib-opal/js_wrap/three/nodes/core/ConstNode.js +149 -0
- data/lib-opal/js_wrap/three/nodes/core/ExpressionNode.js +57 -0
- data/lib-opal/js_wrap/three/nodes/core/FunctionCallNode.js +138 -0
- data/lib-opal/js_wrap/three/nodes/core/FunctionNode.js +259 -0
- data/lib-opal/js_wrap/three/nodes/core/InputNode.js +124 -0
- data/lib-opal/js_wrap/three/nodes/core/Node.js +193 -0
- data/lib-opal/js_wrap/three/nodes/core/NodeBuilder.js +782 -0
- data/lib-opal/js_wrap/three/nodes/core/NodeFrame.js +69 -0
- data/lib-opal/js_wrap/three/nodes/core/NodeLib.js +56 -0
- data/lib-opal/js_wrap/three/nodes/core/NodeUniform.js +53 -0
- data/lib-opal/js_wrap/three/nodes/core/NodeUtils.js +60 -0
- data/lib-opal/js_wrap/three/nodes/core/StructNode.js +131 -0
- data/lib-opal/js_wrap/three/nodes/core/TempNode.js +160 -0
- data/lib-opal/js_wrap/three/nodes/core/VarNode.js +105 -0
- data/lib-opal/js_wrap/three/nodes/effects/BlurNode.js +160 -0
- data/lib-opal/js_wrap/three/nodes/effects/ColorAdjustmentNode.js +139 -0
- data/lib-opal/js_wrap/three/nodes/effects/LuminanceNode.js +106 -0
- data/lib-opal/js_wrap/three/nodes/inputs/BoolNode.js +95 -0
- data/lib-opal/js_wrap/three/nodes/inputs/ColorNode.js +99 -0
- data/lib-opal/js_wrap/three/nodes/inputs/CubeTextureNode.js +136 -0
- data/lib-opal/js_wrap/three/nodes/inputs/FloatNode.js +95 -0
- data/lib-opal/js_wrap/three/nodes/inputs/IntNode.js +95 -0
- data/lib-opal/js_wrap/three/nodes/inputs/Matrix3Node.js +102 -0
- data/lib-opal/js_wrap/three/nodes/inputs/Matrix4Node.js +102 -0
- data/lib-opal/js_wrap/three/nodes/inputs/PropertyNode.js +85 -0
- data/lib-opal/js_wrap/three/nodes/inputs/RTTNode.js +164 -0
- data/lib-opal/js_wrap/three/nodes/inputs/ReflectorNode.js +111 -0
- data/lib-opal/js_wrap/three/nodes/inputs/ScreenNode.js +69 -0
- data/lib-opal/js_wrap/three/nodes/inputs/TextureNode.js +140 -0
- data/lib-opal/js_wrap/three/nodes/inputs/Vector2Node.js +98 -0
- data/lib-opal/js_wrap/three/nodes/inputs/Vector3Node.js +99 -0
- data/lib-opal/js_wrap/three/nodes/inputs/Vector4Node.js +100 -0
- data/lib-opal/js_wrap/three/nodes/materials/BasicNodeMaterial.js +63 -0
- data/lib-opal/js_wrap/three/nodes/materials/MeshStandardNodeMaterial.js +63 -0
- data/lib-opal/js_wrap/three/nodes/materials/NodeMaterial.js +202 -0
- data/lib-opal/js_wrap/three/nodes/materials/PhongNodeMaterial.js +63 -0
- data/lib-opal/js_wrap/three/nodes/materials/SpriteNodeMaterial.js +63 -0
- data/lib-opal/js_wrap/three/nodes/materials/StandardNodeMaterial.js +63 -0
- data/lib-opal/js_wrap/three/nodes/materials/nodes/BasicNode.js +146 -0
- data/lib-opal/js_wrap/three/nodes/materials/nodes/MeshStandardNode.js +133 -0
- data/lib-opal/js_wrap/three/nodes/materials/nodes/PhongNode.js +273 -0
- data/lib-opal/js_wrap/three/nodes/materials/nodes/RawNode.js +101 -0
- data/lib-opal/js_wrap/three/nodes/materials/nodes/SpriteNode.js +176 -0
- data/lib-opal/js_wrap/three/nodes/materials/nodes/StandardNode.js +397 -0
- data/lib-opal/js_wrap/three/nodes/math/CondNode.js +151 -0
- data/lib-opal/js_wrap/three/nodes/math/MathNode.js +266 -0
- data/lib-opal/js_wrap/three/nodes/math/OperatorNode.js +120 -0
- data/lib-opal/js_wrap/three/nodes/misc/BumpMapNode.js +139 -0
- data/lib-opal/js_wrap/three/nodes/misc/NormalMapNode.js +122 -0
- data/lib-opal/js_wrap/three/nodes/misc/TextureCubeNode.js +107 -0
- data/lib-opal/js_wrap/three/nodes/misc/TextureCubeUVNode.js +191 -0
- data/lib-opal/js_wrap/three/nodes/postprocessing/NodePass.js +117 -0
- data/lib-opal/js_wrap/three/nodes/postprocessing/NodePostProcessing.js +128 -0
- data/lib-opal/js_wrap/three/nodes/procedural/CheckerNode.js +104 -0
- data/lib-opal/js_wrap/three/nodes/procedural/Fractal3DNode.js +121 -0
- data/lib-opal/js_wrap/three/nodes/procedural/Noise2DNode.js +115 -0
- data/lib-opal/js_wrap/three/nodes/procedural/Noise3DNode.js +112 -0
- data/lib-opal/js_wrap/three/nodes/utils/BypassNode.js +115 -0
- data/lib-opal/js_wrap/three/nodes/utils/ColorSpaceNode.js +214 -0
- data/lib-opal/js_wrap/three/nodes/utils/JoinNode.js +138 -0
- data/lib-opal/js_wrap/three/nodes/utils/MaxMIPLevelNode.js +88 -0
- data/lib-opal/js_wrap/three/nodes/utils/RemapNode.js +117 -0
- data/lib-opal/js_wrap/three/nodes/utils/SpecularMIPLevelNode.js +121 -0
- data/lib-opal/js_wrap/three/nodes/utils/SubSlotNode.js +112 -0
- data/lib-opal/js_wrap/three/nodes/utils/SwitchNode.js +129 -0
- data/lib-opal/js_wrap/three/nodes/utils/TimerNode.js +126 -0
- data/lib-opal/js_wrap/three/nodes/utils/UVTransformNode.js +104 -0
- data/lib-opal/js_wrap/three/nodes/utils/VelocityNode.js +181 -0
- data/lib-opal/js_wrap/three/objects/Lensflare.js +285 -0
- data/lib-opal/js_wrap/three/objects/LightningStorm.js +238 -0
- data/lib-opal/js_wrap/three/objects/MarchingCubes.js +667 -0
- data/lib-opal/js_wrap/three/objects/Reflector.js +205 -0
- data/lib-opal/js_wrap/three/objects/ReflectorForSSRPass.js +288 -0
- data/lib-opal/js_wrap/three/objects/ReflectorRTT.js +63 -0
- data/lib-opal/js_wrap/three/objects/Refractor.js +243 -0
- data/lib-opal/js_wrap/three/objects/ShadowMesh.js +100 -0
- data/lib-opal/js_wrap/three/objects/Sky.js +107 -0
- data/lib-opal/js_wrap/three/objects/Water.js +246 -0
- data/lib-opal/js_wrap/three/objects/Water2.js +238 -0
- data/lib-opal/js_wrap/three/offscreen/jank.js +51 -0
- data/lib-opal/js_wrap/three/offscreen/offscreen.js +24 -0
- data/lib-opal/js_wrap/three/offscreen/scene.js +99 -0
- data/lib-opal/js_wrap/three/physics/AmmoPhysics.js +266 -0
- data/lib-opal/js_wrap/three/physics/OimoPhysics.js +214 -0
- data/lib-opal/js_wrap/three/postprocessing/AdaptiveToneMappingPass.js +307 -0
- data/lib-opal/js_wrap/three/postprocessing/AfterimagePass.js +116 -0
- data/lib-opal/js_wrap/three/postprocessing/BloomPass.js +132 -0
- data/lib-opal/js_wrap/three/postprocessing/BokehPass.js +143 -0
- data/lib-opal/js_wrap/three/postprocessing/ClearPass.js +85 -0
- data/lib-opal/js_wrap/three/postprocessing/CubeTexturePass.js +104 -0
- data/lib-opal/js_wrap/three/postprocessing/DotScreenPass.js +90 -0
- data/lib-opal/js_wrap/three/postprocessing/EffectComposer.js +272 -0
- data/lib-opal/js_wrap/three/postprocessing/FilmPass.js +91 -0
- data/lib-opal/js_wrap/three/postprocessing/GlitchPass.js +140 -0
- data/lib-opal/js_wrap/three/postprocessing/HalftonePass.js +108 -0
- data/lib-opal/js_wrap/three/postprocessing/LUTPass.js +132 -0
- data/lib-opal/js_wrap/three/postprocessing/MaskPass.js +142 -0
- data/lib-opal/js_wrap/three/postprocessing/OutlinePass.js +480 -0
- data/lib-opal/js_wrap/three/postprocessing/Pass.js +101 -0
- data/lib-opal/js_wrap/three/postprocessing/RenderPass.js +109 -0
- data/lib-opal/js_wrap/three/postprocessing/SAOPass.js +384 -0
- data/lib-opal/js_wrap/three/postprocessing/SMAAPass.js +199 -0
- data/lib-opal/js_wrap/three/postprocessing/SSAARenderPass.js +186 -0
- data/lib-opal/js_wrap/three/postprocessing/SSAOPass.js +388 -0
- data/lib-opal/js_wrap/three/postprocessing/SSRPass.js +537 -0
- data/lib-opal/js_wrap/three/postprocessing/SSRrPass.js +481 -0
- data/lib-opal/js_wrap/three/postprocessing/SavePass.js +96 -0
- data/lib-opal/js_wrap/three/postprocessing/ShaderPass.js +98 -0
- data/lib-opal/js_wrap/three/postprocessing/TAARenderPass.js +159 -0
- data/lib-opal/js_wrap/three/postprocessing/TexturePass.js +91 -0
- data/lib-opal/js_wrap/three/postprocessing/UnrealBloomPass.js +335 -0
- data/lib-opal/js_wrap/three/renderers/CSS2DRenderer.js +213 -0
- data/lib-opal/js_wrap/three/renderers/CSS3DRenderer.js +277 -0
- data/lib-opal/js_wrap/three/renderers/Projector.js +733 -0
- data/lib-opal/js_wrap/three/renderers/SVGRenderer.js +470 -0
- data/lib-opal/js_wrap/three/renderers/nodes/Nodes.js +531 -0
- data/lib-opal/js_wrap/three/renderers/nodes/ShaderNode.js +386 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/CameraNode.js +114 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/MaterialNode.js +140 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/MaterialReferenceNode.js +79 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/ModelNode.js +62 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/ModelViewProjectionNode.js +80 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/NormalNode.js +113 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/Object3DNode.js +136 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/PointUVNode.js +70 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/PositionNode.js +117 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/ReferenceNode.js +124 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/SkinningNode.js +129 -0
- data/lib-opal/js_wrap/three/renderers/nodes/accessors/UVNode.js +77 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/ArrayInputNode.js +74 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/AttributeNode.js +97 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/BypassNode.js +84 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/CodeNode.js +131 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/ContextNode.js +84 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/ExpressionNode.js +81 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/FunctionCallNode.js +123 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/FunctionNode.js +126 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/InputNode.js +103 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/Node.js +120 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeAttribute.js +37 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeBuilder.js +650 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeCode.js +42 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeFrame.js +70 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeFunction.js +55 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeFunctionInput.js +44 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeKeywords.js +117 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeParser.js +46 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeUniform.js +55 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeVar.js +37 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/NodeVary.js +37 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/PropertyNode.js +90 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/TempNode.js +89 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/VarNode.js +101 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/VaryNode.js +101 -0
- data/lib-opal/js_wrap/three/renderers/nodes/core/constants.js +42 -0
- data/lib-opal/js_wrap/three/renderers/nodes/display/ColorSpaceNode.js +165 -0
- data/lib-opal/js_wrap/three/renderers/nodes/display/NormalMapNode.js +120 -0
- data/lib-opal/js_wrap/three/renderers/nodes/functions/BSDFs.js +133 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/BufferNode.js +78 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/ColorNode.js +67 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/FloatNode.js +67 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/IntNode.js +67 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/Matrix3Node.js +67 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/Matrix4Node.js +67 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/TextureNode.js +120 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/Vector2Node.js +67 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/Vector3Node.js +67 -0
- data/lib-opal/js_wrap/three/renderers/nodes/inputs/Vector4Node.js +67 -0
- data/lib-opal/js_wrap/three/renderers/nodes/lights/LightContextNode.js +103 -0
- data/lib-opal/js_wrap/three/renderers/nodes/lights/LightNode.js +115 -0
- data/lib-opal/js_wrap/three/renderers/nodes/lights/LightsNode.js +117 -0
- data/lib-opal/js_wrap/three/renderers/nodes/materials/LineBasicNodeMaterial.js +82 -0
- data/lib-opal/js_wrap/three/renderers/nodes/materials/Materials.js +49 -0
- data/lib-opal/js_wrap/three/renderers/nodes/materials/MeshBasicNodeMaterial.js +82 -0
- data/lib-opal/js_wrap/three/renderers/nodes/materials/MeshStandardNodeMaterial.js +96 -0
- data/lib-opal/js_wrap/three/renderers/nodes/materials/PointsNodeMaterial.js +84 -0
- data/lib-opal/js_wrap/three/renderers/nodes/math/CondNode.js +98 -0
- data/lib-opal/js_wrap/three/renderers/nodes/math/MathNode.js +255 -0
- data/lib-opal/js_wrap/three/renderers/nodes/math/OperatorNode.js +163 -0
- data/lib-opal/js_wrap/three/renderers/nodes/parsers/GLSLNodeFunction.js +158 -0
- data/lib-opal/js_wrap/three/renderers/nodes/parsers/GLSLNodeParser.js +68 -0
- data/lib-opal/js_wrap/three/renderers/nodes/parsers/WGSLNodeFunction.js +126 -0
- data/lib-opal/js_wrap/three/renderers/nodes/parsers/WGSLNodeParser.js +68 -0
- data/lib-opal/js_wrap/three/renderers/nodes/procedural/CheckerNode.js +84 -0
- data/lib-opal/js_wrap/three/renderers/nodes/utils/ArrayElementNode.js +79 -0
- data/lib-opal/js_wrap/three/renderers/nodes/utils/ConvertNode.js +82 -0
- data/lib-opal/js_wrap/three/renderers/nodes/utils/JoinNode.js +88 -0
- data/lib-opal/js_wrap/three/renderers/nodes/utils/OscNode.js +105 -0
- data/lib-opal/js_wrap/three/renderers/nodes/utils/SplitNode.js +96 -0
- data/lib-opal/js_wrap/three/renderers/nodes/utils/SpriteSheetUVNode.js +98 -0
- data/lib-opal/js_wrap/three/renderers/nodes/utils/TimerNode.js +93 -0
- data/lib-opal/js_wrap/three/renderers/webgl/nodes/SlotNode.js +72 -0
- data/lib-opal/js_wrap/three/renderers/webgl/nodes/WebGLNodeBuilder.js +463 -0
- data/lib-opal/js_wrap/three/renderers/webgl/nodes/WebGLNodes.js +62 -0
- data/lib-opal/js_wrap/three/renderers/webgl/nodes/WebGLPhysicalContextNode.js +95 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPU.js +62 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUAttributes.js +118 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUBackground.js +109 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUBinding.js +52 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUBindings.js +254 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUBufferUtils.js +39 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUComputePipelines.js +82 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUGeometries.js +84 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUInfo.js +86 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUObjects.js +64 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUProgrammableStage.js +46 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUProperties.js +63 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPURenderLists.js +180 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPURenderPipeline.js +662 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPURenderPipelines.js +275 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPURenderer.js +883 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUSampledTexture.js +139 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUSampler.js +76 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUStorageBuffer.js +69 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUTextureRenderer.js +64 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUTextureUtils.js +125 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUTextures.js +681 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUUniform.js +237 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUUniformBuffer.js +90 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/WebGPUUniformsGroup.js +294 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/constants.js +263 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/nodes/WebGPUNodeBuilder.js +619 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/nodes/WebGPUNodeSampledTexture.js +67 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/nodes/WebGPUNodeSampler.js +71 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/nodes/WebGPUNodeUniform.js +229 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/nodes/WebGPUNodeUniformsGroup.js +68 -0
- data/lib-opal/js_wrap/three/renderers/webgpu/nodes/WebGPUNodes.js +106 -0
- data/lib-opal/js_wrap/three/shaders/ACESFilmicToneMappingShader.js +45 -0
- data/lib-opal/js_wrap/three/shaders/AfterimageShader.js +46 -0
- data/lib-opal/js_wrap/three/shaders/BasicShader.js +34 -0
- data/lib-opal/js_wrap/three/shaders/BleachBypassShader.js +43 -0
- data/lib-opal/js_wrap/three/shaders/BlendShader.js +47 -0
- data/lib-opal/js_wrap/three/shaders/BokehShader.js +65 -0
- data/lib-opal/js_wrap/three/shaders/BokehShader2.js +125 -0
- data/lib-opal/js_wrap/three/shaders/BrightnessContrastShader.js +47 -0
- data/lib-opal/js_wrap/three/shaders/ColorCorrectionShader.js +47 -0
- data/lib-opal/js_wrap/three/shaders/ColorifyShader.js +41 -0
- data/lib-opal/js_wrap/three/shaders/ConvolutionShader.js +75 -0
- data/lib-opal/js_wrap/three/shaders/CopyShader.js +41 -0
- data/lib-opal/js_wrap/three/shaders/DOFMipMapShader.js +49 -0
- data/lib-opal/js_wrap/three/shaders/DepthLimitedBlurShader.js +95 -0
- data/lib-opal/js_wrap/three/shaders/DigitalGlitch.js +79 -0
- data/lib-opal/js_wrap/three/shaders/DotScreenShader.js +52 -0
- data/lib-opal/js_wrap/three/shaders/FXAAShader.js +78 -0
- data/lib-opal/js_wrap/three/shaders/FilmShader.js +69 -0
- data/lib-opal/js_wrap/three/shaders/FocusShader.js +52 -0
- data/lib-opal/js_wrap/three/shaders/FreiChenShader.js +44 -0
- data/lib-opal/js_wrap/three/shaders/GammaCorrectionShader.js +39 -0
- data/lib-opal/js_wrap/three/shaders/GodRaysShader.js +140 -0
- data/lib-opal/js_wrap/three/shaders/HalftoneShader.js +77 -0
- data/lib-opal/js_wrap/three/shaders/HorizontalBlurShader.js +47 -0
- data/lib-opal/js_wrap/three/shaders/HorizontalTiltShiftShader.js +49 -0
- data/lib-opal/js_wrap/three/shaders/HueSaturationShader.js +47 -0
- data/lib-opal/js_wrap/three/shaders/KaleidoShader.js +50 -0
- data/lib-opal/js_wrap/three/shaders/LuminosityHighPassShader.js +52 -0
- data/lib-opal/js_wrap/three/shaders/LuminosityShader.js +39 -0
- data/lib-opal/js_wrap/three/shaders/MMDToonShader.js +48 -0
- data/lib-opal/js_wrap/three/shaders/MirrorShader.js +44 -0
- data/lib-opal/js_wrap/three/shaders/NormalMapShader.js +48 -0
- data/lib-opal/js_wrap/three/shaders/PixelShader.js +44 -0
- data/lib-opal/js_wrap/three/shaders/RGBShiftShader.js +50 -0
- data/lib-opal/js_wrap/three/shaders/SAOShader.js +85 -0
- data/lib-opal/js_wrap/three/shaders/SMAAShader.js +95 -0
- data/lib-opal/js_wrap/three/shaders/SSAOShader.js +113 -0
- data/lib-opal/js_wrap/three/shaders/SSRShader.js +126 -0
- data/lib-opal/js_wrap/three/shaders/SSRrShader.js +106 -0
- data/lib-opal/js_wrap/three/shaders/SepiaShader.js +43 -0
- data/lib-opal/js_wrap/three/shaders/SobelOperatorShader.js +44 -0
- data/lib-opal/js_wrap/three/shaders/SubsurfaceScatteringShader.js +64 -0
- data/lib-opal/js_wrap/three/shaders/TechnicolorShader.js +41 -0
- data/lib-opal/js_wrap/three/shaders/ToneMapShader.js +53 -0
- data/lib-opal/js_wrap/three/shaders/ToonShader.js +148 -0
- data/lib-opal/js_wrap/three/shaders/TriangleBlurShader.js +47 -0
- data/lib-opal/js_wrap/three/shaders/UnpackDepthRGBAShader.js +42 -0
- data/lib-opal/js_wrap/three/shaders/VerticalBlurShader.js +47 -0
- data/lib-opal/js_wrap/three/shaders/VerticalTiltShiftShader.js +49 -0
- data/lib-opal/js_wrap/three/shaders/VignetteShader.js +46 -0
- data/lib-opal/js_wrap/three/shaders/VolumeShader.js +55 -0
- data/lib-opal/js_wrap/three/shaders/WaterRefractionShader.js +46 -0
- data/lib-opal/js_wrap/three/textures/FlakesTexture.js +61 -0
- data/lib-opal/js_wrap/three/utils/BufferGeometryUtils.js +683 -0
- data/lib-opal/js_wrap/three/utils/CameraUtils.js +97 -0
- data/lib-opal/js_wrap/three/utils/GPUStatsPanel.js +154 -0
- data/lib-opal/js_wrap/three/utils/GeometryCompressionUtils.js +468 -0
- data/lib-opal/js_wrap/three/utils/GeometryUtils.js +192 -0
- data/lib-opal/js_wrap/three/utils/PackedPhongMaterial.js +77 -0
- data/lib-opal/js_wrap/three/utils/RoughnessMipmapper.js +169 -0
- data/lib-opal/js_wrap/three/utils/SceneUtils.js +62 -0
- data/lib-opal/js_wrap/three/utils/ShadowMapViewer.js +182 -0
- data/lib-opal/js_wrap/three/utils/SkeletonUtils.js +400 -0
- data/lib-opal/js_wrap/three/utils/UVsDebug.js +132 -0
- data/lib-opal/js_wrap/three/utils/WorkerPool.js +130 -0
- data/lib-opal/js_wrap/three/webxr/ARButton.js +203 -0
- data/lib-opal/js_wrap/three/webxr/OculusHandModel.js +131 -0
- data/lib-opal/js_wrap/three/webxr/OculusHandPointerModel.js +328 -0
- data/lib-opal/js_wrap/three/webxr/Text2D.js +54 -0
- data/lib-opal/js_wrap/three/webxr/VRButton.js +181 -0
- data/lib-opal/js_wrap/three/webxr/XRControllerModelFactory.js +266 -0
- data/lib-opal/js_wrap/three/webxr/XREstimatedLight.js +221 -0
- data/lib-opal/js_wrap/three/webxr/XRHandMeshModel.js +93 -0
- data/lib-opal/js_wrap/three/webxr/XRHandModelFactory.js +127 -0
- data/lib-opal/js_wrap/three/webxr/XRHandPrimitiveModel.js +85 -0
- data/opal-js_wrap-three.gemspec +4 -4
- metadata +502 -5
@@ -0,0 +1,400 @@
|
|
1
|
+
(function (global, factory) {
|
2
|
+
if (typeof define === "function" && define.amd) {
|
3
|
+
define(["exports", "three"], factory);
|
4
|
+
} else if (typeof exports !== "undefined") {
|
5
|
+
factory(exports, require("three"));
|
6
|
+
} else {
|
7
|
+
var mod = {
|
8
|
+
exports: {}
|
9
|
+
};
|
10
|
+
factory(mod.exports, global.three);
|
11
|
+
global.OutlineEffect = mod.exports;
|
12
|
+
}
|
13
|
+
})(typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : this, function (_exports, _three) {
|
14
|
+
"use strict";
|
15
|
+
|
16
|
+
Object.defineProperty(_exports, "__esModule", {
|
17
|
+
value: true
|
18
|
+
});
|
19
|
+
_exports.OutlineEffect = void 0;
|
20
|
+
|
21
|
+
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
22
|
+
|
23
|
+
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
24
|
+
|
25
|
+
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
26
|
+
|
27
|
+
/**
|
28
|
+
* Reference: https://en.wikipedia.org/wiki/Cel_shading
|
29
|
+
*
|
30
|
+
* API
|
31
|
+
*
|
32
|
+
* 1. Traditional
|
33
|
+
*
|
34
|
+
* const effect = new OutlineEffect( renderer );
|
35
|
+
*
|
36
|
+
* function render() {
|
37
|
+
*
|
38
|
+
* effect.render( scene, camera );
|
39
|
+
*
|
40
|
+
* }
|
41
|
+
*
|
42
|
+
* 2. VR compatible
|
43
|
+
*
|
44
|
+
* const effect = new OutlineEffect( renderer );
|
45
|
+
* let renderingOutline = false;
|
46
|
+
*
|
47
|
+
* scene.onAfterRender = function () {
|
48
|
+
*
|
49
|
+
* if ( renderingOutline ) return;
|
50
|
+
*
|
51
|
+
* renderingOutline = true;
|
52
|
+
*
|
53
|
+
* effect.renderOutline( scene, camera );
|
54
|
+
*
|
55
|
+
* renderingOutline = false;
|
56
|
+
*
|
57
|
+
* };
|
58
|
+
*
|
59
|
+
* function render() {
|
60
|
+
*
|
61
|
+
* renderer.render( scene, camera );
|
62
|
+
*
|
63
|
+
* }
|
64
|
+
*
|
65
|
+
* // How to set default outline parameters
|
66
|
+
* new OutlineEffect( renderer, {
|
67
|
+
* defaultThickness: 0.01,
|
68
|
+
* defaultColor: [ 0, 0, 0 ],
|
69
|
+
* defaultAlpha: 0.8,
|
70
|
+
* defaultKeepAlive: true // keeps outline material in cache even if material is removed from scene
|
71
|
+
* } );
|
72
|
+
*
|
73
|
+
* // How to set outline parameters for each material
|
74
|
+
* material.userData.outlineParameters = {
|
75
|
+
* thickness: 0.01,
|
76
|
+
* color: [ 0, 0, 0 ]
|
77
|
+
* alpha: 0.8,
|
78
|
+
* visible: true,
|
79
|
+
* keepAlive: true
|
80
|
+
* };
|
81
|
+
*/
|
82
|
+
var OutlineEffect = /*#__PURE__*/_createClass(function OutlineEffect(renderer) {
|
83
|
+
var parameters = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
84
|
+
|
85
|
+
_classCallCheck(this, OutlineEffect);
|
86
|
+
|
87
|
+
this.enabled = true;
|
88
|
+
var defaultThickness = parameters.defaultThickness !== undefined ? parameters.defaultThickness : 0.003;
|
89
|
+
var defaultColor = new _three.Color().fromArray(parameters.defaultColor !== undefined ? parameters.defaultColor : [0, 0, 0]);
|
90
|
+
var defaultAlpha = parameters.defaultAlpha !== undefined ? parameters.defaultAlpha : 1.0;
|
91
|
+
var defaultKeepAlive = parameters.defaultKeepAlive !== undefined ? parameters.defaultKeepAlive : false; // object.material.uuid -> outlineMaterial or
|
92
|
+
// object.material[ n ].uuid -> outlineMaterial
|
93
|
+
// save at the outline material creation and release
|
94
|
+
// if it's unused removeThresholdCount frames
|
95
|
+
// unless keepAlive is true.
|
96
|
+
|
97
|
+
var cache = {};
|
98
|
+
var removeThresholdCount = 60; // outlineMaterial.uuid -> object.material or
|
99
|
+
// outlineMaterial.uuid -> object.material[ n ]
|
100
|
+
// save before render and release after render.
|
101
|
+
|
102
|
+
var originalMaterials = {}; // object.uuid -> originalOnBeforeRender
|
103
|
+
// save before render and release after render.
|
104
|
+
|
105
|
+
var originalOnBeforeRenders = {}; //this.cache = cache; // for debug
|
106
|
+
|
107
|
+
var uniformsOutline = {
|
108
|
+
outlineThickness: {
|
109
|
+
value: defaultThickness
|
110
|
+
},
|
111
|
+
outlineColor: {
|
112
|
+
value: defaultColor
|
113
|
+
},
|
114
|
+
outlineAlpha: {
|
115
|
+
value: defaultAlpha
|
116
|
+
}
|
117
|
+
};
|
118
|
+
var vertexShader = ['#include <common>', '#include <uv_pars_vertex>', '#include <displacementmap_pars_vertex>', '#include <fog_pars_vertex>', '#include <morphtarget_pars_vertex>', '#include <skinning_pars_vertex>', '#include <logdepthbuf_pars_vertex>', '#include <clipping_planes_pars_vertex>', 'uniform float outlineThickness;', 'vec4 calculateOutline( vec4 pos, vec3 normal, vec4 skinned ) {', ' float thickness = outlineThickness;', ' const float ratio = 1.0;', // TODO: support outline thickness ratio for each vertex
|
119
|
+
' vec4 pos2 = projectionMatrix * modelViewMatrix * vec4( skinned.xyz + normal, 1.0 );', // NOTE: subtract pos2 from pos because BackSide objectNormal is negative
|
120
|
+
' vec4 norm = normalize( pos - pos2 );', ' return pos + norm * thickness * pos.w * ratio;', '}', 'void main() {', ' #include <uv_vertex>', ' #include <beginnormal_vertex>', ' #include <morphnormal_vertex>', ' #include <skinbase_vertex>', ' #include <skinnormal_vertex>', ' #include <begin_vertex>', ' #include <morphtarget_vertex>', ' #include <skinning_vertex>', ' #include <displacementmap_vertex>', ' #include <project_vertex>', ' vec3 outlineNormal = - objectNormal;', // the outline material is always rendered with BackSide
|
121
|
+
' gl_Position = calculateOutline( gl_Position, outlineNormal, vec4( transformed, 1.0 ) );', ' #include <logdepthbuf_vertex>', ' #include <clipping_planes_vertex>', ' #include <fog_vertex>', '}'].join('\n');
|
122
|
+
var fragmentShader = ['#include <common>', '#include <fog_pars_fragment>', '#include <logdepthbuf_pars_fragment>', '#include <clipping_planes_pars_fragment>', 'uniform vec3 outlineColor;', 'uniform float outlineAlpha;', 'void main() {', ' #include <clipping_planes_fragment>', ' #include <logdepthbuf_fragment>', ' gl_FragColor = vec4( outlineColor, outlineAlpha );', ' #include <tonemapping_fragment>', ' #include <encodings_fragment>', ' #include <fog_fragment>', ' #include <premultiplied_alpha_fragment>', '}'].join('\n');
|
123
|
+
|
124
|
+
function createMaterial() {
|
125
|
+
return new _three.ShaderMaterial({
|
126
|
+
type: 'OutlineEffect',
|
127
|
+
uniforms: _three.UniformsUtils.merge([_three.UniformsLib['fog'], _three.UniformsLib['displacementmap'], uniformsOutline]),
|
128
|
+
vertexShader: vertexShader,
|
129
|
+
fragmentShader: fragmentShader,
|
130
|
+
side: _three.BackSide
|
131
|
+
});
|
132
|
+
}
|
133
|
+
|
134
|
+
function getOutlineMaterialFromCache(originalMaterial) {
|
135
|
+
var data = cache[originalMaterial.uuid];
|
136
|
+
|
137
|
+
if (data === undefined) {
|
138
|
+
data = {
|
139
|
+
material: createMaterial(),
|
140
|
+
used: true,
|
141
|
+
keepAlive: defaultKeepAlive,
|
142
|
+
count: 0
|
143
|
+
};
|
144
|
+
cache[originalMaterial.uuid] = data;
|
145
|
+
}
|
146
|
+
|
147
|
+
data.used = true;
|
148
|
+
return data.material;
|
149
|
+
}
|
150
|
+
|
151
|
+
function getOutlineMaterial(originalMaterial) {
|
152
|
+
var outlineMaterial = getOutlineMaterialFromCache(originalMaterial);
|
153
|
+
originalMaterials[outlineMaterial.uuid] = originalMaterial;
|
154
|
+
updateOutlineMaterial(outlineMaterial, originalMaterial);
|
155
|
+
return outlineMaterial;
|
156
|
+
}
|
157
|
+
|
158
|
+
function isCompatible(object) {
|
159
|
+
var geometry = object.geometry;
|
160
|
+
var hasNormals = false;
|
161
|
+
|
162
|
+
if (object.geometry !== undefined) {
|
163
|
+
if (geometry.isBufferGeometry) {
|
164
|
+
hasNormals = geometry.attributes.normal !== undefined;
|
165
|
+
} else {
|
166
|
+
hasNormals = true; // the renderer always produces a normal attribute for Geometry
|
167
|
+
}
|
168
|
+
}
|
169
|
+
|
170
|
+
return object.isMesh === true && object.material !== undefined && hasNormals === true;
|
171
|
+
}
|
172
|
+
|
173
|
+
function setOutlineMaterial(object) {
|
174
|
+
if (isCompatible(object) === false) return;
|
175
|
+
|
176
|
+
if (Array.isArray(object.material)) {
|
177
|
+
for (var i = 0, il = object.material.length; i < il; i++) {
|
178
|
+
object.material[i] = getOutlineMaterial(object.material[i]);
|
179
|
+
}
|
180
|
+
} else {
|
181
|
+
object.material = getOutlineMaterial(object.material);
|
182
|
+
}
|
183
|
+
|
184
|
+
originalOnBeforeRenders[object.uuid] = object.onBeforeRender;
|
185
|
+
object.onBeforeRender = onBeforeRender;
|
186
|
+
}
|
187
|
+
|
188
|
+
function restoreOriginalMaterial(object) {
|
189
|
+
if (isCompatible(object) === false) return;
|
190
|
+
|
191
|
+
if (Array.isArray(object.material)) {
|
192
|
+
for (var i = 0, il = object.material.length; i < il; i++) {
|
193
|
+
object.material[i] = originalMaterials[object.material[i].uuid];
|
194
|
+
}
|
195
|
+
} else {
|
196
|
+
object.material = originalMaterials[object.material.uuid];
|
197
|
+
}
|
198
|
+
|
199
|
+
object.onBeforeRender = originalOnBeforeRenders[object.uuid];
|
200
|
+
}
|
201
|
+
|
202
|
+
function onBeforeRender(renderer, scene, camera, geometry, material) {
|
203
|
+
var originalMaterial = originalMaterials[material.uuid]; // just in case
|
204
|
+
|
205
|
+
if (originalMaterial === undefined) return;
|
206
|
+
updateUniforms(material, originalMaterial);
|
207
|
+
}
|
208
|
+
|
209
|
+
function updateUniforms(material, originalMaterial) {
|
210
|
+
var outlineParameters = originalMaterial.userData.outlineParameters;
|
211
|
+
material.uniforms.outlineAlpha.value = originalMaterial.opacity;
|
212
|
+
|
213
|
+
if (outlineParameters !== undefined) {
|
214
|
+
if (outlineParameters.thickness !== undefined) material.uniforms.outlineThickness.value = outlineParameters.thickness;
|
215
|
+
if (outlineParameters.color !== undefined) material.uniforms.outlineColor.value.fromArray(outlineParameters.color);
|
216
|
+
if (outlineParameters.alpha !== undefined) material.uniforms.outlineAlpha.value = outlineParameters.alpha;
|
217
|
+
}
|
218
|
+
|
219
|
+
if (originalMaterial.displacementMap) {
|
220
|
+
material.uniforms.displacementMap.value = originalMaterial.displacementMap;
|
221
|
+
material.uniforms.displacementScale.value = originalMaterial.displacementScale;
|
222
|
+
material.uniforms.displacementBias.value = originalMaterial.displacementBias;
|
223
|
+
}
|
224
|
+
}
|
225
|
+
|
226
|
+
function updateOutlineMaterial(material, originalMaterial) {
|
227
|
+
if (material.name === 'invisible') return;
|
228
|
+
var outlineParameters = originalMaterial.userData.outlineParameters;
|
229
|
+
material.fog = originalMaterial.fog;
|
230
|
+
material.toneMapped = originalMaterial.toneMapped;
|
231
|
+
material.premultipliedAlpha = originalMaterial.premultipliedAlpha;
|
232
|
+
material.displacementMap = originalMaterial.displacementMap;
|
233
|
+
|
234
|
+
if (outlineParameters !== undefined) {
|
235
|
+
if (originalMaterial.visible === false) {
|
236
|
+
material.visible = false;
|
237
|
+
} else {
|
238
|
+
material.visible = outlineParameters.visible !== undefined ? outlineParameters.visible : true;
|
239
|
+
}
|
240
|
+
|
241
|
+
material.transparent = outlineParameters.alpha !== undefined && outlineParameters.alpha < 1.0 ? true : originalMaterial.transparent;
|
242
|
+
if (outlineParameters.keepAlive !== undefined) cache[originalMaterial.uuid].keepAlive = outlineParameters.keepAlive;
|
243
|
+
} else {
|
244
|
+
material.transparent = originalMaterial.transparent;
|
245
|
+
material.visible = originalMaterial.visible;
|
246
|
+
}
|
247
|
+
|
248
|
+
if (originalMaterial.wireframe === true || originalMaterial.depthTest === false) material.visible = false;
|
249
|
+
|
250
|
+
if (originalMaterial.clippingPlanes) {
|
251
|
+
material.clipping = true;
|
252
|
+
material.clippingPlanes = originalMaterial.clippingPlanes;
|
253
|
+
material.clipIntersection = originalMaterial.clipIntersection;
|
254
|
+
material.clipShadows = originalMaterial.clipShadows;
|
255
|
+
}
|
256
|
+
|
257
|
+
material.version = originalMaterial.version; // update outline material if necessary
|
258
|
+
}
|
259
|
+
|
260
|
+
function cleanupCache() {
|
261
|
+
var keys; // clear originialMaterials
|
262
|
+
|
263
|
+
keys = Object.keys(originalMaterials);
|
264
|
+
|
265
|
+
for (var i = 0, il = keys.length; i < il; i++) {
|
266
|
+
originalMaterials[keys[i]] = undefined;
|
267
|
+
} // clear originalOnBeforeRenders
|
268
|
+
|
269
|
+
|
270
|
+
keys = Object.keys(originalOnBeforeRenders);
|
271
|
+
|
272
|
+
for (var _i = 0, _il = keys.length; _i < _il; _i++) {
|
273
|
+
originalOnBeforeRenders[keys[_i]] = undefined;
|
274
|
+
} // remove unused outlineMaterial from cache
|
275
|
+
|
276
|
+
|
277
|
+
keys = Object.keys(cache);
|
278
|
+
|
279
|
+
for (var _i2 = 0, _il2 = keys.length; _i2 < _il2; _i2++) {
|
280
|
+
var key = keys[_i2];
|
281
|
+
|
282
|
+
if (cache[key].used === false) {
|
283
|
+
cache[key].count++;
|
284
|
+
|
285
|
+
if (cache[key].keepAlive === false && cache[key].count > removeThresholdCount) {
|
286
|
+
delete cache[key];
|
287
|
+
}
|
288
|
+
} else {
|
289
|
+
cache[key].used = false;
|
290
|
+
cache[key].count = 0;
|
291
|
+
}
|
292
|
+
}
|
293
|
+
}
|
294
|
+
|
295
|
+
this.render = function (scene, camera) {
|
296
|
+
var renderTarget;
|
297
|
+
var forceClear = false;
|
298
|
+
|
299
|
+
if (arguments[2] !== undefined) {
|
300
|
+
console.warn('THREE.OutlineEffect.render(): the renderTarget argument has been removed. Use .setRenderTarget() instead.');
|
301
|
+
renderTarget = arguments[2];
|
302
|
+
}
|
303
|
+
|
304
|
+
if (arguments[3] !== undefined) {
|
305
|
+
console.warn('THREE.OutlineEffect.render(): the forceClear argument has been removed. Use .clear() instead.');
|
306
|
+
forceClear = arguments[3];
|
307
|
+
}
|
308
|
+
|
309
|
+
if (renderTarget !== undefined) renderer.setRenderTarget(renderTarget);
|
310
|
+
if (forceClear) renderer.clear();
|
311
|
+
|
312
|
+
if (this.enabled === false) {
|
313
|
+
renderer.render(scene, camera);
|
314
|
+
return;
|
315
|
+
}
|
316
|
+
|
317
|
+
var currentAutoClear = renderer.autoClear;
|
318
|
+
renderer.autoClear = this.autoClear;
|
319
|
+
renderer.render(scene, camera);
|
320
|
+
renderer.autoClear = currentAutoClear;
|
321
|
+
this.renderOutline(scene, camera);
|
322
|
+
};
|
323
|
+
|
324
|
+
this.renderOutline = function (scene, camera) {
|
325
|
+
var currentAutoClear = renderer.autoClear;
|
326
|
+
var currentSceneAutoUpdate = scene.autoUpdate;
|
327
|
+
var currentSceneBackground = scene.background;
|
328
|
+
var currentShadowMapEnabled = renderer.shadowMap.enabled;
|
329
|
+
scene.autoUpdate = false;
|
330
|
+
scene.background = null;
|
331
|
+
renderer.autoClear = false;
|
332
|
+
renderer.shadowMap.enabled = false;
|
333
|
+
scene.traverse(setOutlineMaterial);
|
334
|
+
renderer.render(scene, camera);
|
335
|
+
scene.traverse(restoreOriginalMaterial);
|
336
|
+
cleanupCache();
|
337
|
+
scene.autoUpdate = currentSceneAutoUpdate;
|
338
|
+
scene.background = currentSceneBackground;
|
339
|
+
renderer.autoClear = currentAutoClear;
|
340
|
+
renderer.shadowMap.enabled = currentShadowMapEnabled;
|
341
|
+
};
|
342
|
+
/*
|
343
|
+
* See #9918
|
344
|
+
*
|
345
|
+
* The following property copies and wrapper methods enable
|
346
|
+
* OutlineEffect to be called from other *Effect, like
|
347
|
+
*
|
348
|
+
* effect = new StereoEffect( new OutlineEffect( renderer ) );
|
349
|
+
*
|
350
|
+
* function render () {
|
351
|
+
*
|
352
|
+
* effect.render( scene, camera );
|
353
|
+
*
|
354
|
+
* }
|
355
|
+
*/
|
356
|
+
|
357
|
+
|
358
|
+
this.autoClear = renderer.autoClear;
|
359
|
+
this.domElement = renderer.domElement;
|
360
|
+
this.shadowMap = renderer.shadowMap;
|
361
|
+
|
362
|
+
this.clear = function (color, depth, stencil) {
|
363
|
+
renderer.clear(color, depth, stencil);
|
364
|
+
};
|
365
|
+
|
366
|
+
this.getPixelRatio = function () {
|
367
|
+
return renderer.getPixelRatio();
|
368
|
+
};
|
369
|
+
|
370
|
+
this.setPixelRatio = function (value) {
|
371
|
+
renderer.setPixelRatio(value);
|
372
|
+
};
|
373
|
+
|
374
|
+
this.getSize = function (target) {
|
375
|
+
return renderer.getSize(target);
|
376
|
+
};
|
377
|
+
|
378
|
+
this.setSize = function (width, height, updateStyle) {
|
379
|
+
renderer.setSize(width, height, updateStyle);
|
380
|
+
};
|
381
|
+
|
382
|
+
this.setViewport = function (x, y, width, height) {
|
383
|
+
renderer.setViewport(x, y, width, height);
|
384
|
+
};
|
385
|
+
|
386
|
+
this.setScissor = function (x, y, width, height) {
|
387
|
+
renderer.setScissor(x, y, width, height);
|
388
|
+
};
|
389
|
+
|
390
|
+
this.setScissorTest = function (boolean) {
|
391
|
+
renderer.setScissorTest(boolean);
|
392
|
+
};
|
393
|
+
|
394
|
+
this.setRenderTarget = function (renderTarget) {
|
395
|
+
renderer.setRenderTarget(renderTarget);
|
396
|
+
};
|
397
|
+
});
|
398
|
+
|
399
|
+
_exports.OutlineEffect = OutlineEffect;
|
400
|
+
});
|
@@ -0,0 +1,90 @@
|
|
1
|
+
(function (global, factory) {
|
2
|
+
if (typeof define === "function" && define.amd) {
|
3
|
+
define(["exports", "three"], factory);
|
4
|
+
} else if (typeof exports !== "undefined") {
|
5
|
+
factory(exports, require("three"));
|
6
|
+
} else {
|
7
|
+
var mod = {
|
8
|
+
exports: {}
|
9
|
+
};
|
10
|
+
factory(mod.exports, global.three);
|
11
|
+
global.ParallaxBarrierEffect = mod.exports;
|
12
|
+
}
|
13
|
+
})(typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : this, function (_exports, _three) {
|
14
|
+
"use strict";
|
15
|
+
|
16
|
+
Object.defineProperty(_exports, "__esModule", {
|
17
|
+
value: true
|
18
|
+
});
|
19
|
+
_exports.ParallaxBarrierEffect = void 0;
|
20
|
+
|
21
|
+
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
22
|
+
|
23
|
+
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
24
|
+
|
25
|
+
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
26
|
+
|
27
|
+
var ParallaxBarrierEffect = /*#__PURE__*/_createClass(function ParallaxBarrierEffect(renderer) {
|
28
|
+
_classCallCheck(this, ParallaxBarrierEffect);
|
29
|
+
|
30
|
+
var _camera = new _three.OrthographicCamera(-1, 1, 1, -1, 0, 1);
|
31
|
+
|
32
|
+
var _scene = new _three.Scene();
|
33
|
+
|
34
|
+
var _stereo = new _three.StereoCamera();
|
35
|
+
|
36
|
+
var _params = {
|
37
|
+
minFilter: _three.LinearFilter,
|
38
|
+
magFilter: _three.NearestFilter,
|
39
|
+
format: _three.RGBAFormat
|
40
|
+
};
|
41
|
+
|
42
|
+
var _renderTargetL = new _three.WebGLRenderTarget(512, 512, _params);
|
43
|
+
|
44
|
+
var _renderTargetR = new _three.WebGLRenderTarget(512, 512, _params);
|
45
|
+
|
46
|
+
var _material = new _three.ShaderMaterial({
|
47
|
+
uniforms: {
|
48
|
+
'mapLeft': {
|
49
|
+
value: _renderTargetL.texture
|
50
|
+
},
|
51
|
+
'mapRight': {
|
52
|
+
value: _renderTargetR.texture
|
53
|
+
}
|
54
|
+
},
|
55
|
+
vertexShader: ['varying vec2 vUv;', 'void main() {', ' vUv = vec2( uv.x, uv.y );', ' gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );', '}'].join('\n'),
|
56
|
+
fragmentShader: ['uniform sampler2D mapLeft;', 'uniform sampler2D mapRight;', 'varying vec2 vUv;', 'void main() {', ' vec2 uv = vUv;', ' if ( ( mod( gl_FragCoord.y, 2.0 ) ) > 1.00 ) {', ' gl_FragColor = texture2D( mapLeft, uv );', ' } else {', ' gl_FragColor = texture2D( mapRight, uv );', ' }', '}'].join('\n')
|
57
|
+
});
|
58
|
+
|
59
|
+
var mesh = new _three.Mesh(new _three.PlaneGeometry(2, 2), _material);
|
60
|
+
|
61
|
+
_scene.add(mesh);
|
62
|
+
|
63
|
+
this.setSize = function (width, height) {
|
64
|
+
renderer.setSize(width, height);
|
65
|
+
var pixelRatio = renderer.getPixelRatio();
|
66
|
+
|
67
|
+
_renderTargetL.setSize(width * pixelRatio, height * pixelRatio);
|
68
|
+
|
69
|
+
_renderTargetR.setSize(width * pixelRatio, height * pixelRatio);
|
70
|
+
};
|
71
|
+
|
72
|
+
this.render = function (scene, camera) {
|
73
|
+
scene.updateMatrixWorld();
|
74
|
+
if (camera.parent === null) camera.updateMatrixWorld();
|
75
|
+
|
76
|
+
_stereo.update(camera);
|
77
|
+
|
78
|
+
renderer.setRenderTarget(_renderTargetL);
|
79
|
+
renderer.clear();
|
80
|
+
renderer.render(scene, _stereo.cameraL);
|
81
|
+
renderer.setRenderTarget(_renderTargetR);
|
82
|
+
renderer.clear();
|
83
|
+
renderer.render(scene, _stereo.cameraR);
|
84
|
+
renderer.setRenderTarget(null);
|
85
|
+
renderer.render(_scene, _camera);
|
86
|
+
};
|
87
|
+
});
|
88
|
+
|
89
|
+
_exports.ParallaxBarrierEffect = ParallaxBarrierEffect;
|
90
|
+
});
|
@@ -0,0 +1,160 @@
|
|
1
|
+
(function (global, factory) {
|
2
|
+
if (typeof define === "function" && define.amd) {
|
3
|
+
define(["exports", "three"], factory);
|
4
|
+
} else if (typeof exports !== "undefined") {
|
5
|
+
factory(exports, require("three"));
|
6
|
+
} else {
|
7
|
+
var mod = {
|
8
|
+
exports: {}
|
9
|
+
};
|
10
|
+
factory(mod.exports, global.three);
|
11
|
+
global.PeppersGhostEffect = mod.exports;
|
12
|
+
}
|
13
|
+
})(typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : this, function (_exports, _three) {
|
14
|
+
"use strict";
|
15
|
+
|
16
|
+
Object.defineProperty(_exports, "__esModule", {
|
17
|
+
value: true
|
18
|
+
});
|
19
|
+
_exports.PeppersGhostEffect = void 0;
|
20
|
+
|
21
|
+
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
22
|
+
|
23
|
+
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
24
|
+
|
25
|
+
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
26
|
+
|
27
|
+
/**
|
28
|
+
* peppers ghost effect based on http://www.instructables.com/id/Reflective-Prism/?ALLSTEPS
|
29
|
+
*/
|
30
|
+
var PeppersGhostEffect = /*#__PURE__*/_createClass(function PeppersGhostEffect(renderer) {
|
31
|
+
_classCallCheck(this, PeppersGhostEffect);
|
32
|
+
|
33
|
+
var scope = this;
|
34
|
+
scope.cameraDistance = 15;
|
35
|
+
scope.reflectFromAbove = false; // Internals
|
36
|
+
|
37
|
+
var _halfWidth, _width, _height;
|
38
|
+
|
39
|
+
var _cameraF = new _three.PerspectiveCamera(); //front
|
40
|
+
|
41
|
+
|
42
|
+
var _cameraB = new _three.PerspectiveCamera(); //back
|
43
|
+
|
44
|
+
|
45
|
+
var _cameraL = new _three.PerspectiveCamera(); //left
|
46
|
+
|
47
|
+
|
48
|
+
var _cameraR = new _three.PerspectiveCamera(); //right
|
49
|
+
|
50
|
+
|
51
|
+
var _position = new _three.Vector3();
|
52
|
+
|
53
|
+
var _quaternion = new _three.Quaternion();
|
54
|
+
|
55
|
+
var _scale = new _three.Vector3(); // Initialization
|
56
|
+
|
57
|
+
|
58
|
+
renderer.autoClear = false;
|
59
|
+
|
60
|
+
this.setSize = function (width, height) {
|
61
|
+
_halfWidth = width / 2;
|
62
|
+
|
63
|
+
if (width < height) {
|
64
|
+
_width = width / 3;
|
65
|
+
_height = width / 3;
|
66
|
+
} else {
|
67
|
+
_width = height / 3;
|
68
|
+
_height = height / 3;
|
69
|
+
}
|
70
|
+
|
71
|
+
renderer.setSize(width, height);
|
72
|
+
};
|
73
|
+
|
74
|
+
this.render = function (scene, camera) {
|
75
|
+
scene.updateMatrixWorld();
|
76
|
+
if (camera.parent === null) camera.updateMatrixWorld();
|
77
|
+
camera.matrixWorld.decompose(_position, _quaternion, _scale); // front
|
78
|
+
|
79
|
+
_cameraF.position.copy(_position);
|
80
|
+
|
81
|
+
_cameraF.quaternion.copy(_quaternion);
|
82
|
+
|
83
|
+
_cameraF.translateZ(scope.cameraDistance);
|
84
|
+
|
85
|
+
_cameraF.lookAt(scene.position); // back
|
86
|
+
|
87
|
+
|
88
|
+
_cameraB.position.copy(_position);
|
89
|
+
|
90
|
+
_cameraB.quaternion.copy(_quaternion);
|
91
|
+
|
92
|
+
_cameraB.translateZ(-scope.cameraDistance);
|
93
|
+
|
94
|
+
_cameraB.lookAt(scene.position);
|
95
|
+
|
96
|
+
_cameraB.rotation.z += 180 * (Math.PI / 180); // left
|
97
|
+
|
98
|
+
_cameraL.position.copy(_position);
|
99
|
+
|
100
|
+
_cameraL.quaternion.copy(_quaternion);
|
101
|
+
|
102
|
+
_cameraL.translateX(-scope.cameraDistance);
|
103
|
+
|
104
|
+
_cameraL.lookAt(scene.position);
|
105
|
+
|
106
|
+
_cameraL.rotation.x += 90 * (Math.PI / 180); // right
|
107
|
+
|
108
|
+
_cameraR.position.copy(_position);
|
109
|
+
|
110
|
+
_cameraR.quaternion.copy(_quaternion);
|
111
|
+
|
112
|
+
_cameraR.translateX(scope.cameraDistance);
|
113
|
+
|
114
|
+
_cameraR.lookAt(scene.position);
|
115
|
+
|
116
|
+
_cameraR.rotation.x += 90 * (Math.PI / 180);
|
117
|
+
renderer.clear();
|
118
|
+
renderer.setScissorTest(true);
|
119
|
+
renderer.setScissor(_halfWidth - _width / 2, _height * 2, _width, _height);
|
120
|
+
renderer.setViewport(_halfWidth - _width / 2, _height * 2, _width, _height);
|
121
|
+
|
122
|
+
if (scope.reflectFromAbove) {
|
123
|
+
renderer.render(scene, _cameraB);
|
124
|
+
} else {
|
125
|
+
renderer.render(scene, _cameraF);
|
126
|
+
}
|
127
|
+
|
128
|
+
renderer.setScissor(_halfWidth - _width / 2, 0, _width, _height);
|
129
|
+
renderer.setViewport(_halfWidth - _width / 2, 0, _width, _height);
|
130
|
+
|
131
|
+
if (scope.reflectFromAbove) {
|
132
|
+
renderer.render(scene, _cameraF);
|
133
|
+
} else {
|
134
|
+
renderer.render(scene, _cameraB);
|
135
|
+
}
|
136
|
+
|
137
|
+
renderer.setScissor(_halfWidth - _width / 2 - _width, _height, _width, _height);
|
138
|
+
renderer.setViewport(_halfWidth - _width / 2 - _width, _height, _width, _height);
|
139
|
+
|
140
|
+
if (scope.reflectFromAbove) {
|
141
|
+
renderer.render(scene, _cameraR);
|
142
|
+
} else {
|
143
|
+
renderer.render(scene, _cameraL);
|
144
|
+
}
|
145
|
+
|
146
|
+
renderer.setScissor(_halfWidth + _width / 2, _height, _width, _height);
|
147
|
+
renderer.setViewport(_halfWidth + _width / 2, _height, _width, _height);
|
148
|
+
|
149
|
+
if (scope.reflectFromAbove) {
|
150
|
+
renderer.render(scene, _cameraL);
|
151
|
+
} else {
|
152
|
+
renderer.render(scene, _cameraR);
|
153
|
+
}
|
154
|
+
|
155
|
+
renderer.setScissorTest(false);
|
156
|
+
};
|
157
|
+
});
|
158
|
+
|
159
|
+
_exports.PeppersGhostEffect = PeppersGhostEffect;
|
160
|
+
});
|