透過網頁讀取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": [] } } }
citalopram para que sirve
aviator pin up: estrela bet aviator – aviator game
http://pinupcassino.pro/# pin up
cassino pin up: pin-up cassino – pin up aviator
ddavp po to iv conversion
https://aviatorjogar.online/# aviator betano
aviator bet: aviator bet – aviator bet
aviator online: jogar aviator – aviator
http://aviatormalawi.online/# aviator malawi
http://aviatorghana.pro/# play aviator
I know this if off topic but I’m looking into starting my own blog and was wondering what all is required to get set up? I’m assuming having a blog like yours would cost a pretty penny? I’m not very internet savvy so I’m not 100 sure. Any tips or advice would be greatly appreciated. Thank you
http://aviatorghana.pro/# aviator game bet
jogos que dão dinheiro: depósito mínimo 1 real – jogo de aposta
pin-up casino entrar: pin-up – pin up cassino online
Great site! I recommend everyone to view this sitemarsbahis guncel adres
aviator jogar: aviator bet – jogar aviator Brasil
aviator login: aviator bet – aviator game online
cozaar hydrochlorothiazide
jogar aviator online: pin up aviator – jogar aviator online
https://aviatorjogar.online/# aviator pin up
aviator game: aviator bet malawi login – aviator game online
https://aviatorjogar.online/# aviator pin up
https://aviatoroyunu.pro/# aviator oyunu
depakote prices
pin up aviator: pin-up casino entrar – pin up
https://aviatormocambique.site/# aviator bet
aviator moçambique: aviator mz – aviator online
order avodart 0.5mg without prescription avodart over the counter ranitidine 150mg tablet
http://pinupcassino.pro/# pin up cassino online
aviator malawi: aviator bet malawi login – aviator game