透過網頁讀取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. 無法依圖層混合模式輸出圖片
解決方法:無法解決
The Most Underrated Companies To Watch In The Depression Treatment Methods Industry
natural Treatment for depression
One of the first things that the pandemic quickly ruled out was close social interaction, 人形 エロmeaning no hugs, massages or even handshakes.
While many mistakenly believe vaginal douching 人形エロhelps maintain cleanliness after sex, it’s strongly advised against.
But what really blew me away was their エロ 人形outstanding customization service.
“Everyone’s on their smartphone, even couples who were 人形 エロobviously traveling together, even parents of children.
Buzzwords De-Buzzed: 10 Different Ways For Saying Bean To
Coffee Machine Organic Bean To Cup Coffee Machine
Several studies suggest that urinating approximately 15 minutes after sex can slightly 人形エロreduce the risk of urinary tract infections (UTIs) in women.
Driven by emotional voids resulting from the absence of a partner人形エロ, these individuals seek a means to satisfy their sexual desires, and high-quality,
By disturbing the delicate balance of the vaginal environment,人形エロ douching creates an environment conducive to these issues.
Here, individuals can autonomously tailor scenarios and details of their 人形エロintimate interactions, fulfilling personalized sexual
While scientific evidence is still limited, 人形エロthe practice of post-sex urination may have potential benefits, especially for women.
Douching may cause problems, including infections, 人形エロpelvic inflammatory disease (PID), and complications during pregnancy.
Even just a quick five or 10 minute clean which sees you remove the anal and mouth sleeves and えろ 人形detachable penis and wash with a water-based toy cleaner will help to prolong the life of your doll,
Moreover, these realistic sex dolls serve as tangible 人形エロcompanions in the real world, alleviating feelings of isolation.
The 3 Biggest Disasters In Bluetooth Fucking Machine The Bluetooth Fucking Machine’s 3 Biggest Disasters In History Affordable Sex Machine (Quailkayak23.Bravejournal.Net)
Not sure what you like in a man? Today’s modern sex dolls are super realistic,えろ 人形with a wide range of body shapes and sizes.
In conclusion, caring the wig of a sex doll and requires 人形エロcare and patience. Through regular cleaning, attention to storage environment, regular combing, and timely replacement of damaged wigs
We made shopping for a sex doll easy.エロ 人形 Read on to discover the best websites to find high quality dolls from top brands at competitive prices.
A doll goes further than sexual release of course. えろ 人形It can also give you free rein to indulge your wildest fantasies,
If you crave more contact, you can also snuggle up to your 人形 エロsex doll in bed, wrap your arms around the doll,
The kids are all on smartphones and so are their parents, 人形 エロand little two-year-olds on iPads.”
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.
Whether you are a seasoned experimenter and always up for trying new things,えろ 人形or are just starting out on your journey,
allowing fans to bring their えろ 人形fantasies to life in the most immersive way possible.
When combing, pay attention to moderate force to人形エロ avoid excessive pulling that may damage the wig.
At all. This is a chance to experiment, to indulgeえろ 人形 and to focus purely on your own pleasure
No more waiting around for a month! And let’s not forget about the cost. GSDoll’人形 エロs flexible shipping options mean I don’t have to shell out a fortune for expensive air freight anymore. It’s a win-win situation.
grappling with dissatisfaction in their sexual 人形エロlives, or harboring a strong yearning for intimate connections.
Sex dolls are open to doing whatever pleases you, and they’re ready when you are.エロ 人形If you have reservations to ask your partner to engage in a sexual act or kinky fantasy you desire,
Even just a quick five or 10 minute clean which sees you remove the anal and mouth sleeves and えろ 人形detachable penis and wash with a water-based toy cleaner will help to prolong the life of your doll,