生存难度系统图像制作器
一个方便的“生存难度系统”图像制作器,可以制作适用于层级等级组件的菱形框内的图片。
使用方式
1. 输入字符,即生存难度图片内的内容。
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, select { border-radius: 0; border: 1px solid #000; } .control { float: left; width: 50%; margin-top: 10px; } .display { margin-left: 50%; } #outputCanvas { background-color: #e8e9e9; background-image: linear-gradient(45deg, #ffffff 25%, transparent 25%), linear-gradient(-45deg, #ffffff 25%, transparent 25%), linear-gradient(45deg, transparent 75%, #ffffff 75%), linear-gradient(-45deg, transparent 75%, #ffffff 75%); background-size: 20px 20px; background-position: 0 0, 0 10px, 10px -10px, -10px 0px; } </style> </head> <body> <h1>生存难度系统图像制作器</h1> <div class="control"> <label for="textInput">输入文字:</label><br> <textarea id="textInput" placeholder="输入文字" maxlength="20"></textarea><br> <label for="fontFamily">选择字体:</label> <select id="fontFamily"> <option value="Arial">Arial</option> <option value="Microsoft YaHei">微软雅黑</option> <option value="SimHei">黑体</option> <option value="SimSun">宋体</option> <option value="Times New Roman">Times New Roman</option> </select><br> <label for="fontSizeInput">调整字体大小:</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 for="bgImage">选择背景图片样式:</label> <select id="bgImage"> <option value="MEGImage">普通</option> <option value="MEGImageStar">普通(带星形)</option> </select><br> <label>选择颜色模式:</label> <select id="colorMode"> <option value="solid">纯色</option> <option value="gradient">渐变色</option> </select> <div id="solid"> <label for="s_color">选择颜色:</label> <input type="color" id="s_color" value="#000000"> </div> <div id="gradient" style="display: none;"> <div class="select"> <div> <label for="color1">起始颜色:</label> <input type="color" id="color1" value="#FF0000"> </div> <div> <label for="color2">结束颜色:</label> <input type="color" id="color2" value="#0000FF"> </div> </div> <label for="dir">渐变方向:</label> <select id="dir"> <option value="hor">水平</option> <option value="ver">垂直</option> </select> </div> </div> <div class="display"> <canvas id="outputCanvas" width="236" height="198"></canvas><br> <button onclick="generateImage()">生成图像</button> <button onclick="downloadImage()">下载图像</button> </div> <script src="https://brsandbox-pro.wdfiles.com/local--code/diy-sd-class-img/2"></script> </body> </html>
let imageDataUrl = ''; const bgImages = { "MEGImage":"", "MEGImageStar": "" } function generateImage() { const text = document.getElementById('textInput').value; const fontSize = document.getElementById('fontSizeInput').value; const fontFamily = document.getElementById('fontFamily').value; const bgImageID = document.getElementById('bgImage').value; var x = document.getElementById('xInput').value; var y = document.getElementById('yInput').value; x = parseInt(x); y = parseInt(y); const colorMode = document.getElementById('colorMode').value; const canvas = document.getElementById('outputCanvas'); const ctx = canvas.getContext('2d'); const img = new Image(); img.crossOrigin = "anonymous"; img.src = bgImages[bgImageID]; img.onload = function () { // 绘制图片 ctx.clearRect(0, 0, canvas.width, canvas.height); ctx.drawImage(img, 0, 0); // 透明信息 const originalData = ctx.getImageData(0, 0, canvas.width, canvas.height); const originalPixels = originalData.data; let gradient; if (colorMode === 'solid') { // 纯色模式 const color = document.getElementById('s_color').value; ctx.fillStyle = color; ctx.fillRect(0, 0, canvas.width, canvas.height); } else { // 渐变色模式 const color1 = document.getElementById('color1').value; const color2 = document.getElementById('color2').value; const direction = document.getElementById('dir').value; if (direction === 'hor') { gradient = ctx.createLinearGradient(0, 0, canvas.width, 0); } else { gradient = ctx.createLinearGradient(0, 0, 0, canvas.height); // 垂直渐变 } gradient.addColorStop(0, color1); gradient.addColorStop(1, color2); ctx.fillStyle = gradient; ctx.fillRect(0, 0, canvas.width, canvas.height); } // 恢复透明度 const newData = ctx.getImageData(0, 0, canvas.width, canvas.height); const newPixels = newData.data; for (let i = 0; i < originalPixels.length; i += 4) { newPixels[i + 3] = originalPixels[i + 3]; } ctx.putImageData(newData, 0, 0); ctx.font = `${fontSize}px ${fontFamily}`; ctx.textAlign = "left"; ctx.textBaseline = "top"; const lines = text.split("\n"); for (let i = 0; i < lines.length; i++) { const lineY = y + i * fontSize; if (colorMode === 'solid') { ctx.fillStyle = document.getElementById('s_color').value; } else { ctx.fillStyle = gradient; } ctx.fillText(lines[i], x, lineY); } // 保存结果 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 hexToRgb(hexColor) { // const hex = hexColor.replace(/^#/, ''); const bigint = parseInt(hex, 16); return [(bigint >> 16) & 255, (bigint >> 8) & 255, bigint & 255]; }*/ function changeColorMode(e) { const mode = e.value; if (mode === 'solid') { document.getElementById('solid').style.display = 'block'; document.getElementById('gradient').style.display = 'none'; } else { document.getElementById('solid').style.display = 'none'; document.getElementById('gradient').style.display = 'block'; } } document.getElementById('colorMode').addEventListener('change', function (e) { changeColorMode(this); });
可能并非最新


