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

12,829 Responses

  1. Lelandmot表示:

    ivermectin for swine can i shower after taking ivermectin

  2. GeorgeBef表示:

    http://stromectolbestprice.com/# ivermectin scabies dosage

  3. Jeffreycok表示:

    http://stromectolbestprice.com/# oral ivermectin cost

  4. RobertHaf表示:

    cost of stromectol stromectol buy online

  5. Dixiepisn表示:

    online casino signup bonus no deposit
    bingo online for money
    free bonus no deposit casino

  6. Careyvew表示:

    ivermectin goat ivermectin american journal of therapeutics

  7. Dixiepisn表示:

    more casino games
    sign up casino bonus
    best mobile casinos

  8. Honeywell ev ürünleri. Ürünlerimizin çoğu diğer şirketler tarafından desteklenmektedir
    zamandan tasarruf edin ve doğrudan kaynağa gidin. Ev Termostatları, Ev Güvenlik Sistemi, Tüm
    Ev Nemlendirici/Hava Filtresi, UV Ampuller: Bir Uzmanla
    Sohbet Edin. Resideo EMEA. Diğer Ülkeler.

  9. Kkbmaf表示:

    sildenafil fast shipping lamictal 200mg price purchase losartan for sale

  10. Dixiepisn表示:

    play mobile casino
    no deposit online casino
    top online casino

  11. Careyvew表示:

    where to buy ivermectin pills ivermectin fenbendazole

  12. Hestiapisn表示:

    dissertations writing
    dissertation editing
    dissertation editing

  13. Jeffreycok表示:

    http://stromectolbestprice.com/# stromectol from costco

  14. Jeffreycok表示:

    https://stromectolbestprice.com/# ivermectin for cattle

  15. Hestiapisn表示:

    doctoral dissertation help
    help me
    writing dissertations

  16. Dotcqj表示:

    buy sildalis purchase cozaar generic order cozaar without prescription

  17. Agcnvu表示:

    sildalis medication sildenafil for men over 50 losartan 25mg pill

  18. GeorgeBef表示:

    https://stromectolbestprice.com/# can you buy ivermectin at a feed store

  19. Verenapisn表示:

    gambling casino online bonus
    best deposit bonus casino
    no deposit slots for real money

  20. GeorgeBef表示:

    http://stromectolbestprice.com/# how do i get ivermectin

  21. Lelandmot表示:

    ivermectin price comparison how to inject ivermectin in a dog

  22. Verenapisn表示:

    online real casino
    online casino real money
    online blackjack for real money

  23. I saw a similar post on another website but the points were not as well articulated.

  24. RobertHaf表示:

    stromectol for pinworms stromectol 0.5 mg

  25. RobertHaf表示:

    stromectol brand stromectol 3 mg for scabies

  26. Jeffreycok表示:

    https://stromectolbestprice.com/# ivermectin 3mg tablets price

  27. Hestiapisn表示:

    doctoral dissertation help
    dissertation proofreading services
    writing a dissertation methodology

發佈留言

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