Как преобразовать URI данных webp в png

Я преобразовал изображение webp в png, используя webJs на лету. Но эта библиотека работает только в графическом файле типа "abc.webp". Он не конвертируется в изображение png из изображения webp, созданного чем-то вроде "....."

Есть ли другой способ / рамки, с помощью которых я могу получить результат, который мне нужен?

Например, приведенный ниже пример работает в Chrome, но не в Firefox.

(function(){
  var WebP=new Image();
  WebP.src="";
  document.getElementById('imageWrapper').appendChild(WebP);
})();
<div id="imageWrapper"></div>

3 ответа

ImageMagick звучит как швейцарский армейский нож, который вам нужен.

Это решение может быть то, что вы ищете:

webp2png.js

Он использует libwebpjs для декодирования изображения webp, записывает данные изображения на холст, а затем использует HTMLCanvasElement.toDataURL для создания URI данных для изображения png.

Получить данные из URL-адреса данных

Для этого обратите внимание, что URL-адрес данных начинается с data:image/webp;base64,, Возьмите часть строки, которая следует за этим заголовком (так что все из UklGRv... до конца строки) и использовать декодер base 64, чтобы превратить его в массив данных.

Как конвертировать WebP в PNG, используя простой js/html

      <!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <title>Bulk convert WebP to png created by anandchakru</title>
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <style>
      body {
        font-family: Arial, sans-serif;
        display: flex;
        justify-content: center;
        align-items: center;
        height: 100vh;
        margin: 0;
      }

      .container {
        text-align: center;
      }

      h1 {
        margin-bottom: 10px;
      }
      h3 {
        color: #777;
      }

      input[type='file'] {
        margin-bottom: 10px;
      }

      button {
        padding: 8px 16px;
        background-color: #007bff;
        color: white;
        border: none;
        cursor: pointer;
        border-radius: 4px;
      }
      button#cleanupButton {
        display: none;
        text-align: center;
      }

      #output {
        margin-top: 20px;
      }
      div.desc {
        margin-bottom: 25px;
      }
    </style>
  </head>

  <body>
    <div class="container">
      <h1>WebP to PNG Converter</h1>
      <h3>
        By <a href="https://rathnas.com">anandchakru</a> Hosted
        <a href="https://free-online-webp-to-png.stackblitz.io/">here</a>
      </h3>
      <div class="desc">Free online tool to convert webp to png</div>
      <input type="file" id="fileInput" accept=".webp" multiple />
      <button id="convertButton">Convert to PNG</button>
      <div id="output"></div>
      <button id="cleanupButton">Cleanup</button>
    </div>
    <script>
      document.addEventListener('DOMContentLoaded', function () {
        const fileInput = document.getElementById('fileInput');
        const convertButton = document.getElementById('convertButton');
        const cleanupButton = document.getElementById('cleanupButton');
        const outputDiv = document.getElementById('output');
        cleanupButton.addEventListener('click', function () {
          outputDiv.innerHTML = ''; // Clear previous output
          cleanupButton.style.display = 'none';
        });

        convertButton.addEventListener('click', function () {
          const files = fileInput.files;
          outputDiv.innerHTML = ''; // Clear previous output
          if (files.length > 0) cleanupButton.style.display = 'unset';
          for (let i = 0; i < files.length; i++) {
            const file = files[i];
            const reader = new FileReader();

            reader.onload = function (event) {
              const img = new Image();
              img.src = event.target.result;

              img.onload = function () {
                const canvas = document.createElement('canvas');
                canvas.width = img.width;
                canvas.height = img.height;
                const ctx = canvas.getContext('2d');
                ctx.drawImage(img, 0, 0, canvas.width, canvas.height);

                const outputImg = new Image();
                outputImg.src = canvas.toDataURL('image/png');

                // Create a download link for the converted PNG
                const link = document.createElement('a');
                link.href = outputImg.src;
                link.download = file.name.replace('.webp', '.png'); // Use the same name, replace extension
                link.textContent = link.download;
                outputDiv.appendChild(link);
                outputDiv.appendChild(document.createElement('br'));
                outputDiv.appendChild(document.createElement('br'));
              };
            };
            reader.readAsDataURL(file);
          }
        });
      });
    </script>
  </body>
</html>

Рабочий пример https://free-online-webp-to-png.stackblitz.io/

Исходный код https://stackblitz.com/edit/free-online-webp-to-png?file=index.html

Другие вопросы по тегам