Mini-Skin Generator

Info | No Wrap | Fullscreen | Raw Text | HTML preview | | | Fork

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.     <meta charset="UTF-8">
  4.     <meta name="viewport" content="width=device-width, initial-scale=1.0">
  5.     <title>Mini-Skin Generator</title>
  6.     <style>
  7.         body {
  8.             font-family: Arial, sans-serif;
  9.             background-color: #f0f0f0;
  10.             display: flex;
  11.             flex-direction: column;
  12.             align-items: center;
  13.             padding: 20px;
  14.             text-align: center;
  15.         }
  16.  
  17.         h1 {
  18.             color: #333;
  19.             margin: auto;
  20.             margin-bottom: 0;
  21.         }
  22.  
  23.         h2 {
  24.             color: #333;
  25.             margin: auto;
  26.             margin-top: 0;
  27.         }
  28.  
  29.         img:not(#example, .exampleheads, .preview) {
  30.             width: 30vw;
  31.             height: 30vw;
  32.             max-width: 300px;
  33.             max-height: 300px;
  34.         }
  35.  
  36.         .example-container {
  37.             margin: auto;
  38.             display: flex;
  39.             justify-content: space-around;
  40.             width: 100%;
  41.             max-width: 600px;
  42.         }
  43.  
  44.         #example {
  45.             display: inline-block;
  46.             height: 40vw;
  47.             max-height: 200px;
  48.         }
  49.  
  50.         .exampleheads {
  51.             display: inline-block;
  52.             height: 100px;
  53.             margin-top: 50px;
  54.             width: 20vw;
  55.             height: 20vw;
  56.             max-width: 100px;
  57.             max-height: 100px;
  58.         }
  59.  
  60.         legend {
  61.             background: white;
  62.             color: #333;
  63.             font-weight: bold;
  64.             border-radius: 3px;
  65.             border: 1px solid #aaa;
  66.             padding: 1px 3px;
  67.         }
  68.  
  69.         .input-container {
  70.             background: white;
  71.             padding: 15px;
  72.             border-radius: 8px;
  73.             box-shadow: 0 2px 10px rgba(0,0,0,0.1);
  74.             margin-bottom: 20px;
  75.             width: calc(100% - 40px);
  76.             max-width: 680px;
  77.             display: flex;
  78.             flex-wrap: wrap;
  79.             justify-content: space-between;
  80.             align-items: center;
  81.         }
  82.  
  83.         input[type="text"] {
  84.             padding: 10px;
  85.             border: 1px solid #ccc;
  86.             border-radius: 5px;
  87.             flex-grow: 1;
  88.             margin-right: 10px;
  89.             width: 30%;
  90.         }
  91.  
  92.         .upload_label {
  93.             background-color: #007BFF;
  94.             color: white;
  95.             padding: 10px;
  96.             border-radius: 5px;
  97.             cursor: pointer;
  98.             transition: background-color 0.3s ease;
  99.         }
  100.  
  101.         .upload_label:hover {
  102.             background-color: #0056b3;
  103.         }
  104.  
  105.         input[type="file"] {
  106.             display: none;
  107.         }
  108.  
  109.         .checkbox-group {
  110.             display: flex;
  111.             align-items: center;
  112.             gap: 10px;
  113.             margin-left: 10px;
  114.         }
  115.  
  116.         .checkbox-group label {
  117.             background: none;
  118.             color: #333;
  119.             padding: 0;
  120.         }
  121.  
  122.         .checkbox-group input[type="checkbox"] {
  123.             accent-color: #007BFF;
  124.         }
  125.  
  126.         canvas {
  127.             display: none;
  128.         }
  129.  
  130.         .images-container {
  131.             margin: auto;
  132.             display: flex;
  133.             justify-content: space-around;
  134.             width: 100%;
  135.             max-width: 1000px;
  136.         }
  137.  
  138.         .images-container img {
  139.             border: 1px solid #333;
  140.             image-rendering: pixelated;
  141.         }
  142.  
  143.         #result-preview {
  144.             margin: auto;
  145.             margin-top: 50px;
  146.         }
  147.        
  148.         @media screen and (max-width: 750px) {
  149.             body {
  150.                 padding: 0;
  151.             }
  152.             .break {
  153.                 flex-basis: 100%;
  154.                 height: 0;
  155.             }
  156.             .checkbox-group {
  157.                 margin-left: 0;
  158.                 margin-top: 10px;
  159.             }
  160.             input[type="text"] {
  161.                 width: 20vw;
  162.             }
  163.         }
  164.     </style>
  165. </head>
  166.     <h1>Mini-Skin Generator</h1>
  167.     <p id="credits">by <a href="https://leroch.net">Christian</a> (<a href="https://73.nu/donation">Donate</a>❤️) | <a href="https://pb.73.nu/miniskin">Sourcecode</a> | <a href="https://pb.73.nu/miniskin-info/fullscreen">Info</a> | <a href="https://github.com/nirastich/miniskin">GitHub</a></p>
  168.     <div class="example-container">
  169.         <img class="exampleheads" src="">
  170.         <img id="example" src="">
  171.         <img class="exampleheads" src="">
  172.     </div>
  173.     <fieldset class="input-container">
  174.         <legend for="username1">Head-Skin</legend>
  175.         <input type="text" id="username1" placeholder="Username">
  176.         <label class="upload_label" for="upload1">Upload&nbsp;File</label>
  177.         <input type="file" id="upload1" accept="image/png">
  178.         <div class="break"></div>
  179.         <div class="checkbox-group">
  180.             <label><input type="checkbox" id="skin1_64x32">64x32 Skin</label>
  181.             <label><input type="checkbox" id="skin1_jacket"><abbr title="Second skin layer for body and pants ignoring head">Show Jacket</abbr></label>
  182.             <label><input type="checkbox" id="fix_eyes"><abbr title="Check this box if eyes are not showing correctly">Fix Eyes</abbr></label>
  183.         </div>
  184.     </fieldset>
  185.     <fieldset class="input-container">
  186.         <legend for="username2">Carrier-Skin</legend>
  187.         <input type="text" id="username2" placeholder="Username">
  188.         <label class="upload_label" for="upload2">Upload&nbsp;File</label>
  189.         <input type="file" id="upload2" accept="image/png">
  190.         <div class="break"></div>
  191.         <div class="checkbox-group">
  192.             <label><input type="checkbox" id="skin2_64x32">64x32 Skin</label>
  193.             <label><input type="checkbox" id="skin2_slim">Slim</label>
  194.         </div>
  195.     </fieldset>
  196.     <canvas id="canvas" width="64" height="64"></canvas>
  197.     <div class="images-container">
  198.         <div>
  199.             <h2>Head</h2>
  200.             <img id="img1" width="128" height="128">
  201.         </div>
  202.         <div>
  203.             <h2>Carrier</h2>
  204.             <img id="img2" width="128" height="128">
  205.         </div>
  206.         <div>
  207.             <h2>Result</h2>
  208.             <img id="combinedImg" width="128" height="128">
  209.         </div>
  210.     </div>
  211.     <div id="result-preview" style="display: none;">
  212.         <img class="preview" id="full-body-preview" src="" alt="Full body preview">
  213.         <img class="preview" id="head-preview" src="" alt="head preview">
  214.     </div>
  215.     <p>Search & Preview powered by <a href="https://vzge.me">vzge.me</a> API</p>
  216.     <script>
  217.        function getUsersFromUrl() {
  218.            const params = new URLSearchParams(window.location.search);
  219.             const headskin = params.get('head') || '';
  220.             const carrierskin = params.get('carrier') || '';
  221.             const skin1_64x32 = params.get('s1x32') == 'true';
  222.             const skin1_jacket = params.get('jacket') == 'true';
  223.             const skin2_64x32 = params.get('s2x32') == 'true';
  224.             const skin2_slim = params.get('slim') == 'true';
  225.             const fix_eyes = params.get('eyes') == 'true';
  226.        
  227.             let img1Loaded = false;
  228.             let img2Loaded = false;
  229.        
  230.             // Set tickbox states based on URL parameters
  231.             document.getElementById('skin1_64x32').checked = skin1_64x32;
  232.             document.getElementById('skin1_jacket').checked = skin1_jacket;
  233.             document.getElementById('skin2_64x32').checked = skin2_64x32;
  234.             document.getElementById('skin2_slim').checked = skin2_slim;
  235.             document.getElementById('fix_eyes').checked = fix_eyes;
  236.        
  237.             if (headskin) {
  238.                 username1.value = headskin;
  239.                 handleInput(username1, function(img) {
  240.                     img1Element.src = img.src;
  241.                     img1Data = getImageData(img);
  242.                     img1Loaded = true;
  243.                     if (img1Loaded && img2Loaded) combineSkins();
  244.                 });
  245.             }
  246.        
  247.             if (carrierskin) {
  248.                 username2.value = carrierskin;
  249.                 handleInput(username2, function(img) {
  250.                     img2Element.src = img.src;
  251.                     img2Data = getImageData(img);
  252.                     img2Loaded = true;
  253.                     if (img1Loaded && img2Loaded) combineSkins();
  254.                 });
  255.             }
  256.        
  257.             return {
  258.                 headskin,
  259.                 carrierskin,
  260.                 skin1_64x32,
  261.                 skin1_jacket,
  262.                 skin2_64x32,
  263.                 skin2_slim,
  264.                 fix_eyes
  265.             };
  266.         }
  267.  
  268.         function setNamesInUrl(headskin, carrierskin) {
  269.             const params = new URLSearchParams();
  270.             const skin1_64x32 = document.getElementById('skin1_64x32').checked;
  271.             const skin1_jacket = document.getElementById('skin1_jacket').checked;
  272.             const skin2_64x32 = document.getElementById('skin2_64x32').checked;
  273.             const skin2_slim = document.getElementById('skin2_slim').checked;
  274.             const fix_eyes = document.getElementById('fix_eyes').checked;
  275.        
  276.             params.set('head', headskin);
  277.             params.set('carrier', carrierskin);
  278.             params.set('s1x32', skin1_64x32);
  279.             params.set('jacket', skin1_jacket);
  280.             params.set('s2x32', skin2_64x32);
  281.             params.set('slim', skin2_slim);
  282.             params.set('eyes', fix_eyes);
  283.        
  284.             window.history.replaceState({}, '', `${window.location.pathname}?${params}`);
  285.         }
  286.        
  287.         const upload1 = document.getElementById('upload1');
  288.         const upload2 = document.getElementById('upload2');
  289.         const username1 = document.getElementById('username1');
  290.         const username2 = document.getElementById('username2');
  291.         const canvas = document.getElementById('canvas');
  292.         const ctx = canvas.getContext('2d');
  293.         const img1Element = document.getElementById('img1');
  294.         const img2Element = document.getElementById('img2');
  295.         const combinedImgElement = document.getElementById('combinedImg');
  296.         const downloadBtn = document.getElementById('downloadBtn');
  297.  
  298.         let img1Data = null;
  299.         let img2Data = null;
  300.  
  301.         function loadImage(fileOrUrl, callback) {
  302.             const img = new Image();
  303.             img.crossOrigin = "Anonymous";
  304.             img.onload = function() {
  305.                 callback(img);
  306.             }
  307.             if (fileOrUrl instanceof File) {
  308.                 const reader = new FileReader();
  309.                 reader.onload = function(event) {
  310.                     img.src = event.target.result;
  311.                 }
  312.                 reader.readAsDataURL(fileOrUrl);
  313.             } else {
  314.                 img.src = fileOrUrl;
  315.             }
  316.         }
  317.  
  318.         function getImageData(img) {
  319.             const tempCanvas = document.createElement('canvas');
  320.             const tempCtx = tempCanvas.getContext('2d');
  321.             tempCanvas.width = 64;
  322.             tempCanvas.height = 64;
  323.  
  324.             tempCtx.clearRect(0, 0, 64, 64);
  325.             tempCtx.drawImage(img, 0, 0, img.width, img.height);
  326.  
  327.             return tempCtx.getImageData(0, 0, 64, 64);
  328.         }
  329.  
  330.         function copyArea(srcData, srcX, srcY, width, height, destX, destY, destData, rotate = false) {
  331.             for (let y = 0; y < height; y++) {
  332.                 for (let x = 0; x < width; x++) {
  333.                     const srcIndex = ((srcY + y) * 64 + (srcX + x)) * 4;
  334.                     let destIndex;
  335.  
  336.                     if (rotate) {
  337.                         const rotatedX = width - 1 - x;
  338.                         const rotatedY = height - 1 - y;
  339.                         destIndex = ((destY + rotatedY) * 64 + (destX + rotatedX)) * 4;
  340.                     } else {
  341.                         destIndex = ((destY + y) * 64 + (destX + x)) * 4;
  342.                     }
  343.  
  344.                     for (let i = 0; i < 4; i++) {
  345.                         destData[destIndex + i] = srcData[srcIndex + i];
  346.                     }
  347.                 }
  348.             }
  349.         }
  350.        
  351.        function setPixel(destData, x, y, color) {
  352.            const index = ((y * 64) + x) * 4;
  353.            destData[index + 0] = color[0]; // Red
  354.            destData[index + 1] = color[1]; // Green
  355.            destData[index + 2] = color[2]; // Blue
  356.            destData[index + 3] = color[3]; // Alpha
  357.        }
  358.  
  359.         function combineSkins() {
  360.             const skin1_64x32 = document.getElementById('skin1_64x32').checked;
  361.             const skin1_jacket = document.getElementById('skin1_jacket').checked;
  362.             const skin2_64x32 = document.getElementById('skin2_64x32').checked;
  363.             const skin2_slim = document.getElementById('skin2_slim').checked;
  364.             const fix_eyes = document.getElementById('fix_eyes').checked;
  365.            
  366.             const headskin = document.getElementById('username1').value;
  367.             const carrierskin = document.getElementById('username2').value;
  368.            
  369.             if (headskin !== "" && carrierskin !== "") {
  370.                 setNamesInUrl(headskin,carrierskin);
  371.             }
  372.            
  373.             const combinedData = ctx.createImageData(64, 64);
  374.             const data = combinedData.data;
  375.            
  376.             // watermark 73.nu/MS
  377.             // 7
  378.             setPixel(data, 62, 46, [0, 0, 0, 255]);
  379.             setPixel(data, 61, 46, [0, 0, 0, 255]);
  380.             setPixel(data, 60, 46, [0, 0, 0, 255]);
  381.             setPixel(data, 59, 45, [0, 0, 0, 255]);
  382.             setPixel(data, 58, 45, [0, 0, 0, 255]);
  383.             setPixel(data, 58, 46, [0, 0, 0, 255]);
  384.             setPixel(data, 58, 47, [0, 0, 0, 255]);
  385.             // 3
  386.             setPixel(data, 62, 43, [0, 0, 0, 255]);
  387.             setPixel(data, 62, 42, [0, 0, 0, 255]);
  388.             setPixel(data, 61, 41, [0, 0, 0, 255]);
  389.             setPixel(data, 60, 42, [0, 0, 0, 255]);
  390.             setPixel(data, 59, 41, [0, 0, 0, 255]);
  391.             setPixel(data, 58, 42, [0, 0, 0, 255]);
  392.             setPixel(data, 58, 43, [0, 0, 0, 255]);
  393.             // .
  394.             setPixel(data, 62, 39, [90, 90, 90, 255]);
  395.             // n
  396.             setPixel(data, 62, 37, [0, 0, 0, 255]);
  397.             setPixel(data, 61, 37, [0, 0, 0, 255]);
  398.             setPixel(data, 60, 37, [0, 0, 0, 255]);
  399.             setPixel(data, 60, 36, [0, 0, 0, 255]);
  400.             setPixel(data, 61, 35, [0, 0, 0, 255]);
  401.             setPixel(data, 62, 35, [0, 0, 0, 255]);
  402.             // u
  403.             setPixel(data, 60, 31, [0, 0, 0, 255]);
  404.             setPixel(data, 61, 33, [0, 0, 0, 255]);
  405.             setPixel(data, 60, 33, [0, 0, 0, 255]);
  406.             setPixel(data, 62, 32, [0, 0, 0, 255]);
  407.             setPixel(data, 61, 31, [0, 0, 0, 255]);
  408.             setPixel(data, 62, 31, [0, 0, 0, 255]);
  409.             // /
  410.             setPixel(data, 62, 29, [90, 90, 90, 255]);
  411.             setPixel(data, 61, 29, [90, 90, 90, 255]);
  412.             setPixel(data, 60, 28, [90, 90, 90, 255]);
  413.             setPixel(data, 59, 28, [90, 90, 90, 255]);
  414.             setPixel(data, 58, 27, [90, 90, 90, 255]);
  415.             setPixel(data, 57, 27, [90, 90, 90, 255]);
  416.             // M
  417.             setPixel(data, 62, 25, [0, 0, 0, 255]);
  418.             setPixel(data, 61, 25, [0, 0, 0, 255]);
  419.             setPixel(data, 60, 25, [0, 0, 0, 255]);
  420.             setPixel(data, 59, 25, [0, 0, 0, 255]);
  421.             setPixel(data, 58, 25, [0, 0, 0, 255]);
  422.             setPixel(data, 59, 24, [0, 0, 0, 255]);
  423.             setPixel(data, 60, 23, [0, 0, 0, 255]);
  424.             setPixel(data, 59, 22, [0, 0, 0, 255]);
  425.             setPixel(data, 62, 21, [0, 0, 0, 255]);
  426.             setPixel(data, 61, 21, [0, 0, 0, 255]);
  427.             setPixel(data, 60, 21, [0, 0, 0, 255]);
  428.             setPixel(data, 59, 21, [0, 0, 0, 255]);
  429.             setPixel(data, 58, 21, [0, 0, 0, 255]);
  430.             // S
  431.             setPixel(data, 62, 19, [0, 0, 0, 255]);
  432.             setPixel(data, 62, 18, [0, 0, 0, 255]);
  433.             setPixel(data, 62, 17, [0, 0, 0, 255]);
  434.             setPixel(data, 61, 16, [0, 0, 0, 255]);
  435.             setPixel(data, 60, 17, [0, 0, 0, 255]);
  436.             setPixel(data, 60, 18, [0, 0, 0, 255]);
  437.             setPixel(data, 59, 19, [0, 0, 0, 255]);
  438.             setPixel(data, 58, 18, [0, 0, 0, 255]);
  439.             setPixel(data, 58, 17, [0, 0, 0, 255]);
  440.             setPixel(data, 58, 16, [0, 0, 0, 255]);
  441.  
  442.             // base
  443.             //copyArea(img1Data.data, 0, 0, 64, 64, 0, 0, data);
  444.  
  445.             // head top
  446.             copyArea(img1Data.data, 8, 0, 8, 8, 8, 0, data);
  447.  
  448.             // head underside
  449.             copyArea(img1Data.data, 4, 16, 4, 4, 16, 0, data);
  450.             copyArea(img1Data.data, 4, 16, 4, 4, 20, 4, data);
  451.             if (skin1_64x32) {
  452.                 copyArea(img1Data.data, 4, 16, 4, 4, 20, 0, data);
  453.                 copyArea(img1Data.data, 4, 16, 4, 4, 16, 4, data);
  454.             } else {
  455.                 copyArea(img1Data.data, 20, 48, 4, 4, 20, 0, data);
  456.                 copyArea(img1Data.data, 20, 48, 4, 4, 16, 4, data);
  457.             }
  458.  
  459.             // head front
  460.             copyArea(img1Data.data, 8, 9, 8, 2, 8, 8, data);
  461.             if (fix_eyes) {
  462.                 copyArea(img1Data.data, 8, 11, 8, 4, 8, 10, data);
  463.             } else {
  464.                 copyArea(img1Data.data, 8, 12, 8, 4, 8, 10, data);
  465.             }
  466.             copyArea(img1Data.data, 4, 20, 4, 1, 12, 15, data);
  467.             copyArea(img1Data.data, 20, 21, 3, 1, 8, 13, data);
  468.             copyArea(img1Data.data, 25, 21, 3, 1, 13, 13, data);
  469.             copyArea(img1Data.data, 20, 22, 8, 1, 8, 14, data);
  470.             copyArea(img1Data.data, 4, 20, 4, 1, 8, 15, data);
  471.             if (skin1_64x32) {
  472.                 copyArea(img1Data.data, 4, 20, 4, 1, 12, 15, data);
  473.             } else {
  474.                 copyArea(img1Data.data, 20, 52, 4, 1, 12, 15, data);
  475.             }
  476.  
  477.             // head back
  478.             copyArea(img1Data.data, 24, 9, 8, 2, 24, 8, data);
  479.             copyArea(img1Data.data, 24, 12, 8, 4, 24, 10, data);
  480.             copyArea(img1Data.data, 32, 21, 8, 1, 24, 13, data);
  481.             copyArea(img1Data.data, 32, 22, 8, 1, 24, 14, data);
  482.             copyArea(img1Data.data, 12, 20, 4, 1, 24, 15, data);
  483.             if (skin1_64x32) {
  484.                 copyArea(img1Data.data, 12, 20, 4, 1, 28, 15, data);
  485.             } else {
  486.                 copyArea(img1Data.data, 28, 52, 4, 1, 28, 15, data);
  487.             }
  488.  
  489.             // head left
  490.             copyArea(img1Data.data, 0, 9, 8, 2, 0, 8, data);
  491.             copyArea(img1Data.data, 0, 12, 8, 4, 0, 10, data);
  492.             copyArea(img1Data.data, 16, 21, 1, 2, 0, 13, data);
  493.             copyArea(img1Data.data, 16, 21, 1, 2, 1, 13, data);
  494.             copyArea(img1Data.data, 17, 21, 1, 2, 2, 13, data);
  495.             copyArea(img1Data.data, 17, 21, 1, 2, 3, 13, data);
  496.             copyArea(img1Data.data, 18, 21, 1, 2, 4, 13, data);
  497.             copyArea(img1Data.data, 18, 21, 1, 2, 5, 13, data);
  498.             copyArea(img1Data.data, 19, 21, 1, 2, 6, 13, data);
  499.             copyArea(img1Data.data, 19, 21, 1, 2, 7, 13, data);
  500.             copyArea(img1Data.data, 0, 20, 4, 1, 0, 15, data);
  501.             copyArea(img1Data.data, 12, 20, 4, 1, 4, 15, data);
  502.  
  503.             // head right
  504.             copyArea(img1Data.data, 16, 9, 8, 2, 16, 8, data);
  505.             copyArea(img1Data.data, 16, 12, 8, 4, 16, 10, data);
  506.             copyArea(img1Data.data, 28, 21, 1, 2, 16, 13, data);
  507.             copyArea(img1Data.data, 28, 21, 1, 2, 17, 13, data);
  508.             copyArea(img1Data.data, 29, 21, 1, 2, 18, 13, data);
  509.             copyArea(img1Data.data, 29, 21, 1, 2, 19, 13, data);
  510.             copyArea(img1Data.data, 30, 21, 1, 2, 20, 13, data);
  511.             copyArea(img1Data.data, 30, 21, 1, 2, 21, 13, data);
  512.             copyArea(img1Data.data, 31, 21, 1, 2, 22, 13, data);
  513.             copyArea(img1Data.data, 31, 21, 1, 2, 23, 13, data);
  514.             copyArea(img1Data.data, 0, 20, 4, 1, 16, 15, data);
  515.             copyArea(img1Data.data, 12, 20, 4, 1, 20, 15, data);
  516.            
  517.             // 2nd layer head top
  518.             copyArea(img1Data.data, 40, 0, 8, 8, 40, 0, data);
  519.  
  520.             // 2nd layer head front
  521.             copyArea(img1Data.data, 40, 9, 8, 2, 40, 8, data);
  522.             if (fix_eyes) {
  523.                 copyArea(img1Data.data, 40, 11, 8, 4, 40, 10, data);
  524.             } else {
  525.                 copyArea(img1Data.data, 40, 12, 8, 4, 40, 10, data);
  526.             }
  527.             if (skin1_jacket) {
  528.                 copyArea(img1Data.data, 20, 37, 3, 1, 40, 13, data);
  529.                 copyArea(img1Data.data, 25, 37, 3, 1, 45, 13, data);
  530.                 copyArea(img1Data.data, 20, 38, 8, 1, 40, 14, data);
  531.                 copyArea(img1Data.data, 4, 36, 4, 1, 40, 15, data);
  532.                 copyArea(img1Data.data, 4, 52, 4, 1, 44, 15, data);
  533.             }
  534.  
  535.             // 2nd layer head back
  536.             copyArea(img1Data.data, 56, 9, 8, 2, 56, 8, data);
  537.             copyArea(img1Data.data, 56, 12, 8, 4, 56, 10, data);
  538.             if (skin1_jacket) {
  539.                 copyArea(img1Data.data, 32, 36, 8, 1, 56, 13, data);
  540.                 copyArea(img1Data.data, 32, 37, 8, 1, 56, 14, data);
  541.                 copyArea(img1Data.data, 12, 36, 4, 1, 56, 15, data);
  542.                 copyArea(img1Data.data, 12, 52, 4, 1, 60, 15, data);
  543.             }
  544.  
  545.             // 2nd layer head left
  546.             copyArea(img1Data.data, 32, 9, 8, 2, 32, 8, data);
  547.             copyArea(img1Data.data, 32, 12, 8, 4, 32, 10, data);
  548.             if (skin1_jacket) {
  549.                 copyArea(img1Data.data, 16, 37, 1, 2, 32, 13, data);
  550.                 copyArea(img1Data.data, 16, 37, 1, 2, 33, 13, data);
  551.                 copyArea(img1Data.data, 17, 37, 1, 2, 34, 13, data);
  552.                 copyArea(img1Data.data, 17, 37, 1, 2, 35, 13, data);
  553.                 copyArea(img1Data.data, 18, 37, 1, 2, 36, 13, data);
  554.                 copyArea(img1Data.data, 18, 37, 1, 2, 37, 13, data);
  555.                 copyArea(img1Data.data, 19, 37, 1, 2, 38, 13, data);
  556.                 copyArea(img1Data.data, 19, 37, 1, 2, 39, 13, data);
  557.                 copyArea(img1Data.data, 0, 37, 1, 1, 32, 15, data);
  558.                 copyArea(img1Data.data, 0, 37, 1, 1, 33, 15, data);
  559.                 copyArea(img1Data.data, 1, 37, 1, 1, 34, 15, data);
  560.                 copyArea(img1Data.data, 1, 37, 1, 1, 35, 15, data);
  561.                 copyArea(img1Data.data, 2, 37, 1, 1, 36, 15, data);
  562.                 copyArea(img1Data.data, 2, 37, 1, 1, 37, 15, data);
  563.                 copyArea(img1Data.data, 3, 37, 1, 1, 38, 15, data);
  564.                 copyArea(img1Data.data, 3, 37, 1, 1, 39, 15, data);
  565.             }
  566.  
  567.             // 2nd layer head right
  568.             copyArea(img1Data.data, 48, 9, 8, 2, 48, 8, data);
  569.             copyArea(img1Data.data, 48, 12, 8, 4, 48, 10, data);
  570.             if (skin1_jacket) {
  571.                 copyArea(img1Data.data, 28, 37, 1, 2, 48, 13, data);
  572.                 copyArea(img1Data.data, 28, 37, 1, 2, 49, 13, data);
  573.                 copyArea(img1Data.data, 29, 37, 1, 2, 50, 13, data);
  574.                 copyArea(img1Data.data, 29, 37, 1, 2, 51, 13, data);
  575.                 copyArea(img1Data.data, 30, 37, 1, 2, 52, 13, data);
  576.                 copyArea(img1Data.data, 30, 37, 1, 2, 53, 13, data);
  577.                 copyArea(img1Data.data, 31, 37, 1, 2, 54, 13, data);
  578.                 copyArea(img1Data.data, 31, 37, 1, 2, 55, 13, data);
  579.                 copyArea(img1Data.data, 8, 37, 1, 1, 48, 15, data);
  580.                 copyArea(img1Data.data, 8, 37, 1, 1, 49, 15, data);
  581.                 copyArea(img1Data.data, 9, 37, 1, 1, 50, 15, data);
  582.                 copyArea(img1Data.data, 9, 37, 1, 1, 51, 15, data);
  583.                 copyArea(img1Data.data, 10, 37, 1, 1, 52, 15, data);
  584.                 copyArea(img1Data.data, 10, 37, 1, 1, 53, 15, data);
  585.                 copyArea(img1Data.data, 11, 37, 1, 1, 54, 15, data);
  586.                 copyArea(img1Data.data, 11, 37, 1, 1, 55, 15, data);
  587.             }
  588.  
  589.             // arms
  590.             copyArea(img1Data.data, 45, 20, 2, 1, 39, 13, data);
  591.             copyArea(img1Data.data, 45, 31, 2, 1, 39, 14, data);
  592.             if (skin1_64x32) {
  593.                 copyArea(img1Data.data, 45, 20, 2, 1, 47, 13, data);
  594.                 copyArea(img1Data.data, 45, 31, 2, 1, 47, 14, data);
  595.             } else {
  596.                 copyArea(img1Data.data, 37, 52, 2, 1, 47, 13, data);
  597.                 copyArea(img1Data.data, 37, 63, 2, 1, 47, 14, data);
  598.             }
  599.             if (skin1_jacket) {
  600.                 copyArea(img1Data.data, 45, 36, 2, 1, 39, 13, data);
  601.                 if (skin1_64x32) {
  602.                     copyArea(img1Data.data, 45, 36, 2, 1, 47, 13, data);
  603.                 } else {
  604.                     copyArea(img1Data.data, 53, 52, 2, 1, 47, 13, data);
  605.                 }
  606.             }
  607.  
  608.             // shoes
  609.             copyArea(img1Data.data, 5, 31, 2, 1, 41, 15, data);
  610.             copyArea(img1Data.data, 9, 17, 2, 1, 49, 7, data);
  611.             if (skin1_64x32) {
  612.                 copyArea(img1Data.data, 5, 31, 2, 1, 45, 15, data);
  613.                 copyArea(img1Data.data, 9, 17, 2, 1, 53, 7, data);
  614.             } else {
  615.                 copyArea(img1Data.data, 21, 63, 2, 1, 45, 15, data);
  616.                 copyArea(img1Data.data, 25, 49, 2, 1, 53, 7, data);
  617.             }
  618.            
  619.             // body front
  620.             copyArea(img2Data.data, 8, 8, 8, 8, 20, 20, data);
  621.             copyArea(img2Data.data, 20, 20, 8, 1, 20, 28, data);
  622.             copyArea(img2Data.data, 20, 22, 8, 1, 20, 29, data);
  623.             copyArea(img2Data.data, 20, 24, 8, 1, 20, 30, data);
  624.             copyArea(img2Data.data, 20, 26, 8, 1, 20, 31, data);
  625.            
  626.             // body top
  627.             copyArea(img2Data.data, 8, 2, 8, 4, 20, 16, data);
  628.  
  629.             // body back
  630.             copyArea(img2Data.data, 24, 8, 8, 8, 32, 20, data);
  631.             copyArea(img2Data.data, 32, 20, 8, 1, 32, 28, data);
  632.             copyArea(img2Data.data, 32, 22, 8, 1, 32, 29, data);
  633.             copyArea(img2Data.data, 32, 24, 8, 1, 32, 30, data);
  634.             copyArea(img2Data.data, 32, 26, 8, 1, 32, 31, data);
  635.  
  636.             // body left
  637.             copyArea(img2Data.data, 2, 8, 1, 8, 16, 20, data);
  638.             copyArea(img2Data.data, 4, 8, 1, 8, 17, 20, data);
  639.             copyArea(img2Data.data, 6, 8, 1, 8, 18, 20, data);
  640.             copyArea(img2Data.data, 7, 8, 1, 8, 19, 20, data);
  641.             copyArea(img2Data.data, 16, 20, 4, 1, 16, 28, data);
  642.             copyArea(img2Data.data, 16, 22, 4, 1, 16, 29, data);
  643.             copyArea(img2Data.data, 16, 24, 4, 1, 16, 30, data);
  644.             copyArea(img2Data.data, 16, 26, 4, 1, 16, 31, data);
  645.  
  646.             // body right
  647.             copyArea(img2Data.data, 16, 8, 1, 8, 28, 20, data);
  648.             copyArea(img2Data.data, 17, 8, 1, 8, 29, 20, data);
  649.             copyArea(img2Data.data, 19, 8, 1, 8, 30, 20, data);
  650.             copyArea(img2Data.data, 21, 8, 1, 8, 31, 20, data);
  651.             copyArea(img2Data.data, 28, 20, 4, 1, 28, 28, data);
  652.             copyArea(img2Data.data, 28, 22, 4, 1, 28, 29, data);
  653.             copyArea(img2Data.data, 28, 24, 4, 1, 28, 30, data);
  654.             copyArea(img2Data.data, 28, 26, 4, 1, 28, 31, data);
  655.            
  656.             // 2nd layer body front
  657.             copyArea(img2Data.data, 40, 8, 8, 8, 20, 36, data);
  658.             if (!skin2_64x32) {
  659.             copyArea(img2Data.data, 20, 36, 8, 1, 20, 44, data);
  660.             copyArea(img2Data.data, 20, 38, 8, 1, 20, 45, data);
  661.             copyArea(img2Data.data, 20, 40, 8, 1, 20, 46, data);
  662.             copyArea(img2Data.data, 20, 42, 8, 1, 20, 47, data);
  663.             }
  664.            
  665.             // 2nd layer body top
  666.             copyArea(img2Data.data, 40, 2, 8, 4, 20, 32, data);
  667.  
  668.             // 2nd layer body back
  669.             copyArea(img2Data.data, 56, 8, 8, 8, 32, 36, data);
  670.             if (!skin2_64x32) {
  671.             copyArea(img2Data.data, 32, 36, 8, 1, 32, 44, data);
  672.             copyArea(img2Data.data, 32, 38, 8, 1, 32, 45, data);
  673.             copyArea(img2Data.data, 32, 40, 8, 1, 32, 46, data);
  674.             copyArea(img2Data.data, 32, 42, 8, 1, 32, 47, data);
  675.             }
  676.            
  677.             // 2nd layer body left
  678.             copyArea(img2Data.data, 34, 8, 1, 8, 16, 36, data);
  679.             copyArea(img2Data.data, 36, 8, 1, 8, 17, 36, data);
  680.             copyArea(img2Data.data, 38, 8, 1, 8, 18, 36, data);
  681.             copyArea(img2Data.data, 39, 8, 1, 8, 19, 36, data);
  682.             if (!skin2_64x32) {
  683.             copyArea(img2Data.data, 16, 36, 4, 1, 16, 44, data);
  684.             copyArea(img2Data.data, 16, 38, 4, 1, 16, 45, data);
  685.             copyArea(img2Data.data, 16, 40, 4, 1, 16, 46, data);
  686.             copyArea(img2Data.data, 16, 42, 4, 1, 16, 47, data);
  687.             }
  688.  
  689.             // 2nd layer body right
  690.             copyArea(img2Data.data, 48, 8, 1, 8, 28, 36, data);
  691.             copyArea(img2Data.data, 49, 8, 1, 8, 29, 36, data);
  692.             copyArea(img2Data.data, 51, 8, 1, 8, 30, 36, data);
  693.             copyArea(img2Data.data, 53, 8, 1, 8, 31, 36, data);
  694.             if (!skin2_64x32) {
  695.             copyArea(img2Data.data, 28, 36, 4, 1, 28, 44, data);
  696.             copyArea(img2Data.data, 28, 38, 4, 1, 28, 45, data);
  697.             copyArea(img2Data.data, 28, 40, 4, 1, 28, 46, data);
  698.             copyArea(img2Data.data, 28, 42, 4, 1, 28, 47, data);
  699.             }
  700.  
  701.             // left leg
  702.             copyArea(img2Data.data, 8, 16, 4, 4, 8, 16, data);
  703.             copyArea(img2Data.data, 28, 16, 4, 4, 4, 16, data);
  704.             copyArea(img2Data.data, 20, 28, 4, 1, 4, 20, data);
  705.             copyArea(img2Data.data, 20, 30, 4, 1, 4, 21, data);
  706.             copyArea(img2Data.data, 36, 28, 4, 1, 12, 20, data);
  707.             copyArea(img2Data.data, 36, 30, 4, 1, 12, 21, data);
  708.             copyArea(img2Data.data, 30, 17, 4, 2, 8, 20, data);
  709.             copyArea(img2Data.data, 16, 28, 4, 1, 0, 20, data);
  710.             copyArea(img2Data.data, 16, 30, 4, 1, 0, 21, data);
  711.             copyArea(img2Data.data, 0, 20, 16, 1, 0, 22, data);
  712.             copyArea(img2Data.data, 0, 22, 16, 1, 0, 23, data);
  713.             copyArea(img2Data.data, 0, 24, 16, 1, 0, 24, data);
  714.             copyArea(img2Data.data, 0, 25, 16, 7, 0, 25, data);
  715.  
  716.             // right leg
  717.             if (skin2_64x32) {
  718.                 copyArea(data, 0, 16, 16, 4, 16, 48, data);
  719.                 copyArea(data, 12, 20, 1, 12, 31, 52, data);
  720.                 copyArea(data, 13, 20, 1, 12, 30, 52, data);
  721.                 copyArea(data, 14, 20, 1, 12, 29, 52, data);
  722.                 copyArea(data, 15, 20, 1, 12, 28, 52, data);
  723.                 copyArea(data, 0, 20, 1, 12, 27, 52, data);
  724.                 copyArea(data, 1, 20, 1, 12, 26, 52, data);
  725.                 copyArea(data, 2, 20, 1, 12, 25, 52, data);
  726.                 copyArea(data, 3, 20, 1, 12, 24, 52, data);
  727.                 copyArea(data, 4, 20, 1, 12, 23, 52, data);
  728.                 copyArea(data, 5, 20, 1, 12, 22, 52, data);
  729.                 copyArea(data, 6, 20, 1, 12, 21, 52, data);
  730.                 copyArea(data, 7, 20, 1, 12, 20, 52, data);
  731.                 copyArea(data, 8, 20, 1, 12, 19, 52, data);
  732.                 copyArea(data, 9, 20, 1, 12, 18, 52, data);
  733.                 copyArea(data, 10, 20, 1, 12, 17, 52, data);
  734.                 copyArea(data, 11, 20, 1, 12, 16, 52, data);
  735.             } else {
  736.                 copyArea(img2Data.data, 24, 48, 4, 4, 24, 48, data);
  737.                 copyArea(img2Data.data, 32, 16, 4, 4, 20, 48, data);
  738.                 copyArea(img2Data.data, 24, 28, 4, 1, 20, 52, data);
  739.                 copyArea(img2Data.data, 24, 30, 4, 1, 20, 53, data);
  740.                 copyArea(img2Data.data, 32, 28, 4, 1, 28, 52, data);
  741.                 copyArea(img2Data.data, 32, 30, 4, 1, 28, 53, data);
  742.                 copyArea(img2Data.data, 30, 17, 4, 2, 24, 52, data);
  743.                 copyArea(img2Data.data, 28, 28, 4, 1, 16, 52, data);
  744.                 copyArea(img2Data.data, 28, 30, 4, 1, 16, 53, data);
  745.                 copyArea(img2Data.data, 16, 52, 16, 1, 16, 54, data);
  746.                 copyArea(img2Data.data, 16, 54, 16, 1, 16, 55, data);
  747.                 copyArea(img2Data.data, 16, 56, 16, 1, 16, 56, data);
  748.                 copyArea(img2Data.data, 16, 57, 16, 7, 16, 57, data);
  749.             }
  750.  
  751.             if (!skin2_64x32) {
  752.             // 2nd layer left leg
  753.             copyArea(img2Data.data, 8, 32, 4, 4, 8, 32, data);
  754.             copyArea(img2Data.data, 20, 44, 4, 1, 4, 36, data);
  755.             copyArea(img2Data.data, 20, 46, 4, 1, 4, 37, data);
  756.             copyArea(img2Data.data, 36, 44, 4, 1, 12, 36, data);
  757.             copyArea(img2Data.data, 36, 46, 4, 1, 12, 37, data);
  758.             copyArea(img2Data.data, 30, 32, 4, 2, 8, 36, data);
  759.             copyArea(img2Data.data, 16, 44, 4, 1, 0, 36, data);
  760.             copyArea(img2Data.data, 16, 46, 4, 1, 0, 37, data);
  761.             copyArea(img2Data.data, 0, 36, 16, 1, 0, 38, data);
  762.             copyArea(img2Data.data, 0, 38, 16, 1, 0, 39, data);
  763.             copyArea(img2Data.data, 0, 40, 16, 1, 0, 40, data);
  764.             copyArea(img2Data.data, 0, 41, 16, 7, 0, 41, data);
  765.  
  766.             // 2nd layer right leg
  767.             copyArea(img2Data.data, 8, 48, 4, 4, 8, 48, data);
  768.             copyArea(img2Data.data, 24, 44, 4, 1, 4, 52, data);
  769.             copyArea(img2Data.data, 24, 46, 4, 1, 4, 53, data);
  770.             copyArea(img2Data.data, 32, 44, 4, 1, 12, 52, data);
  771.             copyArea(img2Data.data, 32, 46, 4, 1, 12, 53, data);
  772.             copyArea(img2Data.data, 30, 32, 4, 2, 0, 52, data);
  773.             copyArea(img2Data.data, 28, 44, 4, 1, 8, 52, data);
  774.             copyArea(img2Data.data, 28, 46, 4, 1, 8, 53, data);
  775.             copyArea(img2Data.data, 0, 52, 16, 1, 0, 54, data);
  776.             copyArea(img2Data.data, 0, 54, 16, 1, 0, 55, data);
  777.             copyArea(img2Data.data, 0, 56, 16, 1, 0, 56, data);
  778.             copyArea(img2Data.data, 0, 57, 16, 7, 0, 57, data);
  779.             }
  780.  
  781.             // left arm
  782.             if (skin2_slim) {
  783.                 copyArea(img2Data.data, 44, 16, 6, 4, 44, 16, data, true);
  784.                 copyArea(img2Data.data, 40, 20, 4, 12, 40, 20, data, true);
  785.                 copyArea(img2Data.data, 44, 20, 3, 12, 51, 20, data, true);
  786.                 copyArea(img2Data.data, 47, 20, 4, 12, 47, 20, data, true);
  787.                 copyArea(img2Data.data, 51, 20, 3, 12, 44, 20, data, true);
  788.             } else {
  789.                 copyArea(img2Data.data, 44, 16, 8, 4, 44, 16, data, true);
  790.                 copyArea(img2Data.data, 48, 20, 4, 12, 48, 20, data, true);
  791.                 copyArea(img2Data.data, 52, 20, 4, 12, 44, 20, data, true);
  792.                 copyArea(img2Data.data, 40, 20, 4, 12, 40, 20, data, true);
  793.                 copyArea(img2Data.data, 44, 20, 4, 12, 52, 20, data, true);
  794.             }
  795.  
  796.             // right arm
  797.             if (skin2_64x32) {
  798.                 copyArea(data, 40, 16, 16, 4, 32, 48, data);
  799.                 copyArea(data, 52, 20, 1, 12, 47, 52, data);
  800.                 copyArea(data, 53, 20, 1, 12, 46, 52, data);
  801.                 copyArea(data, 54, 20, 1, 12, 45, 52, data);
  802.                 copyArea(data, 55, 20, 1, 12, 44, 52, data);
  803.                 copyArea(data, 40, 20, 1, 12, 43, 52, data);
  804.                 copyArea(data, 41, 20, 1, 12, 42, 52, data);
  805.                 copyArea(data, 42, 20, 1, 12, 41, 52, data);
  806.                 copyArea(data, 43, 20, 1, 12, 40, 52, data);
  807.                 copyArea(data, 44, 20, 1, 12, 39, 52, data);
  808.                 copyArea(data, 45, 20, 1, 12, 38, 52, data);
  809.                 copyArea(data, 46, 20, 1, 12, 37, 52, data);
  810.                 copyArea(data, 47, 20, 1, 12, 36, 52, data);
  811.                 copyArea(data, 48, 20, 1, 12, 35, 52, data);
  812.                 copyArea(data, 49, 20, 1, 12, 34, 52, data);
  813.                 copyArea(data, 50, 20, 1, 12, 33, 52, data);
  814.                 copyArea(data, 51, 20, 1, 12, 32, 52, data);
  815.             } else {
  816.                 if (skin2_slim) {
  817.                     copyArea(img2Data.data, 36, 48, 6, 4, 36, 48, data, true);
  818.                     copyArea(img2Data.data, 32, 52, 4, 12, 32, 52, data, true);
  819.                     copyArea(img2Data.data, 36, 52, 3, 12, 43, 52, data, true);
  820.                     copyArea(img2Data.data, 39, 52, 4, 12, 39, 52, data, true);
  821.                     copyArea(img2Data.data, 43, 52, 3, 12, 36, 52, data, true);
  822.                 } else {
  823.                     copyArea(img2Data.data, 36, 48, 8, 4, 36, 48, data, true);
  824.                     copyArea(img2Data.data, 32, 52, 4, 12, 32, 52, data, true);
  825.                     copyArea(img2Data.data, 36, 52, 4, 12, 44, 52, data, true);
  826.                     copyArea(img2Data.data, 40, 52, 4, 12, 40, 52, data, true);
  827.                     copyArea(img2Data.data, 44, 52, 4, 12, 36, 52, data, true);
  828.                 }
  829.             }
  830.  
  831.             if (!skin2_64x32) {
  832.             // 2nd layer left arm
  833.             if (skin2_slim) {
  834.                 copyArea(img2Data.data, 44, 32, 6, 4, 44, 32, data, true);
  835.                 copyArea(img2Data.data, 40, 36, 4, 12, 40, 36, data, true);
  836.                 copyArea(img2Data.data, 44, 36, 3, 12, 51, 36, data, true);
  837.                 copyArea(img2Data.data, 47, 36, 4, 12, 47, 36, data, true);
  838.                 copyArea(img2Data.data, 51, 36, 3, 12, 44, 36, data, true);
  839.             } else {
  840.                 copyArea(img2Data.data, 44, 32, 8, 4, 44, 32, data, true);
  841.                 copyArea(img2Data.data, 48, 36, 4, 12, 48, 36, data, true);
  842.                 copyArea(img2Data.data, 52, 36, 4, 12, 44, 36, data, true);
  843.                 copyArea(img2Data.data, 40, 36, 4, 12, 40, 36, data, true);
  844.                 copyArea(img2Data.data, 44, 36, 4, 12, 52, 36, data, true);
  845.             }
  846.  
  847.             // 2nd layer right arm
  848.             if (skin2_slim) {
  849.                 copyArea(img2Data.data, 52, 48, 6, 4, 52, 48, data, true);
  850.                 copyArea(img2Data.data, 48, 52, 4, 12, 48, 52, data, true);
  851.                 copyArea(img2Data.data, 52, 52, 3, 12, 59, 52, data, true);
  852.                 copyArea(img2Data.data, 55, 52, 4, 12, 55, 52, data, true);
  853.                 copyArea(img2Data.data, 59, 52, 3, 12, 52, 52, data, true);
  854.             } else {
  855.                 copyArea(img2Data.data, 52, 48, 8, 4, 52, 48, data, true);
  856.                 copyArea(img2Data.data, 48, 52, 4, 12, 48, 52, data, true);
  857.                 copyArea(img2Data.data, 52, 52, 4, 12, 60, 52, data, true);
  858.                 copyArea(img2Data.data, 56, 52, 4, 12, 56, 52, data, true);
  859.                 copyArea(img2Data.data, 60, 52, 4, 12, 52, 52, data, true);
  860.             }
  861.             }
  862.  
  863.             ctx.putImageData(combinedData, 0, 0);
  864.            combinedImgElement.src = canvas.toDataURL();
  865.  
  866.            const resultPreview = document.getElementById('result-preview');
  867.            resultPreview.style.display = 'block';
  868.  
  869.            const base64 = combinedImgElement.src.split(',')[1]
  870.                .replace(/\+/g, '-')
  871.                .replace(/\//g, '_')
  872.                .replace(/=+$/, '');
  873.            
  874.            var slimquery = skin2_slim ? "?slim" : "";
  875.  
  876.            document.getElementById('full-body-preview').src = `https://vzge.me/frontfull/384/${base64}` + slimquery;
  877.            document.getElementById('head-preview').src = `https://vzge.me/head/256/${base64}`;
  878.         }
  879.  
  880.         function handleInput(input, callback) {
  881.             if (input.files && input.files[0]) {
  882.                 loadImage(input.files[0], callback);
  883.             } else if (input.value) {
  884.                 const username = input.value.trim();
  885.                 const url = `https://vzge.me/processedskin/${username}`;
  886.                 loadImage(url, callback);
  887.             }
  888.         }
  889.  
  890.         upload1.addEventListener('change', function() {
  891.             handleInput(upload1, function(img) {
  892.                 img1Element.src = img.src;
  893.                 img1Data = getImageData(img);
  894.                 if (img2Data) combineSkins();
  895.             });
  896.         });
  897.  
  898.         upload2.addEventListener('change', function() {
  899.             handleInput(upload2, function(img) {
  900.                 img2Element.src = img.src;
  901.                 img2Data = getImageData(img);
  902.                 if (img1Data) combineSkins();
  903.             });
  904.         });
  905.  
  906.         username1.addEventListener('change', function() {
  907.             handleInput(username1, function(img) {
  908.                 img1Element.src = img.src;
  909.                 img1Data = getImageData(img);
  910.                 if (img2Data) combineSkins();
  911.             });
  912.         });
  913.  
  914.         username2.addEventListener('change', function() {
  915.             handleInput(username2, function(img) {
  916.                 img2Element.src = img.src;
  917.                 img2Data = getImageData(img);
  918.                 if (img1Data) combineSkins();
  919.             });
  920.         });
  921.  
  922.         document.getElementById('skin1_64x32').addEventListener('change', function() {
  923.             if (img2Data) combineSkins();
  924.         });
  925.  
  926.         document.getElementById('skin1_jacket').addEventListener('change', function() {
  927.             if (img2Data) combineSkins();
  928.         });
  929.  
  930.         document.getElementById('skin2_64x32').addEventListener('change', function() {
  931.             if (img2Data) combineSkins();
  932.         });
  933.  
  934.         document.getElementById('skin2_slim').addEventListener('change', function() {
  935.             if (img2Data) combineSkins();
  936.         });
  937.  
  938.         document.getElementById('fix_eyes').addEventListener('change', function() {
  939.             if (img2Data) combineSkins();
  940.         });
  941.        getUsersFromUrl();
  942.     </script>
  943. </body>
  944. </html>