透過網頁讀取PSD後,依圖層輸出PNG檔案
在前面介紹過網頁可以讀取PSD檔案並擷取到該檔案的資訊,接著我們會希望能透過網頁上傳PSD檔之後,依照圖層來輸出圖片,同樣是利用PSD.js來輔助進行,可以透過我們製作的範例頁面來進行輸出測試。
預設輸出效果
透過PSD.js可將PSD內的各圖層輸出成PNG圖檔,亦可轉成Base 64圖檔格式,惟輸出時每個圖檔的尺寸並不會根據整體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 PSD here</p> </div> <div id="image"></div> <pre id="data"></pre> <script type="text/javascript"> (function () { const 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) { for (var i = 0; i < psd.layers.length; i ++){ document.getElementById('image').appendChild(psd.layers[i].image.toPng()); } }); } }()); </script> </body> </html>
依照整體PSD配置進行輸出
我們希望讓每個圖片在輸出後能保時相同的尺寸,也就是依照PSD的畫布大小來輸出每一張圖檔,但在原生PSD.js中並不具備這樣的功能,於是我們透過下述的方式來達成:
- 擷取PSD資訊並將圖檔轉為Base 64格式
- 產生與PSD尺寸大小相同的HTML Canvas
- 將產生的Base 64圖檔,依照原始位置放入Canvas中
- 將Canvas轉成PNG圖檔
可以參考我們製作的範例頁面
<!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 PSD here</p> </div> <div id="image"></div> <pre id="data"></pre> <script type="text/javascript"> (function () { const 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) { const PSDWidth = psd.tree().width; const PSDHeight = psd.tree().height; for (var i = 0; i < psd.layers.length; i ++){ const img = new Image(); img.src = psd.layers[i].image.toBase64(); console.log(psd); const layerWidth = psd.layers[i].width; const layerHeight = psd.layers[i].height; const layerLeft = psd.layers[i].left; const layerTop = psd.layers[i].top; const canvas = document.createElement("canvas"); canvas.setAttribute('class', "canvas"); canvas.width = PSDWidth; canvas.height = PSDHeight; console.log("canvas :", canvas); img.onload = function(){ canvas.getContext("2d").drawImage(img, layerLeft, layerTop, layerWidth, layerHeight); document.getElementById('image').appendChild(canvas); } } }); } }()); </script> </body> </html>
PSD檔案輸出限制
1. 無法輸出帶有效果的圖片
在PSD中我們可能會針對圖層套用一些效果,例如:陰影、光暈、筆畫…等等,但在輸出後的圖檔將不會帶有這些效果。
解決方法:透過點陣化圖層效果,即可輸出相對應的圖檔。
2. 無法輸出帶有遮色片效果的圖片
解決方法:將圖層轉為智慧型物件,即可輸出相對應的圖檔。
3. 無法依圖層混合模式輸出圖片
解決方法:無法解決
my website Daycare Near Me
Pharmacie sans ordonnance: pharmacie en ligne pas cher – pharmacie en ligne france livraison belgique
Профессиональный сервисный центр по ремонту плоттеров в Москве.
Мы предлагаем: ремонт плоттера в москве
Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!
Профессиональный сервисный центр по ремонту серверов в Москве.
Мы предлагаем: ремонт и обслуживание серверов
Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!
Are You Getting Tired Of Symptoms Of Adhd In Adults Test?
10 Inspirational Resources To Revive Your Love For Symptoms Of Adhd In Adults Test symptoms of adhd in adults quiz
10 Facts About Togel4d That Will Instantly Put You In A Good Mood togel
sydney (Odell)
realistic silicone dolls provide a compelling solution.人形エロ The authentic replication of human form, coupled with substantial weight, offers users a heightened sense of pleasure.
McMullen went on to grow his company エロ 人形and sells high-end sex dolls to this day. With the continual development of AI
Mix a mild, antibacterial soap with warm water to create a gentle cleaning solution.えろ 人形 Avoid using harsh chemicals or abrasive cleaners as they can damage the silicone.
Gentleman may we suggest, male sex dolls for homosexualsえろ 人形?
at any time, can only be a good thing when it comes to helping you prepare for truly mind-blowing, えろ 人形long-lasting skin-on-skin contact when the next opportunity or connection presents itself.
When asked if it was anatomically correct,エロ 人形 he realized there was a demand for a female sex doll that served a real function.
embarking on an exciting new directionえろ 人形.
Figuring out the formula for the best way to have えろ 人形sex with a sex doll comes down to your own preferences and predilections.
Not to mention, that total freedom to えろ 人形be in complete control, to explore your deepest desires,
Whether you’re a die-hard anime fan or simply seeking a unique and unforgettable experience,えろ 人形 this anime sex doll is sure to captivate your heart and ignite your passion.
When I reached out to their customer service rep, Leo,エロ 人形 he swiftly provided me with a comprehensive set of customization options and estimated completion times that other vendors simply couldn’t match. It was a game-changer for me.
lifelike dolls could be one of the best things you ever doえろ 人形 for yourself!
making human touch even less frequent人形 エロ.
we can ensure that the wig of the sex doll always maintains 人形エロits beauty and realism, bringing more joy and pleasure to our lives.
I decided to give Kotobuki from AIBEI Doll and Lea from YouQ Doll a go. When it arrived,エロ 人形 I was surprised! From my personal experience, the dolls from GSDoll are on par with the $2,000 dolls.
This correct positioning makes a world of difference when it comes to sex.エロ 人形 In the meantime, all their other dolls (non-Amor) still have decent LHP.
Профессиональный сервисный центр по ремонту серверов в Москве.
Мы предлагаем: ремонт серверов москва
Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!
given how much time we spend on our phones and interacting online rather than meeting in person.人形 エロ That’s before we evenconsider the impact of the pandemic and how it forced us to physically distance from others,
Профессиональный сервисный центр по ремонту плоттеров в Москве.
Мы предлагаем: ремонт плоттеров
Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!
Профессиональный сервисный центр по ремонту серверов в Москве.
Мы предлагаем: ремонт компьютеров серверов
Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!
Профессиональный сервисный центр по ремонту серверов в Москве.
Мы предлагаем: ремонт серверов с гарантией
Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!
Профессиональный сервисный центр по ремонту серверов в Москве.
Мы предлагаем: обслуживание серверов москва
Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!
Look into my web-site … Find top-rated certified Daycares in your area
Сервисный центр предлагает ремонт бесперебойника exegate рядом ремонт бесперебойников exegate