透過網頁讀取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": [] } } }
ivermectin 0.1 ivermectin 3 generic ivermectin
stromectol medication ivermectin 500mg stromectol 3 mg tablet
lisinopril online uk: lisinopril 10 mg order online – 90 lisinopril
otc lisinopril: lisinopril 100 mg – lisinopril 80
https://amoxil.cheap/# buy amoxicillin canada
http://amoxil.cheap/# amoxicillin 500 mg price
ivermectin 3mg tablets: stromectol 3 mg dosage – ivermectin 12
prednisone 50mg cost: 40 mg prednisone pill – canadian online pharmacy prednisone
http://buyprednisone.store/# buy cheap prednisone
furosemida Over The Counter Lasix lasix furosemide
cost of ivermectin 1% cream stromectol over the counter ivermectin 1 cream
lasix 100 mg tablet: Buy Lasix No Prescription – furosemida
https://amoxil.cheap/# rexall pharmacy amoxicillin 500mg
http://furosemide.guru/# lasix 100 mg tablet
http://lisinopril.top/# lisinopril in india
Thank you for being a constant source of inspiration through your blog. Asheville is proud to support you!
purchase priligy for sale order misoprostol pill cost cytotec
Your blog posts are always a joy to read! From Asheville with love, we appreciate your work.
http://lisinopril.top/# cost of lisinopril 5 mg
where to buy prednisone 20mg no prescription: prednisone capsules – prednisone 5 mg tablet cost
https://buyprednisone.store/# prednisone 10 mg daily
amoxicillin 500mg capsules antibiotic: over the counter amoxicillin – amoxicillin order online
amoxicillin price canada amoxicillin 500 capsule buy amoxicillin without prescription
generic drug for lisinopril lisinopril 20 mg tabs price lisinopril 20 mg
http://buyprednisone.store/# prednisone 10 mg tablet cost
amoxicillin online no prescription: price of amoxicillin without insurance – amoxicillin online without prescription
http://stromectol.fun/# ivermectin 0.1
amoxicillin 500 coupon: amoxicillin online without prescription – order amoxicillin uk
prednisone 0.5 mg: prednisone 5 mg tablet without a prescription – 25 mg prednisone
https://amoxil.cheap/# buy amoxicillin over the counter uk