Skip to content

Demo Simulation

Under Construction

This section and others in Getting Started with SceneryStack are under heavy revisement and will be updated in January 2025.

TODO: remove the PhET-specific bits TODO: screenshots

Prerequisites

Before setting up your development environment, ensure the following tools are installed:

  1. Command Line Interface: Use Terminal (macOS/Linux) or Command Prompt (Windows).
  2. Git: Download from git-scm.com or install via Xcode command-line tools on macOS/Linux.
  3. Node.js and npm: Install the latest version from Node.js.

The demo-sim is a great example for setting the structure of a simulation, or for learning how to create or modify a simulation.

Getting Started

To get started:

  1. Clone the demo-sim repository.
  2. Install the dependencies by running npm install.
  3. Start the development server by running npx vite. It will print a url (like http://localhost:5173/) where you can view the running simulation.

Sample Exercises

Here you will find a list of coding exercises that are designed to provide insight into the fundamentals of PhET Sim Development.

This is meant to be a fun learning experience, so do enjoy!

1. Add a second magnet to demo sim ๐Ÿงฒ

Look at the way the first magnet was created in the simulation. How should you go about displaying a second one that shares the same logic? You will frequently find yourself instantiating multiple objects of the same class in PhET sims. Keeping the code organized, and minimizing repetition is something to consider. Remember to read through The Model-View coding pattern .

HintLook into `MagnetsScreenView.js` to see how the magnet is added to the screen. There will be a model field for the magnet, so you'll have to work your way around that in `MagnetsModel.js`...

2. Add a ball โšฝ๏ธ

Create a Ball class in the model, then create the corresponding BallNode class in the view ( it should extend ShadedSphereNode ). Display the ball in the simulation and make the BallNode draggable. This time, you will have to create new files for the object, in both the model and the view directories. When developing sims, you will do this for almost every new class of an object there is on the screen.

HintYou can make the contents of `Ball.js` (The model) very similar to `BarMagnet.js`. As for the Node, read through the constructor documentation of `ShadedSphereNode.js` to know what to add to the `super()` call.

3. Add a checkbox that controls the Ball's visibility โ˜‘๏ธ

Most PhET Simulations have checkboxes that control boolean aspects of the sim. Have you read about phetmarks yet? Use it to access the Sun example to see how checkboxes are implemented, remember you can use Ctrl + Shift + H to get details as to how components are used.

HintLook into `MagnetsControlPanel` in example-sim, that's where you have to add the Checkbox. Also, checkboxes get a Property as their first parameter, so you should probably give it the `visibleProperty` of Ball.

4. Add a HSlider to control the ballโ€™s diameter ๐ŸŽš

Sliders are frequently used as a way for users to interact with the components, physics, or data on the screen. Once again, you should refer to Sun's implementation of Sliders as a starting point to control your ball's diameter.

HintTry passing in the BallNode's radius or diameter properties to the slider, and don't forget to use `link` to ensure these changes are being communicated between the components.

5. Options ๐ŸŽจ

Add an option to the ball constructor to control its color. Read through the Javascript Options design pattern, if you're using JS. Keep in mind that the Javascript options pattern is different than the TypeScript options pattern .

Hint You can look into `ShadedSphereNodeOptions` to know what options you can play with.

6. Layout ๐Ÿ–ผ

Proper layout is a big part of ensuring users have the best experience possible when interacting with PhET sims. Organize the checkbox and slider in their own control panel to the lower left of the screen. Look into the implementation of control panels in other PhET sims. You might find a variety of ways this is done and all of them are right! Be inspired to take from the examples you see, or implement your own approach.

Hint In PhETmarks, Scenery/layout-documentation is the best place to learn about all the amazing tools that have been built for layout management. Start there to discover what tools you have at your disposal, and narrow down the approach you want to use.

7. You did it! ๐ŸŽ‰

Great job you got through all the exercises! Give yourself a pat on the back, you just learned a lot. To get feedback on your solutions, make sure to assign the corresponding issue to your mentor for review. Once you've done that and both you and your mentor feel satisfied, close the issue and delete the branch.