Skip to content

Instantly share code, notes, and snippets.

@cedrickchee
Last active March 31, 2025 23:56
Show Gist options
  • Save cedrickchee/91a6da1b88fcb7f95c13def90487e8e0 to your computer and use it in GitHub Desktop.
Save cedrickchee/91a6da1b88fcb7f95c13def90487e8e0 to your computer and use it in GitHub Desktop.
How to recreate Minecraft for web browser in under few minutes with Gemini Pro 2.5 Pro

How to recreate Minecraft for web browser in under few minutes with Gemini Pro 2.5 Pro

Three.js First-Person Game blueprint.

The Prompt

You are an experienced game developer tasked with creating an interactive first-person 3D game using Three.js. The game should be similar in style to the following game type:

<game_type>
{{GAME_TYPE}}
</game_type>

Your goal is to create a complete, self-contained game within a single HTML file. The game should allow users to place and destroy different types of blocks in a 3D world, similar to Minecraft.

Before writing the code, please consider the following aspects and provide your thoughts in <game_design_analysis> tags inside your thinking block:

1. How can we make the procedurally generated world more visually appealing?
   - Brainstorm at least 3 creative ideas for enhancing the world's appearance.
   - Consider potential challenges and solutions for each idea.

2. What optimizations can we implement to ensure good performance (high FPS, low CPU usage) similar to Minecraft in a web browser?
   - List at least 3 specific optimization techniques.
   - For each technique, briefly explain how it would improve performance.

3. How can we structure the code to maintain readability while keeping everything in a single file?
   - Propose a clear organization strategy for the code.
   - Consider potential challenges in maintaining a single-file structure and how to address them.

4. For each of the following features, brainstorm one unique or innovative idea to enhance the gameplay:
   a. Procedurally generated 3D world
   b. Various block types with different textures
   c. User interface for block selection
   d. Block placement and destruction mechanics
   e. First-person camera controls

After your analysis, please create the HTML file containing the complete game. Include all necessary JavaScript (using Three.js), CSS, and any required assets (you may use data URIs for images if needed). The game should have the following features:

1. A procedurally generated 3D world with a grid-based ground that the user can walk around on.
2. Various block types with different textures (e.g., wood, grass).
3. A user interface to select different block types.
4. Ability to place blocks by clicking, with blocks snapping to the sides of other blocks.
5. Ability to destroy blocks.
6. First-person camera controls for navigation.
7. Optimized performance to handle a reasonable number of blocks smoothly.

Please provide your complete HTML file within <html_code> tags. Ensure that the code is well-commented and organized for readability.

Your final output should consist only of the HTML code within the <html_code> tags and should not duplicate or rehash any of the work you did in the game design analysis section.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment