सीएसएस फिल्टर: पारदर्शिता सफेद के साथ रंग छवि बनाते हैं


138

मेरे पास पारदर्शिता के साथ एक रंगीन png छवि है। मैं पूरी छवि को सफेद बनाने के लिए सीएसएस फिल्टर का उपयोग करना चाहता हूं, लेकिन पारदर्शिता को छोड़ दें। क्या सीएसएस में यह संभव है?


1
आप कोशिश कर सकते हैं filter। यह वर्तमान में केवल वेबकिट ब्राउज़र पर समर्थित है, हालाँकि।
ओरिऑल

मुझे पता है कि मैं फ़िल्टर की कोशिश कर सकता हूं, लेकिन मुझे किस फ़िल्टर का उपयोग करना चाहिए? मैं सटीक सीएसएस कोड देखना चाहूंगा।
पास्कल क्लेन

जवाबों:


430

आप उपयोग कर सकते हैं

filter: brightness(0) invert(1);

प्रथम, brightness(0) पारदर्शी भागों को छोड़कर सभी छवि को काला बनाता है, जो पारदर्शी रहता है।

फिर, invert(1)काले भागों को सफेद बनाता है।


1
@ DanielPerván यह layout.css.filters.enabledसेट पर फ़ायरफ़ॉक्स 34 पर काम करता है true
ओरियल

1
@Gor सैद्धांतिक रूप से यह होना चाहिए brightness(infinity)। लेकिन व्यवहार brightness(10000%)में ग्रे के परिणामस्वरूप पर्याप्त हैcontrast(0)
ओरोल

@ ओरियल 200 आईक्यू डेवलपर
मैक्सपज

60.0.1 (जून 2018) तक फ़ायरफ़ॉक्स के साथ बॉक्स से बाहर काम करता है
Sablefoste

4
@MahmudulHaque आप 2014 से एक टिप्पणी का जवाब दे रहे हैं। उन वर्षों में फ़ायरफ़ॉक्स और IE के 33 प्रमुख संस्करण आए हैं और अनिवार्य रूप से मृत होने के लिए दुनिया के दूसरे सबसे लोकप्रिय ब्राउज़र से चले गए हैं।
डैनियल पेरवान

8

मेरी जानकारी के लिए, एक तत्व को रंगीन करने के लिए दुख की बात है कि कोई सीएसएस फ़िल्टर नहीं है (शायद कुछ एसवीजी फिल्टर जादू के उपयोग के साथ, लेकिन मैं उससे कुछ अपरिचित हूं) और यहां तक ​​कि अगर मामला नहीं था, तो फिल्टर मूल रूप से केवल समर्थित हैं वेबकिट ब्राउज़र।

उस के साथ, आप अभी भी इसके चारों ओर काम कर सकते हैं और canvasअपनी छवि को संशोधित करने के लिए उपयोग कर सकते हैं। मूल रूप से, आप एक कैनवास पर एक छवि तत्व खींच सकते हैं और फिर पिक्सेल के माध्यम से लूप कर सकते हैं, संबंधित आरजीबीए मूल्यों को आपके इच्छित रंग में संशोधित कर सकते हैं।

हालांकि, कैनवस कुछ प्रतिबंधों के साथ आते हैं। सबसे महत्वपूर्ण बात, आपको यह सुनिश्चित करना होगा कि छवि src पृष्ठ के समान डोमेन से आए। अन्यथा ब्राउज़र आपको कैनवास के पिक्सेल डेटा को पढ़ने या संशोधित करने की अनुमति नहीं देगा।

यहाँ JSFiddle ने JSFiddle लोगो का रंग बदल दिया है।

//Base64 source, but any local source will work
var src = "";
var canvas = document.getElementById("theCanvas");
var ctx = canvas.getContext("2d");
var img = new Image;

//wait for the image to load
img.onload = function() {
    //Draw the original image so that you can fetch the colour data
    ctx.drawImage(img,0,0);
    var imgData = ctx.getImageData(0, 0, canvas.width, canvas.height);
    
    /*
    imgData.data is a one-dimensional array which contains 
    the respective RGBA values for every pixel 
    in the selected region of the context 
    (note i+=4 in the loop)
    */
    
    for (var i = 0; i < imgData.data.length; i+=4) {
			imgData.data[i] = 255; //Red, 0-255
			imgData.data[i+1] = 255; //Green, 0-255
			imgData.data[i+2] = 255; //Blue, 0-255
			/* 
			imgData.data[i+3] contains the alpha value
			which we are going to ignore and leave
			alone with its original value
			*/
    }
    ctx.clearRect(0, 0, canvas.width, canvas.height); //clear the original image
    ctx.putImageData(imgData, 0, 0); //paint the new colorised image
}

//Load the image!
img.src = src;
body {
    background: green;
}
<canvas id="theCanvas"></canvas>

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.