透過網頁讀取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,555 Responses

  1. Josephdit表示:

    регистрация драгон мани казино https://trucktir.ru

  2. RobertveM表示:

    Rio Bet RioBet

  3. ThomasBut表示:

    отчаянные домохозяйки 5 серия https://domohozyayki-serial.ru

  4. FrankAparf表示:

    can i buy tiktok followers to go live https://buy-tiktok-followers.com

  5. JamesKar表示:

    buy tiktok account with 1000 followers https://tiktok-followers-buy.com

  6. Jasonutent表示:

    молодые проститутки https://prostitutki-213.ru

  7. ThomasBut表示:

    отчаянные домохозяйки онлайн хорошее качество сериал отчаянные домохозяйки смотреть

  8. JamesKar表示:

    buy tiktok followers australia how to buy tiktok followers

  9. En guvenilir online casino Sweet bonanza

  10. Tmnwvu表示:

    buy aldactone 25mg without prescription – purchase persantine online cheap buy cheap generic naltrexone

  11. nob表示:

    Among the extensive slot offerings at the Parq, players will find titles like Dragon Link and 88 Fortunes — which indicates a certain modern quality to the gaming at the facility. Dragon Link is the foundation of a full series of digital slot games across the web, and 88 Fortunes is prominently featured among the slots on Foxy Games, where virtually every selection represents the cutting edge of slot arcades. Slots at Parq Vancouver Casino are split over floors 2 and 3, with the 3rd floor hosting the higher jackpot slots salon. Doors at the aptly named, ‘The Poker Room’, swung open on Level 2 of the casino with games of Pot-Limit Omaha and $1-$3 and $2-$5 No-Limit Hold ‘Em at eight tables with room for 9-10 players on the rail at each table. The poker room is open 24 7 with one or more tables available at all times.
    http://training.monro.com/forum/posts/m128529-related-site#post128529
    Ace-King is a premium hand in Texas Hold’em and is one of the strongest drawing poker hands. The Ace King poker hand is also known as Anna Kournikova or Big Slick and is the fourth-best starting hand as it beats all pocket pairs except for pocket aces and pocket kings. A suited Ace-King is stronger than an unsuited Ace-King as the player can hit a nit flush easily. The poker hand holds a 34% equity in Texas Hold’em poker making it one of the strongest unpaired holdings even against the pocket kings. Poker has been a popular game for many years. Some think it evolved from the French game Poque and the Persian game As-Nas. For many people, it is just a fun game to play, while for others, it can be their full-time profession. While there are many different ways to play poker, one aspect that is true throughout all poker games is hand rankings. One of the first things you’ll need to learn in poker as a beginner is the different hands and how they rank. In this post, we will dive into all of the different poker hands so that you can look like an expert the next time you play.

  12. En guvenilir kumarhanede eglenin Sweet bonanza

  13. DennisFut表示:

    Romelu Menama Lukaku Bolingoli https://romelu-lukaku.prostoprosport-cz.org Belgicky fotbalista, utocnik anglickeho klubu Chelsea a Belgican vyber. Na hostovani hraje za italsky klub Roma.

  14. GregoryPrask表示:

    Darwin Gabriel Nunez Ribeiro https://darwin-nunez.prostoprosport-cz.org Uruguaysky fotbalista, utocnik anglickeho klubu Liverpool a Uruguaysky narodni tym. Bronzovy medailista mistrovstvi Jizni Ameriky mezi mladeznickymi tymy.

  15. Dustinger表示:

    Toni Kroos https://toni-kroos.prostoprosport-cz.org je nemecky fotbalista, ktery hraje jako stredni zaloznik za Real Madrid a nemecky narodni tym. Mistr sveta 2014. Prvni nemecky hrac v historii, ktery sestkrat vyhral Ligu mistru UEFA.

  16. En prestijli kumarhanede oynay?n Sweet bonanza

  17. CurtisDiz表示:

    Toni Kroos https://toni-kroos.prostoprosport-cz.org je nemecky fotbalista, ktery hraje jako stredni zaloznik za Real Madrid a nemecky narodni tym. Mistr sveta 2014. Prvni nemecky hrac v historii, ktery sestkrat vyhral Ligu mistru UEFA.

  18. Michaelguend表示:

    Bruno Guimaraes Rodriguez Moura https://bruno-guimaraes.prostoprosport-cz.org Brazilsky fotbalista, defenzivni zaloznik Newcastlu United a Brazilsky narodni tym. Vitez olympijskych her 2020 v Tokiu.

  19. ArnoldDrilt表示:

    Virgil van Dijk https://virgil-van-dijk.prostoprosport-cz.org Nizozemsky fotbalista, stredni obrance, kapitan anglickeho klubu Liverpool a kapitan nizozemskeho narodniho tymu.

  20. Terrellbax表示:

    Thibaut Nicolas Marc Courtois https://thibaut-courtois.prostoprosport-cz.org Belgicky fotbalista, brankar spanelskeho klubu Real Madrid . V sezone 2010/11 byl uznan jako nejlepsi brankar v belgicke Pro League a take hrac roku pro Genk. Trojnasobny vitez Ricardo Zamora Trophy

  21. Lesliebom表示:

    Karim Benzema https://karim-benzema.prostoprosport-cz.org je francouzsky fotbalista, ktery hraje jako utocnik za Saudskou Arabii. Arabsky klub Al-Ittihad. Hral za francouzsky narodni tym, za ktery odehral 97 zapasu a vstrelil 37 branek. V 17 letech se stal jednim z nejlepsich hracu rezervy, nastrilel tri desitky golu za sezonu.

  22. Gilbertsaunc表示:

    Alison Ramses Becker https://alisson-becker.prostoprosport-cz.org Brazilsky fotbalista nemeckeho puvodu, brankar klubu Liverpool a brazilsky narodni tym. Je povazovan za jednoho z nejlepsich brankaru sve generace a je znamy svymi vynikajicimi zakroky, presnosti prihravek a schopnosti jeden na jednoho.

  23. DennisFef表示:

    Rodrigo Silva de Goiz https://rodrygo.prostoprosport-cz.org Brazilsky fotbalista, utocnik Realu Madrid a brazilskeho narodniho tymu. V breznu 2017 byl Rodrigo povolan do narodniho tymu Brazilie U17 na zapasy Montague Tournament.

  24. Antonioavasy表示:

    Pedro Gonzalez Lopez https://pedri.prostoprosport-cz.org lepe znamy jako Pedri, je spanelsky fotbalista, ktery hraje jako utocny zaloznik. za Barcelonu a spanelskou reprezentaci. Bronzovy medailista z mistrovstvi Evropy 2020 a zaroven nejlepsi mlady hrac tohoto turnaje.

  25. видеостена под ключ http://www.kupit-videostenu.ru .

發佈留言

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