A university physics project for simulating satellites in orbit.
- Clone the git repository locally or download the source-code and extract it.
- Install Node.js 16.x on your system.
- Enable Yarn through
corepack
, which ships with Node 16.x.
# Use an elevated shell (Administrator shell on Windows, sudo on Unix).
corepack enable
- Open a terminal in the root of the repository and install the project's dependencies.
yarn
- Start the development server.
yarn start
- A browser page should automatically open with the project running in it.
- Three.js
- TypeScript
- Husky and ESLint
- Webpack
It's a webserver provided by webpack that serves the project while being built in realtime and stored in memory.
You can read more about it here, here and here.
Runs by default on port 9000 and so can be accessed at http://localhost:9000/ (should automatically open when starting the dev server).
When using the development server you'll have the benefit of automatic live reload whenever changes are made.
The HMR support is enabled in the project, but the code has to support it.
Which means writing code that accepts the module replacements and does any adjustments needed.
That is implemented for src/app.ts
in src/index.ts
.
So when app.ts
is modified it's hot reloaded without reloading the whole page, by replacing the old scene instance by a new one.
But when files such as src/physics/kepler-math.ts
are modified with no HMR support, a whole page reload is automatically performed.
During the project development you might wish to implement HMR support for other sub-modules, for example to avoid losing the state of created scene objects.
You can read more at webpack's documentation page.
After following the installation instructions run:
yarn build
The build can be then accessed at /dist
and could be served as static page content.
Icons are from: https://www.svgrepo.com/
Satellite 3D model, under Creative Commons Attribution, was modified by RedDeadAlice.
- Rami Sabbagh (rami.sab07@gmail.com).
- Hasan Mothaffar (hasan.mozafar@gmail.com).
- Yaman Qassas (yaman102011@gmail.com).
- Edward Karra (edwardkarra@gmail.com).
- RedDeadAlice.