Skip to content

Commit

Permalink
Sun Motion sim: Add fixes for current version of three.js
Browse files Browse the repository at this point in the history
There have been many three.js changes since this app was last built -
these required some changes in our code to fix the scene up.

https://github.com/mrdoob/three.js/wiki/Migration-Guide
  • Loading branch information
nikolas committed Aug 31, 2023
1 parent c28eb3a commit 1d26c0f
Show file tree
Hide file tree
Showing 6 changed files with 92 additions and 79 deletions.
2 changes: 1 addition & 1 deletion sun-motion-simulator/dist/bundle.js

Large diffs are not rendered by default.

96 changes: 52 additions & 44 deletions sun-motion-simulator/dist/bundle.js.LICENSE.txt
Original file line number Diff line number Diff line change
Expand Up @@ -5,138 +5,146 @@ object-assign
*/

/*!
* @pixi/app - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/app - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/app is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/constants - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/constants - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/constants is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/core - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/core - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/core is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/display - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/display - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/display is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/extract - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/extensions - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/extract is licensed under the MIT License.
* @pixi/extensions is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/filter-displacement - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/filter-displacement - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/filter-displacement is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/math - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/math - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/math is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/mesh-extras - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/mesh-extras - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/mesh-extras is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/mixin-get-child-by-name - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/mixin-get-child-by-name - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/mixin-get-child-by-name is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/mixin-get-global-position - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/mixin-get-global-position - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/mixin-get-global-position is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/polyfill - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/polyfill - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/polyfill is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/prepare - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/prepare - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/prepare is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/ticker - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/settings - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/settings is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/ticker - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/ticker is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* @pixi/utils - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* @pixi/utils - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* @pixi/utils is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*!
* pixi.js - v6.3.0
* Compiled Wed, 23 Mar 2022 18:58:56 UTC
* pixi.js - v6.5.1
* Compiled Sun, 24 Jul 2022 20:56:21 UTC
*
* pixi.js is licensed under the MIT License.
* http://www.opensource.org/licenses/mit-license
*/

/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0

THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.

See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
Copyright (c) Microsoft Corporation.

Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.

THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */

/*! For license information please see index.js.LICENSE.txt */
Expand All @@ -145,7 +153,7 @@ and limitations under the License.

/**
* @license
* Copyright 2010-2022 Three.js Authors
* Copyright 2010-2023 Three.js Authors
* SPDX-License-Identifier: MIT
*/

Expand Down
2 changes: 1 addition & 1 deletion sun-motion-simulator/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ <h5 class="modal-title" id="aboutModalLabel">
</div>
<div class="modal-body">
<p class="sim-version">
sun-motion-simulator 0.8.0 (build date: 2021-05-07)
sun-motion-simulator 0.8.0 (build date: 2023-08-31)
</p>
<p>
See
Expand Down
1 change: 1 addition & 0 deletions sun-motion-simulator/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

26 changes: 15 additions & 11 deletions sun-motion-simulator/src/CelestialSphere.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,13 @@ import React from 'react';
import PropTypes from 'prop-types';
import * as THREE from 'three';
import WEBGL from './utils/WebGL';
import {OrbitControls} from 'three/examples/jsm/controls/OrbitControls.js';
import {FXAAShader} from 'three/examples/jsm/shaders/FXAAShader.js';
import {EffectComposer} from 'three/examples/jsm/postprocessing/EffectComposer.js';
import {RenderPass} from 'three/examples/jsm/postprocessing/RenderPass.js';
import {ShaderPass} from 'three/examples/jsm/postprocessing/ShaderPass.js';
import {FontLoader} from 'three/examples/jsm/loaders/FontLoader.js';
import {TextGeometry} from 'three/examples/jsm/geometries/TextGeometry.js';
import {OrbitControls} from 'three/addons/controls/OrbitControls.js';
import {FXAAShader} from 'three/addons/shaders/FXAAShader.js';
import {EffectComposer} from 'three/addons/postprocessing/EffectComposer.js';
import {RenderPass} from 'three/addons/postprocessing/RenderPass.js';
import {ShaderPass} from 'three/addons/postprocessing/ShaderPass.js';
import {FontLoader} from 'three/addons/loaders/FontLoader.js';
import {TextGeometry} from 'three/addons/geometries/TextGeometry.js';
import {getDayOfYear, getEqnOfTime, getPosition, getTime} from './utils';
import MutedColorsShader from './shaders/MutedColorsShader';

Expand Down Expand Up @@ -113,14 +113,18 @@ export default class CelestialSphere extends React.Component {
renderer.domElement.addEventListener(
'pointerout', this.onMouseUp, false);
renderer.setPixelRatio(window.devicePixelRatio);
renderer.setClearColor(0x000000);
//renderer.setClearColor(0x000000);
renderer.shadowMap.enabled = true;

// TODO: this will be removed in the future, but necessary for now:
// https://discourse.threejs.org/t/updates-to-lighting-in-three-js-r155/53733
renderer.useLegacyLights = true;

// Lights
const ambient = new THREE.AmbientLight(0x909090);
const ambient = new THREE.AmbientLight(0xd0d0d0);
scene.add(ambient);

const light = new THREE.DirectionalLight(0xb0b0b0);
const light = new THREE.DirectionalLight(0xc0c0c0);
this.light = light;
const declinationRad = this.getSunDeclinationRadius(
this.props.sunDeclination);
Expand Down Expand Up @@ -314,7 +318,7 @@ export default class CelestialSphere extends React.Component {
this.props.sunDeclination);
this.sun.rotation.x = this.props.sunDeclination;

this.light.position.copy(this.sun.position)
this.light.position.copy(this.sun.position);
this.light.rotation.x = this.props.sunDeclination;

if (this.props.showDeclinationCircle) {
Expand Down
44 changes: 22 additions & 22 deletions sun-motion-simulator/src/shaders/MutedColorsShader.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,40 +5,40 @@
* https://github.com/mrdoob/three.js/blob/master/examples/js/shaders/SepiaShader.js
*/
const MutedColorsShader = {
uniforms: {
"tDiffuse": { value: null },
"amount": { value: 1.0 }
},
uniforms: {
"tDiffuse": { value: null },
"amount": { value: 1.0 }
},

vertexShader: [
"varying vec2 vUv;",
vertexShader: [
"varying vec2 vUv;",

"void main() {",
"void main() {",

"vUv = uv;",
"gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );",
"vUv = uv;",
"gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );",

"}"
].join( "\n" ),
"}"
].join( "\n" ),

fragmentShader: [
"uniform float amount;",
fragmentShader: /* glsl */`
"uniform sampler2D tDiffuse;",
uniform float amount;
"varying vec2 vUv;",
uniform sampler2D tDiffuse;
"void main() {",
varying vec2 vUv;
"vec4 color = texture2D( tDiffuse, vUv );",
"vec3 c = color.rgb;",
void main() {
"color.g = dot( c, vec3( 0.2 * amount, 1.0 - 0.314 * amount, 0.168 * amount ) );",
vec4 color = texture2D( tDiffuse, vUv );
vec3 c = color.rgb;
"gl_FragColor = vec4( min( vec3( 1.0 ), color.rgb ), color.a );",
color.g = dot( c, vec3( 0.349 * amount, 1.0 - 0.314 * amount, 0.168 * amount ) );
"}"
].join( "\n" )
gl_FragColor = vec4( min( vec3( 1.0 ), color.rgb ), color.a );
}`
};

export default MutedColorsShader;

0 comments on commit 1d26c0f

Please sign in to comment.