透過網頁讀取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": [] } } }
http://prednisonetablets.shop/# prednisone 20mg online without prescription
cost cheap clomid now: buying generic clomid tablets – can i buy generic clomid without insurance
http://ivermectin.store/# ivermectin buy nz
http://azithromycin.bid/# zithromax antibiotic without prescription
where to get prednisone prednisone 2.5 mg price prednisone pills cost
stromectol sales stromectol generic ivermectin human
stromectol tab 3mg: ivermectin 9 mg – ivermectin ebay
where can i buy zithromax in canada: buy zithromax no prescription – where can i buy zithromax uk
Best in Dubai, flipping houses. Recommend!
http://prednisonetablets.shop/# prednisone buy canada
ivermectin pills: ivermectin 5 – stromectol sales
54 prednisone: prednisone 20 mg prices – 100 mg prednisone daily
https://ivermectin.store/# ivermectin 500mg
where can i get clomid: where buy clomid for sale – how to buy cheap clomid tablets
2.5 mg prednisone daily prednisone 4 mg daily prednisone 4 mg daily
can you buy prednisone over the counter in mexico canine prednisone 5mg no prescription price of prednisone 5mg
cost of generic clomid tablets: can i purchase clomid without prescription – how to buy cheap clomid
http://azithromycin.bid/# buy generic zithromax no prescription
https://clomiphene.icu/# generic clomid without prescription
https://amoxicillin.bid/# ampicillin amoxicillin
cheap tizanidine buy tizanidine generic tizanidine online buy
ivermectin 500ml: oral ivermectin cost – how much is ivermectin
ivermectin buy uk: where to buy ivermectin cream – oral ivermectin cost
zithromax buy online no prescription zithromax online no prescription zithromax 500 without prescription
http://amoxicillin.bid/# where to buy amoxicillin pharmacy
where to get zithromax zithromax online paypal how to get zithromax online
http://ivermectin.store/# stromectol ivermectin 3 mg
can you get generic clomid without insurance: how to get clomid without prescription – can i purchase cheap clomid without insurance
http://azithromycin.bid/# buy zithromax 1000mg online
buy zithromax without presc: where to get zithromax – generic zithromax over the counter