OpenCV - त्वरित गाइड

OpenCV एक क्रॉस-प्लेटफॉर्म लाइब्रेरी है जिसका उपयोग करके हम वास्तविक समय का विकास कर सकते हैं computer vision applications। यह मुख्य रूप से इमेज प्रोसेसिंग, वीडियो कैप्चर और विश्लेषण पर केंद्रित है जिसमें फेस डिटेक्शन और ऑब्जेक्ट डिटेक्शन जैसी विशेषताएं शामिल हैं।

चलो "कंप्यूटर विजन" शब्द को परिभाषित करके अध्याय शुरू करते हैं।

कंप्यूटर दृष्टी

कंप्यूटर विज़न को एक अनुशासन के रूप में परिभाषित किया जा सकता है जो यह बताता है कि दृश्य में मौजूद संरचना के गुणों के संदर्भ में इसकी 2 डी छवियों से 3 डी दृश्य को कैसे फिर से बनाना, समझना और समझना है। यह कंप्यूटर सॉफ्टवेयर और हार्डवेयर का उपयोग करके मानव दृष्टि की मॉडलिंग और नकल करने से संबंधित है।

कंप्यूटर विज़न निम्नलिखित क्षेत्रों के साथ महत्वपूर्ण रूप से ओवरलैप करता है -

  • Image Processing - यह छवि हेरफेर पर केंद्रित है।

  • Pattern Recognition - यह पैटर्न को वर्गीकृत करने के लिए विभिन्न तकनीकों की व्याख्या करता है।

  • Photogrammetry - यह छवियों से सटीक माप प्राप्त करने से संबंधित है।

कंप्यूटर विज़न बनाम इमेज प्रोसेसिंग

Image processingछवि-से-छवि परिवर्तन से संबंधित है। इमेज प्रोसेसिंग का इनपुट और आउटपुट दोनों ही इमेज हैं।

Computer visionउनकी छवि से भौतिक वस्तुओं के स्पष्ट, सार्थक विवरण का निर्माण है। कंप्यूटर दृष्टि का आउटपुट 3 डी दृश्य में संरचनाओं का वर्णन या व्याख्या है।

कंप्यूटर विजन के अनुप्रयोग

यहाँ हमने कुछ प्रमुख डोमेन सूचीबद्ध किए हैं जहाँ कंप्यूटर विज़न का भारी उपयोग किया जाता है।

रोबोटिक्स एप्लीकेशन

  • स्थानीयकरण - स्वचालित रूप से रोबोट स्थान निर्धारित करें

  • Navigation

  • बाधा से बचाव

  • विधानसभा (खूंटी में छेद, वेल्डिंग, पेंटिंग)

  • हेरफेर (उदाहरण PUMA रोबोट मैनिप्युलेटर)

  • मानव रोबोट इंटरैक्शन (एचआरआई) - लोगों के साथ बातचीत करने और उनकी सेवा करने के लिए बुद्धिमान रोबोटिक्स

चिकित्सा अनुप्रयोग

  • वर्गीकरण और पहचान (जैसे घाव या कोशिकाओं का वर्गीकरण और ट्यूमर का पता लगाना)
  • 2D / 3D विभाजन
  • 3 डी मानव अंग पुनर्निर्माण (एमआरआई या अल्ट्रासाउंड)
  • दृष्टि निर्देशित रोबोटिक्स सर्जरी

औद्योगिक स्वचालन आवेदन

  • औद्योगिक निरीक्षण (दोष का पता लगाना)
  • Assembly
  • बारकोड और पैकेज लेबल पढ़ना
  • वस्तु छँटाई
  • दस्तावेज़ की समझ (जैसे OCR)

सुरक्षा अनुप्रयोग

  • बॉयोमीट्रिक्स (आईरिस, फिंगर प्रिंट, चेहरे की पहचान)

  • निगरानी - कुछ संदिग्ध गतिविधियों या व्यवहारों का पता लगाना

परिवहन आवेदन

  • स्वायत्त वाहन
  • सुरक्षा, जैसे, चालक सतर्कता निगरानी

OpenCV लाइब्रेरी की विशेषताएं

OpenCV लाइब्रेरी का उपयोग, आप कर सकते हैं -

  • चित्र पढ़ें और लिखें

  • वीडियो कैप्चर करें और सहेजें

  • प्रक्रिया छवियों (फिल्टर, परिवर्तन)

  • फ़ीचर डिटेक्शन करें

  • वीडियो या छवियों में विशिष्ट वस्तुओं जैसे चेहरे, आंखों, कारों का पता लगाएं।

  • वीडियो का विश्लेषण करें, अर्थात, इसमें गति का अनुमान लगाएं, पृष्ठभूमि को घटाएं, और इसमें वस्तुओं को ट्रैक करें।

OpenCV मूल रूप से C ++ में विकसित किया गया था। इसके अलावा, पायथन और जावा बाइंडिंग प्रदान किए गए थे। OpenCV विभिन्न ऑपरेटिंग सिस्टम जैसे विंडोज, लिनक्स, ओएसएक्स, फ्रीबीएसडी, नेट बीएसडी, ओपन बीएसडी, आदि पर चलता है।

यह ट्यूटोरियल जावा बाइंडिंग का उपयोग करके ओपनसीवी की अवधारणाओं की व्याख्या करता है।

OpenCV लाइब्रेरी मॉड्यूल

निम्नलिखित OpenCV पुस्तकालय के मुख्य पुस्तकालय मॉड्यूल हैं।

कोर फंक्शनलिटी

यह मॉड्यूल मूल डेटा संरचनाओं जैसे कि स्केलर, पॉइंट, रेंज, आदि को कवर करता है, जिनका उपयोग ओपनसीवी अनुप्रयोगों के निर्माण के लिए किया जाता है। इनके अतिरिक्त, इसमें बहुआयामी सरणी भी शामिल हैMat, जिसका उपयोग छवियों को संग्रहीत करने के लिए किया जाता है। ओपनसीवी के जावा पुस्तकालय में, इस मॉड्यूल को नाम के साथ एक पैकेज के रूप में शामिल किया गया हैorg.opencv.core

इमेज प्रोसेसिंग

इस मॉड्यूल में विभिन्न इमेज प्रोसेसिंग ऑपरेशन शामिल हैं जैसे कि इमेज फ़िल्टरिंग, ज्यामितीय छवि परिवर्तन, रंग अंतरिक्ष रूपांतरण, हिस्टोग्राम, आदि ओपनसीवी की जावा लाइब्रेरी में, इस मॉड्यूल को नाम के साथ एक पैकेज के रूप में शामिल किया गया है। org.opencv.imgproc

वीडियो

यह मॉड्यूल गति विश्लेषण, पृष्ठभूमि घटाव और ऑब्जेक्ट ट्रैकिंग जैसे वीडियो विश्लेषण अवधारणाओं को कवर करता है। ओपनसीवी के जावा पुस्तकालय में, इस मॉड्यूल को नाम के साथ एक पैकेज के रूप में शामिल किया गया हैorg.opencv.video

वीडियो I / O

यह मॉड्यूल OpenCV लाइब्रेरी का उपयोग करके वीडियो कैप्चरिंग और वीडियो कोडेक्स की व्याख्या करता है। ओपनसीवी के जावा पुस्तकालय में, इस मॉड्यूल को नाम के साथ एक पैकेज के रूप में शामिल किया गया हैorg.opencv.videoio

calib3d

इस मॉड्यूल में बुनियादी मल्टीपल-व्यू ज्योमेट्री एल्गोरिदम, सिंगल और स्टीरियो कैमरा कैलिब्रेशन, ऑब्जेक्ट पोज़ अनुमान, स्टीरियो पत्राचार और 3 डी पुनर्निर्माण के तत्व के बारे में एल्गोरिदम शामिल हैं। ओपनसीवी के जावा पुस्तकालय में, इस मॉड्यूल को नाम के साथ एक पैकेज के रूप में शामिल किया गया हैorg.opencv.calib3d

features2d

इस मॉड्यूल में फीचर डिटेक्शन और विवरण की अवधारणाएं शामिल हैं। ओपनसीवी के जावा पुस्तकालय में, इस मॉड्यूल को नाम के साथ एक पैकेज के रूप में शामिल किया गया हैorg.opencv.features2d

Objdetect

इस मॉड्यूल में पूर्वनिर्धारित कक्षाओं की वस्तुओं और उदाहरणों का पता लगाना शामिल है जैसे कि चेहरे, आंखें, मग, लोग, कारें, आदि। OpenCV के जावा पुस्तकालय में, इस मॉड्यूल को नाम के साथ एक पैकेज के रूप में शामिल किया गया है। org.opencv.objdetect

highgui

यह सरल यूआई क्षमताओं के साथ एक आसान-से-उपयोग इंटरफ़ेस है। OpenCV की जावा लाइब्रेरी में, इस मॉड्यूल की विशेषताओं को दो अलग-अलग पैकेजों में शामिल किया गया है,org.opencv.imgcodecs तथा org.opencv.videoio

OpenCV का एक संक्षिप्त इतिहास

OpenCV शुरू में सीपीयू-गहन अनुप्रयोगों को सलाह देने के लिए एक इंटेल शोध पहल थी। इसे आधिकारिक तौर पर 1999 में लॉन्च किया गया था।

  • वर्ष 2006 में, इसका पहला प्रमुख संस्करण, OpenCV 1.0 जारी किया गया था।
  • अक्टूबर 2009 में, दूसरा प्रमुख संस्करण, ओपनसीवी 2 जारी किया गया था।
  • अगस्त 2012 में, OpenCV को एक गैर-लाभकारी संगठन OpenCV.org द्वारा लिया गया था।

इस अध्याय में, आप सीखेंगे कि OpenCV को कैसे स्थापित किया जाए और अपने सिस्टम में इसका वातावरण सेट करें।

OpenCV की स्थापना

सबसे पहले, आपको अपने सिस्टम पर OpenCV डाउनलोड करना होगा। नीचे दिए गए चरणों का पालन करें।

Step 1 - का होमपेज खोलें OpenCV निम्नलिखित लिंक पर क्लिक करके: http://opencv.org/ क्लिक करने पर, आपको नीचे दिखाए गए अनुसार इसका होमपेज दिखाई देगा।

Step 2 - अब, पर क्लिक करें Downloadsलिंक ऊपर दिए गए स्क्रीनशॉट में हाइलाइट किया गया है। क्लिक करने पर, आपको OpenCV के डाउनलोड पृष्ठ पर निर्देशित किया जाएगा।

Step 3 - ऊपर दिए गए स्क्रीनशॉट में हाइलाइट किए गए लिंक पर क्लिक करने पर, एक फाइल opencv-3.1.0.exeडाउनलोड किया जाएगा। एक फ़ोल्डर उत्पन्न करने के लिए इस फ़ाइल को निकालेंopencv आपके सिस्टम में, जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 4 - फोल्डर को खोलें OpenCVbuildjava। यहां आपको OpenCV नाम की जार फाइल मिलेगीopencv-310.jar। इस फ़ाइल को आगे उपयोग के लिए एक अलग फ़ोल्डर में सहेजें।

ग्रहण स्थापना

आवश्यक JAR फ़ाइलों को डाउनलोड करने के बाद, आपको इन JAR फ़ाइलों को अपने ग्रहण वातावरण में एम्बेड करना होगा। आप इन JAR फ़ाइलों के निर्माण पथ का उपयोग करके और उपयोग करके कर सकते हैंpom.xml

निर्माण पथ की स्थापना

निम्नलिखित OpenCV को ग्रहण में स्थापित करने के चरण हैं -

Step 1- सुनिश्चित करें कि आपने अपने सिस्टम में ग्रहण स्थापित किया है। यदि नहीं, तो अपने सिस्टम में ग्रहण को डाउनलोड और इंस्टॉल करें।

Step 2 - ओपन एक्लिप्स, फाइल पर क्लिक करें, नया, और एक नया प्रोजेक्ट खोलें जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 3 - प्रोजेक्ट का चयन करने पर आपको मिलेगा New Projectजादूगर। इस विज़ार्ड में, जावा प्रोजेक्ट चुनें और क्लिक करके आगे बढ़ेंNext बटन, जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 4 - आगे बढ़ने पर, आपको निर्देशित किया जाएगा New Java Project wizard। एक नया प्रोजेक्ट बनाएं और क्लिक करेंNext, जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 5- नया प्रोजेक्ट बनाने के बाद उस पर राइट क्लिक करें। चुनते हैंBuild Path और क्लिक करें Configure Build Path… जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 6 - क्लिक करने पर Build Path विकल्प, आपको निर्देशित किया जाएगा Java Build Path wizard। दबाएंAdd External JARs बटन, जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 7 - उस पथ का चयन करें जहां आपने फ़ाइल को सहेजा है opencv-310.jar

Step 8 - क्लिक करने पर Open उपरोक्त स्क्रीनशॉट में बटन, उन फ़ाइलों को आपके पुस्तकालय में जोड़ा जाएगा।

Step 9 - पर क्लिक करें OK, आप वर्तमान परियोजना के लिए आवश्यक JAR फ़ाइलों को सफलतापूर्वक जोड़ देंगे और आप संदर्भित पुस्तकालयों का विस्तार करके इन जोड़ा पुस्तकालयों को सत्यापित कर सकते हैं।

मूल पुस्तकालयों के लिए पथ की स्थापना

JAR फ़ाइलों के अलावा, आपको OpenCV के मूल पुस्तकालयों (DLL फ़ाइलों) के लिए पथ सेट करने की आवश्यकता है।

Location of DLL files - की स्थापना फ़ोल्डर खोलें OpenCV और उप-फ़ोल्डर में जाएं buildjava। यहां आपको दो फोल्डर मिलेंगेx64 (64 बिट) और x86 (32 बिट) जिसमें सम्‍मिलित है dll OpenCV की फाइलें।

अपने ऑपरेटिंग सिस्टम के लिए उपयुक्त संबंधित फ़ोल्डर खोलें, फिर आप देख सकते हैं dll फ़ाइल, जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

अब, नीचे दिए गए चरणों का पालन करके इस फ़ाइल के लिए पथ निर्धारित करें -

Step 1- एक बार फिर, JavaBuildPath विंडो खोलें। यहां आप जोड़े गए JAR फ़ाइल और अवलोकन कर सकते हैंJRE System Library

Step 2 - इसे विस्तारित करने पर, आपको सिस्टम लाइब्रेरी मिलेगी और Native library location, जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 3 - पर डबल क्लिक करें Native library location। यहां, आप देख सकते हैंNative Library Folder Configuration window जैसा की नीचे दिखाया गया।

यहां, बटन पर क्लिक करें External Folder… और का स्थान चुनें dll अपने सिस्टम में फाइल करें।

एक छवि को पकड़ने के लिए, हम कैमरे और स्कैनर जैसे उपकरणों का उपयोग करते हैं। ये डिवाइस छवि के संख्यात्मक मान रिकॉर्ड करते हैं (उदा: पिक्सेल मान)। OpenCV एक पुस्तकालय है जो डिजिटल छवियों को संसाधित करता है, इसलिए हमें इन छवियों को प्रसंस्करण के लिए संग्रहीत करने की आवश्यकता है।

MatOpenCV लाइब्रेरी के वर्ग का उपयोग किसी छवि के मूल्यों को संग्रहीत करने के लिए किया जाता है। यह एक एन-आयामी सरणी का प्रतिनिधित्व करता है और इसका उपयोग ग्रेस्केल या रंग छवियों, स्वर वॉल्यूम, वेक्टर फ़ील्ड, पॉइंट क्लाउड, टेनर्स, हिस्टोग्राम, आदि के छवि डेटा को स्टोर करने के लिए किया जाता है।

इस वर्ग में दो डेटा भाग शामिल हैं: a header और एक pointer

  • Header - इसमें आकार, भंडारण के लिए उपयोग की जाने वाली विधि और मैट्रिक्स का पता (आकार में स्थिर) जैसी जानकारी शामिल है।

  • Pointer - छवि के पिक्सेल मूल्यों को संग्रहीत करता है (अलग-अलग रहता है)।

द मैट क्लास

OpenCV जावा पुस्तकालय इस नाम के साथ यह वर्ग प्रदान करता है (Mat) पैकेज के भीतर org.opencv.core

कंस्ट्रक्टर्स

OpenCV जावा लाइब्रेरी के मैट क्लास में विभिन्न कंस्ट्रक्टर हैं, जिनके उपयोग से आप मैट ऑब्जेक्ट का निर्माण कर सकते हैं।

S.No कंस्ट्रक्टर और विवरण
1

Mat()

यह अधिकांश मामलों में कोई पैरामीटर नहीं होने के साथ डिफ़ॉल्ट निर्माता है। हम इसका उपयोग कंस्ट्रक्टर के लिए एक खाली मैट्रिक्स बनाने के लिए करते हैं और इसे अन्य OpenCV विधियों में पास करते हैं।

2

Mat(int rows, int cols, int type)

यह कंस्ट्रक्टर पूर्णांक प्रकार के तीन मापदंडों को एक 2 डी सरणी में पंक्तियों और स्तंभों की संख्या और सरणी के प्रकार (जो डेटा को संग्रहीत करने के लिए उपयोग किया जाना है) को स्वीकार करता है।

3

Mat(int rows, int cols, int type, Scalar s)

पिछले एक के मापदंडों को शामिल करते हुए, यह निर्माता अतिरिक्त रूप से वर्ग स्केलर के एक ऑब्जेक्ट को पैरामीटर के रूप में स्वीकार करता है।

4

Mat(Size size, int type)

यह कंस्ट्रक्टर दो मापदंडों को स्वीकार करता है, मैट्रिक्स के आकार का प्रतिनिधित्व करने वाला ऑब्जेक्ट और डेटा को स्टोर करने के लिए उपयोग किए जाने वाले सरणी के प्रकार का प्रतिनिधित्व करने वाला पूर्णांक।

5

Mat(Size size, int type, Scalar s)

पिछले एक के मापदंडों को शामिल करते हुए, यह निर्माता अतिरिक्त रूप से वर्ग स्केलर के एक ऑब्जेक्ट को पैरामीटर के रूप में स्वीकार करता है।

6

Mat(long addr)

7

Mat(Mat m, Range rowRange)

यह कंस्ट्रक्टर एक अन्य मैट्रिक्स की एक वस्तु को स्वीकार करता है और एक नई मैट्रिक्स बनाने के लिए ली जाने वाली पंक्तियों की सीमा का प्रतिनिधित्व करने वाली श्रेणी की श्रेणी का एक ऑब्जेक्ट है।

8

Mat(Mat m, Range rowRange, Range colRange)

पिछले एक के मापदंडों को शामिल करते हुए, यह निर्माता अतिरिक्त रूप से कक्षा की एक वस्तु को स्वीकार करता है। स्तंभ श्रेणी का प्रतिनिधित्व करने वाली श्रेणी।

9

Mat(Mat m, Rect roi)

यह निर्माता दो वस्तुओं को स्वीकार करता है, एक अन्य मैट्रिक्स का प्रतिनिधित्व करता है और दूसरा अन्य का प्रतिनिधित्व करता है Region OInterest।

Note -

  • सरणी प्रकार। CV_8UC1, ..., CV_64FC4 का उपयोग 1-4 चैनल मैट्रिसेस बनाने के लिए करें, या CV_8UC (n), ..., CV_64FC (n) मल्टी-चैनल (CV_CN_MAX चैनल तक) मैट्रिसेस बनाने के लिए।

  • मैट्रिस के प्रकार को कक्षा के विभिन्न क्षेत्रों द्वारा दर्शाया गया था CvType जो पैकेज के अंतर्गत आता है org.opencv.core

तरीके और विवरण

मैट क्लास द्वारा दिए गए कुछ तरीके निम्नलिखित हैं।

S.No तरीके और विवरण
1

Mat col(int x)

यह विधि किसी स्तंभ के सूचकांक का प्रतिनिधित्व करने वाले पूर्णांक पैरामीटर को स्वीकार करती है और उस स्तंभ को पुनः प्राप्त और वापस लाती है।

2

Mat row(int y)

यह विधि किसी पूर्णांक पैरामीटर को एक पंक्ति के सूचकांक का प्रतिनिधित्व करती है और उस पंक्ति को पुनः प्राप्त और वापस लाती है।

3

int cols()

यह विधि मैट्रिक्स में स्तंभों की संख्या लौटाती है।

4

int rows()

यह विधि मैट्रिक्स में पंक्तियों की संख्या लौटाती है।

5

Mat setTo(Mat value)

यह विधि किसी वस्तु को स्वीकार करती है Mat प्रकार और निर्दिष्ट तत्वों को निर्दिष्ट मान पर सेट करता है।

6

Mat setTo(Scalar s)

यह विधि किसी वस्तु को स्वीकार करती है Scalar प्रकार और निर्दिष्ट तत्वों को निर्दिष्ट मान पर सेट करता है।

मैट्रिक्स बनाना और प्रदर्शित करना

इस खंड में, हम अपने पहले OpenCV उदाहरण पर चर्चा करने जा रहे हैं। हम देखेंगे कि सरल OpenCV मैट्रिक्स कैसे बनायें और प्रदर्शित करें।

OpenCV में मैट्रिक्स बनाने और प्रदर्शित करने के लिए नीचे दिए गए चरणों का पालन किया गया है।

चरण 1: OpenCV देशी लाइब्रेरी लोड करें

OpenCV लाइब्रेरी का उपयोग करके जावा कोड लिखते समय, आपको जो पहला कदम उठाने की ज़रूरत है, वह है OpenCV के मूल पुस्तकालय को लोड करके loadLibrary()। OpenCV देशी लाइब्रेरी को लोड करें जैसा कि नीचे दिखाया गया है।

//Loading the core library 
System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

चरण 2: त्वरित चटाई वर्ग

इस अध्याय में पहले बताए गए कार्यों में से किसी का उपयोग करके मैट क्लास को इंस्टेंट करें।

//Creating a matrix 
Mat matrix = new Mat(5, 5, CvType.CV_8UC1, new Scalar(0));

चरण 3: विधियों का उपयोग करके मैट्रिक्स भरें

आप अनुक्रमणिका मानों की विधियों द्वारा मैट्रिक्स की विशेष पंक्तियों / स्तंभों को पुनः प्राप्त कर सकते हैं row()/col()

और, आप इनमें से किसी भी वैरिएंट का उपयोग करके मान सेट कर सकते हैं setTo() तरीकों।

//Retrieving the row with index 0 
Mat row0 = matrix.row(0); 
     
//setting values of all elements in the row with index 0 
row0.setTo(new Scalar(1)); 
     
//Retrieving the row with index 3 
Mat col3 = matrix.col(3);  
     
//setting values of all elements in the row with index 3 
col3.setTo(new Scalar(3));

Example

आप OpenCV लाइब्रेरी का उपयोग करके जावा में एक सरल मैट्रिक्स बनाने और प्रदर्शित करने के लिए निम्न प्रोग्राम कोड का उपयोग कर सकते हैं।

import org.opencv.core.Core; 
import org.opencv.core.Mat;  
import org.opencv.core.CvType;  
import org.opencv.core.Scalar;   

class DisplayingMatrix { 
   public static void main(String[] args) {     
      //Loading the core library 
      System.loadLibrary(Core.NATIVE_LIBRARY_NAME);     

      //Creating a matrix 
      Mat matrix = new Mat(5, 5, CvType.CV_8UC1, new Scalar(0));  

      //Retrieving the row with index 0 
      Mat row0 = matrix.row(0);

      //setting values of all elements in the row with index 0 
      row0.setTo(new Scalar(1)); 

      //Retrieving the row with index 3 
      Mat col3 = matrix.col(3);  

      //setting values of all elements in the row with index 3 
      col3.setTo(new Scalar(3)); 

      //Printing the matrix 
      System.out.println("OpenCV Mat data:\n" + matrix.dump()); 
   } 
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

OpenCV Mat data: 
[  1,   1,   1,   3,   1; 
   0,   0,   0,   3,   0; 
   0,   0,   0,   3,   0; 
   0,   0,   0,   3,   0; 
   0,   0,   0,   3,   0]

JavaSE API का उपयोग करके चित्र लोड हो रहा है

BufferedImage की कक्षा java.awt.image.BufferedImage पैकेज का उपयोग छवि और स्टोर करने के लिए किया जाता है ImageIO पैकेज की कक्षा import javax.imageio छवियाँ पढ़ने और लिखने के लिए तरीके प्रदान करता है।

Example

जावाएसई लाइब्रेरी का उपयोग करके छवियों को लोड करने और सहेजने के लिए आप निम्न प्रोग्राम कोड का उपयोग कर सकते हैं।

import java.awt.image.BufferedImage; 
import java.io.File; 
import java.io.IOException; 
import javax.imageio.ImageIO;
  
public class LoadingImage_JSE_library {
   public static void main( String[] args ) throws IOException {
      //Input File 
      File input = new File("C:/EXAMPLES/OpenCV/sample.jpg");
          
      //Reading the image 
      BufferedImage image = ImageIO.read(input);
      
      //Saving the image with a different name
      File ouptut = new File("C:/OpenCV/sample.jpg");
      ImageIO.write(image, "jpg", ouptut);
         
      System.out.println("image Saved");
   } 
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

image Saved

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप सहेजे गए चित्र को निम्नानुसार देख सकते हैं -

Imgcodecs पैकेज की कक्षा org.opencv.imgcodecsछवियों को पढ़ने और लिखने के लिए तरीके प्रदान करता है। OpenCV का उपयोग करके, आप एक छवि पढ़ सकते हैं और इसे मैट्रिक्स में संग्रहीत कर सकते हैं (यदि आवश्यक हो तो मैट्रिक्स पर रूपांतरण करें)। बाद में, आप संसाधित मैट्रिक्स को एक फ़ाइल में लिख सकते हैं।

read() की विधि ImgcodecsOpenCV का उपयोग करके छवि को पढ़ने के लिए कक्षा का उपयोग किया जाता है। इस विधि का वाक्य विन्यास निम्नलिखित है।

imread(filename)

यह एक तर्क को स्वीकार करता है (filename), पढ़ने के लिए है कि फ़ाइल के पथ का प्रतिनिधित्व स्ट्रिंग प्रकार का एक चर।

नीचे दिए गए चरणों में OpenCV लाइब्रेरी का उपयोग करके जावा में चित्र पढ़ने के लिए चरण दिए गए हैं।

चरण 1: OpenCV देशी लाइब्रेरी लोड करें

का उपयोग कर OpenCV देशी पुस्तकालय लोड करें load() विधि, जैसा कि नीचे दिखाया गया है।

//Loading the core library 
System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

चरण 2: तत्काल Imgcodecs वर्ग

झटपट Imgcodecs कक्षा।

//Instantiating the Imgcodecs class 
Imgcodecs imageCodecs = new Imgcodecs();

चरण 3: छवि को पढ़ना

विधि का उपयोग करके छवि पढ़ें imread()। यह विधि छवि के पथ का प्रतिनिधित्व करने वाले एक स्ट्रिंग तर्क को स्वीकार करती है और इस रूप में पढ़ी गई छवि को वापस करती हैMat वस्तु।

//Reading the Image from the file  
Mat matrix = imageCodecs.imread(Path of the image);

उदाहरण

निम्न प्रोग्राम कोड दिखाता है कि आप कैसे कर सकते हैं read an image OpenCV लाइब्रेरी का उपयोग करना।

import org.opencv.core.Core; 
import org.opencv.core.Mat;  
import org.opencv.imgcodecs.Imgcodecs;
 
public class ReadingImages {
   public static void main(String args[]) { 
      //Loading the OpenCV core library  
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME ); 
     
      //Instantiating the Imagecodecs class 
      Imgcodecs imageCodecs = new Imgcodecs(); 
     
      //Reading the Image from the file  
      String file ="C:/EXAMPLES/OpenCV/sample.jpg"; 
      Mat matrix = imageCodecs.imread(file); 
     
      System.out.println("Image Loaded");     
   } 
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, OpenCV निर्दिष्ट छवि को लोड करता है और निम्न आउटपुट प्रदर्शित करता है -

Image Loaded

write() की विधि ImgcodecsOpenCV का उपयोग करके छवि लिखने के लिए कक्षा का उपयोग किया जाता है। एक छवि लिखने के लिए, पिछले उदाहरण से पहले तीन चरणों को दोहराएं।

एक छवि लिखने के लिए, आपको आह्वान करने की आवश्यकता है imwrite() की विधि Imgcodecs कक्षा।

इस विधि का वाक्य विन्यास निम्नलिखित है।

imwrite(filename, mat)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • filename - ए String चर फ़ाइल को बचाने के लिए पथ का प्रतिनिधित्व करता है।

  • mat - ए Mat लिखी जाने वाली छवि का प्रतिनिधित्व करने वाली वस्तु।

उदाहरण

निम्नलिखित कार्यक्रम एक उदाहरण है write an image OpenCV लाइब्रेरी का उपयोग करके जावा प्रोग्राम का उपयोग करना।

import org.opencv.core.Core; 
import org.opencv.core.Mat; 
import org.opencv.imgcodecs.Imgcodecs;
 
public class WritingImages {  
   public static void main(String args[]) { 
      //Loading the OpenCV core library  
      System.loadLibrary(Core.NATIVE_LIBRARY_NAME); 
      
      //Instantiating the imagecodecs class 
      Imgcodecs imageCodecs = new Imgcodecs(); 

      //Reading the Image from the file and storing it in to a Matrix object 
      String file ="C:/EXAMPLES/OpenCV/sample.jpg";   
      Mat matrix = imageCodecs.imread(file); 

      System.out.println("Image Loaded ..........");
      String file2 = "C:/EXAMPLES/OpenCV/sample_resaved.jpg"; 

      //Writing the image 
      imageCodecs.imwrite(file2, matrix); 
      System.out.println("Image Saved ............"); 
   } 
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Loaded .......... 
Image Saved ...........

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप नीचे दिखाए गए अनुसार सहेजे गए चित्र का अवलोकन कर सकते हैं -

पहले के अध्यायों में, हमने चर्चा की है कि ओपनसीवी जावा पुस्तकालय का उपयोग करके एक छवि को कैसे पढ़ा और बचाया जाए। इसके अतिरिक्त, हम GUI पुस्तकालयों जैसे AWT / Swings और JavaFX का उपयोग करके एक अलग विंडो में लोड की गई छवियों को भी प्रदर्शित कर सकते हैं।

बफ़र्ड छवि के लिए चटाई परिवर्तित

एक छवि पढ़ने के लिए हम विधि का उपयोग करते हैं imread()। यह विधि के रूप में पढ़ी गई छवि को वापस लौटाती हैMatrix। लेकिन, GUI पुस्तकालयों (AWT / स्विंग और JavaFX) के साथ इस छवि का उपयोग करने के लिए, इसे कक्षा की एक वस्तु के रूप में परिवर्तित किया जाना चाहिएBufferedImage पैकेज का java.awt.image.BufferedImage

निम्नलिखित कन्वर्ट करने के लिए कदम हैं Mat OpenCV की वस्तु BufferedImage वस्तु।

चरण 1: Mat को MatOfByte में एन्कोड करें

सबसे पहले, आपको मैट्रिक्स को बाइट के मैट्रिक्स में बदलना होगा। आप इसे विधि का उपयोग करके कर सकते हैंimencode() वर्ग का Imgcodecs। इस विधि का वाक्य विन्यास निम्नलिखित है।

imencode(ext, image, matOfByte);

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • Ext - छवि प्रारूप (.jpg, .png, आदि) निर्दिष्ट करने वाला एक स्ट्रिंग पैरामीटर

  • image - छवि का एक मैट ऑब्जेक्ट

  • matOfByte - वर्ग MatOfByte की एक खाली वस्तु

इस विधि का उपयोग करके छवि को एनकोड करें जैसा कि नीचे दिखाया गया है।

//Reading the image 
Mat image = Imgcodecs.imread(file);

//instantiating an empty MatOfByte class 
MatOfByte matOfByte = new MatOfByte();

//Converting the Mat object to MatOfByte 
Imgcodecs.imencode(".jpg", image, matOfByte);

चरण 2: बाइट सरणी में MatOfByte ऑब्जेक्ट कन्वर्ट करें

रूपांतरित करें MatOfByte विधि का उपयोग करके एक बाइट सरणी में ऑब्जेक्ट toArray()

byte[] byteArray = matOfByte.toArray();

चरण 3: InputStream ऑब्जेक्ट तैयार करना

के निर्माण के लिए पिछले चरण में बनाए गए बाइट सरणी को पास करके InputStream ऑब्जेक्ट तैयार करें ByteArrayInputStream कक्षा।

//Preparing the InputStream object 
InputStream in = new ByteArrayInputStream(byteArray);

चरण 4: InputStream ऑब्जेक्ट तैयार करना

पिछले चरण में बनाई गई इनपुट स्ट्रीम ऑब्जेक्ट को पास करें read() की विधि ImageIOकक्षा। यह एक BufferedImage ऑब्जेक्ट लौटाएगा।

//Preparing the BufferedImage 
BufferedImage bufImage = ImageIO.read(in);

AWT / स्विंग का उपयोग करके छवि प्रदर्शित करना

AWT / स्विंग फ्रेम का उपयोग करके एक छवि प्रदर्शित करने के लिए, सबसे पहले, एक छवि का उपयोग करके पढ़ें imread() विधि और इसे में परिवर्तित करें BufferedImage उपर्युक्त चरणों का पालन करना।

फिर, तुरंत JFrame वर्ग और JFrame के ContentPane में बनाई गई बफ़र्ड छवि जोड़ें, जैसा कि नीचे दिखाया गया है -

//Instantiate JFrame 
JFrame frame = new JFrame();
 
//Set Content to the JFrame 
frame.getContentPane().add(new JLabel(new ImageIcon(bufImage))); 
frame.pack(); 
frame.setVisible(true);

Example

निम्न प्रोग्राम कोड दिखाता है कि आप कैसे कर सकते हैं read एक छवि और display OpenCV लाइब्रेरी का उपयोग करके स्विंग विंडो के माध्यम से।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;

import javax.imageio.ImageIO;
import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.imgcodecs.Imgcodecs;

public class DisplayingImagesUsingSwings {
   public static void main(String args[]) throws Exception { 
      //Loading the OpenCV core library  
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME ); 
    
      //Reading the Image from the file and storing it in to a Matrix object 
      String file = "C:/EXAMPLES/OpenCV/sample.jpg"; 
      Mat image = Imgcodecs.imread(file); 
    
      //Encoding the image 
      MatOfByte matOfByte = new MatOfByte();       
      Imgcodecs.imencode(".jpg", image, matOfByte); 

      //Storing the encoded Mat in a byte array 
      byte[] byteArray = matOfByte.toArray(); 

      //Preparing the Buffered Image 
      InputStream in = new ByteArrayInputStream(byteArray); 
      BufferedImage bufImage = ImageIO.read(in); 

      //Instantiate JFrame 
      JFrame frame = new JFrame(); 

      //Set Content to the JFrame 
      frame.getContentPane().add(new JLabel(new ImageIcon(bufImage))); 
      frame.pack(); 
      frame.setVisible(true);
      
      System.out.println("Image Loaded");     
   } 
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Loaded

इसके अलावा, आप लोड की गई छवि को प्रदर्शित करते हुए एक विंडो देख सकते हैं, निम्नानुसार है -

जावाएफएक्स का उपयोग करके छवि प्रदर्शित करना

जावाएफएक्स का उपयोग करके एक छवि प्रदर्शित करने के लिए, सबसे पहले, छवि का उपयोग करके पढ़ें imread() विधि और इसे में परिवर्तित करें BufferedImage। फिर, बफ़रेडआईमेज को WritableImage में कनवर्ट करें, जैसा कि नीचे दिखाया गया है।

WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

इसे पास करो WritableImage के निर्माता के लिए आपत्ति ImageView कक्षा।

ImageView imageView = new ImageView(writableImage);

Example

निम्न प्रोग्राम कोड दिखाता है कि कैसे read एक छवि और display OpenCV लाइब्रेरी का उपयोग करके JavaFX विंडो के माध्यम से।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import javax.imageio.ImageIO;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.imgcodecs.Imgcodecs;

public class DisplayingImagesJavaFX extends Application {
   @Override 
   public void start(Stage stage) throws IOException {   
      WritableImage writableImage = loadImage(); 
  
      //Setting the image view 
      ImageView imageView = new ImageView(writableImage); 
        
      //Setting the position of the image 
      imageView.setX(50); 
      imageView.setY(25); 
        
      //setting the fit height and width of the image view 
      imageView.setFitHeight(400); 
      imageView.setFitWidth(500);
      
      //Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);
      
      //Creating a Group object  
      Group root = new Group(imageView);
      
      //Creating a scene object
      Scene scene = new Scene(root, 600, 400);
      
      //Setting title to the Stage 
      stage.setTitle("Loading an image");
      
      //Adding scene to the stage
      stage.setScene(scene);

      //Displaying the contents of the stage
      stage.show();
   } 
   public WritableImage loadImage() throws IOException {
      //Loading the OpenCV core library  
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
      
      //Reading the Image from the file and storing it in to a Matrix object
      String file ="C:/EXAMPLES/OpenCV/sample.jpg";
      Mat image = Imgcodecs.imread(file);
      
      //Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", image, matOfByte);

      //Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();
      
      //Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray); 
      BufferedImage bufImage = ImageIO.read(in);

      System.out.println("Image Loaded");
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage; 
   }
   public static void main(String args[]) {
      launch(args); 
   } 
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Loaded

इसके अलावा, आप लोड की गई छवि को प्रदर्शित करते हुए एक विंडो देख सकते हैं, निम्नानुसार है -

OpenCV विभिन्न प्रकार की छवियों जैसे रंगीन, बाइनरी, ग्रेस्केल आदि का उपयोग करके समर्थन करता है imread() विधि और पूर्वनिर्धारित क्षेत्र Imgcodecs वर्ग, आप किसी दिए गए चित्र को दूसरे प्रकार के रूप में पढ़ सकते हैं।

इम्रेड () विधि (IMREAD_XXX) के झंडे पैरामीटर

पहले के अध्यायों में, हमने वाक्य रचना को देखा है imread() की विधि Imgcodecsकक्षा। यह उस स्ट्रिंग तर्क को स्वीकार करता है जो उस छवि के स्थान का प्रतिनिधित्व करता है जिसे पढ़ा जाना है।

imread(filename)

imread() विधि का एक और वाक्य विन्यास है।

imread(filename, int flags)

यह वाक्यविन्यास दो मापदंडों को स्वीकार करता है -

  • filename - यह एक तर्क को स्वीकार करता है (filename), पढ़ने के लिए है कि फ़ाइल के पथ का प्रतिनिधित्व स्ट्रिंग प्रकार का एक चर।

  • flags- एक पूर्ववर्ती ध्वज मान का प्रतिनिधित्व करने वाला पूर्णांक मान। प्रत्येक मान के लिए, यह दी गई छवि को एक विशिष्ट प्रकार (ग्रे स्केल रंग आदि) के रूप में पढ़ता है

निम्नलिखित तालिका में प्रदान किए गए विभिन्न क्षेत्रों की सूची है Imgproc इस पैरामीटर के लिए मान के रूप में वर्ग।

S.No फ़ील्ड और विवरण
1

IMREAD_COLOR

यदि ध्वज को इस मान पर सेट किया जाता है, तो लोड की गई छवि को 3-चैनल बीजीआर (ब्लू ग्रीन रेड) रंग छवि में बदल दिया जाएगा।

2

IMREAD_GRAYSCALE

यदि ध्वज को इस मान पर सेट किया जाता है, तो लोड की गई छवि को एकल-चैनल ग्रेस्केल छवि में बदल दिया जाएगा।

3

IMREAD_LOAD_GDAL

यदि ध्वज इस मान पर सेट है, तो आप छवि का उपयोग करके लोड कर सकते हैं gdal चालक।

4

IMREAD_ANYCOLOR

यदि ध्वज को इस मान पर सेट किया जाता है, तो छवि को किसी भी संभावित रंग प्रारूप में पढ़ा जाता है।

5

IMREAD_REDUCED_COLOR_2

IMREAD_REDUCED_COLOR_4

IMREAD_REDUCED_COLOR_8

झंडा यह मान पर सेट है, तो छवि के रूप में तीन चैनल बीजीआर पढ़ा जाता है, और छवि का आकार आधा करने के लिए कम हो जाता है, ¼ वें या ⅛ वें इस्तेमाल किया क्षेत्र के संबंध में छवि के मूल आकार के।

6

IMREAD_REDUCED_GRAYSCALE_2

IMREAD_REDUCED_GRAYSCALE_4

IMREAD_REDUCED_GRAYSCALE_8

झंडा यह मान पर सेट है, तो छवि केवल एक चैनल ग्रेस्केल छवि के रूप में पढ़ा जाता है, और छवि का आकार आधा करने के लिए कम हो जाता है, ¼ वें या ⅛ वें मूल क्षेत्र के संबंध में छवि का आकार का उपयोग किया जाता है ।

7

IMREAD_UNCHANGED

यदि ध्वज को इस मान पर सेट किया गया है, तो लोड की गई छवि वापस आ गई है।

निम्न प्रोग्राम दर्शाता है कि रंगीन छवि को ग्रेस्केल के रूप में कैसे पढ़ा जाए और जावाएफएक्स विंडो का उपयोग करके इसे प्रदर्शित किया जाए। यहाँ में, हमने ध्वज को पास करके छवि को पढ़ा हैIMREAD_GRAYSCALE स्ट्रिंग के साथ एक रंगीन छवि का मार्ग पकड़े हुए।

import java.awt.image.BufferedImage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

public class ReadingAsGrayscale extends Application {
   @Override
   public void start(Stage stage) throws Exception {
      WritableImage writableImage = loadAndConvert();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // Setting the position of the image
      imageView.setX(10);
      imageView.setY(10);

      // setting the fit height and width of the image view
      imageView.setFitHeight(400);
      imageView.setFitWidth(600);
      
      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);
      
      // Creating a Group object  
      Group root = new Group(imageView);
      
      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);
      
      // Setting title to the Stage
      stage.setTitle("Reading image as grayscale");
      
      // Adding scene to the stage
      stage.setScene(scene);
      
      // Displaying the contents of the stage
      stage.show();
   } 
   public WritableImage loadAndConvert() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Instantiating the imagecodecs class
      Imgcodecs imageCodecs = new Imgcodecs();

      String input = "C:/EXAMPLES/OpenCV/sample.jpg";

      // Reading the image
      Mat src = imageCodecs.imread(input, Imgcodecs.IMREAD_GRAYSCALE);
       
      byte[] data1 = new byte[src.rows() * src.cols() * (int)(src.elemSize())];
      src.get(0, 0, data1);
      
      // Creating the buffered image
      BufferedImage bufImage = new BufferedImage(src.cols(),src.rows(), 
         BufferedImage.TYPE_BYTE_GRAY);
      
      // Setting the data elements to the image
      bufImage.getRaster().setDataElements(0, 0, src.cols(), src.rows(), data1);
              
      // Creating a WritableImage
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      System.out.println("Image Read");
      return writableImage;
   } 
   public static void main(String args[]) throws Exception { 
      launch(args); 
   } 
}

इनपुट छवि

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

आउटपुट छवि

कार्यक्रम को निष्पादित करने पर, आपको निम्न आउटपुट मिलेगा।

निम्न प्रोग्राम दर्शाता है कि रंगीन छवि को BGR प्रकार की छवि के रूप में कैसे पढ़ा जाए और इसे JavaFX विंडो का उपयोग करके प्रदर्शित किया जाए। यहाँ में, हमने ध्वज को पास करके छवि को पढ़ा हैIMREAD_COLOR विधि के लिए imread() स्ट्रिंग के साथ एक रंगीन छवि का मार्ग पकड़े हुए।

import java.awt.image.BufferedImage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

public class ReadingAsColored extends Application {
   @Override 
   public void start(Stage stage) throws Exception {
      WritableImage writableImage = loadAndConvert();
       
      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // Setting the position of the image
      imageView.setX(10);
      imageView.setY(10);

      // setting the fit height and width of the image view
      imageView.setFitHeight(400);
      imageView.setFitWidth(600);
      
      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);
      
      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);
     
      // Setting title to the Stage
      stage.setTitle("Reading as colored image");

      // Adding scene to the stage
      stage.setScene(scene);
      
      // Displaying the contents of the stage
      stage.show();
   } 
   public WritableImage loadAndConvert() throws Exception {     
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
       
      String input = "C:/EXAMPLES/OpenCV/sample.jpg";
       
      Mat dst = new Mat();

      // Reading the image
      Mat src = Imgcodecs.imread(input, Imgcodecs.IMREAD_COLOR);

      byte[] data1 = new byte[src.rows() * src.cols() * (int)(src.elemSize())]; 
      src.get(0, 0, data1);
      
      // Creating the buffered image
      BufferedImage bufImage = new BufferedImage(src.cols(),src.rows(), 
         BufferedImage.TYPE_3BYTE_BGR);

      // Setting the data elements to the image 
      bufImage.getRaster().setDataElements(0, 0, src.cols(), src.rows(), data1);

      // Creating a WritableImage
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      System.out.println("Image read");
      return writableImage;
   } 
   public static void main(String args[]) throws Exception {
      launch(args);
   } 
}

इनपुट छवि

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

आउटपुट छवि

कार्यक्रम को निष्पादित करने पर, आपको निम्न आउटपुट मिलेगा।

पहले के अध्यायों में, हमने चर्चा की कि इनपुट इमेज को विभिन्न प्रकारों (बाइनरी, ग्रेस्केल, बीजीआर, आदि) के रूप में कैसे पढ़ा जाए। इस अध्याय में, हम सीखेंगे कि एक प्रकार की छवि को दूसरे में कैसे परिवर्तित किया जाए।

नाम का वर्ग Imgproc पैकेज का org.opencv.imgproc एक छवि को एक रंग से दूसरे रंग में बदलने के तरीके प्रदान करता है।

ग्रेस्केल में रंगीन छवियों को परिवर्तित करना

नामक विधि cvtColor()रंगीन चित्रों को ग्रेस्केल में बदलने के लिए उपयोग किया जाता है। इस विधि का वाक्य विन्यास निम्नलिखित है।

cvtColor(Mat src, Mat dst, int code)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - एक मैट्रिक्स स्रोत का प्रतिनिधित्व करता है।

  • dst - एक मैट्रिक्स जो गंतव्य का प्रतिनिधित्व करता है।

  • code - एक पूर्णांक कोड रूपांतरण के प्रकार का प्रतिनिधित्व करता है, उदाहरण के लिए, आरजीबी से ग्रेस्केल।

आप कोड को पास करके रंगीन चित्रों को ग्रे स्केल में बदल सकते हैं Imgproc.COLOR_RGB2GRAY स्रोत और गंतव्य मैट्रिक्स के साथ एक पैरामीटर के रूप में cvtColor() तरीका।

उदाहरण

निम्न कार्यक्रम दर्शाता है कि रंगीन छवि को ग्रेस्केल छवि के रूप में कैसे पढ़ा जाए और जावाएफएक्स विंडो का उपयोग करके इसे प्रदर्शित किया जाए।

import java.awt.image.BufferedImage;
  
import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;

import javafx.stage.Stage;

public class ColorToGrayscale extends Application {
   @Override
   public void start(Stage stage) throws Exception {
      WritableImage writableImage = loadAndConvert();
       
      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // Setting the position of the image
      imageView.setX(10);
      imageView.setY(10);

      // setting the fit height and width of the image view
      imageView.setFitHeight(400);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Colored to grayscale image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   } 
   public WritableImage loadAndConvert() throws Exception {
      //Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      String input = "C:/EXAMPLES/OpenCV/sample.jpg";

      //Reading the image
      Mat src = Imgcodecs.imread(input);

      //Creating the empty destination matrix
      Mat dst = new Mat();

      //Converting the image to gray sacle and saving it in the dst matrix
      Imgproc.cvtColor(src, dst, Imgproc.COLOR_RGB2GRAY);
      
      //Extracting data from the transformed image (dst)
      byte[] data1 = new byte[dst.rows() * dst.cols() * (int)(dst.elemSize())];
      dst.get(0, 0, data1);

      //Creating Buffered image using the data
      BufferedImage bufImage = new BufferedImage(dst.cols(),dst.rows(), 
         BufferedImage.TYPE_BYTE_GRAY);

      //Setting the data elements to the image
      bufImage.getRaster().setDataElements(0, 0, dst.cols(), dst.rows(), data1);

      //Creating a WritableImage
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      System.out.println("Converted to Grayscale");
      return writableImage;
   }
   public static void main(String args[]) throws Exception {
      launch(args);
   }
}

इनपुट छवि

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

आउटपुट छवि

कार्यक्रम को निष्पादित करने पर, आपको निम्न आउटपुट मिलेगा।

नामक विधि threshold()इसका उपयोग स्केल इमेज को बाइनरी इमेज में बदलने के लिए किया जाता है। इस विधि का वाक्य विन्यास निम्नलिखित है।

threshold(Mat src, Mat dst, double thresh, double maxval, int type)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat इनपुट छवि का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat ऑब्जेक्ट आउटपुट इमेज का प्रतिनिधित्व करता है।

  • thresh - दहलीज मान का प्रतिनिधित्व करने वाला पूर्णांक।

  • maxval - THRESH_BINARY और THRESH_BINARY_INV थ्रेश प्रकार के साथ उपयोग करने के लिए अधिकतम मान का प्रतिनिधित्व करने वाला पूर्णांक।

  • type - एक पूर्णांक कोड रूपांतरण के प्रकार का प्रतिनिधित्व करता है, उदाहरण के लिए, आरजीबी से ग्रेस्केल।

आप कोड को पास करके एक स्केल इमेज को बाइनरी इमेज में बदल सकते हैं Imgproc.THRESH_BINARY शेष मापदंडों के मूल्यों के साथ।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि रंगीन छवि को बाइनरी इमेज के रूप में कैसे पढ़ा जाए और जावाएफएक्स विंडो का उपयोग करके इसे प्रदर्शित किया जाए।

import java.awt.image.BufferedImage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

public class ColorToBinary extends Application {
   @Override
   public void start(Stage stage) throws Exception {
      WritableImage writableImage = loadAndConvert();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // Setting the position of the image
      imageView.setX(10);
      imageView.setY(10);

      // setting the fit height and width of the image view
      imageView.setFitHeight(400);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);
      
      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);
      
      // Setting title to the Stage
      stage.setTitle("Loading an image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage loadAndConvert() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Instantiating the Imgcodecs class
      Imgcodecs imageCodecs = new Imgcodecs();
        
      // File input = new File("C:/EXAMPLES/OpenCV/sample.jpg");
      String input = "C:/EXAMPLES/OpenCV/sample.jpg";

      // Reading the image
      Mat src = imageCodecs.imread(input);

      // Creating the destination matrix
      Mat dst = new Mat();

      // Converting to binary image...
      Imgproc.threshold(src, dst, 200, 500, Imgproc.THRESH_BINARY);

      // Extracting data from the transformed image (dst)
      byte[] data1 = new byte[dst.rows() * dst.cols() * (int)(dst.elemSize())];
      dst.get(0, 0, data1);

      // Creating Buffered image using the data
      BufferedImage bufImage = new BufferedImage(dst.cols(),dst.rows(), 
         BufferedImage.TYPE_BYTE_GRAY);

      // Setting the data elements to the image
      bufImage.getRaster().setDataElements(0, 0, dst.cols(), dst.rows(), data1);

      // Creating a Writable image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      System.out.println("Converted to binary");
      return writableImage;
   }  
   public static void main(String args[]) throws Exception {
      launch(args);
   }
}

इनपुट छवि

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

आउटपुट छवि

कार्यक्रम को निष्पादित करने पर, आपको निम्न आउटपुट मिलेगा।

एक ग्रेस्केल छवि को द्विआधारी छवि में बदलने के लिए आप पिछले अध्याय में बताए गए समान विधि का उपयोग कर सकते हैं। इस प्रोग्राम के इनपुट के रूप में बस एक ग्रेस्केल इमेज के लिए रास्ता पास करें।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि एक ग्रेसेले छवि को बाइनरी इमेज के रूप में कैसे पढ़ा जाए और जावाएफएक्स विंडो का उपयोग करके इसे प्रदर्शित किया जाए।

import java.awt.image.BufferedImage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

public class GrayScaleToBinary extends Application {
   @Override
   public void start(Stage stage) throws Exception {
      WritableImage writableImage = loadAndConvert();
       
      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // Setting the position of the image
      imageView.setX(10);
      imageView.setY(10);
      
      // Setting the fit height and width of the image view
      imageView.setFitHeight(400);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Grayscale to binary image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage loadAndConvert() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Instantiating the imagecodecs class
      Imgcodecs imageCodecs = new Imgcodecs();

      String input = "E:/OpenCV/chap7/grayscale.jpg";

      // Reading the image
      Mat src = imageCodecs.imread(input);

      // Creating the destination matrix
      Mat dst = new Mat();

      // Converting to binary image...
      Imgproc.threshold(src, dst, 200, 500, Imgproc.THRESH_BINARY);

      // Extracting data from the transformed image (dst)
      byte[] data1 = new byte[dst.rows() * dst.cols() * (int)(dst.elemSize())];
      dst.get(0, 0, data1);

      // Creating Buffered image using the data
      BufferedImage bufImage = new BufferedImage(dst.cols(),dst.rows(), 
         BufferedImage.TYPE_BYTE_BINARY);

      // Setting the data elements to the image
      bufImage.getRaster().setDataElements(0, 0, dst.cols(), dst.rows(), data1);

      // Creating a Writable image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      System.out.println("Converted to binary");
      return writableImage;
   }
   public static void main(String args[]) throws Exception {
      launch(args);
   }
}

इनपुट छवि

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

आउटपुट छवि

कार्यक्रम को निष्पादित करने पर, आपको निम्न आउटपुट मिलेगा।

आप संबंधित आकृति का उपयोग करके एक छवि पर सर्किल, आयत, रेखा, दीर्घवृत्त, पॉलीलाइन्स, उत्तल, पॉलीलाइन, पॉलीलाइन जैसी विभिन्न आकृतियाँ बना सकते हैं। org.opencv.imgproc पैकेज।

आप विधि का उपयोग करके एक छवि पर एक वृत्त खींच सकते हैं circle() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

circle(img, center, radius, color, thickness)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat उस छवि का प्रतिनिधित्व करना जिस पर वृत्त खींचा जाना है।

  • point - ए Point वृत्त के केंद्र का प्रतिनिधित्व करने वाली वस्तु।

  • radius - प्रकार का एक चर integer वृत्त की त्रिज्या का प्रतिनिधित्व करना।

  • scalar - ए Scalarसर्कल के रंग का प्रतिनिधित्व करने वाली वस्तु। (बीजीआर)

  • thickness - ए integerसर्कल की मोटाई का प्रतिनिधित्व करना; डिफ़ॉल्ट रूप से, मोटाई का मान 1 है।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि किसी चित्र पर एक वृत्त कैसे खींचना है और इसे JavaFX विंडो का उपयोग करके प्रदर्शित करना है।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingCircle extends Application {
   Mat matrix = null;
   
   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingCircle obj = new DrawingCircle();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Drawing Circle on the image");
      
      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }      
   public WritableImage LoadImage() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      //Drawing a Circle Imgproc.circle ( matrix, //Matrix obj of the image new Point(230, 160), //Center of the circle 100, //Radius new Scalar(0, 0, 255), //Scalar object for color 10 //Thickness of the circle );
      
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);
      this.matrix = matrix;
      
      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

आप विधि का उपयोग करके छवि पर एक रेखा खींच सकते हैं line() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

line(img, pt1, pt2, color, thickness)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat छवि उस रेखा का प्रतिनिधित्व करती है जिस पर रेखा खींची जानी है।

  • pt1 and pt2 - दो Point उन बिंदुओं का प्रतिनिधित्व करती है जिनके बीच रेखा खींची जानी है।

  • scalar - ए Scalarसर्कल के रंग का प्रतिनिधित्व करने वाली वस्तु। (बीजीआर)

  • thickness- लाइन की मोटाई का प्रतिनिधित्व करने वाला पूर्णांक; डिफ़ॉल्ट रूप से, मोटाई का मान 1 है।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि किसी चित्र पर एक रेखा कैसे खींची जाए और इसे JavaFX विंडो का उपयोग करके प्रदर्शित किया जाए।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingLine extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
   
      // Capturing the snapshot from the camera
      DrawingLine obj = new DrawingLine();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object  
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Drawing a line on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      // Drawing a line Imgproc.line ( matrix, //Matrix obj of the image new Point(10, 200), //p1 new Point(300, 200), //p2 new Scalar(0, 0, 255), //Scalar object for color 5 //Thickness of the line );
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);

      this.matrix = matrix;

      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

आप विधि का उपयोग करके एक छवि पर एक आयत बना सकते हैं rectangle() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

rectangle(img, pt1, pt2, color, thickness)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat उस छवि का प्रतिनिधित्व करने वाला ऑब्जेक्ट जिस पर आयत खींचना है।

  • pt1 and pt2 - दो Point आयत के सिरों को दर्शाने वाली वस्तुएँ जिन्हें खींचना है।

  • scalar - ए Scalarआयत के रंग का प्रतिनिधित्व करने वाली वस्तु। (बीजीआर)

  • thickness- आयत की मोटाई का प्रतिनिधित्व करने वाला पूर्णांक; डिफ़ॉल्ट रूप से, मोटाई का मान 1 है।

उदाहरण

निम्न उदाहरण दर्शाता है कि छवि पर एक आयत कैसे खींचना है और इसे JavaFX विंडो का उपयोग करके प्रदर्शित करना है।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingRectangle extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingRectangle obj = new DrawingRectangle();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Drawing Rectangle on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      // Drawing a Rectangle Imgproc.rectangle ( matrix, //Matrix obj of the image new Point(130, 50), //p1 new Point(300, 280), //p2 new Scalar(0, 0, 255), //Scalar object for color 5 //Thickness of the line );
      
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);

      this.matrix = matrix;

      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

आप विधि का उपयोग करके एक छवि पर एक दीर्घवृत्त खींच सकते हैं rectangle() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

ellipse(img, box, color, thickness)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat उस छवि का प्रतिनिधित्व करना जिस पर आयत खींचना है।

  • box - एक रोटेटेक्ट ऑब्जेक्ट (दीर्घवृत्त को इस आयत में अंकित किया गया है।)

  • scalar - ए Scalarआयत के रंग का प्रतिनिधित्व करने वाली वस्तु। (बीजीआर)

  • thickness- आयत की मोटाई का प्रतिनिधित्व करने वाला पूर्णांक; डिफ़ॉल्ट रूप से, मोटाई का मान 1 है।

के निर्माता RotatedRect वर्ग कक्षा की एक वस्तु को स्वीकार करता है Point, वर्ग आकार की एक वस्तु, और प्रकार डबल का एक चर, जैसा कि नीचे दिखाया गया है।

RotatedRect(Point c, Size s, double a)

उदाहरण

निम्न प्रोग्राम दर्शाता है कि किसी चित्र पर एक दीर्घवृत्त कैसे खींचना है और इसे JavaFX विंडो का उपयोग करके प्रदर्शित करना है।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.RotatedRect;
import org.opencv.core.Scalar;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingEllipse extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingEllipse obj = new DrawingEllipse();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Drawing Ellipse on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      // Drawing an Ellipse Imgproc.ellipse ( matrix, //Matrix obj of the image new RotatedRect ( // RotatedRect(Point c, Size s, double a) new Point(200, 150), new Size(260, 180), 180 ), new Scalar(0, 0, 255), //Scalar object for color 10 //Thickness of the line );
      
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);

      this.matrix = matrix;
      
      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

आप विधि का उपयोग करके एक छवि पर पॉलीइलाइन खींच सकते हैं polylines() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

polylines(img, pts, isClosed, color, thickness)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat उस छवि का प्रतिनिधित्व करने वाली वस्तु जिस पर पॉलीनेन्स खींचना है।

  • pts - ए List प्रकार की वस्तुओं को धारण करने वाली वस्तु MatOfPoint

  • isClosed - बूलियन निर्दिष्ट मौसम के प्रकार का एक पैरामीटर पॉलीलाइन बंद हो जाता है।

  • scalar - ए ScalarPolylines के रंग का प्रतिनिधित्व करने वाली वस्तु। (बीजीआर)

  • thickness- पॉलिने की मोटाई का प्रतिनिधित्व करने वाला एक पूर्णांक; डिफ़ॉल्ट रूप से, मोटाई का मान 1 है।

के निर्माता MatOfPoint वर्ग की वस्तुओं को स्वीकार करता है Point

MatOfPoint(Point... a)

उदाहरण

निम्न कार्यक्रम दर्शाता है कि एक छवि पर पॉलीइन्स कैसे खींचना है और जावाएफएक्स विंडो का उपयोग करके इसे प्रदर्शित करना है।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;

import java.util.ArrayList;
import java.util.List;
import javax.imageio.ImageIO;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.core.MatOfPoint;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingPolyLines extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingPolyLines obj = new DrawingPolyLines();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Drawing Polylines on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }      
   public WritableImage LoadImage() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      List<MatOfPoint> list = new ArrayList();
      list.add(
         new MatOfPoint (
            new Point(75, 100), new Point(350, 100),
            new Point(75, 150), new Point(350, 150),
            new Point(75, 200), new Point(350, 200),
            new Point(75, 250), new Point(350, 250)
         )
      );
      // Drawing polylines Imgproc.polylines ( matrix, // Matrix obj of the image list, // java.util.List<MatOfPoint> pts false, // isClosed new Scalar(0, 0, 255), // Scalar object for color 2 // Thickness of the line );
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);

      this.matrix = matrix;

      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

आप विधि का उपयोग करके एक छवि पर उत्तल पॉलीलाइन खींच सकते हैं fillconvexPoly() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

fillConvexPoly(Mat img, MatOfPoint points, Scalar color)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat उस छवि का प्रतिनिधित्व करने वाली वस्तु जिस पर उत्तल पॉलीलाइन को खींचा जाना है।

  • points - ए MatOfPoint उन बिंदुओं को दर्शाने वाले बिंदु जिनके बीच उत्तल पॉलीनेन्स खींचे जाने हैं।

  • scalar - ए Scalarउत्तल पॉलीलाइन के रंग का प्रतिनिधित्व करने वाली वस्तु। (बीजीआर)

के निर्माता MatOfPoint वर्ग की वस्तुओं को स्वीकार करता है Point

MatOfPoint(Point... a)

उदाहरण

निम्न कार्यक्रम दर्शाता है कि एक छवि पर उत्तल पॉलीलाइन कैसे खींचना है और जावाएफएक्स विंडो का उपयोग करके इसे प्रदर्शित करना है।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.core.MatOfPoint;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class FillConvexPoly extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      FillConvexPoly obj = new FillConvexPoly();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      imageView.setFitWidth(600);

      //Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Drawing convex Polylines (fill) on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      MatOfPoint matOfPoint = new MatOfPoint (
         new Point(75, 100), new Point(350, 100),
         new Point(75, 150), new Point(350, 150),
         new Point(75, 200), new Point(350, 200),
         new Point(75, 250), new Point(350, 250)
      ); 
      // Drawing polylines Imgproc.fillConvexPoly ( matrix, // Matrix obj of the image matOfPoint, // java.util.List<MatOfPoint> pts new Scalar(0, 0, 255) // Scalar object for color );
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);
      this.matrix = matrix;
            
      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   } 
   public static void main(String args[]) {
      launch(args);
   }
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

आप विधि का उपयोग करके एक छवि पर एक तीर वाली रेखा खींच सकते हैं arrowedLine() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

arrowedLine(Mat img, Point pt1, Point pt2, Scalar color)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat उस छवि का प्रतिनिधित्व करना जिस पर तीर वाली रेखा खींची जानी है।

  • pt1 and pt2 - दो Point उन बिंदुओं का प्रतिनिधित्व करती है जिनके बीच तीर वाली रेखा खींची जानी है।

  • scalar - ए Scalarतीर वाली रेखा के रंग का प्रतिनिधित्व करने वाली वस्तु। (बीजीआर)

उदाहरण

निम्न प्रोग्राम दर्शाता है कि एक छवि पर तीर वाली रेखा कैसे खींची जाए और इसे JavaFX विंडो का उपयोग करके प्रदर्शित किया जाए।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingArrowedLine extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingArrowedLine obj = new DrawingArrowedLine();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Drawing a line on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="C:/EXAMPLES/OpenCV/Aish.jpg";
      Mat matrix = Imgcodecs.imread(file);

      //Drawing a line Imgproc.arrowedLine( matrix, // Matrix obj of the image new Point(10, 200), // p1 new Point(590, 200), // p2 new Scalar(0, 100, 255) // Scalar object for color );

      // arrowedLine(Mat img, Point pt1, Point pt2, Scalar color)
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);
      this.matrix = matrix;

      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

आप विधि का उपयोग करके छवि में पाठ जोड़ सकते हैं arrowedLine() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

putText(img, text, org, fontFace, fontScale, Scalar color, int thickness)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • mat - ए Mat उस छवि का प्रतिनिधित्व करना जिस पर पाठ जोड़ा जाना है।

  • text - ए string उस पाठ को दर्शाने का चर जिसे जोड़ा जाना है।

  • org - ए Point छवि में निचले बाएं कोने के टेक्स्ट स्ट्रिंग का प्रतिनिधित्व करने वाली वस्तु।

  • fontFace - फ़ॉन्ट प्रकार का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • fontScale - टाइप-टू का एक वैरिएबल जो स्केल फैक्टर का प्रतिनिधित्व करता है, जिसे फ़ॉन्ट-विशिष्ट आधार आकार से गुणा किया जाता है।

  • scalar - ए Scalarजो पाठ जोड़ना है, उसके रंग का प्रतिनिधित्व करने वाली वस्तु। (बीजीआर)

  • thickness - एक पूर्णांक डिफ़ॉल्ट रूप से रेखा की मोटाई का प्रतिनिधित्व करता है, मोटाई का मान 1 है।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि छवि में टेक्स्ट कैसे जोड़ें और इसे JavaFX विंडो का उपयोग करके प्रदर्शित करें।

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class AddingTextToImage extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      AddingTextToImage obj = new AddingTextToImage();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Adding text to an image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      // Adding Text Imgproc.putText ( matrix, // Matrix obj of the image "Ravivarma's Painting", // Text to be added new Point(10, 50), // point Core.FONT_HERSHEY_SIMPLEX , // front face 1, // front scale new Scalar(0, 0, 0), // Scalar object for color 4 // Thickness );
      
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);
      this.matrix = matrix;

      //Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

धुंधला (चौरसाई) छवि शोर को कम करने के लिए आमतौर पर इस्तेमाल किया जाने वाला इमेज प्रोसेसिंग ऑपरेशन है। प्रक्रिया छवि से किनारों की तरह उच्च-आवृत्ति सामग्री को निकालती है और इसे सुचारू बनाती है।

सामान्य रूप से धुंधला हो जाने पर (प्रति तत्व के प्रत्येक तत्व को उसके स्थानीय पड़ोसियों के साथ जोड़ा जाता है), कम पास फिल्टर कर्नेल के माध्यम से छवि को प्राप्त किया जाता है।

ब्लर (एवरेजिंग)

इस ऑपरेशन के दौरान, छवि को एक बॉक्स फिल्टर (सामान्यीकृत) के साथ सजाया जाता है। इस प्रक्रिया में, कर्नेल क्षेत्र में छवि के केंद्रीय तत्व को सभी पिक्सेल के औसत से बदल दिया जाता है।

आप इस ऑपरेशन को विधि का उपयोग करके एक छवि पर कर सकते हैं blur() का imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

blur(src, dst, ksize, anchor, borderType)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • ksize - ए Size कर्नेल के आकार का प्रतिनिधित्व करने वाली वस्तु।

  • anchor - लंगर बिंदु का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • borderType - आउटपुट के लिए उपयोग की जाने वाली सीमा के प्रकार का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि छवि पर औसत (धुंधला) ऑपरेशन कैसे किया जाए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Point;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class BlurTest {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="C:/EXAMPLES/OpenCV/sample.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Creating the Size and Point objects
      Size size = new Size(45, 45);
      Point point = new Point(20, 30);

      // Applying Blur effect on the Image
      Imgproc.blur(src, dst, size, point, Core.BORDER_DEFAULT);

      // blur(Mat src, Mat dst, Size ksize, Point anchor, int borderType)
      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap9/blur.jpg", dst);
      System.out.println("Image processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

गाऊसी ब्लाउर ऑपरेशन में, छवि को बॉक्स फिल्टर के बजाय गाऊसी फिल्टर के साथ सजाया जाता है। गाऊसी फिल्टर एक कम-पास फिल्टर है जो उच्च आवृत्ति घटकों को हटा देता है कम हो जाता है।

आप इस ऑपरेशन का उपयोग करके एक छवि पर कर सकते हैं Gaussianblur() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

GaussianBlur(src, dst, ksize, sigmaX)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • ksize - ए Size कर्नेल के आकार का प्रतिनिधित्व करने वाली वस्तु।

  • sigmaX - एक्स दिशा में गाऊसी कर्नेल मानक विचलन का प्रतिनिधित्व करने वाले टाइप डबल का एक चर।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि एक छवि पर गॉसियन ब्लर ऑपरेशन कैसे करें।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class GaussianTest {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="C:/EXAMPLES/OpenCV/sample.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();
    
      // Applying GaussianBlur on the Image
      Imgproc.GaussianBlur(src, dst, new Size(45, 45), 0);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap9/Gaussian.jpg", dst);
      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

मेडियन धुंधला ऑपरेशन अन्य औसत तरीकों के समान है। यहां, कर्नेल क्षेत्र में छवि के केंद्रीय तत्व को सभी पिक्सेल के माध्यिका से बदल दिया जाता है। यह ऑपरेशन शोर को दूर करते हुए किनारों को संसाधित करता है।

आप इस ऑपरेशन का उपयोग करके एक छवि पर कर सकते हैं medianBlur() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

medianBlur(src, dst, ksize)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • ksize - ए Size कर्नेल के आकार का प्रतिनिधित्व करने वाली वस्तु।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि किसी छवि पर माध्यिका धब्बा ऑपरेशन कैसे किया जाता है।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class MedianBlurTest {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="C:/EXAMPLES/OpenCV/sample.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying MedianBlur on the Image
      Imgproc.medianBlur(src, dst, 15);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap9/median.jpg", dst);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

छवि फ़िल्टरिंग आपको एक छवि पर विभिन्न प्रभाव लागू करने की अनुमति देता है। इस अध्याय और उसके बाद के तीन अध्यायों में, हम विभिन्न फ़िल्टर ऑपरेशन जैसे कि द्विपक्षीय फ़िल्टर, बॉक्स फ़िल्टर, SQR बॉक्स फ़िल्टर और फ़िल्टर 2D पर चर्चा करने जा रहे हैं।

द्विपक्षीय फ़िल्टर

द्विपक्षीय फ़िल्टर ऑपरेशन एक फ़िल्टर के लिए एक द्विपक्षीय छवि लागू करता है। आप इस ऑपरेशन का उपयोग करके एक छवि पर कर सकते हैंmedianBlur() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

bilateralFilter(src, dst, d, sigmaColor, sigmaSpace, borderType)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • d - पिक्सेल पड़ोस के व्यास का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • sigmaColor - रंग अंतरिक्ष में फिल्टर सिग्मा का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • sigmaSpace - समन्वित स्थान में फिल्टर सिग्मा का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • borderType - एक पूर्णांक वस्तु जिसका उपयोग सीमा के प्रकार का प्रतिनिधित्व करता है।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि एक छवि पर द्विपक्षीय फ़िल्टर ऑपरेशन कैसे किया जाए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class BilateralFilter {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap11/filter_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying Bilateral filter on the Image
      Imgproc.bilateralFilter(src, dst, 15, 80, 80, Core.BORDER_DEFAULT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap11/bilateralfilter.jpg", dst);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है filter_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

बॉक्स फ़िल्टर ऑपरेशन औसत ब्लर ऑपरेशन के समान है; यह एक फ़िल्टर करने के लिए एक द्विपक्षीय छवि लागू करता है। यहां, आप चुन सकते हैं कि बॉक्स को सामान्य किया जाना चाहिए या नहीं।

आप इस ऑपरेशन का उपयोग करके एक छवि पर कर सकते हैं boxFilter() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

boxFilter(src, dst, ddepth, ksize, anchor, normalize, borderType)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • ddepth - आउटपुट छवि की गहराई का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • ksize - ए Size धुंधला कर्नेल के आकार का प्रतिनिधित्व करने वाली वस्तु।

  • anchor - लंगर बिंदु का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • Normalize - कर्नेल के मौसम को निर्दिष्ट करने वाले बूलियन के एक चर को सामान्य किया जाना चाहिए।

  • borderType - एक पूर्णांक वस्तु जिसका उपयोग सीमा के प्रकार का प्रतिनिधित्व करता है।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि एक छवि पर बॉक्स फ़िल्टर ऑपरेशन कैसे करें।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Point;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class BoxFilterTest {
   public static void main( String[] args ) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file = "E:/OpenCV/chap11/filter_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Creating the objects for Size and Point
      Size size = new Size(45, 45);
      Point point = Point(-1, -1);

      // Applying Box Filter effect on the Image
      Imgproc.boxFilter(src, dst, 50, size, point, true, Core.BORDER_DEFAULT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap11/boxfilterjpg", dst);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है filter_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

आप का उपयोग करके एक छवि पर SQRBox फ़िल्टर ऑपरेशन कर सकते हैं boxFilter() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

sqrBoxFilter(src, dst, ddepth, ksize)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • ddepth - आउटपुट छवि की गहराई का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • ksize - ए Size धुंधला कर्नेल के आकार का प्रतिनिधित्व करने वाली वस्तु।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि किसी दिए गए चित्र पर Sqrbox फ़िल्टर ऑपरेशन कैसे करें।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class SqrBoxFilterTest {
   public static void main( String[] args ) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap11/filter_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying Box Filter effect on the Image
      Imgproc.sqrBoxFilter(src, dst, -1, new Size(1, 1));
     
      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap11/sqrboxfilter.jpg", dst);

      System.out.println("Image Processed");
   } 
}

मान लें कि निम्नलिखित इनपुट छवि है filter_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

Filter2D ऑपरेशन कर्नेल के साथ एक छवि को दर्शाता है। आप इस ऑपरेशन का उपयोग करके एक छवि पर कर सकते हैंFilter2D() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

filter2D(src, dst, ddepth, kernel)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • ddepth - आउटपुट छवि की गहराई का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

  • kernel - ए Mat कनवल्शन कर्नेल का प्रतिनिधित्व करने वाली वस्तु।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि किसी छवि पर Filter2D ऑपरेशन कैसे करें।

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class Filter2D {
   public static void main( String[] args ) {
      //Loading the OpenCV core library  
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      //Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap11/filter_input.jpg";
      Mat src = Imgcodecs.imread(file);

      //Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Creating kernel matrix
      Mat kernel = Mat.ones(2,2, CvType.CV_32F);
      
      for(int i = 0; i<kernel.rows(); i++) {
         for(int j = 0; j<kernel.cols(); j++) {
            double[] m = kernel.get(i, j);

            for(int k = 1; k<m.length; k++) {
               m[k] = m[k]/(2 * 2);
            }
            kernel.put(i,j, m);
         }
      }
      Imgproc.filter2D(src, dst, -1, kernel);
      Imgcodecs.imwrite("E:/OpenCV/chap11/filter2d.jpg", dst);
      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है filter_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

कटाव और फैलाव दो प्रकार के रूपात्मक ऑपरेशन हैं। जैसा कि नाम से प्रतीत होता है, रूपात्मक संचालन उन परिचालनों का समूह है जो उनके आकार के अनुसार छवियों को संसाधित करते हैं।

दी गई इनपुट छवि के आधार पर एक "संरचनात्मक तत्व" विकसित किया जाता है। यह किसी भी दो प्रक्रियाओं में किया जा सकता है। इनका उद्देश्य शोर को दूर करना और खामियों को दूर करना है, जिससे छवि स्पष्ट हो सके।

फैलाव

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

अधिकतम पिक्सेल मान की गणना करने के लिए इस कर्नेल को चित्र पर ओवरलैप किया जाता है। गणना करने के बाद, चित्र को केंद्र में लंगर के साथ बदल दिया जाता है। इस प्रक्रिया के साथ, उज्ज्वल क्षेत्रों के क्षेत्र आकार में बढ़ते हैं और इसलिए छवि का आकार बढ़ता है।

उदाहरण के लिए, सफेद छाया या उज्ज्वल छाया में किसी वस्तु का आकार बढ़ता है, जबकि काली छाया या अंधेरे छाया में किसी वस्तु का आकार घट जाता है।

आप का उपयोग कर एक छवि पर फैलाव ऑपरेशन कर सकते हैं dilate() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

dilate(src, dst, kernel)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • kernel - ए Mat कर्नेल का प्रतिनिधित्व करने वाली वस्तु।

उदाहरण

आप कर्नेल मैट्रिक्स का उपयोग करके तैयार कर सकते हैं getStructuringElement()तरीका। यह विधि एक पूर्णांक को दर्शाती हैmorph_rect प्रकार और प्रकार की एक वस्तु Size

Imgproc.getStructuringElement(int shape, Size ksize);

निम्न कार्यक्रम दर्शाता है कि किसी दिए गए चित्र पर फैलाव ऑपरेशन कैसे किया जाए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DilateTest {
   public static void main( String[] args ) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="C:/EXAMPLES/OpenCV/sample.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Preparing the kernel matrix object 
      Mat kernel = Imgproc.getStructuringElement(Imgproc.MORPH_RECT, 
         new  Size((2*2) + 1, (2*2)+1));

      // Applying dilate on the Image
      Imgproc.dilate(src, dst, kernel);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap10/Dilation.jpg", dst);

      System.out.println("Image Processed");
   } 
}

इनपुट

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

फैलाव के रूप में कटाव काफी समान प्रक्रिया है। लेकिन यहाँ गणना की गई पिक्सेल वैल्यू अधिकतम होने की बजाय न्यूनतम है। छवि को एंकर बिंदु के तहत उस न्यूनतम पिक्सेल मूल्य के साथ बदल दिया जाता है।

इस प्रक्रिया के साथ, अंधेरे क्षेत्रों के क्षेत्र आकार में बढ़ते हैं और उज्ज्वल क्षेत्र कम हो जाते हैं। उदाहरण के लिए, डार्क शेड या ब्लैक शेड में किसी ऑब्जेक्ट का आकार बढ़ जाता है, जबकि यह सफेद शेड या ब्राइट शेड में घट जाता है।

उदाहरण

आप इस ऑपरेशन का उपयोग करके एक छवि पर कर सकते हैं erode() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

erode(src, dst, kernel)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • kernel - ए Mat कर्नेल का प्रतिनिधित्व करने वाली वस्तु।

आप कर्नेल मैट्रिक्स का उपयोग करके तैयार कर सकते हैं getStructuringElement()तरीका। यह विधि एक पूर्णांक को दर्शाती हैmorph_rect प्रकार और प्रकार की एक वस्तु Size

Imgproc.getStructuringElement(int shape, Size ksize);

निम्न कार्यक्रम दर्शाता है कि किसी दिए गए चित्र पर कटाव संचालन कैसे किया जाए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class ErodeTest {
   public static void main( String[] args ) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="C:/EXAMPLES/OpenCV/sample.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Preparing the kernel matrix object
      Mat kernel = Imgproc.getStructuringElement(Imgproc.MORPH_RECT, 
         new  Size((2*2) + 1, (2*2)+1));

      // Applying erode on the Image
      Imgproc.erode(src, dst, kernel);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap10/Erosion.jpg", dst);

      System.out.println("Image processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है sample.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Loaded

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

पहले के अध्यायों में, हमने इस प्रक्रिया पर चर्चा की erosion तथा dilation। इन दोनों के अलावा, OpenCV में अधिक रूपात्मक परिवर्तन होते हैं। morphologyEx() कक्षा की विधि Imgproc का उपयोग किसी दिए गए चित्र पर इन कार्यों को करने के लिए किया जाता है।

इस विधि का वाक्य विन्यास निम्नलिखित है -

morphologyEx(src, dst, op, kernel)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • dst - कक्षा का उद्देश्य Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

  • op - एक पूर्णांक जो आकृति विज्ञान ऑपरेशन के प्रकार का प्रतिनिधित्व करता है।

  • kernel - एक कर्नेल मैट्रिक्स।

उदाहरण

निम्न कार्यक्रम दर्शाता है कि रूपात्मक ऑपरेशन को कैसे लागू किया जाए "top-hat" OpenCV लाइब्रेरी का उपयोग करके एक छवि पर।

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class MorphologyExTest {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap12/morph_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Creating kernel matrix
      Mat kernel = Mat.ones(5,5, CvType.CV_32F);

      // Applying Blur effect on the Image 
      Imgproc.morphologyEx(src, dst, Imgproc.MORPH_TOPHAT, kernel);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap12/morph_tophat.jpg", dst);

      System.out.println("Image Processed");
   } 
}

मान लें कि निम्नलिखित इनपुट छवि है morph_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

अधिक संचालन

रूपात्मक ऑपरेशन के अलावा TOPHAT, पिछले में प्रदर्शन किया example, ओपनसीवी विभिन्न अन्य प्रकार के आकारिकी को पूरा करता है। इन सभी प्रकारों को पूर्वनिर्धारित स्थिर क्षेत्रों (निश्चित मूल्यों) द्वारा दर्शाया जाता हैImgproc कक्षा।

आप पैरामीटर से संबंधित उनके पूर्वनिर्धारित मूल्य को पारित करके अपनी जरूरत के प्रकार का चयन कर सकते हैं op का morphologyEx() तरीका।

// Applying Blur effect on the Image
Imgproc.morphologyEx(src, dst, Imgproc.MORPH_TOPHAT, kernel);

निम्नलिखित मान रूपात्मक कार्यों के प्रकार और उनके संबंधित आउटपुट का प्रतिनिधित्व करते हैं।

ऑपरेशन और विवरण उत्पादन
MORPH_BLACKHAT
MORPH_CLOSE
MORPH_CROSS
MORPH_DILATE
MORPH_ELLIPSE
MORPH_ERODE
MORPH_GRADIENT
MORPH_OPEN
MORPH_RECT
MORPH_TOPHAT

पिरामिड एक छवि पर एक ऑपरेशन है जहां,

  • एक इनपुट छवि को शुरू में एक विशेष चौरसाई फ़िल्टर (उदा: गॉसियन, लाप्लासियन) का उपयोग करके चिकना किया जाता है और फिर चिकनी छवि को हटा दिया जाता है।

  • यह प्रक्रिया कई बार दोहराई जाती है।

पिरामिड ऑपरेशन के दौरान, छवि की चिकनाई बढ़ जाती है और संकल्प (आकार) कम हो जाता है।

पिरामिड ऊपर

पिरामिड अप में, छवि शुरू में सैंपल और फिर धुंधली होती है। आप किसी चित्र का उपयोग करके पिरामिड अप ऑपरेशन कर सकते हैंpyrUP() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

pyrUp(src, dst, dstsize, borderType)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • mat - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

  • size - कक्षा की एक वस्तु Size उस आकार का प्रतिनिधित्व करना जिसमें छवि को बढ़ाना या घटाना है।

  • borderType - पूर्णांक प्रकार का एक चर जिसका उपयोग करने के लिए सीमा के प्रकार का प्रतिनिधित्व करता है।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि एक छवि पर पिरामिड अप ऑपरेशन कैसे करें।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class PyramidUp {
   public static void main( String[] args ) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying pyrUp on the Image
      Imgproc.pyrUp(src, dst, new Size(src.cols()*2,  src.rows()*2), Core.BORDER_DEFAULT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap13/pyrUp_output.jpg", dst);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है pyramid_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

पिरामिड डाउन

पिरामिड डाउन में, छवि शुरू में धुंधली है और फिर नीचे-नमूना है। आप किसी चित्र का उपयोग करके पिरामिड डाउन ऑपरेशन कर सकते हैंpyrDown() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

pyrDown(src, dst, dstsize, borderType)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • mat - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

  • size - कक्षा की एक वस्तु Size उस आकार का प्रतिनिधित्व करना जिसमें छवि को बढ़ाना या घटाना है।

  • borderType - पूर्णांक प्रकार का एक चर जिसका उपयोग करने के लिए सीमा के प्रकार का प्रतिनिधित्व करता है।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि एक छवि पर पिरामिड डाउन ऑपरेशन कैसे करें।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class PyramidDown {
   public static void main( String[] args ) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying pyrDown on the Image
      Imgproc.pyrDown(src, dst, new Size(src.cols()/2,  src.rows()/2),
         Core.BORDER_DEFAULT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap13/pyrDown_output.jpg", dst);

      System.out.println("Image Processed");
   } 
}

मान लें कि निम्नलिखित इनपुट छवि है pyramid_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

मतलब शिफ्ट फिल्टरिंग

मीन शिफ्टिंग पिरामिड ऑपरेशन में, इमेज के शिफ्ट सेगमेंटेशन का एक प्रारंभिक चरण किया जाता है।

आप एक छवि पर पिरामिड मीन शिफ्ट फ़िल्टरिंग ऑपरेशन कर सकते हैं pyrDown() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

pyrMeanShiftFiltering(src, dst, sp, sr)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • mat - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

  • sp - स्थानिक खिड़की त्रिज्या का प्रतिनिधित्व करने वाले प्रकार डबल का एक चर।

  • sr - रंग विंडो त्रिज्या का प्रतिनिधित्व करने वाले डबल प्रकार का एक चर।

उदाहरण

निम्न प्रोग्राम यह दर्शाता है कि किसी दिए गए चित्र पर मीन शिफ्ट फ़िल्टरिंग ऑपरेशन कैसे करें।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class PyramidMeanShift {
   public static void main( String[] args ) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying meanShifting on the Image
      Imgproc.pyrMeanShiftFiltering(src, dst, 200, 300);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap13/meanShift_output.jpg", dst);
      
      System.out.println("Image Processed");
   } 
}

मान लें कि निम्नलिखित इनपुट छवि है pyramid_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

थ्रेसहोल्डिंग छवि विभाजन की एक विधि है, सामान्य तौर पर इसका उपयोग द्विआधारी छवियों को बनाने के लिए किया जाता है। थ्रेसहोल्डिंग दो प्रकार की होती है, साधारण थ्रेशोल्डिंग और एडेप्टिव थ्रेसहोल्डिंग।

साधारण थ्रेसहोल्डिंग

साधारण थ्रेशोल्ड ऑपरेशन में वे पिक्सल जिनके मान निर्दिष्ट थ्रेशोल्ड मान से अधिक हैं, उन्हें एक मानक मान के साथ सौंपा गया है।

आप विधि का उपयोग करके एक छवि पर सरल थ्रेशोल्ड ऑपरेशन कर सकते हैं threshold() का Imgproc class, इस विधि का वाक्यविन्यास निम्नलिखित है।

threshold(src, dst, thresh, maxval, type)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • dst - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

  • thresh - दहलीज मान का प्रतिनिधित्व करने वाले दोहरे प्रकार का एक चर।

  • maxval - डबल वैल्यू का वैरिएबल उस वैल्यू का प्रतिनिधित्व करता है जो दिया जाना है अगर पिक्सेल वैल्यू थ्रेशोल्ड वैल्यू से अधिक है।

  • type - पूर्णांक प्रकार का एक चर जिसका उपयोग करने के लिए दहलीज के प्रकार का प्रतिनिधित्व करता है।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि OpenCV में एक छवि पर सरल थ्रेसहोल्ड ऑपरेशन कैसे किया जाए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class Thresh {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap14/thresh_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();
      Imgproc.threshold(src, dst, 50, 255, Imgproc.THRESH_BINARY);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap14/thresh_trunc.jpg", dst);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है thresh_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

अन्य प्रकार की साधारण थ्रेसहोल्डिंग

इसके अलावा THRESH_BINARYऑपरेशन पिछले उदाहरण में दिखाया गया है, OpenCV विभिन्न प्रकार के थ्रेशोल्ड ऑपरेशनों को पूरा करता है। इन सभी प्रकारों को पूर्वनिर्धारित स्थिर क्षेत्रों (निश्चित मूल्यों) द्वारा दर्शाया जाता हैImgproc कक्षा।

आप अपने संबंधित पूर्वनिर्धारित मान को नामांकित पैरामीटर को पास करके, अपनी आवश्यकता के प्रकार का चयन कर सकते हैं type का threshold() तरीका।

Imgproc.threshold(src, dst, 50, 255, Imgproc.THRESH_BINARY);

विभिन्न प्रकार के थ्रेशोल्ड ऑपरेशन और उनके संबंधित आउटपुट का प्रतिनिधित्व करने वाले मूल्य निम्नलिखित हैं।

ऑपरेशन और विवरण उत्पादन
THRESH_BINARY
THRESH_BINARY_INV
THRESH_TRUNC
THRESH_TOZERO
THRESH_TOZERO_INV

में simple thresholdingदहलीज मान वैश्विक है, अर्थात, यह छवि के सभी पिक्सेल के लिए समान है। Adaptive thresholding वह विधि है जहां छोटे क्षेत्रों के लिए सीमा मूल्य की गणना की जाती है और इसलिए, विभिन्न क्षेत्रों के लिए अलग-अलग सीमा मूल्य होंगे।

OpenCV में, आप विधि का उपयोग करके एक छवि पर अनुकूली सीमा ऑपरेशन कर सकते हैं adaptiveThreshold() का Imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

adaptiveThreshold(src, dst, maxValue, adaptiveMethod, thresholdType, blockSize, C)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • dst - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

  • maxValue - डबल वैल्यू का वैरिएबल उस वैल्यू का प्रतिनिधित्व करता है जो दिया जाना है अगर पिक्सेल वैल्यू थ्रेशोल्ड वैल्यू से अधिक है।

  • adaptiveMethod- पूर्णांक के एक चर का उपयोग करने के लिए अनुकूली विधि का प्रतिनिधित्व करने वाला प्रकार। यह या तो निम्नलिखित दो मूल्यों में से एक होगा

    • ADAPTIVE_THRESH_MEAN_C - दहलीज मान पड़ोस के क्षेत्र का मतलब है।

    • ADAPTIVE_THRESH_GAUSSIAN_C - थ्रेसहोल्ड मान पड़ोस के मूल्यों की भारित राशि है जहां वजन एक गाऊसी खिड़की है।

  • thresholdType - पूर्णांक प्रकार का एक चर जिसका उपयोग करने के लिए दहलीज के प्रकार का प्रतिनिधित्व करता है।

  • blockSize - पूर्णांक मान की गणना करने के लिए उपयोग किए जाने वाले पिक्सेनेबोरहुड के आकार का प्रतिनिधित्व करने वाले पूर्णांक प्रकार का एक चर।

  • C - दोनों तरीकों में उपयोग किए गए निरंतर का प्रतिनिधित्व करने वाले दोहरे प्रकार का एक चर (माध्य या भारित माध्य से घटाया गया)।

  • उदाहरण

    निम्न कार्यक्रम दर्शाता है कि OpenCV में एक छवि पर अनुकूली थ्रेशोल्ड ऑपरेशन कैसे किया जाए। यहां हम प्रकार के अनुकूली सीमा का चयन कर रहे हैंbinary तथा ADAPTIVE_THRESH_MEAN_C दहलीज विधि के लिए।

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class AdaptiveThresh {
       public static void main(String args[]) throws Exception {
          // Loading the OpenCV core library
          System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
    
          // Reading the Image from the file and storing it in to a Matrix object
          String file ="E:/OpenCV/chap14/thresh_input.jpg";
          
          // Reading the image
          Mat src = Imgcodecs.imread(file,0);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
    
          Imgproc.adaptiveThreshold(src, dst, 125, Imgproc.ADAPTIVE_THRESH_MEAN_C,
             Imgproc.THRESH_BINARY, 11, 12);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap14/Adaptivemean_thresh_binary.jpg", dst);
    
          System.out.println("Image Processed");
       } 
    }

    मान लें कि निम्नलिखित इनपुट छवि है thresh_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

    उत्पादन

    कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

    Image Processed

    यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

    अन्य प्रकार के अनुकूली थ्रेसहोल्डिंग

    इसके अलावा ADAPTIVE_THRESH_MEAN_C अनुकूली विधि के रूप में और THRESH_BINARY पिछले उदाहरण में प्रदर्शित की गई थ्रेशोल्ड प्रकार के रूप में, हम इन दो मूल्यों के अधिक संयोजनों को चुन सकते हैं।

    Imgproc.adaptiveThreshold(src, dst, 125, Imgproc.ADAPTIVE_THRESH_MEAN_C, Imgproc.THRESH_BINARY, 11, 12);

    मापदंडों के लिए मूल्यों के विभिन्न संयोजनों का प्रतिनिधित्व करने वाले मूल्य निम्नलिखित हैं adaptiveMethod तथा thresholdType और उनके संबंधित आउटपुट।

    एडेप्टिवमेथोड / थ्रेसहोल्ड टाइप ADAPTIVE_THRESH_MEAN_C ADAPTIVE_THRESH_GAUSSIAN_C:
    THRESH_BINARY
    THRESH_BINARY_INV

    यह अध्याय आपको सिखाता है कि एक छवि के लिए सीमाएँ कैसे तय की जाती हैं।

    CopyMakeBorder () विधि

    आप विधि का उपयोग करके एक छवि में विभिन्न सीमाओं को जोड़ सकते हैं copyMakeBorder() कोर नामक वर्ग का, जो पैकेज का है org.opencv.core. इस विधि का वाक्य विन्यास निम्नलिखित है।

    copyMakeBorder(src, dst, top, bottom, left, right, borderType)

    यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

    • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

    • dst - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

    • top - पूर्णांक का एक प्रकार छवि के शीर्ष पर सीमा की लंबाई का प्रतिनिधित्व करने वाला पूर्णांक है।

    • bottom - पूर्णांक का एक चर छवि के तल पर सीमा की लंबाई का प्रतिनिधित्व करने वाला प्रकार पूर्णांक।

    • left - पूर्णांक का एक चर छवि के बाईं ओर सीमा की लंबाई का प्रतिनिधित्व करने वाला पूर्णांक।

    • right - पूर्णांक का एक प्रकार छवि के दाईं ओर सीमा की लंबाई का प्रतिनिधित्व करने वाला पूर्णांक है।

    • borderType - उपयोग किए जाने वाले सीमा के प्रकार का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

    उदाहरण

    निम्नलिखित कार्यक्रम एक उदाहरण है, जिसमें दिखाया गया है कि किसी दिए गए चित्र में बॉर्डर को कैसे जोड़ा जाए।

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    import org.opencv.imgcodecs.Imgcodecs;
    
    public class AddingBorder {
       public static void main( String[] args ) {
          // Loading the OpenCV core library
          System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
          // Reading the Image from the file and storing it in to a Matrix object
          String file ="E:/OpenCV/chap15/input.jpg";
          Mat src = Imgcodecs.imread(file);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
       
          Core.copyMakeBorder(src, dst, 20, 20, 20, 20, Core.BORDER_CONSTANT);
          Imgcodecs.imwrite("E:/OpenCV/chap15/border_constant.jpg", dst);
    
          System.out.println("Image Processed");
       }
    }

    मान लें कि निम्नलिखित इनपुट छवि है thresh_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

    उत्पादन

    कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

    Image Processed

    यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

    अन्य प्रकार की सीमाएँ

    सीमा प्रकार के अलावा, BORDER_CONSTANTपिछले उदाहरण में प्रदर्शित, OpenCV विभिन्न अन्य प्रकार की सीमाओं को पूरा करता है। इन सभी प्रकारों का प्रतिनिधित्व कोर क्लास के पूर्वनिर्धारित स्थिर क्षेत्रों (निश्चित मूल्यों) द्वारा किया जाता है।

    आप अपने संबंधित पूर्वनिर्धारित मान को नामांकित पैरामीटर को पास करके, अपनी आवश्यकता के प्रकार का चयन कर सकते हैं borderType का copyMakeBorder() तरीका।

    Core.copyMakeBorder(src, dst, 20, 20, 20, 20, Core.BORDER_CONSTANT);

    विभिन्न प्रकार की सीमाओं के संचालन और उनके संबंधित आउटपुट का प्रतिनिधित्व करने वाले मूल्य निम्नलिखित हैं।

    ऑपरेशन और विवरण उत्पादन
    BORDER_CONSTANT
    BORDER_ISOLATED
    BORDER_DEFAULT
    BORDER_REFLECT
    BORDER_REFLECT_101
    BORDER_REFLECT101
    BORDER_REPLICATE
    BORDER_WRAP

    का उपयोग करते हुए sobel operation, आप क्षैतिज और ऊर्ध्वाधर दोनों दिशाओं में एक छवि के किनारों का पता लगा सकते हैं। आप विधि का उपयोग करके एक छवि पर सोबेल ऑपरेशन लागू कर सकते हैंsobel()। इस विधि का वाक्य विन्यास निम्नलिखित है -

    Sobel(src, dst, ddepth, dx, dy)

    यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

    • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

    • dst - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

    • ddepth - छवि की गहराई का प्रतिनिधित्व करने वाला पूर्णांक चर (-1)

    • dx- x-व्युत्पन्न का प्रतिनिधित्व करने वाला पूर्णांक चर। (0 या 1)

    • dy- एक पूर्णांक चर y- व्युत्पन्न का प्रतिनिधित्व करता है। (0 या 1)

    उदाहरण

    निम्नलिखित कार्यक्रम दर्शाता है कि किसी दिए गए चित्र पर Sobel ऑपरेशन कैसे किया जाए।

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class SobelTest {
       public static void main(String args[]) {
          // Loading the OpenCV core library
          System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
    
          // Reading the Image from the file and storing it in to a Matrix object
          String file ="E:/OpenCV/chap16/sobel_input.jpg";
          Mat src = Imgcodecs.imread(file);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
    
          // Applying sobel on the Image
          Imgproc.Sobel(src, dst, -1, 1, 1);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap16/sobel_output.jpg", dst);
    
          System.out.println("Image processed");
       }
    }

    मान लें कि निम्नलिखित इनपुट छवि है sobel_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

    उत्पादन

    कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

    Image Processed

    यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

    सोबेल वेरिएंट्स

    विभिन्न मानों को अंतिम मानदंड (dx और डाई) पास करने पर (0 और 1 के बीच), आपको अलग-अलग आउटपुट मिलेंगे -

    // Applying sobel on the Image
    Imgproc.Sobel(src, dst, -1, 1, 1);

    निम्न तालिका चर के विभिन्न मूल्यों को सूचीबद्ध करती है dx तथा dy विधि का Sobel() और उनके संबंधित आउटपुट।

    एक्स-व्युत्पन्न वाई के व्युत्पन्न उत्पादन
    0 1
    1 0
    1 1

    स्क्रहर का उपयोग क्षैतिज और ऊर्ध्वाधर दिशाओं में एक छवि के दूसरे डेरिवेटिव का पता लगाने के लिए भी किया जाता है। आप विधि का उपयोग करके एक छवि पर scharr ऑपरेशन कर सकते हैंscharr()। इस विधि का वाक्य विन्यास निम्नलिखित है -

    Scharr(src, dst, ddepth, dx, dy)

    यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

    • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

    • dst - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

    • ddepth - छवि की गहराई का प्रतिनिधित्व करने वाला पूर्णांक चर (-1)

    • dx- x-व्युत्पन्न का प्रतिनिधित्व करने वाला पूर्णांक चर। (0 या 1)

    • dy- एक पूर्णांक चर y- व्युत्पन्न का प्रतिनिधित्व करता है। (0 या 1)

    उदाहरण

    निम्न कार्यक्रम दर्शाता है कि किसी दिए गए चित्र पर scharr कैसे लागू किया जाए।

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class ScharrTest {
    
       public static void main( String[] args ) {
    
          // Loading the OpenCV core library
          System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
    
          // Reading the Image from the file and storing it in to a Matrix object
          String file ="E:/OpenCV/chap16/sobel_input.jpg";
          Mat src = Imgcodecs.imread(file);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
    
          // Applying Box Filter effect on the Image
          Imgproc.Scharr(src, dst, Imgproc.CV_SCHARR, 0, 1);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap16/scharr_output.jpg", dst);
    
          System.out.println("Image processed");
       }
    }

    मान लें कि निम्नलिखित इनपुट छवि है scharr_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

    उत्पादन

    इसे निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

    Image Processed

    यदि आप निर्दिष्ट पथ खोलते हैं तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

    अधिक scrr डेरिवेटिव्स

    पैरामीटर (dx और डाई) के अंतिम से भिन्न मान (0 और 1 के बीच) पास करने पर आपको अलग-अलग आउटपुट मिलेंगे -

    // Applying scharr on the Image
    Imgproc.Scharr(src, dst, -1, 1, 1);

    निम्नलिखित चर के लिए विभिन्न मूल्यों को सूचीबद्ध करने वाली एक तालिका है dx तथा dy विधि का scharr() और उनके संबंधित आउटपुट।

    एक्स-व्युत्पन्न वाई के व्युत्पन्न उत्पादन
    0 1
    1 0

    लाप्लासियन ऑपरेटर भी एक व्युत्पन्न ऑपरेटर है जिसका उपयोग किसी छवि में किनारों को खोजने के लिए किया जाता है। यह एक दूसरा क्रम व्युत्पन्न मुखौटा है। इस मास्क में हमारे पास दो और वर्गीकरण हैं, एक है पॉजिटिव लाप्लासियन ऑपरेटर और दूसरा है नेगेटिव लाप्लासियन ऑपरेटर।

    अन्य ऑपरेटरों के विपरीत लाप्लासियन ने किसी विशेष दिशा में किनारों को नहीं निकाला, लेकिन निम्नलिखित वर्गीकरण में किनारों को बाहर निकालता है।

    • आवक किनारों
    • बाहरी किनारों

    आप प्रदर्शन कर सकते हैं Laplacian Transform का उपयोग कर एक छवि पर ऑपरेशन Laplacian() की विधि imgproc वर्ग, इस विधि का वाक्यविन्यास निम्नलिखित है।

    Laplacian(src, dst, ddepth)

    यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

    • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

    • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

    • ddepth - गंतव्य छवि की गहराई का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

    उदाहरण

    निम्नलिखित कार्यक्रम दर्शाता है कि लैप्लस को किसी दिए गए चित्र पर ऑपरेशन कैसे बदलना है।

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class LaplacianTest {
       public static void main(String args[]) {
          // Loading the OpenCV core library
          System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
    
          //Reading the Image from the file and storing it in to a Matrix object
          String file ="E:/OpenCV/chap18/laplacian_input.jpg";
          Mat src = Imgcodecs.imread(file);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
    
          // Applying GaussianBlur on the Image
          Imgproc.Laplacian(src, dst, 10);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap18/laplacian.jpg", dst);
    
          System.out.println("Image Processed");
       }
    }

    मान लें कि निम्नलिखित इनपुट छवि है laplacian_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

    उत्पादन

    कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

    Image Processed

    यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

    distance transformऑपरेटर आमतौर पर इनपुट के रूप में बाइनरी इमेज लेता है। इस ऑपरेशन में, अग्रभूमि क्षेत्रों के अंदर बिंदुओं के ग्रे स्तर की तीव्रता को उनके संबंधित दूरी को निकटतम 0 मान (सीमा) से दूर करने के लिए बदल दिया जाता है।

    आप OpenCV में विधि का उपयोग करके दूरी परिवर्तन लागू कर सकते हैं distanceTransform()। इस विधि का वाक्य विन्यास निम्नलिखित है।

    distanceTransform(src, dst, distanceType, maskSize)

    यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

    • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

    • dst - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

    • distanceType - लागू करने के लिए दूरी परिवर्तन के प्रकार का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

    • maskSize - पूर्णांक प्रकार का एक वैरिएबल जिसका उपयोग करने के लिए मुखौटा आकार का प्रतिनिधित्व करता है।

    उदाहरण

    निम्न कार्यक्रम दर्शाता है कि किसी दिए गए चित्र पर दूरी परिवर्तन ऑपरेशन कैसे करें।

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class DistanceTransform {
       public static void main(String args[]) {
          // Loading the OpenCV core library
          System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
    
          // Reading the Image from the file and storing it in to a Matrix object
          String file ="E:/OpenCV/chap19/input.jpg";
          Mat src = Imgcodecs.imread(file,0);
    
          // Creating an empty matrix to store the results
          Mat dst = new Mat();
          Mat binary = new Mat();
    
          // Converting the grayscale image to binary image
          Imgproc.threshold(src, binary, 100, 255, Imgproc.THRESH_BINARY);
    
          // Applying distance transform
          Imgproc.distanceTransform(mat, dst, Imgproc.DIST_C, 3);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap19/distnceTransform.jpg", dst);
    
          System.out.println("Image Processed");
       }
    }

मान लें कि निम्नलिखित इनपुट छवि है input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

दूरी रूपांतरण संचालन के प्रकार

दूरी ऑपरेशन प्रकार के अलावा DIST_Cपिछले उदाहरण में प्रदर्शित, OpenCV विभिन्न अन्य प्रकार के दूरी परिवर्तन संचालन को पूरा करता है। इन सभी प्रकारों को Imgproc वर्ग के पूर्वनिर्धारित स्थिर क्षेत्रों (निश्चित मूल्यों) द्वारा दर्शाया जाता है।

आप अपने संबंधित पूर्वनिर्धारित मान को नामांकित पैरामीटर को पास करके, आपके द्वारा आवश्यक दूरी परिवर्तन ऑपरेशन का प्रकार चुन सकते हैं distanceType का distanceTransform() तरीका।

// Applying distance transform 
Imgproc.distanceTransform(mat, dst, Imgproc.DIST_C, 3);

विभिन्न प्रकारों का प्रतिनिधित्व करने वाले मूल्य निम्नलिखित हैं distanceTransform संचालन और उनके संबंधित आउटपुट।

ऑपरेशन और विवरण उत्पादन
DIST_C
DIST_L1
DIST_L2
DIST_LABEL_PIXEL
DIST_MASK_3

इस अध्याय में, हम सीखेंगे कि सिस्टम कैमरे का उपयोग करके फ़्रेम को पकड़ने के लिए OpenCV का उपयोग कैसे करें। VideoCapture की कक्षा org.opencv.videoioपैकेज में कैमरे का उपयोग करके वीडियो कैप्चर करने के लिए कक्षाएं और विधियाँ हैं। आइए, कदम से कदम मिलाएं और जानें कि कैसे फ्रेम पर कब्जा करना है -

चरण 1: OpenCV देशी लाइब्रेरी लोड करें

OpenCV लाइब्रेरी का उपयोग करके जावा कोड लिखते समय, आपको जो पहला कदम उठाने की ज़रूरत है, वह है OpenCV के मूल पुस्तकालय को लोड करके loadLibrary()। OpenCV देशी लाइब्रेरी को लोड करें जैसा कि नीचे दिखाया गया है।

// Loading the core library 
System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

चरण 2: वीडियो कैप्चर क्लास को तुरंत देखें

इस ट्यूटोरियल में पहले बताए गए फंक्शन्स में से किसी का उपयोग करके मैट क्लास को इंस्टेंट करें।

// Instantiating the VideoCapture class (camera:: 0) 
VideoCapture capture = new VideoCapture(0);

चरण 3: फ़्रेम पढ़ें

आप कैमरे से फ़्रेम का उपयोग करके पढ़ सकते हैं read() की विधि VideoCaptureकक्षा। यह विधि कक्षा की एक वस्तु को स्वीकार करती हैMat पढ़ने के लिए फ्रेम स्टोर करने के लिए।

// Reading the next video frame from the camera 
Mat matrix = new Mat(); 
capture.read(matrix);

उदाहरण

निम्न प्रोग्राम दर्शाता है कि कैमरे का उपयोग करके फ़्रेम को कैसे कैप्चर किया जाए और जावाएफएक्स विंडो का उपयोग करके इसे प्रदर्शित किया जाए। यह भी कब्जा कर लिया फ्रेम बचाता है।

import java.awt.image.BufferedImage;
import java.awt.image.DataBufferByte;
import java.awt.image.WritableRaster;

import java.io.FileNotFoundException;
import java.io.IOException;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.videoio.VideoCapture;

public class CameraSnapshotJavaFX extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws FileNotFoundException, IOException {
      // Capturing the snapshot from the camera
      CameraSnapshotJavaFX obj = new CameraSnapshotJavaFX();
      WritableImage writableImage = obj.capureSnapShot();

      // Saving the image
      obj.saveImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(400);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Capturing an image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage capureSnapShot() {
      WritableImage WritableImage = null;

      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Instantiating the VideoCapture class (camera:: 0)
      VideoCapture capture = new VideoCapture(0);

      // Reading the next video frame from the camera
      Mat matrix = new Mat();
      capture.read(matrix);

      // If camera is opened
      if( capture.isOpened()) {
         // If there is next video frame
         if (capture.read(matrix)) {
            // Creating BuffredImage from the matrix
            BufferedImage image = new BufferedImage(matrix.width(), 
               matrix.height(), BufferedImage.TYPE_3BYTE_BGR);
            
            WritableRaster raster = image.getRaster();
            DataBufferByte dataBuffer = (DataBufferByte) raster.getDataBuffer();
            byte[] data = dataBuffer.getData();
            matrix.get(0, 0, data);
            this.matrix = matrix;
            
            // Creating the Writable Image
            WritableImage = SwingFXUtils.toFXImage(image, null);
         }
      }
      return WritableImage;
   }
   public void saveImage() {
      // Saving the Image
      String file = "E:/OpenCV/chap22/sanpshot.jpg";

      // Instantiating the imgcodecs class
      Imgcodecs imageCodecs = new Imgcodecs();

      // Saving it again 
      imageCodecs.imwrite(file, matrix);
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्न आउटपुट मिलेगा।

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप उसी फ़्रेम का निरीक्षण कर सकते हैं जो कि jpg फ़ाइल के रूप में सहेजा गया है।

VideoCapture की कक्षा org.opencv.videoioपैकेज में सिस्टम कैमरा का उपयोग करके वीडियो कैप्चर करने के लिए कक्षाएं और विधियाँ हैं। आइए कदम से कदम मिलाते हैं और इसे करना सीखें।

चरण 1: OpenCV देशी लाइब्रेरी लोड करें

OpenCV लाइब्रेरी का उपयोग करके जावा कोड लिखते समय, आपको जो पहला कदम उठाने की ज़रूरत है, वह है OpenCV के मूल पुस्तकालय को लोड करके loadLibrary()। OpenCV देशी लाइब्रेरी को लोड करें जैसा कि नीचे दिखाया गया है।

// Loading the core library 
System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

चरण 2: CascadeClassifier वर्ग को त्वरित करें

CascadeClassifier पैकेज की कक्षा org.opencv.objdetectका उपयोग क्लासिफायर फाइल को लोड करने के लिए किया जाता है। इस कक्षा को उत्तीर्ण करके त्वरित करेंxml फ़ाइल lbpcascade_frontalface.xml जैसा की नीचे दिखाया गया।

// Instantiating the CascadeClassifier 
String xmlFile = "E:/OpenCV/facedetect/lbpcascade_frontalface.xml"; 
CascadeClassifier classifier = new CascadeClassifier(xmlFile);

चरण 3: चेहरों का पता लगाएं

आप विधि का उपयोग करके छवि में चेहरे का पता लगा सकते हैं detectMultiScale() नामित वर्ग का CascadeClassifier। यह विधि कक्षा की एक वस्तु को स्वीकार करती हैMat इनपुट छवि और कक्षा का एक ऑब्जेक्ट पकड़ना MatOfRect का पता लगाने के चेहरे को स्टोर करने के लिए।

// Detecting the face in the snap 
MatOfRect faceDetections = new MatOfRect(); 
classifier.detectMultiScale(src, faceDetections);

उदाहरण

निम्नलिखित कार्यक्रम दर्शाता है कि एक छवि में चेहरे का पता कैसे लगाया जाए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfRect;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Scalar;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
import org.opencv.objdetect.CascadeClassifier;
  
public class FaceDetectionImage {
   public static void main (String[] args) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap23/facedetection_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Instantiating the CascadeClassifier
      String xmlFile = "E:/OpenCV/facedetect/lbpcascade_frontalface.xml";
      CascadeClassifier classifier = new CascadeClassifier(xmlFile);

      // Detecting the face in the snap
      MatOfRect faceDetections = new MatOfRect();
      classifier.detectMultiScale(src, faceDetections);
      System.out.println(String.format("Detected %s faces", 
         faceDetections.toArray().length));

      // Drawing boxes for (Rect rect : faceDetections.toArray()) { Imgproc.rectangle( src, // where to draw the box new Point(rect.x, rect.y), // bottom left new Point(rect.x + rect.width, rect.y + rect.height), // top right new Scalar(0, 0, 255), 3 // RGB colour );
      }

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap23/facedetect_output1.jpg", src);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है facedetection_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Detected 3 faces 
Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

निम्न प्रोग्राम दर्शाता है कि सिस्टम कैमरा का उपयोग करके चेहरों का पता कैसे लगाया जा सकता है और इसे JavaFX विंडो का उपयोग करके प्रदर्शित किया जाता है।

उदाहरण

import java.awt.image.BufferedImage;
import java.awt.image.DataBufferByte;
import java.awt.image.WritableRaster;

import java.io.FileNotFoundException;
import java.io.IOException;

import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfRect;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
import org.opencv.objdetect.CascadeClassifier;
import org.opencv.videoio.VideoCapture;

public class faceDetectionJavaFXX extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws FileNotFoundException, IOException {
      // Capturing the snapshot from the camera
      faceDetectionJavaFXX obj = new faceDetectionJavaFXX();
      WritableImage writableImage = obj.capureFrame();

      // Saving the image
      obj.saveImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(400);
      imageView.setFitWidth(600);

      // Setting the preserve ratio of the image view
      imageView.setPreserveRatio(true);

      // Creating a Group object
      Group root = new Group(imageView);

      // Creating a scene object
      Scene scene = new Scene(root, 600, 400);

      // Setting title to the Stage
      stage.setTitle("Capturing an image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage capureFrame() {
      WritableImage writableImage = null;

      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Instantiating the VideoCapture class (camera:: 0)
      VideoCapture capture = new VideoCapture(0);

      // Reading the next video frame from the camera
      Mat matrix = new Mat();
      capture.read(matrix);

      // If camera is opened
      if(!capture.isOpened()) {
         System.out.println("camera not detected");
      } else
         System.out.println("Camera detected ");
           
      // If there is next video frame
      if (capture.read(matrix)) {
         /////// Detecting the face in the snap /////
         String file = "E:/OpenCV/facedetect/lbpcascade_frontalface.xml";
         CascadeClassifier classifier = new CascadeClassifier(file);

         MatOfRect faceDetections = new MatOfRect();
         classifier.detectMultiScale(matrix, faceDetections);
         System.out.println(String.format("Detected %s faces",
            faceDetections.toArray().length));

         // Drawing boxes for (Rect rect : faceDetections.toArray()) { Imgproc.rectangle( matrix, //where to draw the box new Point(rect.x, rect.y), //bottom left new Point(rect.x + rect.width, rect.y + rect.height), //top right new Scalar(0, 0, 255) //RGB colour );
         }
         // Creating BuffredImage from the matrix
         BufferedImage image = new BufferedImage(matrix.width(), matrix.height(),
            BufferedImage.TYPE_3BYTE_BGR);
         
         WritableRaster raster = image.getRaster();
         DataBufferByte dataBuffer = (DataBufferByte) raster.getDataBuffer();
         byte[] data = dataBuffer.getData();
         matrix.get(0, 0, data);

         this.matrix = matrix;
           
         // Creating the Writable Image
         writableImage = SwingFXUtils.toFXImage(image, null);
      }
      return writableImage;
   }
   public void saveImage() {
      // Saving the Image
      String file = "E:/OpenCV/chap23/facedetected.jpg";

      // Instantiating the imagecodecs class
      Imgcodecs imageCodecs = new Imgcodecs();

      // Saving it again
      imageCodecs.imwrite(file, matrix);
   }
   public static void main(String args[]) {
      launch(args);
   }
}

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्न आउटपुट मिलेगा।

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप उसी स्नैपशॉट को एक के रूप में सहेज कर देख सकते हैं jpg छवि।

आप प्रदर्शन कर सकते हैं affine translation का उपयोग कर एक छवि पर warpAffine()imgproc वर्ग की विधि। इस विधि का वाक्य विन्यास निम्नलिखित है -

Imgproc.warpAffine(src, dst, tranformMatrix, size);

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • tranformMatrix - ए Mat परिवर्तन मैट्रिक्स का प्रतिनिधित्व करने वाली वस्तु।

  • size - आउटपुट छवि के आकार का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

उदाहरण

निम्नलिखित कार्यक्रम दर्शाता है कि किसी दिए गए चित्र पर affine ऑपरेशन कैसे लागू किया जाए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfPoint2f;
import org.opencv.core.Point;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class AffineTranslation {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap24/transform_input.jpg";
      Mat src = Imgcodecs.imread(file);

      //Creating an empty matrix to store the result
      Mat dst = new Mat();

      Point p1 = new Point( 0,0 );
      Point p2 = new Point( src.cols() - 1, 0 );
      Point p3 = new Point( 0, src.rows() - 1 );
      Point p4 = new Point( src.cols()*0.0, src.rows()*0.33 );
      Point p5 = new Point( src.cols()*0.85, src.rows()*0.25 );
      Point p6 = new Point( src.cols()*0.15, src.rows()*0.7 );
      
      MatOfPoint2f ma1 = new MatOfPoint2f(p1,p2,p3);
      MatOfPoint2f ma2 = new MatOfPoint2f(p4,p5,p6);

      // Creating the transformation matrix
      Mat tranformMatrix = Imgproc.getAffineTransform(ma1,ma2);

      // Creating object of the class Size
      Size size = new Size(src.cols(), src.cols());

      // Applying Wrap Affine
      Imgproc.warpAffine(src, dst, tranformMatrix, size);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap24/Affinetranslate.jpg", dst);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है transform_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

इसे निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

आप ऐसा कर सकते हैं perform rotation का उपयोग कर एक छवि पर ऑपरेशन warpAffine() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है -

Imgproc.warpAffine(src, dst, rotationMatrix, size);

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • rotationMatrix - ए Mat रोटेशन मैट्रिक्स का प्रतिनिधित्व करने वाली वस्तु।

  • size - आउटपुट छवि के आकार का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

उदाहरण

निम्न प्रोग्राम दर्शाता है कि छवि को कैसे घुमाना है।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Point;
import org.opencv.core.Size;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class Rotation {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap24/transform_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Creating a Point object
      Point point = new Point(300, 200)

      // Creating the transformation matrix M
      Mat rotationMatrix = Imgproc.getRotationMatrix2D(point, 30, 1);

      // Creating the object of the class Size
      Size size = new Size(src.cols(), src.cols());

      // Rotating the given image
      Imgproc.warpAffine(src, dst, rotationMatrix, size);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap24/rotate_output.jpg", dst);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है transform_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

आप प्रदर्शन कर सकते हैं scaling का उपयोग कर एक छवि पर resize() की विधि imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

resize(Mat src, Mat dst, Size dsize, double fx, double fy, int interpolation)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dst - ए Mat इस ऑपरेशन के लिए गंतव्य (आउटपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • dsize - ए Size आउटपुट छवि के आकार का प्रतिनिधित्व करने वाली वस्तु।

  • fx - क्षैतिज अक्ष के साथ स्केल कारक का प्रतिनिधित्व करने वाले टाइप डबल का एक चर।

  • fy - ऊर्ध्वाधर अक्ष के साथ स्केल कारक का प्रतिनिधित्व करने वाले प्रकार डबल का एक चर।

  • Interpolation - इंटरपोलेशन विधि का प्रतिनिधित्व करने वाला पूर्णांक चर।

उदाहरण

निम्न प्रोग्राम प्रदर्शित करता है कि आवेदन कैसे करें scale transformation एक छवि के लिए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class Scaling {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap24/transform_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Creating the Size object
      Size size = new Size(src.rows()*2, src.rows()*2);

      // Scaling the Image
      Imgproc.resize(src, dst, size, 0, 0, Imgproc.INTER_AREA);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap24/scale_output.jpg", dst);

      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है transform_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट (आकार - चौड़ाई: 300px और ऊंचाई: 300px)।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं (आकार - चौड़ाई: 600px और ऊंचाई: 600px) -

OpenCV में, आप विधि का उपयोग करके एक छवि के लिए अलग-अलग रंग के नक्शे लागू कर सकते हैं applyColorMap() वर्ग का Imgproc। इस विधि का वाक्य विन्यास निम्नलिखित है -

applyColorMap(Mat src, Mat dst, int colormap)

यह तीन मापदंडों को स्वीकार करता है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • dst - कक्षा की एक वस्तु Mat गंतव्य (आउटपुट) छवि का प्रतिनिधित्व करना।

  • colormap - पूर्णांक प्रकार का एक वेरिएबल जो लागू होने वाले रंगीन नक्शे के प्रकार का प्रतिनिधित्व करता है।

उदाहरण

निम्न प्रोग्राम प्रदर्शित करता है कि आवेदन कैसे करें color map एक छवि के लिए।

import org.opencv.core.Core;
import org.opencv.core.Mat;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class ColorMapTest {
   public static void main(String args[]) {
      // Loading the OpenCV core library
      System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap25/color_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying color map to an image
      Imgproc.applyColorMap(src, dst, Imgproc.COLORMAP_HOT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap25/colormap_hot.jpg", dst);
      System.out.println("Image processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है color_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

अधिक संचालन

के अतिरिक्त COLORMAP_HOTपिछले उदाहरण में प्रदर्शित, OpenCV विभिन्न प्रकार के रंगीन मानचित्रों को पूरा करता है। इन सभी प्रकारों को Imgproc वर्ग के पूर्वनिर्धारित स्थिर क्षेत्रों (निश्चित मूल्यों) द्वारा दर्शाया जाता है।

आप अपने संबंधित पूर्वनिर्धारित मान को नामांकित पैरामीटर को पास करके, अपनी ज़रूरत के प्रकार के कोलोराप को चुन सकते हैं colormap का applyColorMap() तरीका।

Imgproc.applyColorMap(src, dst, Imgproc.COLORMAP_HOT);

विभिन्न प्रकार के रंगीन मानचित्रों और उनके संबंधित आउटपुट का प्रतिनिधित्व करने वाले मूल्य निम्नलिखित हैं।

ऑपरेशन और विवरण उत्पादन
COLORMAP_AUTUMN
COLORMAP_BONE
COLORMAP_COOL
COLORMAP_HOT
COLORMAP_HSV
COLORMAP_JET
COLORMAP_OCEAN
COLORMAP_PARULA
COLORMAP_PINK
COLORMAP_RAINBOW
COLORMAP_SPRING
COLORMAP_SUMMER
COLORMAP_WINTER

एक छवि में किनारों का पता लगाने के लिए कैनी एज डिटेक्शन का उपयोग किया जाता है। यह ग्रे स्केल इमेज को इनपुट के रूप में स्वीकार करता है और यह मल्टीस्टेज एल्गोरिथ्म का उपयोग करता है।

आप इस ऑपरेशन का उपयोग करके एक छवि पर कर सकते हैं Canny() की विधि imgproc वर्ग, इस विधि का वाक्यविन्यास निम्नलिखित है।

Canny(image, edges, threshold1, threshold2)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • image - ए Mat इस ऑपरेशन के लिए स्रोत (इनपुट छवि) का प्रतिनिधित्व करने वाली वस्तु।

  • edges - ए Mat इस ऑपरेशन के लिए गंतव्य (किनारों) का प्रतिनिधित्व करने वाली वस्तु।

  • threshold1 - हिस्टैरिसीस प्रक्रिया के लिए पहले थ्रेशोल्ड का प्रतिनिधित्व करने वाले टाइप डबल का एक चर।

  • threshold2 - हिस्टैरिसीस प्रक्रिया के लिए दूसरी दहलीज का प्रतिनिधित्व करने वाले टाइप डबल का एक चर।

उदाहरण

निम्नलिखित कार्यक्रम एक उदाहरण है, जो एक दी गई छवि पर कैनी एज डिटेक्शन ऑपरेशन को प्रदर्शित करता है।

import org.opencv.core.Core;
import org.opencv.core.Mat;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class CannyEdgeDetection {
   public static void main(String args[]) throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

      // Reading the Image from the file and storing it in to a Matrix object
      String file = "E:/OpenCV/chap17/canny_input.jpg";

      // Reading the image
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat gray = new Mat();

      // Converting the image from color to Gray
      Imgproc.cvtColor(src, gray, Imgproc.COLOR_BGR2GRAY);
      Mat edges = new Mat();

      // Detecting the edges
      Imgproc.Canny(gray, edges, 60, 60*3);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap17/canny_output.jpg", edges);
      System.out.println("Image Loaded");
   } 
}

मान लें कि निम्नलिखित इनपुट छवि है canny_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

आप किसी दिए गए चित्र के आकार का पता लगा सकते हैं Hough Transform technique विधि का उपयोग कर HoughLines() का Imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

HoughLines(image, lines, rho, theta, threshold)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • image - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • lines - कक्षा की एक वस्तु Mat वेक्टर को स्टोर करता है जो लाइनों के मापदंडों (आर, stores) को संग्रहीत करता है।

  • rho - पिक्सेल में पैरामीटर r के रिज़ॉल्यूशन को दर्शाने वाला टाइप डबल का एक वैरिएबल।

  • theta - रेडियंस में पैरामीटर rad के रिज़ॉल्यूशन का प्रतिनिधित्व करने वाले टाइप डबल का एक वेरिएबल।

  • threshold - लाइन का "पता लगाने" के लिए चौराहों की न्यूनतम संख्या का प्रतिनिधित्व करने वाले प्रकार पूर्णांक का एक चर।

उदाहरण

निम्नलिखित कार्यक्रम दर्शाता है कि किसी दिए गए चित्र में हूप लाइनों का पता कैसे लगाया जाए।

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Point;
import org.opencv.core.Scalar;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class HoughlinesTest {
   public static void main(String args[]) throws Exception {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file = "E:/OpenCV/chap21/hough_input.jpg";

      // Reading the image
      Mat src = Imgcodecs.imread(file,0);

      // Detecting edges of it
      Mat canny = new Mat();
      Imgproc.Canny(src, canny, 50, 200, 3, false);

      // Changing the color of the canny
      Mat cannyColor = new Mat();
      Imgproc.cvtColor(canny, cannyColor, Imgproc.COLOR_GRAY2BGR);

      // Detecting the hough lines from (canny)
      Mat lines = new Mat();
      Imgproc.HoughLines(canny, lines, 1, Math.PI/180, 100);

      System.out.println(lines.rows());
      System.out.println(lines.cols());

      // Drawing lines on the image
      double[] data;
      double rho, theta;
      Point pt1 = new Point();
      Point pt2 = new Point();
      double a, b;
      double x0, y0;
      
      for (int i = 0; i < lines.cols(); i++) {
         data = lines.get(0, i);
         rho = data[0];
         theta = data[1];
         
         a = Math.cos(theta);
         b = Math.sin(theta);
         x0 = a*rho;
         y0 = b*rho;
         
         pt1.x = Math.round(x0 + 1000*(-b));
         pt1.y = Math.round(y0 + 1000*(a));
         pt2.x = Math.round(x0 - 1000*(-b));
         pt2.y = Math.round(y0 - 1000 *(a));
         Imgproc.line(cannyColor, pt1, pt2, new Scalar(0, 0, 255), 6);
      }
      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap21/hough_output.jpg", cannyColor);
          
      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है hough_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

143 
1 
Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -

histogramछवि की पिक्सल की तीव्रता के मूल्यों की आवृत्ति को दर्शाता है। एक छवि हिस्टोग्राम में, एक्स-अक्ष ग्रे स्तर की तीव्रता को दिखाता है और वाई-अक्ष इन तीव्रता की आवृत्ति को दर्शाता है।

Histogram equalizationएक छवि के विपरीत को बेहतर बनाता है, ताकि इंटेनस्टी रेंज को बाहर खींचा जा सके। आप विधि का उपयोग करके किसी दिए गए चित्र के हिस्टोग्राम की बराबरी कर सकते हैंequalizeHist() का Imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

equalizeHist(src, dst)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • dst - कक्षा की एक वस्तु Matआउटपुट का प्रतिनिधित्व करते हैं। (हिस्टोग्राम को बराबर करने के बाद प्राप्त छवि)

उदाहरण

निम्न कार्यक्रम दर्शाता है कि किसी दिए गए चित्र के हिस्टोग्राम को कैसे बराबर किया जाए।

import java.util.ArrayList;
import java.util.List;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class HistoTest {
   public static void main (String[] args) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap20/histo_input.jpg";

      // Load the image
      Mat img = Imgcodecs.imread(file);

      // Creating an empty matrix
      Mat equ = new Mat();
      img.copyTo(equ);

      // Applying blur
      Imgproc.blur(equ, equ, new Size(3, 3));

      // Applying color
      Imgproc.cvtColor(equ, equ, Imgproc.COLOR_BGR2YCrCb);
      List<Mat> channels = new ArrayList<Mat>();

      // Splitting the channels
      Core.split(equ, channels);

      // Equalizing the histogram of the image
      Imgproc.equalizeHist(channels.get(0), channels.get(0));
      Core.merge(channels, equ);
      Imgproc.cvtColor(equ, equ, Imgproc.COLOR_YCrCb2BGR);

      Mat gray = new Mat();
      Imgproc.cvtColor(equ, gray, Imgproc.COLOR_BGR2GRAY);
      Mat grayOrig = new Mat();
      Imgproc.cvtColor(img, grayOrig, Imgproc.COLOR_BGR2GRAY);

      Imgcodecs.imwrite("E:/OpenCV/chap20/histo_output.jpg", equ);
      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है histo_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -