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 - फोल्डर को खोलें OpenCV → build → java। यहां आपको 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 और उप-फ़ोल्डर में जाएं build → java। यहां आपको दो फोल्डर मिलेंगे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 Oच Interest। |
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
यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -