Starting yesteday, Gemini Advanced users can create with Canvas on Gemini 2.5 Pro (experimental).
Canvas mode make it easy to create prototypes quickly, like this game I made in under few hours with just 50 prompts.
I vibe coded this game while I'm on the move, taking bus and train.
Full prompts. Excluding the JS errors in Chrome Developer console, the total effective prompts are lower than 50.
1. Make a 3D flying plane game in browser with trees, sky, clouds
2. Make it work on mobile using touch gestures and ensure the layout is responsive
3. The plane mechanics is wrong. Can you make the plane yaw?
4. Make the ground landscape visual more interesting
5. I'm seeing a black screen and I cannot see the plane. Something wrong. Fix them
6. I got an error in Chrome developer console.
<log>
Error during initialization: TypeError: color.clamp is not a function
</log>
Can you fix the error?
7. Make the sky visual more appealing. Change to sky blue color. Maybe add some simple birds with different varieties
8. It looks OK but not visually appealing. Add more birds. Make it larger. Randomize the bird sizes.
9. The birds looks good now. Let's move on. Now add 5 hot air baloons in the sky with different color and size animating freely and random path in the sky space.
10. They look great! Let's continue. Make the urban landscape more interesting. Add a variety of simple houses with roof, windows and maybe chimney. Scattered across the ground and respecting the ground height. Random house size - big, small, wide, tall
11. The triangular prism roof on top the box for the main body of the house doesn't align properly. Can you correct this and update the code?
12. Still the same issue. Nevermind. Remove the houses. Let's move on.
13. Now, add 2 simple giant robot with two red eyes minecraft style on the ground to make the urban landscape more appealing.
14. I can see the 2 giant robots. Can you change the color to dark blue for the body, light blue for the head, and dark green for the legs and hands?
15. It looks good! Let's continue improving the game design and visual. Add a big castle, minecraft style voxel or blocky.
16. Not bad! Now let's add a 10 tall and big mountains on the ground and scattered them across the whole ground. Make sure they don't collide with existing structure like trees, castle, robot on the ground landscape.
17. It looks boring. Make them slightly more visually interesting and change the mountain color to darker green.
18. I got an error in Chrome developer console.
<log>
Error during initialization: TypeError: finalColor.clamp is not a function
createMountain :381
createScenery :439
init :303
EventListener.handleEvent* :555
error :30
init
</log>
Please find the bug if any and fix the error.
19. The error is gone. Now make the urban landscape more interesting; add some ponds.
20. The pond visual is boring. Can you improve the shape or geometry such that it doesn't look very circle or oval? Also, change the colour of the water in the pond to brighter light blue.
21. I got an error in my Chrome developer console.
<log>
Error during initialization: ReferenceError: POND_SEGMENTS is not defined
createPond :389
createScenery :462
init :315
EventListener.handleEvent* :582
error :30
init
</log>
Fix them?
22. Good. Now let's add 5 parks
23. Let's continue. Now add 2 large area farms with cows in them, minecraft style on the ground.
24. It looks great! Now add some villages near the rural area on the ground. Again, I prefer the village design to be minecraft style.
25. OK. Add an Eiffel Tower somewhere on the ground.
26. It looks weird. Anyway, I want to move on and focus on UI/UX features. First, add a minimap showing the plane speed and altitutude.
27. It looks fine. Now, can you add sea and beaches on the ground?
28. I got an error in Chrome Developer console.
<log>
Error during initialization: TypeError: finalColor.clamp is not a function
createGround :469
init
</log>
Can you fix the code?
29. I got another error.
<log>
Error during initialization: ReferenceError: geometry is not defined
createGround :466
init
</log>
Be careful. Can you find the bug if any and fix it?
30. The error was resolved. The position of the beach and sea should not split the land (ground into two sides). Put the beach and sea area surrounding the land. Can you correct them?
31. Looks good! Now add some big ship in the sea area. I want the ship design in minecraft style.
32. It looks good. Now 30 cars in minecraft style scattered on the land mostly and some near the beach area. Animate some of the cars moving in a fixed path.
33. Everything is good. Now, let's add 3 big factories minecraft style on the ground.
34. Looks fine. Let's move on to gaming sound. Add plane engine sounds (varying with speed).
35. I got a similar error in my developer console.
<log>
Error during initialization: ReferenceError: factories is not defined
createScenery :608
init :446
EventListener.handleEvent* :758
error :30
init
</log>
Can you fix the code?
36. Great, I can hear the engine sound. I don't like the engine sound like brown noise. Change it to a sound that best represent realistic cesna or classic 2-seater small plane engine sound.
37. This is good! Can you add collision sounds?
38. OK. Lets' improve the UI. Add a simple aircraft radar display that presents radar data to the operator (the player). It should looks like a circle with a pulsating green light scanning for other planes. If those planes are within the radar zone, show a red dot on the radar display.
39. Looks nice. Let's work on the gameplay next. Add weapons and dogfighting mechanics (shooting, health, damage)
40. Great. I can shoot and destroy the balloon. Change the bullet color to red. Show the balloon health in the UI.
41. I got an error in Chrome Developer console
<log>
Uncaught SyntaxError: redeclaration of const bulletMaterial :778:15
note: Previously declared at line 455, column 15
</log>
Fix the error.
42. Still the same error
Uncaught SyntaxError: redeclaration of const bulletMaterial :750:15
note: Previously declared at line 455, column 15
43. The fix works. Now I got a different error.
<log>
Error during animation frame: ReferenceError: carGroup is not defined
updateCars :810
updateCars :810
animate
</log>
Please fix them.
44. Error resolved. Let's move on to update the UI. Add a loading screen. For gameplay, tell the player their objectives and missions. Clearer indicators for other players (names, distance). Menus for settings, player lists, etc.
45. Update the HUD display. Add pitch, roll, yaw, heading, health, baloons hit, balloon left, score. Placeholder if the value is not available yet.
46. I cannot see the restart button and start screen. I think it's hidden? Can you please correct them? Also the "Game Over" message should not tell the player to "refresh to play again."
47. Make the user experience much better. Update the start screen with more engaging message. Put a cool game name with a big text there. Add a welcome message to players and introduce the game in 1-2 sentences.
48. The start screen is good for now. Let's move on. The game is not occupying the full width and height of the browser window. It was working fine previously. I think the problem is in the canvas or container width and height. Can you fix them?
49. The corrected code fix the issue. I want to adjust the UI. Move the HUD display to the top-left of the game container and move the instructions box down. In addition, change the instruction box background color from white to the same background color as the HUD display. The game canvas should fill the full viewport height and width.
50. The basic combat mechanics is broken. The player cannot shoot and destroy the hot air balloons. Actually, I think they can shoot but they cannot see the red bullet anymore. Can you fix the bug?
51. Now I can see the red bullets. The bullet animation is wrong. It's moving in the wrong direction from the plane. It's floating and moving very slow and moving backward from the plan. The bullet should move forward and towards the enemy target. All these were working previously.
Mind-blowing! 🫡 @cedrickchee