透過網頁讀取Photoshop PSD檔案內容

在專案中有需要透過網頁來讀取Photoshop PSD檔案的內部資訊,我們透過PSD.js備用載點)來實現這樣的功能,在官方提供的功能展示頁中,我們可以看到在頁面中只需引入psd.min.js後,加入透過少量的Javascript就可以針對PSD進行解析。

<!DOCTYPE html>
<html>
<head>
  <title>psd.js image example</title>
  <style type="text/css">
  body, html {
    padding: 0;
    margin: 0;
  }
  #dropzone {
    width: 500px;
    height: 100px;
    border: 1px #ababab dashed;
    margin: 50px auto;
  }
  #dropzone p {
    text-align: center;
    line-height: 100px;
    margin: 0;
    padding: 0;
  }
  #image {
    text-align: center;
  }
  </style>
  <script type="text/javascript" src="psd.min.js"></script>
</head>
<body>
  <div id="dropzone">
    <p>Drop here</p>
  </div>
  <div id="image"></div>
  <pre id="data"></pre>
  <script type="text/javascript">
  (function () {
    var PSD = require('psd');
    document.getElementById('dropzone').addEventListener('dragover', onDragOver, true);
    document.getElementById('dropzone').addEventListener('drop', onDrop, true);
    function onDragOver(e) {
      e.stopPropagation();
      e.preventDefault();
      e.dataTransfer.dropEffect = 'copy';
    }
    function onDrop(e) {
      e.stopPropagation();
      e.preventDefault();
      PSD.fromEvent(e).then(function (psd) {
        var data = JSON.stringify(psd.tree().export(), undefined, 2);
        document.getElementById('data').innerHTML = data;
        document.getElementById('image').appendChild(psd.image.toPng());
      });
    }
  }());
  </script>
</body>
</html>

我們透過下圖這樣的一個PSD檔案對頁面進行測試,檔案中共有三個圖層,包含一個文字圖層。

頁面將PSD分析出結果後,以json格式顯示在頁面上,可以看到文字圖層的部分,不僅能讀到圖層名稱也包含文字內容和字型名稱。

{
  "children": [
    {
      "type": "layer",
      "visible": true,
      "opacity": 1,
      "blendingMode": "normal",
      "name": "Photoshop Text",
      "left": 302,
      "right": 723,
      "top": 90,
      "bottom": 128,
      "height": 38,
      "width": 421,
      "mask": {},
      "text": {
        "value": "THIS IS TEXT LAYER",
        "font": {
          "name": "MyriadPro-Regular\u0000",
          "sizes": [
            53
          ],
          "colors": [
            [
              0,
              0,
              0,
              255
            ]
          ],
          "alignment": [
            "center"
          ]
        },
        "left": 0,
        "top": 0,
        "right": 0,
        "bottom": 0,
        "transform": {
          "xx": 1,
          "xy": 0,
          "yx": 0,
          "yy": 1,
          "tx": 513,
          "ty": 127
        }
      },
      "image": {}
    },
    {
      "type": "layer",
      "visible": true,
      "opacity": 1,
      "blendingMode": "normal",
      "name": "PSD Icon",
      "left": 287,
      "right": 738,
      "top": 209,
      "bottom": 669,
      "height": 460,
      "width": 451,
      "mask": {},
      "image": {}
    },
    {
      "type": "layer",
      "visible": true,
      "opacity": 1,
      "blendingMode": "normal",
      "name": "Background",
      "left": 0,
      "right": 1024,
      "top": 0,
      "bottom": 800,
      "height": 800,
      "width": 1024,
      "mask": {},
      "image": {}
    }
  ],
  "document": {
    "width": 1024,
    "height": 800,
    "resources": {
      "layerComps": [],
      "guides": [],
      "slices": []
    }
  }
}

You may also like...

21,252 Responses

  1. Robertmug表示:

    buying prescription drugs in mexico online buying prescription drugs in mexico buying from online mexican pharmacy

  2. Ggluht表示:

    loratadine 10mg oral claritin ca claritin price

  3. Robertmug表示:

    mexican online pharmacies prescription drugs mexico drug stores pharmacies mexican border pharmacies shipping to usa

  4. Petercaurl表示:

    mexican mail order pharmacies mexican drugstore online mexico pharmacies prescription drugs

  5. Petercaurl表示:

    mexico pharmacy mexican online pharmacies prescription drugs pharmacies in mexico that ship to usa

  6. Robertmug表示:

    mexican rx online mexican drugstore online medication from mexico pharmacy

  7. Robertmug表示:

    buying prescription drugs in mexico mexican border pharmacies shipping to usa mexico drug stores pharmacies

  8. Robertmug表示:

    medicine in mexico pharmacies pharmacies in mexico that ship to usa mexico drug stores pharmacies

  9. Petercaurl表示:

    buying prescription drugs in mexico online mexico pharmacies prescription drugs reputable mexican pharmacies online

  10. Your dedication to your craft shines brightly in every post. Thank you for sharing your passion with us. Asheville is grateful!

  11. Robertmug表示:

    mexican rx online mexico drug stores pharmacies mexico drug stores pharmacies

  12. JulioAxowl表示:

    mexico drug stores pharmacies buying from online mexican pharmacy mexican border pharmacies shipping to usa

  13. Great site! I recommend to everyone!escort paris

  14. Thank you for consistently delivering top-notch content. We’re huge fans of your blog here in Asheville!

  15. Petercaurl表示:

    medication from mexico pharmacy mexican border pharmacies shipping to usa mexican rx online

  16. JerryMig表示:

    mexico pharmacies prescription drugs pharmacies in mexico that ship to usa mexican pharmaceuticals online

  17. JerryMig表示:

    mexico pharmacy buying from online mexican pharmacy mexican pharmacy

  18. Robertmug表示:

    mexican rx online buying prescription drugs in mexico mexican pharmaceuticals online

  19. Petercaurl表示:

    buying prescription drugs in mexico online mexico drug stores pharmacies buying prescription drugs in mexico online

  20. Petercaurl表示:

    mexican rx online mexico pharmacy buying from online mexican pharmacy

  21. Robertmug表示:

    pharmacies in mexico that ship to usa mexican mail order pharmacies best mexican online pharmacies

  22. Robertmug表示:

    best online pharmacies in mexico mexican online pharmacies prescription drugs medicine in mexico pharmacies

  23. JerryMig表示:

    pharmacies in mexico that ship to usa medication from mexico pharmacy mexico pharmacies prescription drugs

  24. JerryMig表示:

    medicine in mexico pharmacies pharmacies in mexico that ship to usa reputable mexican pharmacies online

  25. Auto Blog表示:

    Your writing has a way of touching hearts and minds. We’re proud supporters of your blog from Asheville!

  26. TravisNOb表示:

    http://mexicanph.shop/# buying prescription drugs in mexico online
    buying prescription drugs in mexico

  27. TravisNOb表示:

    https://mexicanph.shop/# medicine in mexico pharmacies
    mexico pharmacies prescription drugs

  28. Thank you for enriching our lives with your wonderful blog. Asheville is blessed to have you!

  29. Robertmug表示:

    reputable mexican pharmacies online best online pharmacies in mexico pharmacies in mexico that ship to usa

  30. Petercaurl表示:

    buying prescription drugs in mexico online mexico drug stores pharmacies mexican online pharmacies prescription drugs

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。