生存难度系统图像制作器
资源中心 » 生存难度系统图像制作器
此为一个方便的“生存难度系统图像制作器”,可以制作适用于层级等级组件的菱形框内的图片。
使用方式
1. 输入1~5个字符,即生存难度图片内的内容。(您可先空生成一次查看图片)
2. 点击 生成图像,生成图片。
3. 进行微调,通过调整X坐标、Y坐标、颜色及字体大小对图片进行调整。
4. 保存图片,然后上传到任意网站进行使用。
使用示例
[[include component:level-class
|class=符号
|lang=cn/tr
|color=颜色
|image=图片链接
]]
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>生存难度系统图像制作器</title> <style> body { font-family: Arial, sans-serif; text-align: center; margin: 20px; } canvas { border: 1px solid #ccc; margin-top: 20px; } input, button { border-radius: 0; border: 1px solid #000; } </style> </head> <body> <h1>生存难度系统图像制作器</h1> <label for="textInput">输入图片文字(字数限制为 5):</label> <input type="text" id="textInput" placeholder="输入文字" maxlength="5"><br> <label for="fontSizeInput">调整字体大小(单个字推荐60 - 70):</label> <input type="number" id="fontSizeInput" min="24" max="128" value="68"><br> <label for="xInput">X 坐标(可选):</label> <input type="number" id="xInput" placeholder="X 坐标" min="-50" max="280" value="100"><br> <label for="yInput">Y 坐标(可选):</label> <input type="number" id="yInput" placeholder="Y 坐标" min="-50" max="250" value="15"><br> <label>选择颜色:</label> <input type="color" id="colorInput" value="#000000"><br> <canvas id="outputCanvas" width="236" height="198"></canvas><br> <button onclick="generateImage()">生成图像</button> <button onclick="downloadImage()">下载图像</button> <script> let imageDataUrl = ''; function generateImage() { const text = document.getElementById('textInput').value; const fontSize = document.getElementById('fontSizeInput').value; const x = document.getElementById('xInput').value; const y = document.getElementById('yInput').value; const color = document.getElementById('colorInput').value; const canvas = document.getElementById('outputCanvas'); const ctx = canvas.getContext('2d'); const img = new Image(); img.crossOrigin = "anonymous"; img.src = ""; img.onload = function() { ctx.clearRect(0, 0, canvas.width, canvas.height); ctx.drawImage(img, 0, 0); ctx.font = fontSize + "px Arial"; ctx.textAlign = "left"; ctx.textBaseline = "top"; ctx.fillStyle = color; ctx.fillText(text, parseInt(x, 10), parseInt(y, 10)); const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height); for (let i = 0; i < imageData.data.length; i += 4) { if (imageData.data[i + 3] !== 0) { const [r, g, b] = colorToRgb(color); imageData.data[i] = r; imageData.data[i + 1] = g; imageData.data[i + 2] = b; } } ctx.putImageData(imageData, 0, 0); imageDataUrl = canvas.toDataURL(); }; } function downloadImage() { if (imageDataUrl) { const a = document.createElement('a'); a.href = imageDataUrl; a.download = 'result_image.png'; a.click(); } else { alert('请先生成图像!'); } } function colorToRgb(hexColor) { const hex = hexColor.replace(/^#/, ''); const bigint = parseInt(hex, 16); return [(bigint >> 16) & 255, (bigint >> 8) & 255, bigint & 255]; } </script> </body> </html>