Skip to content

Commit

Permalink
Merge pull request #1977 from ananyag309/master
Browse files Browse the repository at this point in the history
Added Patter Creation Game
  • Loading branch information
Sulagna-Dutta-Roy authored Jun 29, 2024
2 parents 5a5f78e + 4537987 commit 3b6ed3e
Show file tree
Hide file tree
Showing 5 changed files with 271 additions and 0 deletions.
25 changes: 25 additions & 0 deletions Pattern Creation Game/Readme.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<h1>Pattern Creation Game </h1>

A web-based game that allows users to create, save, load, and share patterns using a customizable grid. Users can select colors, change brush sizes, use an eraser, and apply a fill tool to create intricate designs.
<br>
<h3> Features </h3>

1- Color Picker: Select any color using an HTML color input. <br>
2- Brush Size Tool: Change the size of the brush to color multiple cells at once. <br>
3- Eraser Tool: Erase colors from the grid cells. <br>
4- Fill Tool: Fill the entire grid with the selected color. <br>
5- Undo/Redo: Revert or reapply the last few actions. <br>
6- Save Pattern: Save the current pattern as a JSON string. <br>
7- Load Pattern: Load a pattern from a JSON string. <br>
8- Clear Grid: Reset the entire grid to white.
<br>
<h3> How to Play </h3>

1- Select a Color: Use the color picker to choose a color, or click the "Eraser" to select the eraser tool. <br>
2- Change Brush Size: Select the desired brush size from the dropdown menu. <br>
3- Color the Grid: Click on grid cells to color them with the selected brush size and color. <br>
4- Fill Grid: Click the "Fill Grid" button to fill the entire grid with the selected color. <br>
5- Clear Grid: Click the "Clear Grid" button to reset the grid to white. <br>
6- Undo/Redo: Use the "Undo" and "Redo" buttons to revert or reapply the last few actions. <br>
7- Save Pattern: Click the "Save Pattern" button to save the current pattern as a JSON string in the textarea. <br>
8- Load Pattern: Enter a JSON string in the textarea and click the "Load Pattern" button to load the pattern.
36 changes: 36 additions & 0 deletions Pattern Creation Game/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Pattern Creation Game</title>
<link rel="stylesheet" href="styles.css">
<link rel="manifest" href="manifest.json">
</head>
<body>
<div id="game-container">
<div id="color-palette">
<input type="color" id="color-picker" onchange="selectColor(this.value)">
<div class="color eraser" onclick="selectColor('white')">Eraser</div>
</div>
<div id="controls">
<button onclick="savePattern()">Save Pattern</button>
<button onclick="loadPattern()">Load Pattern</button>
<button onclick="undo()">Undo</button>
<button onclick="redo()">Redo</button>
<button onclick="clearGrid()">Clear Grid</button>
<button onclick="fillGrid()">Fill Grid</button>
<label for="brush-size">Brush Size: </label>
<select id="brush-size" onchange="changeBrushSize(this.value)">
<option value="1">1x1</option>
<option value="2">2x2</option>
<option value="3">3x3</option>
</select>
</div>
<div id="grid-container"></div>
<textarea id="pattern-code" placeholder="Pattern code for save/load"></textarea>
</div>

<script src="script.js"></script>
</body>
</html>
22 changes: 22 additions & 0 deletions Pattern Creation Game/manifest.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
{
"name": "Pattern Creation Game",
"short_name": "PatternGame",
"description": "A game to create and save patterns.",
"start_url": "/",
"display": "standalone",
"background_color": "#ffffff",
"theme_color": "#000000",
"icons": [
{
"src": "icon-192x192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "icon-512x512.png",
"sizes": "512x512",
"type": "image/png"
}
]
}

110 changes: 110 additions & 0 deletions Pattern Creation Game/script.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
const gridContainer = document.getElementById('grid-container');
const patternCode = document.getElementById('pattern-code');
let selectedColor = 'black';
let brushSize = 1;
let grid = [];
let history = [];
let redoStack = [];

function createGrid() {
gridContainer.innerHTML = '';
for (let i = 0; i < 10; i++) {
grid[i] = [];
for (let j = 0; j < 10; j++) {
const cell = document.createElement('div');
cell.classList.add('grid-cell');
cell.addEventListener('click', () => colorCell(i, j));
grid[i][j] = { element: cell, color: 'white' };
gridContainer.appendChild(cell);
}
}
}

function colorCell(row, col) {
for (let i = 0; i < brushSize; i++) {
for (let j = 0; j < brushSize; j++) {
if (grid[row + i] && grid[row + i][col + j]) {
const cell = grid[row + i][col + j];
if (cell.color !== selectedColor) {
history.push({ row: row + i, col: col + j, color: cell.color });
redoStack = [];
cell.color = selectedColor;
cell.element.style.backgroundColor = selectedColor;
}
}
}
}
}

function selectColor(color) {
selectedColor = color;
}

function savePattern() {
const pattern = grid.map(row => row.map(cell => cell.color));
patternCode.value = JSON.stringify(pattern);
}

function loadPattern() {
try {
const pattern = JSON.parse(patternCode.value);
pattern.forEach((row, i) => {
row.forEach((color, j) => {
grid[i][j].color = color;
grid[i][j].element.style.backgroundColor = color;
});
});
history = [];
redoStack = [];
} catch (error) {
alert('Invalid pattern code');
}
}

function undo() {
const lastAction = history.pop();
if (lastAction) {
redoStack.push({ ...lastAction, color: grid[lastAction.row][lastAction.col].color });
grid[lastAction.row][lastAction.col].color = lastAction.color;
grid[lastAction.row][lastAction.col].element.style.backgroundColor = lastAction.color;
}
}

function redo() {
const lastUndo = redoStack.pop();
if (lastUndo) {
history.push({ ...lastUndo, color: grid[lastUndo.row][lastUndo.col].color });
grid[lastUndo.row][lastUndo.col].color = lastUndo.color;
grid[lastUndo.row][lastUndo.col].element.style.backgroundColor = lastUndo.color;
}
}

function clearGrid() {
for (let row of grid) {
for (let cell of row) {
cell.color = 'white';
cell.element.style.backgroundColor = 'white';
}
}
history = [];
redoStack = [];
}

function fillGrid() {
for (let row of grid) {
for (let cell of row) {
if (cell.color !== selectedColor) {
history.push({ row: grid.indexOf(row), col: row.indexOf(cell), color: cell.color });
cell.color = selectedColor;
cell.element.style.backgroundColor = selectedColor;
}
}
}
redoStack = [];
}

function changeBrushSize(size) {
brushSize = parseInt(size);
}

createGrid();
78 changes: 78 additions & 0 deletions Pattern Creation Game/styles.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
body {
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
margin: 0;
font-family: Arial, sans-serif;
background-color: #f0f0f0;
}

#game-container {
display: flex;
flex-direction: column;
align-items: center;
}

#color-palette {
display: flex;
margin-bottom: 20px;
}

#color-picker {
width: 40px;
height: 40px;
margin-right: 10px;
}

.color {
width: 30px;
height: 30px;
margin: 0 5px;
border: 1px solid #000;
cursor: pointer;
}

.eraser {
display: flex;
align-items: center;
justify-content: center;
width: auto;
padding: 0 10px;
background-color: white;
border: 1px solid #000;
font-size: 14px;
}

#controls {
margin-bottom: 20px;
}

button {
margin: 0 5px;
padding: 10px;
font-size: 14px;
cursor: pointer;
}

#grid-container {
display: grid;
grid-template-columns: repeat(10, 30px);
grid-template-rows: repeat(10, 30px);
gap: 2px;
}

.grid-cell {
width: 30px;
height: 30px;
background-color: white;
border: 1px solid #ddd;
cursor: pointer;
}

#pattern-code {
margin-top: 20px;
width: 300px;
height: 100px;
resize: none;
}

0 comments on commit 3b6ed3e

Please sign in to comment.