透過網頁讀取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...

46,382 Responses

  1. безопасная сделка аккаунтов marketplace-akkauntov-top.ru

  2. VictorFaIca表示:

    Профессиональное агентство рекламное агентство Витрувий: разработка рекламы, брендинг, digital-маркетинг, наружка и SMM. Комплексное продвижение для бизнеса любого масштаба.

  3. Davidmaphy表示:

    The best online slots slot big bamboo in one place: classics, new releases, jackpots and themed machines. Play without registration, test the demo or make real bets with bonuses.

  4. Dwightkak表示:

    USACanadaPharm: online canadian pharmacy review – USACanadaPharm

  5. VictorFaIca表示:

    Профессиональное агентство https://prvitruvio.ru: разработка рекламы, брендинг, digital-маркетинг, наружка и SMM. Комплексное продвижение для бизнеса любого масштаба.

  6. StephenCer表示:

    canadian pharmacy meds review: USACanadaPharm – usa canada pharm

  7. StephenCer表示:

    canadian online drugs: canadapharmacyonline – canadian pharmacy 1 internet online drugstore

  8. Davidmaphy表示:

    The best online slots rise of olympus in one place: classics, new releases, jackpots and themed machines. Play without registration, test the demo or make real bets with bonuses.

  9. Dwightkak表示:

    usa canada pharm: reddit canadian pharmacy – USACanadaPharm

  10. Dwightkak表示:

    canada discount pharmacy: ed drugs online from canada – USACanadaPharm

  11. TimothyDok表示:

    canadian pharmacies comparison canadian pharmacy ltd usa canada pharm

  12. sma bokep表示:

    In line with my research, after a foreclosures home is marketed at an auction, it is common for that borrower to still have the remaining balance on the mortgage loan. There are many loan providers who attempt to have all service fees and liens paid back by the upcoming buyer. Nonetheless, depending on a number of programs, legislation, and state regulations there may be a few loans that aren’t easily sorted out through the shift of lending options. Therefore, the responsibility still remains on the lender that has got his or her property in foreclosure. Thank you for sharing your ideas on this weblog.

  13. VictorFaIca表示:

    Профессиональное агентство https://prvitruvio.ru/: разработка рекламы, брендинг, digital-маркетинг, наружка и SMM. Комплексное продвижение для бизнеса любого масштаба.

  14. Davidmaphy表示:

    The best online slots slot big bamboo in one place: classics, new releases, jackpots and themed machines. Play without registration, test the demo or make real bets with bonuses.

  15. JeffreyImita表示:

    Калининград Куршская коса экскурсия https://kurshskaya-kosa-ekskursii.ru/ — это возможность провести день на одном из красивейших природных объектов региона

  16. StephenCer表示:

    USACanadaPharm: USACanadaPharm – usa canada pharm

  17. Albertbiave表示:

    https://usacanadapharm.com/# safe canadian pharmacies

  18. TimothyDok表示:

    canadian pharmacy store ed drugs online from canada usa canada pharm

  19. TimothyDok表示:

    USACanadaPharm is canadian pharmacy legit usa canada pharm

  20. TimothyDok表示:

    usa canada pharm best canadian online pharmacy usa canada pharm

  21. TimothyDok表示:

    usa canada pharm canadianpharmacy com usa canada pharm

  22. StephenCer表示:

    usa canada pharm: USACanadaPharm – canadian pharmacy world

  23. StephenCer表示:

    online pharmacy canada: buying drugs from canada – canadian pharmacy 365

發佈回覆給「SamuelHeeni」的留言 取消回覆

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