Bouncing Ball
The bouncing ball is the "Hello World!" of the Processing system. It contains the key element that shows the power of the Processing system: graphics with movement. In the area of MicroSims, we also want clearly visible user interface elements that can control the running of our simulations. This version contains a slider to control the speed of the ball's movement.
Prompt
Here is a simple prompt to get you started.
Generate a single p5.js sketch of a blue bouncing ball on a 500x300 canvas.
Copy the prompt into ChatGPT. It will generate a JavaScript file you can copy and paste or download into the p5.js editor to test.
Here is a more precise prompt that also allows us to change the speed using a slider.
The sketch shows a ball bouncing around a rectangular area.
The canvas should be 500 wide and 300 high.
The default text size is 16.
The ball is blue and has a radius of 20.
There is a slider that changes the speed from 0 to 20 with a default speed of 3.
The slider should be placed at the bottom of the canvas.
The slider should have a label "Speed: " and the speed value to the left of the slider.
The slider should span the width of the canvas after the label and value.
DD NOT use objects - just functions.
Here is an additional example that allows the user to change both the speed and the ball size:
Sample Source Code
Here is some sample source code that has been generated and modified just a little for readability.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
|
Key Points about the Code
- We created some global variables before the setup() function
- We created a setup() function to initialize the canvas and the slider
- We created a draw() function to render check that moves the ball, checks the edges, and draws the circle and text.
Use In Classroom
- Physics Lesson: Use this simulation to discuss concepts like velocity, acceleration, and kinetic energy. Ask students to predict how changing the speed will affect the ball's movement.
- Math Integration: Introduce concepts of geometry and algebra, such as calculating the ball's trajectory or the distance traveled over time.
- Coding Concepts: Use this as a base for teaching basic programming concepts, such as variables, functions, and object-oriented programming. Students can modify the code to change the ball's size, color, or even add more balls.
Lesson Plan for a 9th-Grade Physical Science Class
Objective
Students will understand the concepts of kinetic and potential energy, and how these energies are transformed during the motion of a bouncing ball.
Materials
- Computer with internet access for the p5.js editor.
- The bouncing ball simulation (as provided in the previous response).
- Whiteboard or chalkboard.
- Writing materials for students.
Lesson Plan
Introduction (10 minutes)
- Begin with a brief discussion on energy: what it is and its different forms, focusing on kinetic and potential energy.
- Introduce the concept of energy transformation, particularly how potential energy is converted to kinetic energy and vice versa.
Demonstration (15 minutes)
- Display the bouncing ball simulation to the class.
- Show how the ball’s speed (kinetic energy) increases as it falls (due to potential energy converting to kinetic energy) and decreases as it rises (kinetic converting back to potential).
Interactive Activity (20 minutes)
- Have the students access the simulation on their computers.
- Ask them to experiment with different speeds and observe the ball’s behavior.
- Prompt questions for exploration:
- How does changing the speed affect the ball’s motion?
- Can they identify when the ball has the most kinetic or potential energy?
Group Discussion (15 minutes)
- Bring the class back together to discuss their observations.
- Facilitate a conversation about how the simulation demonstrates the concepts of kinetic and potential energy.
- Discuss real-world examples, like a roller coaster or a skateboarder in a halfpipe.
Concept Application (20 minutes)
- Provide a worksheet with problems related to kinetic and potential energy.
- Include problems where students calculate the potential energy at the ball’s highest point and the kinetic energy at different points of the motion.
- Students can use the simulation to visually understand the problems.
Wrap-Up and Reflection (10 minutes)
- Summarize the key concepts learned in the lesson.
- Ask students to write a short paragraph on how the simulation helped them understand the energy transformation.
Homework
- Assign a project where students create their own simulation or modify the existing one to demonstrate a different physics concept.
Assessment
- Participation in the interactive activity and group discussion.
- Accuracy and understanding shown in the worksheet.
- Reflection paragraph and homework project.