這篇文章主要介紹CSS濾鏡和混合模式處理的圖片需要怎樣上傳下載,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
成都創(chuàng)新互聯(lián)專業(yè)為企事業(yè)單位提供成都網(wǎng)站建設(shè)公司、成都網(wǎng)站設(shè)計,網(wǎng)站優(yōu)化、微信開發(fā)、手機(jī)網(wǎng)站建設(shè)、域名注冊、虛擬主機(jī)、企業(yè)郵箱等互聯(lián)網(wǎng)基礎(chǔ)服務(wù)。從2013年成立,我們先后簽約近千家中小型企業(yè)和科技發(fā)展公司的網(wǎng)站建設(shè)和網(wǎng)站推廣項(xiàng)目。通過多年的創(chuàng)新發(fā)展,已發(fā)展成為專業(yè)能力較強(qiáng),服務(wù)較好的建站公司。一、使用CSS濾鏡和混合模式在線PS
使用CSS濾鏡和混合模式可以實(shí)現(xiàn)各種各樣的圖像處理效果,例如CSSgram項(xiàng)目,內(nèi)置眾多圖像處理效果,部分效果示意如下縮略圖:
進(jìn)入demo頁面你也可以點(diǎn)擊這里的按鈕,更換你本地的素材,查看對應(yīng)的圖像效果:
呈現(xiàn)的效果雖好,但是也帶來另外一個問題,雖然視覺上是已經(jīng)處理后的圖片,但是如果我們右鍵-圖片另存為,會發(fā)現(xiàn)還是原圖。
如果用戶覺得某個圖片處理后的效果很棒,想要保存到自己的本機(jī),就會受阻。
或者說,我們基于CSS濾鏡和混合模式制作了一款圖像處理的工具,最后需要把這些已經(jīng)處理好的圖片上傳到后臺,作為一個獨(dú)立的元素使用,也會受阻。
怎么辦?難道我們要放棄這么好的特性,還使用canvas來處理圖像嗎?
不需要的,實(shí)際上是有方法可以得到CSS處理后的圖像的。
二、SVG foreignObject元素與視覺存儲
SVG中有個
而SVG本質(zhì)上就是個圖像,也就是說,我們只需要把圖像處理相關(guān)的HTML代碼和CSS代碼放在
demo頁面最后一張圖片和CSS處理后的圖片長相雖同,但是本質(zhì)卻不同,一個還是原始圖(試試右鍵-另存為),一個本質(zhì)上是合成圖(試試右鍵-另存為),如下截圖示意:
于是,接下來,無論是是要下載到本機(jī)還是上傳到服務(wù)器都不是問題。
關(guān)于純前端下載圖片,可以參考我之前這篇文章:“JS前端創(chuàng)建html或json文件并下載”的part3部分。
關(guān)于上傳,可以傳輸圖像canvas.toDataURL()的base64數(shù)據(jù),也可以傳輸canvas.toBlob()的Blob數(shù)據(jù):
// canvas轉(zhuǎn)為blob并上傳canvas.toBlob(function (blob) { // 圖片ajax上傳 var xhr = new XMLHttpRequest(); // 文件上傳成功 xhr.onload = function() { // xhr.responseText就是返回的數(shù)據(jù) }; // 開始上傳 xhr.open("POST", 'upload.php', true); xhr.send(blob); }, 'image/jpeg');
三、我該如何在項(xiàng)目中使用?
上面的demo頁面中,我寫了個名為cssRenderImage2PureImage()的方法,可以把類似下面代碼結(jié)構(gòu)的CSS圖像處理結(jié)果變成一張圖片:
.clarendon-filter { filter: contrast(1.2) saturate(1.35); display: inline-block; position: relative; } .clarendon-filter::before { content: ''; display: block; height: 100%; width: 100%; top: 0; left: 0; position: absolute; background: rgba(127,187,227,.2); mix-blend-mode: overlay; pointer-events: none; }
cssRenderImage2PureImage()方法語法:
cssRenderImage2PureImage(dom, callback);
其中:
dom必須參數(shù)。DOM對象。callback可選參數(shù)。Function。回調(diào)方法,支持一個參數(shù),為合成后的圖片的base64信息。
示例:
cssRenderImage2PureImage(input, function (url) { // url就是合成后的圖片base64地址 // 你可以對url做你任何你想做的事情……});
四、其它說明以及結(jié)束語
cssRenderImage2PureImage方法高度定制,如果你的CSS濾鏡處理的DOM結(jié)構(gòu)有所不同,你需要根據(jù)你的項(xiàng)目場景調(diào)整下cssRenderImage2PureImage方法里面的代碼;
此技術(shù)實(shí)現(xiàn)請在Chrome瀏覽器下玩耍。
以上是CSS濾鏡和混合模式處理的圖片需要怎樣上傳下載的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。