Chrome वीडियो में अल्फ़ा ट्रांसपेरंसी (पारदर्शिता)

Chrome वीडियो में ऐल्फ़ा ट्रांसपेरेंसी

Chrome 31 में अब WebM फ़ॉर्मैट में वीडियो के अल्फा ट्रांसपेरेंसी की सुविधा काम करती है.

दूसरे शब्दों में, Chrome, 'ग्रीन स्क्रीन' वाले ऐसे वीडियो चलाते समय, अल्फा चैनल को ध्यान में रखता है जिन्हें WebM (VP8 और VP9) में एन्कोड किया गया है. इसका मतलब है कि वेब पेजों, इमेज या दूसरे वीडियो पर, पारदर्शी बैकग्राउंड वाले वीडियो चलाए जा सकते हैं.

simpl.info/videoalpha पर इसका डेमो उपलब्ध है. यह थोड़ा-बहुत असली नहीं है और किनारों पर थोड़ा-बहुत खराब है (सचमुच), लेकिन आपको इसका आइडिया मिल गया है!

ऐल्फ़ा वीडियो बनाने का तरीका

हमने जो तरीका बताया है उसमें ओपन सोर्स टूल Blender और ffmpeg का इस्तेमाल किया गया है:

  1. अपने विषय को एक रंग के बैकग्राउंड के सामने फ़िल्म करें, जैसे कि चमकदार हरे रंग का पर्दे.
  2. पारदर्शिता वाले डेटा के साथ PNG स्टिल इमेज का कलेक्शन बनाने के लिए, वीडियो को प्रोसेस करें.
  3. वीडियो को किसी फ़ॉर्मैट में एन्कोड करें. इस मामले में, WebM.

यही काम करने के लिए, Adobe After Effects जैसे मालिकाना टूल भी उपलब्ध हैं. ये टूल इस्तेमाल करना आसान हो सकता है.

1. ग्रीन स्क्रीन वाला वीडियो बनाना

सबसे पहले, आपको अपने विषय को इस तरह से रिकॉर्ड करना होगा कि बैकग्राउंड में मौजूद हर चीज़ को बाद में प्रोसेस करके 'हटाया' (पारदर्शी बनाया) जा सके.

ऐसा करने का सबसे आसान तरीका है कि वीडियो को एक रंग के बैकग्राउंड के सामने रिकॉर्ड करें. जैसे, स्क्रीन या पर्दे के सामने. ज़्यादातर हरे या नीले रंग का इस्तेमाल किया जाता है. ऐसा इसलिए, क्योंकि ये रंग त्वचा के रंग से अलग होते हैं.

ग्रीन स्क्रीन वीडियो (इसे क्रोमा की भी कहा जाता है) रिकॉर्ड करने के लिए, ऑनलाइन कई गाइड मौजूद हैं. साथ ही, ग्रीन और ब्लू स्क्रीन बैकड्रॉप खरीदने के लिए कई जगहें हैं. इसके अलावा, क्रोम की पेंट की मदद से भी बैकग्राउंड को पेंट किया जा सकता है.

'द ग्रेट गैट्सबी' के वीएफ़एक्स रील से पता चलता है कि ग्रीन स्क्रीन की मदद से कितनी बेहतरीन चीज़ें की जा सकती हैं.

वीडियो रिकॉर्ड करने के लिए कुछ सलाह:

  • पक्का करें कि वीडियो में मौजूद व्यक्ति के कपड़े या ऑब्जेक्ट, बैकग्राउंड के रंग से मेल न खाते हों. ऐसा होने पर, आखिरी वीडियो में ये 'छेद' के तौर पर दिखेंगे. छोटे लोगो या आभूषण भी समस्या पैदा कर सकते हैं.
  • एक जैसी और बेहतर लाइटिंग का इस्तेमाल करें. साथ ही, छाया से बचें: इसका मकसद बैकग्राउंड में कम से कम रंगों का इस्तेमाल करना है, ताकि बाद में उन्हें पारदर्शी बनाया जा सके.
  • कई डिफ़्यूज़ लाइट का इस्तेमाल करने से, शैडो और बैकग्राउंड के रंग में होने वाले बदलावों से बचा जा सकता है.
  • चमकदार बैकग्राउंड का इस्तेमाल न करें: मैट सतहें रोशनी को बेहतर तरीके से फैलाती हैं.

2. ग्रीन स्क्रीन वाले वीडियो से रॉ अल्फा वीडियो बनाना

यहां ग्रीन स्क्रीन वीडियो से रॉ अल्फा वीडियो बनाने का एक तरीका बताया गया है:

  1. ग्रीन स्क्रीन वीडियो शूट करने के बाद, Blender जैसे ओपन सोर्स टूल का इस्तेमाल करके, वीडियो को अल्फा डेटा वाली PNG फ़ाइलों के कलेक्शन में बदला जा सकता है. ग्रीन स्क्रीन हटाने और उसे पारदर्शी बनाने के लिए, Blender की कलर कीइंग का इस्तेमाल करें. (ध्यान दें कि PNG फ़ॉर्मैट का इस्तेमाल करना ज़रूरी नहीं है: ऐल्फ़ा चैनल का डेटा सेव करने वाला कोई भी फ़ॉर्मैट इस्तेमाल किया जा सकता है.)
  2. ffmpeg जैसे ओपन सोर्स टूल का इस्तेमाल करके, PNG फ़ाइलों के कलेक्शन को रॉ YUVA वीडियो में बदलें:

    ffmpeg -i image%04d.png -pix_fmt yuva420p video.raw

    इसके अलावा, ffmpeg कमांड का इस्तेमाल करके, फ़ाइलों को सीधे WebM में एन्कोड करें. इसके लिए, इस तरह का कमांड इस्तेमाल करें:

    ffmpeg -i image%04d.png output.webm

अगर आपको ऑडियो जोड़ना है, तो ffmpeg का इस्तेमाल करके, इस तरह के निर्देश के साथ उसे म्यूक्स किया जा सकता है:

ffmpeg -i image%04d.png -i audio.wav output.webm

3. ऐल्फ़ा वीडियो को WebM में एन्कोड करना

रॉ अल्फा वीडियो को WebM में दो तरीकों से एन्कोड किया जा सकता है.

  1. ffmpeg के साथ: हमने WebM अल्फा वीडियो को एन्कोड करने के लिए, ffmpeg में सहायता जोड़ी है.

    अल्फा डेटा वाले इनपुट वीडियो के साथ ffmpeg का इस्तेमाल करें. साथ ही, आउटपुट फ़ॉर्मैट को WebM पर सेट करें. इससे, स्पेसिफ़िकेशन के मुताबिक, एन्कोडिंग अपने-आप सही फ़ॉर्मैट में हो जाएगी. ध्यान दें: फ़िलहाल, यह काम करने के लिए आपको git ट्री से ffmpeg का नया वर्शन डाउनलोड करना होगा.

    निर्देश का सैंपल:

    ffmpeg -i myAlphaVideo.webm output.webm

  2. webm-tools का इस्तेमाल करके:

    git clone https://chromium.googlesource.com/webm/libvpx

    webm-tools, WebM से जुड़े आसान ओपन सोर्स टूल का एक सेट है. इसे WebM प्रोजेक्ट के लेखक मैनेज करते हैं. इसमें, अल्फा ट्रांसपेरेंसी वाले WebM वीडियो बनाने के लिए एक टूल भी शामिल है.

    alpha_encoder के साथ काम करने वाले विकल्पों की सूची देखने के लिए, --help के साथ बाइनरी चलाएं.

4. Chrome में वीडियो चलाना

कोड में बदली गई WebM फ़ाइल को Chrome में चलाने के लिए, फ़ाइल को वीडियो एलिमेंट के सोर्स के तौर पर सेट करें.

उन्होंने यह कैसे किया?

हमने इस प्रोजेक्ट पर काम करने वाले Google इंजीनियर, विग्नेश वेंकटसुब्रमणियन से बात की. उन्होंने इन चुनौतियों के बारे में बताया:

  • VP8 बिटस्ट्रीम में ऐल्फ़ा चैनल की सुविधा काम नहीं करती थी. इसलिए, हमें VP8 बिटस्ट्रीम को बदले बिना और मौजूदा प्लेयर को बदले बिना, ऐल्फ़ा को शामिल करना पड़ा.
  • Chrome का रेंडरर, अल्फा वाले वीडियो रेंडर नहीं कर पा रहा था.
  • Chrome में, एक से ज़्यादा हार्डवेयर/GPU डिवाइसों के लिए, रेंडरिंग के कई पाथ होते हैं. अल्फा वीडियो को रेंडर करने के लिए, हर रेंडरिंग पाथ को बदलना पड़ा.

वीडियो के अल्फा ट्रांसपेरेंसी के इस्तेमाल के कई दिलचस्प उदाहरण हैं: गेम, इंटरैक्टिव वीडियो, साथ मिलकर कहानी सुनाना (बैकग्राउंड वीडियो/इमेज में अपना वीडियो जोड़ना), वैकल्पिक किरदारों या प्लॉट वाले वीडियो, ओवरले वीडियो कॉम्पोनेंट का इस्तेमाल करने वाले वेब ऐप्लिकेशन.

फ़िल्म बनाने के लिए शुभकामनाएं! अगर आपको पारदर्शिता के अल्फा वर्शन की मदद से कुछ शानदार बनाना है, तो हमें बताएं.

काम के संसाधन