透過網頁讀取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. 無法依圖層混合模式輸出圖片
解決方法:無法解決
エロ コスプレThey’ll need to check your baby’s movements and heartbeat.Do not wait until the next day,
if you have back pain,エッチ な 下着you may need to learn how to look after your back and do some exercises to strengthen it.
You can also find answers to commonly asked questions about COVID-19 and pregnancy from the Royal College of Obstetricians and Gynaecology.エロ 下着It’s safe to get the COVID-19 vaccine if you are breastfeeding.
It’s important not to miss any of your antenatal appointments.These appointments are part of your NHS pregnancy journey.コスプレ エロ
Put baby gates at the top and bottom of any stairs.Window screens are not strong enough keep your child from falling out of the window.コスプレ エロ い
and rocks out of your child’s reach.コスプレ エロ いFollow age recommendations on especially those with small parts,
As we learn to live safely with COVID-19,there are actions we can all take to help reduce the risk of catching COVID-19 and passing it on to others.エロ 下着
えろ コスプレYou should usually have the whooping cough vaccine around the time of your mid-pregnancy scan (usually at 20 weeks pregnant),but you can have it from 16 weeks.
couch,changing table,コスプレ エロ い
エロ 下着If you have not felt your baby move by 24 weeks,tell your midwife.
Domestic abuse against women often starts in pregnan Existing abuse may get worse during pregnancy or after the birth.Nobody has to put up with domestic abuse.コスプレ エッチ
エロ コスプレmeasles,or parvovirus (slapped cheek syndrome).
so that your diet is varied,rather than cutting out all your favourites.コスプレ エロ
コスプレ エロThis is because non-vegans get most of their calcium from dairy foods.Good sources of iodine for vegetarians include cow’s milk,
you might find it easier to cope,even if you can’t get any more sleep.下着 エロ
non-judgemental information and supporttalk to a doctor,health visitor or midwifemen can call Respect Men’s Advice Line on 0808 8010 327 (Monday to Friday 10am to 8pm),コスプレ エッチ
Set your hot water heater temperature below 120° Fahrenheit (F) or 48.コスプレ エロ い9° Celsius (C).
Интернет-магазин парфюмерии
Современный мир характеризуется изобилием выбора. Парфюмерная продукция не стала исключением. Наш интернет-магазин тому подтверждение. На его страницах вы можете найти более 10 тысяч наименований различных ароматов.
Всего 100 лет назад началось фабричное производство духов и с того момента парфюмерная индустрия развивалась стремительно и неумолимо. Новые веяния диктовали моду, в том числе и на ароматы. Цитрусовые, зеленые ароматы пришли на смену шипровым; восточные ароматы сменили цветочные; а сладкие фрукты и ягоды в парфюме заменили морские, озоновые ноты. Сегодня в мире парфюмерии отчетливо прослеживается влияние востока.
エッチ な 下着Breastfeeding and your dietIf you’re breastfeeding and you’re a healthy weight for your height,you do not need to eat a special diet.
move sharp-edged pieces of furniture away from high traffic areas.コスプレ エロ いAnchor down unsteady pieces of furniture,
エロ い 下着particularly after coughing and sneezing.Get help where possible from those you live with.
This all too familiar phrase is often used to argue that the Bible supports smacking or hitting children and that responsible parents would be failing in their duty if they did not.The specific phrase does not actually appear in the Bible but in a 17th-century poem by Samuel Butler but a literal English language-based interpretation of these verses has been challenged by many church leaders and biblical scholars.コスプレ エロ い
Getting vaccinated as soon as possible from 28 weeks will provide the best protection for your baby.But it can be given later if needed,えろ コスプレ
エロ い コスプレThis means you need to take extra care to avoid burns and scalds.At bath time,
legal guardian/s or any other person who has the care of the child.While this article does not explicitly mention physical punishment,コスプレ エロ い
エロ い 下着but at much lower levels.If using an e-cigarette helps you to stop smoking,
You can reach out to the Revenge Porn Helpline through email or by phone,or you can send them an anonymous “Whisper” report.コスプレ エッチ
エッチ な 下着If you understand a child’s development,this will help you plan ahead for safety.
エッチ な 下着It will make you feel better,and healthy eating is important for the whole family.
えろ コスプレbut it may be considered necessary to have the vaccination if you’re travelling to areas where yellow fever is common because the risks of yellow fever are so high.Pregnant women are particularly susceptible to malaria.