Retro Video Game Idea Generator
Generated Game Idea:
Click "Generate Idea" to conjure a new retro video game concept!
Unique Retro Feature: ${uniqueFeature}
`; outputContent.innerHTML = outputHTML; } function downloadPdf() { const { jsPDF } = window.jspdf; const doc = new jsPDF({ orientation: 'P', // Portrait unit: 'mm', format: 'a4' }); // Target the output section for PDF const element = document.getElementById('ideaOutput'); // Apply temporary print styles for PDF generation (cleaner output) const pdfStyles = ` #retroGameIdeaGenerator { background-color: #ffffff !important; /* White background for print */ color: #000 !important; /* Black text */ box-shadow: none !important; border: none !important; padding: 10mm !important; /* Use mm for consistency */ margin: 0 !important; font-size: 10pt !important; line-height: 1.5 !important; font-family: sans-serif !important; /* Use standard font */ } #retroGameIdeaGenerator h2, #retroGameIdeaGenerator h3, #retroGameIdeaGenerator #outputContent strong{ color: #000 !important; /* Black headings and labels */ text-shadow: none !important; font-family: sans-serif !important; } #retroGameIdeaGenerator h2 { font-size: 14pt !important; } #retroGameIdeaGenerator h3 { font-size: 12pt !important; border-bottom-color: #ccc !important; } #retroGameIdeaGenerator .controls-section { display: none !important; /* Hide controls */ } #retroGameIdeaGenerator .output-section { border: none !important; background-color: #fff !important; padding: 0 !important; min-height: auto !important; } #retroGameIdeaGenerator #outputContent { min-height: auto !important; color: #000 !important; /* Black text */ white-space: pre-wrap !important; line-height: 1.5 !important; font-size: 10pt !important; } #retroGameIdeaGenerator #outputContent strong { display: inline !important; margin-right: 3mm !important; font-size: 10pt !important; } #retroGameIdeaGenerator #outputContent p { margin-bottom: 8mm !important; /* Space between paragraphs */ } `; const styleTag = document.createElement('style'); styleTag.setAttribute('id', 'pdfPrintStyles'); styleTag.innerHTML = pdfStyles; document.head.appendChild(styleTag); // Use html2canvas to render the element as an image/canvas html2canvas(element, { scale: 2, // Increase scale for better resolution in PDF logging: false, // Disable html2canvas logging backgroundColor: '#ffffff' // Explicitly set white background }).then(canvas => { const imgData = canvas.toDataURL('image/png'); const pdfWidth = doc.internal.pageSize.getWidth(); const pdfHeight = doc.internal.pageSize.getHeight(); const imgWidth = pdfWidth - 20; // Leave 10mm margin on each side const imgHeight = canvas.height * imgWidth / canvas.width; let heightLeft = imgHeight; let position = 10; // Starting Y position (10mm margin) // Add the image to the PDF const imgX = (pdfWidth - imgWidth) / 2; // Center the image doc.addImage(imgData, 'PNG', imgX, position, imgWidth, imgHeight); heightLeft -= (pdfHeight - position); // Handle multiple pages if content exceeds one page while (heightLeft >= 0) { position = 10; // Reset position for new page doc.addPage(); // Add background to the new page doc.setFillColor(255); // White doc.rect(0, 0, pdfWidth, pdfHeight, 'F'); // Calculate the source y position on the canvas image const srcY = imgHeight - heightLeft; // Add the remaining part of the image doc.addImage(imgData, 'PNG', imgX, position, imgWidth, heightLeft, null, null, 0, srcY); heightLeft -= (pdfHeight - position); } // Add a title specifically for the PDF doc.setFontSize(18); doc.setTextColor(50, 50, 50); // Dark Gray doc.text("Retro Video Game Idea", pdfWidth / 2, 8, { align: 'center' }); // Remove the temporary print styles const addedTag = document.getElementById('pdfPrintStyles'); if (addedTag) { addedTag.remove(); } doc.save('retro_game_idea.pdf'); }).catch(error => { console.error("Error generating PDF:", error); alert("Could not generate PDF. Please try again."); // Ensure styles are removed even on error const addedTag = document.getElementById('pdfPrintStyles'); if (addedTag) { addedTag.remove(); } }); } // Event Listeners generateBtn.addEventListener('click', generateIdea); downloadPdfBtn.addEventListener('click', downloadPdf); // Initial text outputContent.innerHTML = 'Click "Generate Idea" to conjure a new retro video game concept!
'; });Key Features:
Customizable Inputs: Users can input game genre, setting, and main character to generate unique retro video game ideas.
AI-Generated Ideas: The tool creates vivid and imaginative retro video game concepts based on user inputs.
Centered Design: The tool is perfectly centered on the page, ensuring a clean and professional look.
PDF Download: Users can download the generated game idea as a PDF, complete with the same color scheme for consistency.
Responsive Design: The tool is fully responsive and works seamlessly on all devices.
Benefits for End Users:
Creative Fun: Users can generate unique and imaginative retro video game ideas for entertainment or personal projects.
Customizable Outputs: The tool allows users to tailor the generated game ideas based on specific traits.
Educational Tool: Great for students and educators to explore creativity and game design concepts.
Portable Results: The PDF download feature allows users to save and share their generated game ideas easily.
User-Friendly Interface: The simple and intuitive design ensures that users of all ages and technical skill levels can use the tool effortlessly.
