इमेज कैप्चर एक ऐसा एपीआई है जिसका इस्तेमाल करके, स्टिल इमेज कैप्चर की जा सकती हैं और कैमरे के हार्डवेयर की सेटिंग कॉन्फ़िगर की जा सकती हैं. यह एपीआई, Android और डेस्कटॉप पर Chrome 59 में उपलब्ध है. हमने ImageCapture polyfill लाइब्रेरी भी पब्लिश की है.
इस एपीआई की मदद से, कैमरे की सुविधाओं को कंट्रोल किया जा सकता है. जैसे, ज़ूम, रोशनी, कंट्रास्ट, आईएसओ, और व्हाइट बैलेंस. सबसे अच्छी बात यह है कि इमेज कैप्चर की मदद से, डिवाइस के किसी भी कैमरे या वेबकैम का पूरा रिज़ॉल्यूशन ऐक्सेस किया जा सकता है. वेब पर फ़ोटो लेने की पिछली तकनीकों में, वीडियो स्नैपशॉट का इस्तेमाल किया जाता था. ये स्नैपशॉट, स्टिल इमेज के मुकाबले कम रिज़ॉल्यूशन वाले होते हैं.
ImageCapture
ऑब्जेक्ट को सोर्स के तौर पर MediaStreamTrack
के साथ बनाया जाता है. इसके बाद, एपीआई में कैप्चर करने के दो तरीके takePhoto()
और grabFrame()
होते हैं. साथ ही, कैमरे की सुविधाओं और सेटिंग को वापस पाने और उन सेटिंग को बदलने के तरीके भी होते हैं.
निर्माण
Image Capture API को getUserMedia()
से मिले MediaStreamTrack
के ज़रिए कैमरे का ऐक्सेस मिलता है:
navigator.mediaDevices.getUserMedia({video: true})
.then(gotMedia)
.catch(error => console.error('getUserMedia() error:', error));
function gotMedia(mediaStream) {
const mediaStreamTrack = mediaStream.getVideoTracks()[0];
const imageCapture = new ImageCapture(mediaStreamTrack);
console.log(imageCapture);
}
DevTools कंसोल से इस कोड को आज़माया जा सकता है.
कैप्चर करें
स्क्रीनशॉट दो तरीकों से लिया जा सकता है: फ़ुल फ़्रेम और क्विक स्नैपशॉट. takePhoto()
, Blob
दिखाता है. यह एक फ़ोटो एक्सपोज़र का नतीजा होता है. इसे ब्राउज़र से डाउनलोड किया जा सकता है, स्टोर किया जा सकता है या <img>
एलिमेंट में दिखाया जा सकता है. इस तरीके में, फ़ोटोग्राफ़ी कैमरे के सबसे ज़्यादा रिज़ॉल्यूशन का इस्तेमाल किया जाता है.
उदाहरण के लिए:
const img = document.querySelector('img');
// ...
imageCapture.takePhoto()
.then(blob => {
img.src = URL.createObjectURL(blob);
img.onload = () => { URL.revokeObjectURL(this.src); }
})
.catch(error => console.error('takePhoto() error:', error));
grabFrame()
, ImageBitmap
ऑब्जेक्ट दिखाता है, जो लाइव वीडियो का स्नैपशॉट होता है. उदाहरण के लिए, इसे <canvas
> पर ड्रॉ किया जा सकता है. इसके बाद, रंग की वैल्यू को चुनिंदा तौर पर बदलने के लिए, पोस्ट-प्रोसेस किया जा सकता है. ध्यान दें कि ImageBitmap
में सिर्फ़ वीडियो सोर्स का रिज़ॉल्यूशन होगा. आम तौर पर, यह रिज़ॉल्यूशन कैमरे की स्टिल इमेज की सुविधाओं से कम होगा. उदाहरण के लिए:
const canvas = document.querySelector('canvas');
// ...
imageCapture.grabFrame()
.then(imageBitmap => {
canvas.width = imageBitmap.width;
canvas.height = imageBitmap.height;
canvas.getContext('2d').drawImage(imageBitmap, 0, 0);
})
.catch(error => console.error('grabFrame() error:', error));
सुविधाएं और सेटिंग
कैप्चर सेटिंग में बदलाव करने के कई तरीके हैं. यह इस बात पर निर्भर करता है कि बदलाव MediaStreamTrack
में दिखेंगे या सिर्फ़ takePhoto()
के बाद दिखेंगे. उदाहरण के लिए, zoom
लेवल में किया गया बदलाव, MediaStreamTrack
पर तुरंत लागू हो जाता है. वहीं, लाल आंखों को कम करने की सुविधा सेट होने पर, वह सिर्फ़ फ़ोटो खींचने के दौरान लागू होती है.
"लाइव" कैमरे की सुविधाओं और सेटिंग में बदलाव करने के लिए, झलक देखें MediaStreamTrack
का इस्तेमाल किया जाता है: MediaStreamTrack.getCapabilities()
इससे एक MediaTrackCapabilities
डिक्शनरी मिलती है.इसमें, काम करने वाली सुविधाओं और रेंज या अनुमति वाली वैल्यू की जानकारी होती है. जैसे, ज़ूम की रेंज या अनुमति वाले व्हाइट बैलेंस मोड.
इसी तरह, MediaStreamTrack.getSettings()
मौजूदा सेटिंग के साथ MediaTrackSettings
दिखाता है. ज़ूम, स्क्रीन की रोशनी, और टॉर्च मोड, इस कैटगरी में आते हैं. उदाहरण के लिए:
var zoomSlider = document.querySelector('input[type=range]');
// ...
const capabilities = mediaStreamTrack.getCapabilities();
const settings = mediaStreamTrack.getSettings();
if (capabilities.zoom) {
zoomSlider.min = capabilities.zoom.min;
zoomSlider.max = capabilities.zoom.max;
zoomSlider.step = capabilities.zoom.step;
zoomSlider.value = settings.zoom;
}
"नॉन-लाइव" कैमरे की सुविधाओं और सेटिंग में बदलाव करने के लिए, ImageCapture
ऑब्जेक्ट का इस्तेमाल किया जाता है: ImageCapture.getPhotoCapabilities()
एक ऐसा PhotoCapabilities
ऑब्जेक्ट दिखाता है जो "नॉन-लाइव" कैमरे की उपलब्ध सुविधाओं का ऐक्सेस देता है.
इसी तरह, Chrome 61 से ImageCapture.getPhotoSettings()
, मौजूदा सेटिंग के साथ PhotoSettings
ऑब्जेक्ट दिखाता है. फ़ोटो का रिज़ॉल्यूशन, रेड आई कम करने की सुविधा, और फ़्लैश मोड (टार्च को छोड़कर) इस सेक्शन में आते हैं. उदाहरण के लिए:
var widthSlider = document.querySelector('input[type=range]');
// ...
imageCapture.getPhotoCapabilities()
.then(function(photoCapabilities) {
widthSlider.min = photoCapabilities.imageWidth.min;
widthSlider.max = photoCapabilities.imageWidth.max;
widthSlider.step = photoCapabilities.imageWidth.step;
return imageCapture.getPhotoSettings();
})
.then(function(photoSettings) {
widthSlider.value = photoSettings.imageWidth;
})
.catch(error => console.error('Error getting camera capabilities and settings:', error));
कॉन्फ़िगर करना
"लाइव" कैमरे की सेटिंग को झलक के MediaStreamTrack
applyConstraints()
सीमाओं के ज़रिए कॉन्फ़िगर किया जा सकता है. उदाहरण के लिए:
var zoomSlider = document.querySelector('input[type=range]');
mediaStreamTrack.applyConstraints({ advanced: [{ zoom: zoomSlider.value }]})
.catch(error => console.error('Uh, oh, applyConstraints() error:', error));
"नॉन-लाइव" कैमरे की सेटिंग, takePhoto()
के वैकल्पिक PhotoSettings
डिक्शनरी के साथ कॉन्फ़िगर की जाती हैं. उदाहरण के लिए:
var widthSlider = document.querySelector('input[type=range]');
imageCapture.takePhoto({ imageWidth : widthSlider.value })
.then(blob => {
img.src = URL.createObjectURL(blob);
img.onload = () => { URL.revokeObjectURL(this.src); }
})
.catch(error => console.error('Uh, oh, takePhoto() error:', error));
कैमरे की सुविधाएं
ऊपर दिया गया कोड चलाने पर, आपको grabFrame()
और takePhoto()
के नतीजों के बीच डाइमेंशन में अंतर दिखेगा.
takePhoto()
तरीके से, कैमरे के सबसे ज़्यादा रिज़ॉल्यूशन का ऐक्सेस मिलता है.
grabFrame()
, रेंडरर प्रोसेस में MediaStreamTrack
में मौजूद अगला उपलब्ध VideoFrame
लेता है. वहीं, takePhoto()
MediaStream
को रोकता है, कैमरे को फिर से कॉन्फ़िगर करता है, फ़ोटो लेता है (आम तौर पर, संपीड़ित फ़ॉर्मैट में, इसलिए Blob
) और फिर MediaStreamTrack
को फिर से शुरू करता है. इसका मतलब है कि takePhoto()
, कैमरे की फ़ोटो क्वालिटी के सभी विकल्पों का ऐक्सेस देता है. पहले, 'फ़ोटो लेना' सिर्फ़ तब किया जा सकता था, जब किसी canvas
एलिमेंट पर drawImage()
को कॉल करके, सोर्स के तौर पर वीडियो का इस्तेमाल किया जाता था. उदाहरण के लिए, यहां दिया गया तरीका.
ज़्यादा जानकारी के लिए, README.md सेक्शन देखें.
इस डेमो में, <canvas>
डाइमेंशन को वीडियो स्ट्रीम के रिज़ॉल्यूशन पर सेट किया गया है. वहीं, <img>
का नैचुरल साइज़, कैमरे की स्टिल इमेज का ज़्यादा से ज़्यादा रिज़ॉल्यूशन होता है. सीएसएस का इस्तेमाल, दोनों के डिसप्ले साइज़ को सेट करने के लिए किया जाता है.
स्टिल इमेज के लिए, कैमरे के उपलब्ध रिज़ॉल्यूशन की पूरी रेंज को PhotoCapabilities.imageHeight
और
imageWidth
के लिए MediaSettingsRange
वैल्यू का इस्तेमाल करके पाया और सेट किया जा सकता है. ध्यान दें कि getUserMedia()
के लिए, चौड़ाई और ऊंचाई की तय सीमा, वीडियो के लिए है. जैसा कि हमने बताया है, यह सीमा, स्टिल इमेज के लिए कैमरे की सुविधाओं से अलग हो सकती है. दूसरे शब्दों में, हो सकता है कि getUserMedia()
से कैनवस में सेव करते समय, आपके डिवाइस की पूरी रिज़ॉल्यूशन क्षमताओं को ऐक्सेस न किया जा सके. WebRTC रिज़ॉल्यूशन की पाबंदी के डेमो में, रिज़ॉल्यूशन के लिए getUserMedia()
पाबंदियां सेट करने का तरीका बताया गया है.
और कुछ?
आकार का पता लगाने वाला एपीआई, इमेज कैप्चर के साथ बेहतर तरीके से काम करता है:
FaceDetector
याBarcodeDetector
मेंImageBitmap
को फ़ीड करने के लिए,grabFrame()
को बार-बार कॉल किया जा सकता है. एपीआई के बारे में ज़्यादा जानने के लिए, पॉल किनलन की ब्लॉग पोस्ट पढ़ें.कैमरा फ़्लैश (डिवाइस की लाइट) को ऐक्सेस करने के लिए,
PhotoCapabilities
में जाकरFillLightMode
पर टैप करें. हालांकि, टार्च मोड (फ़्लैश हमेशा चालू रहता है) को ऐक्सेस करने के लिए,MediaTrackCapabilities
पर जाएं.
डेमो और कोड सैंपल
सहायता
- Android और डेस्कटॉप पर Chrome 59.
- Android और डेस्कटॉप पर Chrome Canary का 59 से पहले का वर्शन, जिसमें प्रयोग के तौर पर उपलब्ध वेब प्लैटफ़ॉर्म की सुविधाएं चालू हों.