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

यह अध्याय OpenGL, उसके कार्यों, जावा में OpenGL बाइंडिंग (GL4java, LWJGL, JOGL), और अन्य OpenGL बाइंडिंग पर JOGL के लाभों का परिचय देता है।

Jएवा के लिए बाध्यकारी OकलमGL(JOGL) जावा में ओपनजीएल ग्राफिक्स एपीआई के लिए हाल ही में बाध्यकारी है। यह एक रैपर लाइब्रेरी है, जो ओपनजीएल एपीआई का उपयोग कर सकती है, और इसे जावा में कोडित 2 डी और 3 डी ग्राफिक्स अनुप्रयोगों को बनाने के लिए डिज़ाइन किया गया है। JOGL एक ओपन-सोर्स लाइब्रेरी है जिसे शुरुआत में MIT के पूर्व स्नातक छात्रों केन रसेल और क्रिस क्लाइन द्वारा विकसित किया गया था। बाद में, यह सन माइक्रोसिस्टम्स में गेमिंग समूह द्वारा अपनाया गया था, और अब इसे ग्राफिक्स ऑडियो और प्रोसेसिंग (JJPT) पर जावा द्वारा बनाए रखा गया है। JOGL विभिन्न ऑपरेटिंग सिस्टम जैसे विंडोज, सोलारिस, मैक ओएस एक्स और लिनक्स (x86 पर) पर कार्य करता है।

OpenGL क्या है?

OpenGL का अर्थ Open Graphics Library है, जो 2D और 3D ग्राफिक्स बनाने के लिए कमांड का एक संग्रह है। ओपनजीएल के साथ, आप बहुत ही मूल आदिमता जैसे बिंदुओं, रेखाओं, बहुभुज, बिटमैप, और छवियों का उपयोग करके जटिल 3 डी आकृतियाँ बना सकते हैं।

यहाँ OpenGL की कुछ विशेषताएं हैं -

  • यह कई प्लेटफार्मों पर काम कर सकता है।

  • इसकी कई भाषाओं जैसे कि C ++, Python आदि में बाइंडिंग है

  • यह 2D और 3D वेक्टर ग्राफिक्स रेंडर कर सकता है।

  • यह शीघ्र और उच्च गुणवत्ता प्रदान करने के लिए ग्राफिकल प्रोसेसिंग यूनिट (GPU) के साथ सहभागिता करता है। प्रतिपादन 2 डी या 3 डी मॉडल से एक छवि बनाने की प्रक्रिया है।

  • यह 3D ग्राफिक्स एप्लिकेशन लिखने के लिए एक उद्योग मानक एपीआई है। उदाहरण के लिए, खेल, स्क्रीनसेवर, आदि।

  • इसमें लगभग 150 कमांड होते हैं, जो प्रोग्रामर अनुप्रयोगों को विकसित करने के लिए वस्तुओं और संचालन को निर्दिष्ट करने के लिए उपयोग कर सकते हैं।

  • इसमें ओपनजीएल यूटिलिटी लाइब्रेरी (जीएलयू) है जो विभिन्न मॉडलिंग सुविधाएँ प्रदान करता है, जैसे कि क्वाड्रिक सतहों और एनयूआरबीएस वक्र्स। GLU OpenGL का एक मानक घटक है।

  • ओपनजीएल का डिज़ाइन कई भाषाओं का उपयोग करते हुए कई प्लेटफार्मों पर दक्षता, प्रभावशीलता और इसके कार्यान्वयन पर केंद्रित है। OpenGL API की सादगी बनाए रखने के लिए, विंडोिंग कार्य शामिल नहीं हैं।

इसलिए, OpenGL विंडो कार्यों के लिए अन्य प्रोग्रामिंग भाषाओं पर निर्भर करता है।

ओपन बंधन एपीआई के लिए जावा बाइंडिंग

यह एक जावा स्पेसिफिकेशन रिक्वेस्ट (JSR) API स्पेसिफिकेशन है, जो जावा प्लेटफॉर्म पर OpenGL का उपयोग करने की अनुमति देता है।

विशेष विवरण विवरण
जेएसआर 231 यह जावा बाइंडिंग पैकेज जावा एसई प्लेटफॉर्म का समर्थन करता है।
जेएसआर 239 यह जावा बाइंडिंग पैकेज जावा एमई प्लेटफॉर्म का समर्थन करता है।

जावा में विभिन्न OpenGL बाइंडिंग हैं। उनकी चर्चा नीचे की गई है

GL4java

इसे जावा तकनीक के लिए ओपनजीएल के रूप में जाना जाता है। इसमें OpenGL 1.3 के लिंक और लगभग सभी विक्रेता एक्सटेंशन हैं। साथ ही, इसे Abstract Window Toolkit (AWT) और स्विंग के साथ इस्तेमाल किया जा सकता है। यह एक गेम है जो OpenGL बाइंडिंग है, जो कि सिंगल विंडो है जो फुल स्क्रीन एप्लिकेशन प्रदर्शित करता है।

LWJGL

  • लाइट वेट जावा गेम लाइब्रेरी (LWJGL), OpenGL 1.5 का उपयोग करता है और जावा के नवीनतम संस्करण के साथ काम करता है।

  • यह JSE 1.4 की पूर्ण स्क्रीन क्षमताओं का उपयोग कर सकता है। इसमें AWT / स्विंग के लिए सीमित समर्थन है।

  • यह हल्के उपकरणों जैसे मोबाइल फोन, एम्बेडेड डिवाइस आदि के लिए उपयुक्त है।

JOGL

  • JOGL केवल 2D और 3D रेंडरिंग पर केंद्रित है। ध्वनि और इनपुट-आउटपुट से निपटने वाले इंटरफेस JOGL में शामिल नहीं हैं।

  • इसमें ग्राफिक्स यूटिलिटी लाइब्रेरी (जीएलयू), जीएल यूटिलिटी टूलकिट (जीएलयूटी), और इसका अपना एपीआई - नेटिव विंडविंग टूलकिट (NEWT) शामिल है।

क्यों JOGL?

  • यह ओपनजीएल एपीआई (संस्करण 1.0, 4.3, ईएस 1, ईएस 2 और ईएस 3) के साथ-साथ लगभग सभी विक्रेता एक्सटेंशन तक पूर्ण पहुंच प्रदान करता है। इसलिए, OpenGL की सभी विशेषताएं JOGL में शामिल हैं।

  • JOGL AWT, स्विंग और स्टैंडर्ड विजेट टूलकिट (SWT) के साथ एकीकृत होता है। इसमें स्वयं के मूल निवासी घुमावदार टूलकिट (NEWT) भी शामिल हैं। इसलिए, यह विंडोिंग के लिए पूर्ण समर्थन प्रदान करता है।

JOGL का इतिहास

  • 1992 - सिलिकॉन ग्राफिक्स इंक ने पहला ओपनग्ल स्पेसिफिकेशन जारी किया।

  • 2003 - Java.net वेबसाइट को नई विशेषताओं के साथ लॉन्च किया गया और JOGL पहली बार उसी वेबसाइट पर प्रकाशित हुई।

  • 2010 - वर्ष 2010 से, यह बीएसडी लाइसेंस के तहत स्वतंत्र स्रोत परियोजना रही है, जो कंप्यूटर सॉफ्टवेयर के लिए एक उदार लाइसेंस है।

इस अध्याय में विभिन्न एकीकृत विकास वातावरणों (IDEs) का उपयोग करके JOGL को आपके सिस्टम पर उपयोग करने के लिए पर्यावरण की स्थापना शामिल है।

JOGL की स्थापना

JOGL इंस्टॉलेशन के लिए, आपको निम्नलिखित सिस्टम आवश्यकताएं होनी चाहिए -

सिस्टम आवश्यकताएं

आपकी मशीन पर जावा डेवलपमेंट किट (JDK) स्थापित होना पहली आवश्यकता है।

आवश्यकता विवरण
JDK संस्करण 1.4 या इसके बाद के संस्करण
याद कोई न्यूनतम आवश्यकता नहीं
डिस्क में जगह कोई न्यूनतम आवश्यकता नहीं
ऑपरेटिंग सिस्टम कोई न्यूनतम आवश्यकता नहीं

JOGL एप्लिकेशन विकास के साथ शुरू करने के लिए आपको अपने वातावरण को सेटअप करने के लिए दिए गए चरणों का पालन करने की आवश्यकता है -

चरण 1 - अपनी मशीन पर जावा इंस्टॉलेशन को सत्यापित करना

अपने सिस्टम का कंसोल खोलें और निम्न जावा कमांड निष्पादित करें -

मंच टास्क COMMAND
खिड़कियाँ ओपन कमांड कंसोल C: \> जावा संस्करण
लिनक्स कमांड टर्मिनल खोलें $ जावा-विचलन
मैक टर्मिनल खोलें मशीन: ~ joseph $ java -version

संबंधित ऑपरेटिंग सिस्टम पर आउटपुट को सत्यापित करें।

मंच उत्पादन
खिड़कियाँ

Java “1.6.0.21”

जावा (टीएम) एसई रनटाइम एनवायरनमेंट (बिल्ड 1..6.0_21-b07) जावा हॉटस्पॉट (टीएम) क्लाइंट वीएम (बिल्ड 17.0-बी 7, मिश्रित मोड, साझाकरण)

लिनक्स

Java “1.6.0.21”

जावा (टीएम) एसई रनटाइम एनवायरनमेंट (बिल्ड 1..6.0_21-b07) जावा हॉटस्पॉट (टीएम) क्लाइंट वीएम (बिल्ड 17.0-बी 7, मिश्रित मोड, साझाकरण)

मैक

Java “1.6.0.21”

जावा (टीएम) एसई रनटाइम एनवायरनमेंट (बिल्ड 1..6.0_21-b07) जावा हॉटस्पॉट (टीएम) क्लाइंट वीएम (बिल्ड 17.0-बी 7, मिश्रित मोड, साझाकरण)

चरण 2 - जावा डेवलपमेंट किट (JDK) की स्थापना

यदि जावा आपके मशीन पर स्थापित नहीं है, तो आपको ओरेकल वेबसाइट: ओरेकल से जावा एसडीके स्थापित करने की आवश्यकता है । आप डाउनलोड की गई फ़ाइलों से JDK को स्थापित करने के लिए निर्देश पा सकते हैं। सेटअप को स्थापित करने और कॉन्फ़िगर करने के लिए आपको दिए गए निर्देशों का पालन करना होगा। अंत में, PATH और JAVA_HOME वातावरण चर को उस निर्देशिका के संदर्भ में सेट करें जिसमें क्रमशः java.exe और javac.exe फाइलें हैं, आमतौर पर java_install_dir / bin और java_install_dir।

सेट Java-home पर्यावरण चर उसी मार्ग पर आधार निर्देशिका स्थान को इंगित करने के लिए, जहां जावा आपकी मशीन पर स्थापित है।

मंच आदेश
खिड़कियाँ पर्यावरण चर JAVA_HOME को C: \ ProgramFiles \ Java \ Jdk1.6.0_21 पर सेट करें
लिनक्स निर्यात JAVA_HOME = / usr / स्थानीय / जावा-वर्तमान
मैक निर्यात JAVA_HOME = / लाइब्रेरी / जावा / होम

सिस्टम पथ के लिए जावा संकलक स्थान को इस प्रकार संलग्न करें -

मंच आदेश
खिड़कियाँ सिस्टम चर और पथ के अंत में स्ट्रिंग जोड़ें;% JAVA_HOME% बिन
लिनक्स निर्यात पथ =$PATH:$JAVA_HOME / bin /
मैक की जरूरत नहीं है

चरण 3 - JOGL डाउनलोड करना

  • आप JOGL के नवीनतम संस्करण को वेबसाइट www.jogamp.org से डाउनलोड कर सकते हैं

  • Www.jogamp.org के होम पेज पर जाएं

  • बिल्ड / डाउनलोड> करंट (ज़िप) पर क्लिक करें।

यह आपको वेबसाइट द्वारा बनाए गए सभी एपीआई के लिए .jar फाइलों की सूची में ले जाता है।

  • लाइब्रेरी .jar फ़ाइल डाउनलोड करें jogamp-all-platforms.7z, जावा ओपन लाइब्रेरी के लिए जावा दस्तावेज़ glugen-javadoc.7z, और JOGL jogl-javadocs.7z.

  • किसी भी जिप एक्सट्रैक्टिंग सॉफ्टवेयर का उपयोग करके डाउनलोड की गई .jar फ़ाइलों को निकालें।

जब आप निकाले गए फ़ोल्डर को खोलते हैं, तो आपको जार फ़ोल्डर, स्रोत-कोड और अन्य फाइलें मिलेंगी।

स्रोत कोड प्राप्त करें gluegen-java-src.zip तथा jogl-java-src.zipIDE का समर्थन करने के लिए। यह वैकल्पिक है।

  • जार फ़ोल्डर के अंदर, कई .jar फाइलें होती हैं। फ़ाइलों का यह संग्रह Glugen और JOGL के अंतर्गत आता है।

  • JOAMP विभिन्न ऑपरेटिंग सिस्टम जैसे विंडोज, सोलारिस, लिनक्स और एंड्रॉइड का समर्थन करने वाली देशी लाइब्रेरी प्रदान करता है। इसलिए, आपको उचित जार फाइलें लेने की जरूरत है जो आपके इच्छित प्लेटफॉर्म पर निष्पादित हो सकती हैं। उदाहरण के लिए, यदि आप विंडोज 64-बिट ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं, तो जार फ़ोल्डर से निम्न .jar फाइलें प्राप्त करें -

    • gluegenrt.jar
    • jogl-all.jar
    • gluegen-rt-natives-windows-amd64.jar
    • jogl-all-natives-windowsamd64.jar

ग्रहण के लिए JOGL की स्थापना 4.4

JOGL स्थापित करने के लिए दी गई प्रक्रिया का पालन करें -

पुस्तकालय जोड़ना

Step 1 - ग्रहण खोलें।

Step 2 - एक नया प्रोजेक्ट बनाएं।

Step 3- प्रोजेक्ट फ़ोल्डर में lib नाम का नया फोल्डर बनाएं ।

Step 4- फाइलों को कॉपी करें ggengen-rt-natives-windows-amd64.jar, gamgenrt.jar, jogl-all-natives-windowsamd64.jar औरjogl-all.jarमें lib फ़ोल्डर।

Step 5- अब इन फाइलों का चयन करें और अपने माउस बटन पर राइट क्लिक करें। एक शॉर्टकट मेनू प्रदर्शित किया जाता है, जिसमें शामिल हैंBuild Path > Add to Build Path.

Step 6- अन्य परियोजनाओं के लिए सभी .jar फाइलें उपलब्ध कराने के लिए, मुख्य मेनू पर जाएं। विंडो> वरीयताएँ चुनें। प्राथमिकताएँ विंडो प्रकट होती है।

  • वरीयताएँ विंडो में, बाएँ हाथ की ओर स्थित ड्रॉप डाउन मेनू में, पदानुक्रम- Java → बिल्ड पाथ → उपयोगकर्ता लाइब्रेरीज़ का अनुसरण करें।

  • "नया ..." बटन पर क्लिक करें।

  • यह एक डायलॉग बॉक्स खोलता है। लाइब्रेरी का नाम jogl2.1 दर्ज करें।

  • जार फाइलें जोड़ें glugen-rt.jar तथा jogl-all.jar बटन का उपयोग "बाहरी जार जोड़ें ..."।

  • यह नाम से एक नया उपयोगकर्ता पुस्तकालय बनाता है jogl2.1.

उसी तरह, हम add.jar फ़ाइलों के लिए जावा प्रलेखन और स्रोत कोड जोड़ सकते हैं।

मूल पुस्तकालयों को जोड़ना

Step 1 - जॉगल- all.jar नोड का विस्तार करें, Javadoc स्थान (कोई नहीं) का चयन करें।

Step 2- "नया ..." बटन पर क्लिक करें। JOGL Java दस्तावेज़ के लिए नाम दर्ज करें।

Step 3 - "बाहरी जार जोड़ें ..." बटन पर क्लिक करें।

Step 4 - यह एक डायलॉग बॉक्स खोलता है जहाँ आपको JOGL Java डॉक्यूमेंटेशन के स्थान का चयन करना होगा, जिसे हमने पहले ही डाउनलोड कर लिया है।

स्रोत कोड जोड़ना

Step 1 - नोड मूल पुस्तकालय स्थान का चयन करें: (कोई नहीं)।

Step 2 - "नया ..." बटन पर क्लिक करें।

Step 3 - देशी पुस्तकालयों के लिए नाम दर्ज करें और "ओके" बटन पर क्लिक करें।

Step 4 - "बाहरी जार जोड़ें ..." बटन पर क्लिक करें।

Step 5- अब उस पथ का चयन करें जहां देशी पुस्तकालय फाइलें ('ग्लूगन-आरटी-नेटिव्स-विंडो-एमड64.जर और जोगल-नेटिव्स-विंडो-एमड64.जर') स्थित हैं।

Step 6 - सोर्स कोड के लिए एक ही प्रक्रिया दोहराएं।

Step 7 - हम Javadoc, स्रोत कोड और जार फ़ाइलों के लिए स्थान उसी तरह सेट कर सकते हैं जैसे कि दोनों मूल लाइब्रेरी फ़ाइलों के लिए ऊपर दिए गए हैं glegen-rt.jar तथा glugen-natives-windows-amd64.jar.

NetBeans 4.4 के लिए JOGL की स्थापना

आइए हम नेटबाइन्स 4.4 के लिए JOGL की स्थापना के चरणों के माध्यम से चलते हैं -

पुस्तकालय जोड़ना

Step 1 - मुख्य मेनू में, का चयन करें Tools > Libraries

Step 2 - यह आपको ले जाता है Ant Library Manager

Step 3 - के तहत Classpath टैब पर क्लिक करें New Libraryबटन निचले निचले कोने पर स्थित है। यह एक छोटा डायलॉग बॉक्स खोलता है।

Step 4 - लाइब्रेरी का नाम इस प्रकार दर्ज करें JoGl2.0.

Step 5 - "ओके" बटन पर क्लिक करें।

Step 6 - “ऐड जार / फोल्डर…” बटन पर क्लिक करें।

Step 7 - जहाँ पथ .jar फ़ाइलों का चयन करें jogl.all.jar तथा gluegen-rt.jar स्थित हैं।

JOGL लाइब्रेरी को प्रत्येक प्रोजेक्ट में शामिल करने के लिए, नीचे दिए गए चरणों का पालन करें -

Step 1 - पर राइट-क्लिक करें project name। यह एक शॉर्ट-कट मेनू दिखाता है।

Step 2 - चयन करें Properties. यह एक विंडो खोलता है जिसका नाम है Project properties

Step 3 - चयन करें Libraries बाईं ओर से श्रेणियाँ।

Step 4 - चयन करें Compile tabऔर "लाइब्रेरी जोड़ें ..." बटन पर क्लिक करें। जोड़ें पुस्तकालय संवाद बॉक्स आता है।

Step 5 - अब JOGL2.0 लाइब्रेरी जोड़ें, जिसे आपने पहले बनाया था।

प्रत्येक परियोजना में मूल निवासी पुस्तकालय शामिल है

प्रत्येक परियोजना में देशी पुस्तकालय को शामिल करने के लिए दिए गए चरणों का पालन करें -

Step 1 - प्रोजेक्ट को राइट-क्लिक करें।

Step 2 - चयन करें Set Configuration > Customize…

यह आपको ले जाता है Project Properties खिड़की।

Step 3 - दाहिने हाथ की तरफ, में VM options, "अनुकूलित करें" बटन पर क्लिक करें।

Step 4 - उस रास्ते के लिए ब्राउज़ करें जिसमें JOGL देशी लाइब्रेरी हैं gluegen-rtnatives-windows-amd64.jar'' तथा 'jogl-all-natives-windowsamd64.jar.

मूल पुस्तकालयों के जावा प्रलेखन जोड़ना

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

Step 1 - खोलें main menu

Step 2 - चयन करें Tools > Libraries। यह आपको ले जाता हैLibrary manager

Step 3 - के तहत JavaDoc टैब, "नई लाइब्रेरी ..." बटन पर क्लिक करें।

Step 4 - दर्ज करें JOGLJavadocनाम दें। (आप किसी भी वांछित नाम को दर्ज कर सकते हैं।)

Step 5 - "जार / लाइब्रेरी जोड़ें ..." बटन पर क्लिक करें।

Step 6 - जहां अनजिप किया गया है, उस पथ का चयन करें JOGL documentation कोड स्थित है।

मूल पुस्तकालयों का स्रोत कोड जोड़ना

Step 1 - के तहत Sourcesटैब, "नई लाइब्रेरी ..." बटन पर क्लिक करें। दर्जJOGLsources नाम दें।

Step 2- "जार / लाइब्रेरी जोड़ें ..." बटन पर क्लिक करें। उस पथ का चयन करें जहां अनज़िप्ड सोर्स कोड स्थित है।

JDK संपादक को अनुकूलित करना

Step 1 - सेट करें Classpath फ़ाइलों के लिए jogl.all.jar तथा gluegen-rt.jar.

Step 2- देशी पुस्तकालयों के लिए सेट पथ gluegen-RT-मूल निवासी-windowsamd64.jar और joglall-मूल निवासी-windowsamd64.jar या जहाँ आप उन्हें में डाउनलोड किया है और उन्हें पेस्ट है फ़ोल्डर से सभी जार फ़ाइलों की प्रतिलिपिjse lib फ़ोल्डर।

JOGL प्रोग्रामिंग का उपयोग करते हुए, विभिन्न ग्राफिकल आकृतियों जैसे कि सीधी रेखाएं, त्रिकोण, 3D आकृतियों को विशेष रूप से खींचना संभव है जैसे कि रोटेशन, प्रकाश व्यवस्था, रंग आदि। JOGL में वस्तुओं को आकर्षित करने के लिए सबसे पहले हमें एक JOGL फ्रेम का निर्माण करना होगा। । नीचे दिए गए वर्गों को एक मूल फ्रेम बनाने की आवश्यकता है।

GLEventListener इंटरफ़ेस

अपने प्रोग्राम को JOGL ग्राफिकल एपीआई का उपयोग करने में सक्षम बनाने के लिए, आपको लागू करने की आवश्यकता है GLEventListenerइंटरफेस। आप पा सकते हैंGLEventListener में इंटरफ़ेस javax.media.opengl पैकेज।

निम्न तालिका विभिन्न तरीकों और विवरणों का विवरण प्रदान करती है GLEventListener इंटरफ़ेस -

अनु क्रमांक। तरीके और विवरण
1

Void display(GLAutoDrawable drawable)

यह GLAutoDrawable इंटरफ़ेस के ऑब्जेक्ट द्वारा क्लाइंट द्वारा OpenGL रेंडरिंग शुरू करने के लिए कहा जाता है। यानी, इस पद्धति में ओपनजीएल एपीआई का उपयोग करके ग्राफिकल तत्वों को खींचने के लिए उपयोग किए जाने वाले तर्क शामिल हैं।

2

Void dispose(GLAutoDrawable drawable)

यह विधि श्रोता को प्रत्येक GLContext, जैसे मेमोरी बफ़र और जीएलएसएल प्रोग्राम्स के अनुसार सभी ओएनजीसीएल संसाधनों की रिलीज़ करने के लिए संकेत देती है।

3

Void init(GLAutoDrawble drawable)

OpenGL संदर्भ प्रारंभ होने के तुरंत बाद GLAutoDrawable इंटरफ़ेस की ऑब्जेक्ट द्वारा इसे कॉल किया जाता है।

4

Void reshape(GLAutoDrawble drawble, int x, int y, int width, int height)

घटक के आकार बदलने के बाद पहली बार पुनरावृत्ति के दौरान GLAutoDrawable इंटरफ़ेस के ऑब्जेक्ट द्वारा इसे कॉल किया जाता है। यह भी कहा जाता है जब भी खिड़की पर घटक की स्थिति बदल जाती है।

के सभी तरीके GLEventListener वस्तु की आवश्यकता है GLAutoDrawable एक पैरामीटर के रूप में इंटरफ़ेस।

GLAutoDrawable इंटरफ़ेस

यह इंटरफ़ेस ईवेंट-आधारित तंत्र की आपूर्ति करता है (GLEventListener) OpenGL रेंडरिंग करने के लिए। GLAutoDrawable स्वचालित रूप से एक प्राथमिक प्रतिपादन प्रसंग बनाता है जो इससे जुड़ा होता है GLAutoDrawable वस्तु के जीवनकाल के लिए।

निम्न तालिका विभिन्न तरीकों और विवरणों का विवरण प्रदान करती है GLAutoDrawable इंटरफ़ेस -

अनु क्रमांक तरीके और विवरण
1

GL getGL()

GL पाइपलाइन की वह वस्तु लौटाता है जिसका उपयोग GLAutoDrawable इंटरफ़ेस की वर्तमान वस्तु द्वारा किया जाता है।

2

void addGLEventListener(GLEventListener Listener)

दी गई श्रोता को वर्तमान आकर्षित करने योग्य कतार के अंत में जोड़ता है।

3

void addGLEventListener(int index, GLEventListener listener)

दिए गए श्रोता को इस आहरण योग्य कतार के दिए गए सूचकांक में जोड़ता है।

4

void destroy()

Destroys GLAutoDrawable इंटरफ़ेस के इस ऑब्जेक्ट से जुड़े सभी संसाधन, जिसमें GLContext भी शामिल है।

Note- इस पैकेज में अन्य तरीके हैं। इस इंटरफ़ेस में टेम्पलेट से संबंधित केवल कुछ महत्वपूर्ण तरीकों पर चर्चा की गई है।

GLCanvas क्लास

GLCanvas तथा GLJpanel JOGL GUI के दो मुख्य वर्ग हैं जो लागू होते हैं GLAutoDrawable इंटरफ़ेस, जिसका उपयोग OpenGL कमांड के लिए ड्राइंग सतहों के रूप में किया जा सकता है।

GLCanvas एक हैवीवेट AWT कंपोनेंट है जो OpenGL रेंडरिंग सपोर्ट प्रदान करता है। यह एक का प्राथमिक कार्यान्वयन हैAWTAutoGLDrawableइंटरफेस। यह विरासत में भी मिलता हैjava.awt.Canvasकक्षा। चूंकि यह कुछ मामलों में एक हेवीवेट घटक है,GLJCanvasस्विंग कंपोनेंट के साथ सही तरीके से एकीकरण नहीं हो सकता इसलिए, स्विंग के साथ इसका उपयोग करते समय सावधानी बरतनी चाहिए। जब भी आपको समस्याओं का सामना करना पड़ता हैGLJCanvas, तो आप का उपयोग करना चाहिए GLJPanel कक्षा।

वर्ग का श्रेणीबद्ध चित्र GLCanvas नीचे दिखाया जा सकता है -

  • GLEventistener इंटरफ़ेस साथ काम करता है GLCanvasकक्षा। यह परिवर्तनों के प्रति प्रतिक्रिया करता हैGLCanvas कक्षा और उनके द्वारा किए गए ड्राइंग अनुरोधों के लिए।

  • जब कभी GLCanvas वर्ग त्वरित है, init() उसकि विधि GLEventListenerआह्वान किया गया है। आप OpenGL स्थिति को प्रारंभ करने के लिए इस विधि को ओवरराइड कर सकते हैं।

  • जब कभी GLCanvas शुरू में (तात्कालिक) या आकार बदल दिया जाता है, reshape() उसकि विधि GLEventListenerनिष्पादित किया जाता है। इसका उपयोग ओपनजीएल व्यूपोर्ट और प्रोजेक्शन मैट्रिक्स को शुरू करने के लिए किया जाता है। जब भी घटक का स्थान बदला जाता है, तो इसे भी कहा जाता है।

  • प्रदर्शन () विधि GLEventListener3 डी दृश्य प्रदान करने के लिए कोड शामिल है। इसे जब भी प्रदर्शित किया जाता है () विधिGLCanvas आह्वान किया गया है।

नीचे दिए गए कंस्ट्रक्टर GLCanvas क्लास को तत्काल करने के लिए आवश्यक हैं।

अनु क्रमांक कंस्ट्रक्टर और विवरण
1

GLCanvas()

यह डिफ़ॉल्ट स्क्रीन डिवाइस पर डिफ़ॉल्ट OpenGL क्षमताओं के चयन तंत्र का उपयोग करते हुए, OpenGL क्षमताओं के डिफ़ॉल्ट सेट के साथ एक नया GLCanvas घटक बनाता है।

2

GLCanvas(GLCapabilitiesImmutable)

यह डिफ़ॉल्ट स्क्रीन डिवाइस पर डिफ़ॉल्ट ओपनजीएल क्षमताओं के चयन तंत्र का उपयोग करके ओपनजीएल क्षमताओं के अनुरोध किए गए सेट के साथ एक नया जीएलसीनवास घटक बनाता है।

नीचे दिए गए तरीके GLCanvas क्लास के इवेंट हैंडलिंग के लिए उपयोग किए गए हैं।

अनु क्रमांक। तरीके और विवरण
1

void addGLEventListener(GLEventListener listener)

दिए गए श्रोता को इस आकर्षक कतार के अंत में जोड़ता है।

2

void addGLEventListener(int indexGLEventListener listener)

दिए गए श्रोता को इस आहरण योग्य कतार के दिए गए सूचकांक में जोड़ता है।

इन्स्तांत करना GLCanvas वर्ग, आपको वस्तु की आवश्यकता है GLCapabilitiesImmutable इंटरफ़ेस, जो ओपनजीएल क्षमताओं के एक अपरिवर्तनीय सेट को निर्दिष्ट करता है।

किसी वस्तु को प्राप्त करने के तरीकों में से एक CapabilitiesImmutable इंटरफ़ेस तुरंत करना है GLCapabilitiesवर्ग, जो इंटरफ़ेस को लागू करता है। का उदाहरण हैGLCapabilities कक्षा का उपयोग उद्देश्य की पूर्ति के लिए किया जा सकता है।

GLCapabilities वर्ग

यह वर्ग OpenGL क्षमताओं का एक सेट निर्दिष्ट करता है। यह पैरामीटर के रूप में GLCapabilities ऑब्जेक्ट लेता है। GLCapabilities वर्ग वांछित क्षमताओं का वर्णन करता है जो एक प्रतिपादन संदर्भ का समर्थन करना चाहिए, जैसे कि ओपनजीएल प्रोफाइल।

नीचे दिया गया GLCapabilities वर्ग को तत्काल करने के लिए एक कंस्ट्रक्टर है

अनु क्रमांक। तरीके और विवरण
1

GLCapabilities(GLProfile glprofile)

यह एक GLCapabilities ऑब्जेक्ट बनाता है।

इन्स्तांत करना GLCanvas वर्ग, आपको GLCapabilitiesImmutable इंटरफ़ेस की एक वस्तु की आवश्यकता है, जो OpenGL क्षमताओं के एक अपरिवर्तनीय सेट को निर्दिष्ट करता है।

किसी वस्तु को प्राप्त करने के तरीकों में से एक CapabilitiesImmutable इंटरफ़ेस तुरंत करना है GLCapabilitiesवर्ग, जो इंटरफ़ेस को लागू करता है। का उदाहरण हैGLCapabilities कक्षा का उपयोग उद्देश्य की पूर्ति के लिए किया जा सकता है।

GLCapabilities बदले में वर्ग की आवश्यकता है GLProfile वस्तु।

GLProfile वर्ग

चूंकि ओपनजीएल एपीआई के कई संस्करण जारी किए गए थे; आपको अपने प्रोग्राम में उपयोग किए जा रहे OpenGL API के सटीक संस्करण को अपने जावा वर्चुअल मशीन (JVM) में निर्दिष्ट करने की आवश्यकता है। यह प्रयोग किया जाता हैGLProfile कक्षा।

get() इस वर्ग की पद्धति विभिन्न पूर्वनिर्धारित स्वीकार करती है Stringपैरामीटर के रूप में ऑब्जेक्ट। प्रत्येक स्ट्रिंग ऑब्जेक्ट एक इंटरफ़ेस का नाम है और प्रत्येक इंटरफ़ेस OpenGL के कुछ संस्करणों का समर्थन करता है। यदि आप इस क्लास को स्टेटिक और सिंगलटन के रूप में इनिशियलाइज़ करते हैं, तो यह आपको सिंगलटन देता हैGLProfile प्रत्येक उपलब्ध JOGL प्रोफ़ाइल के लिए ऑब्जेक्ट।

नीचे दिए गए GLProfile वर्ग की विधि का प्रोटोटाइप है।

अनु क्रमांक। विधि और विवरण
1

Static GLProfile get(String profile)

डिफ़ॉल्ट डिवाइस का उपयोग करता है।

चूंकि यह एक स्थिर विधि है, इसलिए आपको इसे क्लास नाम का उपयोग करके इनवॉइस करने की आवश्यकता है, और इसके लिए पैरामीटर के रूप में पूर्वनिर्धारित स्टेटिक स्ट्रिंग चर की आवश्यकता होती है। इस वर्ग में 12 ऐसे चर हैं, प्रत्येक जीएल इंटरफ़ेस के एक व्यक्तिगत कार्यान्वयन का प्रतिनिधित्व करता है।

GLProfile.get(GLProfile.GL2);

प्राप्त करने के पैरामीटर () विधि

अनु क्रमांक पूर्वनिर्धारित स्ट्रिंग मूल्य (इंटरफ़ेस नाम) और विवरण
1

GL2

इस इंटरफ़ेस में सभी OpenGL [1.0… 3.0] विधियां हैं और साथ ही साथ इस विनिर्देश के समय इसके अधिकांश एक्सटेंशन परिभाषित हैं।

2

GLES1

इस इंटरफ़ेस में सभी OpenGL ES [1.0 ... 1.1] विधियाँ हैं और साथ ही इस विनिर्देश के समय इसके अधिकांश एक्सटेंशन भी परिभाषित हैं।

3

GLES2

इस इंटरफ़ेस में सभी OpenGL ES 2.0 विधियाँ हैं और साथ ही इसके अधिकांश विस्तार इस विनिर्देशन के समय परिभाषित किए गए हैं।

4

GLES3

इस इंटरफ़ेस में सभी OpenGL ES 3.0 विधियां हैं और साथ ही इस विनिर्देश के समय इसके अधिकांश एक्सटेंशन परिभाषित हैं।

5

GL2ES1

इस इंटरफ़ेस में GL2 और GLES1 का सामान्य सबसेट है।

6

GL2ES2

इस इंटरफ़ेस में GL3, GL2 और GLES2 का सामान्य सबसेट है।

7

GL2GL3

इस इंटरफ़ेस में कोर GL3 (OpenGL 3.1+) और GL2 का सामान्य सबसेट है।

8

GL3

इस इंटरफ़ेस में सभी OpenGL [3.1 ... 3.3] कोर विधियाँ हैं और साथ ही साथ इसके अधिकांश विस्तार इस विनिर्देशन के समय परिभाषित किए गए हैं।

9

GL3bc

इस इंटरफ़ेस में सभी OpenGL [3.1 ... 3.3] संगतता विधियाँ हैं, साथ ही इसके अधिकांश विस्तार इस विनिर्देश के समय परिभाषित किए गए हैं।

10

GL3ES3

इस इंटरफ़ेस में कोर GL3 (OpenGL 3.1+) और GLES3 (OpenGL ES 3.0) के सामान्य उपसमूह शामिल हैं।

1 1

GL4

इस इंटरफ़ेस में सभी OpenGL [4.0 ... 4.3] मुख्य विधियाँ हैं, साथ ही इसके अधिकांश विस्तार इस विनिर्देश के समय परिभाषित किए गए हैं।

12

GL4bc

इस इंटरफ़ेस में सभी OpenGL [4.0 ... 4.3] संगतता प्रोफ़ाइल है , साथ ही साथ इसके अधिकांश एक्सटेंशन इस विनिर्देश के समय परिभाषित किए गए हैं।

13

GL4ES3

कोर GL4 (OpenGL 4.0+) और GLES3 (OpenGL ES 3.0) के सामान्य सबसेट वाले इंटरफ़ेस।

GLJPanel क्लास

यह एक हल्का स्विंगिंग घटक है जो ओपनजीएल रेंडरिंग सपोर्ट प्रदान करता है। यह स्विंग के साथ संगतता के लिए प्रदान किया जाता है।

GLJPanel वर्ग पदानुक्रम

नीचे दिया गया चित्र आरेख GLJPanel वर्ग के श्रेणी पदानुक्रम का प्रतिनिधित्व करता है।

नीचे दिए गए विभिन्न कंस्ट्रक्टर GLJPanel क्लास हैं।

अनु क्रमांक। कंस्ट्रक्टर और विवरण
1

GJPanel()

यह OpenGL क्षमताओं के डिफ़ॉल्ट सेट के साथ एक नया GLJPanel घटक बनाता है।

2

(GLCapabilitiesImmutable)

यह OpenGL क्षमताओं के अनुरोधित सेट के साथ एक नया GLJPanel घटक बनाता है।

3

GLJPanel(GLCapabilitiesImmutable userCapsRequest, GLCapabilitiesChooser chooser)

यह एक नया GLJPanel घटक बनाता है।

नीचे दिए गए GLJPanel वर्ग के तरीके हैं।

अनु क्रमांक। तरीके और विवरण
1

void addGLEventListener(GLEventListener listener)

यह विधि दी गई श्रोता को इस आकर्षित करने योग्य कतार के अंत में जोड़ती है।

2

void addGLEventListener(int indexGLEventListener listener)

यह विधि दी गई श्रोता को इस आकर्षित करने योग्य कतार के दिए गए सूचकांक में जोड़ती है।

यह अध्याय आपको बताता है कि AWT फ्रेम के साथ कैनवास का उपयोग करके एक JOGL बुनियादी फ्रेम कैसे बनाया जाए। यहाँ हम एक AWT फ्रेम का निर्माण करेंगे और AWT फ्रेम का उपयोग करके कैनवस ऑब्जेक्ट को जोड़ेंगेadd() फ्रेम वर्ग की विधि।

नीचे दिए गए प्रोग्राम को लिखने के लिए चरण हैं जो JOGL के कैनवास वर्ग और AWT के फ़्रेम वर्ग के संयोजन के साथ एक JOGL मूल फ़्रेम बनाता है।

Step1: क्लास बनाना

प्रारंभ में एक ऐसा वर्ग बनाएं जो लागू करता हो GlEventListenerइंटरफ़ेस और पैकेज javax.media.opengl आयात करें। सभी चार तरीकों को लागू करेंdisplay(), dispose(), reshape(), init().चूँकि यह मूल फ्रेम है, इसलिए आदिम कार्य जैसे कैनवास क्लास बनाना, इसे फ्रेम में जोड़ना चर्चा की गई। सबGLEVentListener इंटरफ़ेस विधियों को लागू नहीं किया गया था।

चरण 2: कैनवास तैयार करना

(a) निर्माण करना GLCanvas वर्ग वस्तु

final GLCanvas glcanvas = new GLCanvas( xxxxxxx );

//here capabilities obj should be passed as parameter

(b) तात्कालिकता GLCapabilities कक्षा

GLCapabilities capabilities = new GLCapabilities( xxxxx );

//here profile obj should be passed as parameter

(c) उत्पादक GLProfile वस्तु

जैसा कि यह स्थैतिक विधि है, इसे वर्ग नाम का उपयोग करके किया जाता है। चूंकि यह ट्यूटोरियल JOGL2 के बारे में है, इसलिए हम GL2 इंटरफ़ेस ऑब्जेक्ट जेनरेट करते हैं।

final GLProfile profile = GLProfile.get( GLProfile.GL2 );

// both, variable and method are static hence both are called using class name.

आइए हम कैनवास के लिए कोड स्निपेट देखते हैं।

//getting the capabilities object of GL2 profile

final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);

// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);

(d) अब जोड़ें GLEventListener विधि का उपयोग करके कैनवास पर addGLEventListener()। इस विधि को वस्तु की आवश्यकता हैGLEventListenerपैरामीटर के रूप में इंटरफ़ेस। इसलिए, लागू होने वाले वर्ग के ऑब्जेक्ट को पास करेंGLEventListener

BasicFrame basicframe = newBasic Frame( );// class which implements
GLEventListener interface
glcanvas.addGLEventListener( basicframe );

(e) फ्रेम के सेट का उपयोग कर सेट करें आकार () विधि GLCanvas द्वारा javax.media.opengl.awt.AWTGLAutoDrawable से विरासत में मिली।

glcanvas.setSize( 400, 400 );

अब आप के साथ तैयार हैं GLCanvas

Step3: फ़्रेम बनाना

फ्रेम को तत्काल बनाकर बनाएँ Frame JSE AWT फ्रेम कंपोनेंट का क्लास ऑब्जेक्ट।

इसमें कैनवास जोड़ें और फ्रेम को दृश्यमान बनाएं।

//creating frame
final Frame frame = new frame( " Basic Frame" );

//adding canvas to frame
frame.add( glcanvas );
frame.setVisible( true );

चरण 4: पूर्ण स्क्रीन में फ़्रेम देखना

पूर्ण स्क्रीन में फ़्रेम देखने के लिए, डिफ़ॉल्ट स्क्रीन आकार का उपयोग करें java.awt.Toolkitकक्षा। अब, उन डिफ़ॉल्ट स्क्रीन आकार आयामों का उपयोग करके, फ्रेम आकार का उपयोग करके सेट करेंsetSize() तरीका।

Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
frame.setSize(screenSize.width, screenSize.height);

आइए हम AWT का उपयोग करके मूल फ्रेम बनाने के लिए कार्यक्रम के माध्यम से चलते हैं -

import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;

import javax.swing.JFrame;

public class BasicFrame implements GLEventListener {

   @Override
   public void display(GLAutoDrawable arg0) {
      // method body
   }
	
   @Override
   public void dispose(GLAutoDrawable arg0) {
      //method body
   }
	
   @Override
   public void init(GLAutoDrawable arg0) {
      // method body
   }
	
   @Override
   public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
      // method body
   }
	
   public static void main(String[] args) {
   
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);
        
      // The canvas
      final GLCanvas glcanvas = new GLCanvas(capabilities);
      BasicFrame b = new BasicFrame();
      glcanvas.addGLEventListener(b);        
      glcanvas.setSize(400, 400);
        
      //creating frame
      final Frame frame = new Frame (" Basic Frame");
        
      //adding canvas to frame
      frame.add(glcanvas);
      frame.setSize( 640, 480 );
      frame.setVisible(true);
   }
	
}

यदि आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है। जब हम उपयोग करते हैं तो यह एक आधारभूत फ्रेम का गठन करता हैGLCanvas AWT के साथ वर्ग -

यह अध्याय आपको बताता है कि JOGL के आधारभूत फ्रेम का उपयोग कैसे करें Canvas, तथा JFramejavax.swing पैकेज की कक्षा। यहाँ हम एक JFrame को इंस्टाल करेंगे और कैनवास ऑब्जेक्ट को JFrame के उदाहरण से जोड़ेंगेadd() तरीका।

एडब्ल्यूटी के साथ कैनवस का उपयोग करना आपको हेवीवेट विशेषताओं के साथ एक ग्राफिकल फ्रेम प्रदान करता है। हल्के ग्राफिकल फ्रेम होने के लिए, आपको उपयोग करने की आवश्यकता हैGLCanvasस्विंग के साथ। प्रयोग करते समयGLCanvas स्विंग के साथ, आप जगह कर सकते हैं GLCanvas में JFrame खिड़की सीधे, या आप इसे करने के लिए जोड़ सकते हैं JPanel

नीचे दिया गया कार्यक्रम है जो JOGL के संयोजन के साथ एक JOGL मूल फ्रेम बनाता है GLCanvas वर्ग और JFramejavax.swing पैकेज की कक्षा ।

import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;

import javax.swing.JFrame;

public class BasicFrame implements GLEventListener {

   @Override
   public void display(GLAutoDrawable arg0) {
      // method body
   }
	
   @Override
   public void dispose(GLAutoDrawable arg0) {
      //method body
   }
	
   @Override
   public void init(GLAutoDrawable arg0) {
      // method body
   } 
	
   @Override
   public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
      // method body
   }
	
   public static void main(String[] args) {
   
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);
               
      // The canvas
      final GLCanvas glcanvas = new GLCanvas(capabilities);
      BasicFrame b = new BasicFrame();
      glcanvas.addGLEventListener(b);
      glcanvas.setSize(400, 400);
		
      //creating frame
      final JFrame frame = new JFrame (" Basic Frame");
		
      //adding canvas to it
      frame.getContentPane().add(glcanvas);
      frame.setSize(frame.getContentPane().getPreferredSize());
      frame.setVisible(true);
      
   }//end of main
	
}//end of classimport

यदि आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है। जब हम उपयोग करते हैं तो यह एक आधारभूत फ्रेम का गठन करता हैGLCanvas स्विंग खिड़की के साथ।

यह अध्याय आपको बताता है कि GLJpanel वर्ग का उपयोग करके JOGL बुनियादी फ्रेम कैसे बनाया जाए। यह एक हल्का स्विंगिंग घटक है जो ओपनजीएल रेंडरिंग सपोर्ट प्रदान करता है। यह स्विंग के साथ संगतता के लिए प्रदान किया जाता है। यहाँ हम एक JFrame को इंस्टाल करेंगे और GLJpanel ऑब्जेक्ट को JFrame के उदाहरण से जोड़कर उपयोग करेंगेadd() तरीका।

निम्न प्रोग्राम का उपयोग कर एक मूल फ्रेम उत्पन्न करता है GLJPanel झूला खिड़की के साथ -

import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;

import javax.swing.JFrame;

public class BasicFrame implements GLEventListener {

   @Override
   public void display(GLAutoDrawable arg0) {
      // method body
   }
   
   @Override
   public void dispose(GLAutoDrawable arg0) {
      //method body
   }
   
   @Override
   public void init(GLAutoDrawable arg0) {
      // method body
   }
   
   @Override
   public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
      // method body
   }
   
   public static void main(String[] args) {
   
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);
      
      // The GLJpanel class
      GLJPanel gljpanel = new GLJPanel( glcapabilities ); 
      BasicFrame b = new BasicFrame();
      gljpanel.addGLEventListener(b);
      gljpanel.setSize(400, 400);
      
      //creating frame
      final JFrame frame = new JFrame (" Basic Frame");
      
      //adding canvas to it
      frame.getContentPane().add( gljpanel);
      frame.setSize(frame.getContentPane().getPreferredSize());
      frame.setVisible(true);
      
   }//end of main
	
}//end of classimport

यदि आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है। जब हम उपयोग करते हैं तो यह एक आधारभूत फ्रेम का गठन करता हैGLJPanel स्विंग विंडो के साथ -

ओपनजीएल एपीआई ने मूल ग्राफिकल तत्वों जैसे बिंदु, शीर्ष, रेखा आदि को खींचने के लिए आदिम तरीके प्रदान किए हैं। इन विधियों का उपयोग करके, आप त्रिकोण, बहुभुज और वृत्त जैसी आकृतियों को विकसित कर सकते हैं। दोनों में, 2 डी और 3 डी आयाम। यह अध्याय आपको सिखाता है कि जावा प्रोग्राम में JOGL का उपयोग करके एक मूल रेखा कैसे बनाई जाए।

वस्तुओं को खींचना

उन प्रोग्रामों तक पहुँचने के लिए जो एक हार्डवेयर और ऑपरेटिंग सिस्टम प्लेटफ़ॉर्म के लिए विशिष्ट हैं और जहाँ लाइब्रेरियों को C और C ++ (देशी एप्लिकेशन) जैसी अन्य भाषाओं में लिखा जाता है, जावा नामक एक प्रोग्रामिंग फ्रेमवर्क का उपयोग करता है Java Native Interface (JNI)। JOGL इस इंटरफेस का उपयोग आंतरिक रूप से OpenGL फ़ंक्शन को एक्सेस करने के लिए करता है जैसा कि निम्नलिखित चित्र में दिखाया गया है।

के सभी चार तरीके GLEventListenerइंटरफ़ेस में OpenGL फ़ंक्शन को आंतरिक रूप से कॉल करने के लिए कोड (जावा JOGL तरीके) हैं। उन JOGL विधियों का नामकरण भी OpenGL के नामकरण सम्मेलनों के समान है। यदि OpenGL में फ़ंक्शन का नाम हैglBegin(), यह के रूप में प्रयोग किया जाता है gl.glBegin()

जब भी gl.glBegin() जावा JOGL की विधि को कहा जाता है, यह आंतरिक रूप से आह्वान करती है glBegin()ओपनजीएल की विधि। JOGL को स्थापित करने के समय उपयोगकर्ता सिस्टम पर मूल लाइब्रेरी फ़ाइलों को स्थापित करने का यही कारण है।

प्रदर्शन () विधि

यह एक महत्वपूर्ण विधि है जो विकासशील ग्राफिक्स के लिए कोड रखती है। इसकी आवश्यकता हैGLAutoDrawable इंटरफ़ेस ऑब्जेक्ट इसके पैरामीटर के रूप में।

display()विधि शुरू में GL इंटरफ़ेस का उपयोग करके OpenGL संदर्भ प्राप्त करती है (GL ने GLBase इंटरफ़ेस को इनहेरिट किया है, जिसमें सभी OpenGL संदर्भ ऑब्जेक्ट उत्पन्न करने के तरीके शामिल हैं)। चूंकि यह ट्यूटोरियल JOGL2 के बारे में है, इसलिए हम GL2 ऑब्जेक्ट जेनरेट करते हैं।

निम्न कोड स्निपेट दिखाता है कि GL2 ऑब्जेक्ट कैसे बनाया जाता है -

//Generating GL object
GL gl = drawable.getGL();
GL gl = drawable.getGL();

//Using this Getting the Gl2 Object
//this can be written in a single line like
final GL2 gl = drawable.getGL().getGL2();

GL2 इंटरफ़ेस के ऑब्जेक्ट का उपयोग करते हुए, कोई भी इस इंटरफ़ेस के सदस्यों तक पहुंच सकता है, जो ओपनजीएल [1.0 ... 3.0] कार्यों तक पहुंच प्रदान करता है।

रेखा खींचना

GL2 इंटरफ़ेस में विधियों की एक विशाल सूची है, लेकिन यहाँ तीन मुख्य महत्वपूर्ण तरीकों पर चर्चा की गई है glBegin(), glVertex(), तथा glEnd()

अनु क्रमांक। तरीके और विवरण
1

glBegin()

यह विधि एक रेखा खींचने की प्रक्रिया शुरू करती है। यह पूर्वनिर्धारित स्ट्रिंग पूर्णांक "GL_LINES" को एक पैरामीटर के रूप में लेता है, जिसे GL इंटरफ़ेस से विरासत में मिला है।

2

glVertex3f()/glVertex2f()

यह विधि शीर्ष बनाता है और हमें निर्देशांक 3f और 2f के मापदंडों के रूप में पास करना होता है, जो क्रमशः 3-आयामी फ्लोटिंग पॉइंट निर्देशांक और 2-आयामी फ़्लोटिंग पॉइंट निर्देशांक को दर्शाता है।

3

glEnd()

लाइन को समाप्त करता है

नीचे JOGL का उपयोग करके एक मूल रेखा खींचने का कार्यक्रम दिया गया है -

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;

import javax.swing.JFrame;

public class Line implements GLEventListener{

   @Override
   public void display(GLAutoDrawable drawable) {
      final GL2 gl = drawable.getGL().getGL2();
            
      gl.glBegin (GL2.GL_LINES);//static field
      gl.glVertex3f(0.50f,-0.50f,0);
      gl.glVertex3f(-0.50f,0.50f,0);
      gl.glEnd();

   }
            
   @Override
   public void dispose(GLAutoDrawable arg0) {
      //method body
   }
            
   @Override
   public void init(GLAutoDrawable arg0) {
      // method body
   }
	
   public static void main(String[] args) {

      //getting the capabilities object of GL2 profile        
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);
   
      // The canvas
      final GLCanvas glcanvas = new GLCanvas(capabilities);
      Line l = new Line();
      glcanvas.addGLEventListener(l);
      glcanvas.setSize(400, 400);
   
      //creating frame
      final JFrame frame = new JFrame ("straight Line");
   
      //adding canvas to frame
      frame.getContentPane().add(glcanvas);
                 
      frame.setSize(frame.getContentPane().getPreferredSize());
      frame.setVisible(true);
      
   }//end of main
	
}//end of classimport javax.media.opengl.GL2;

पिछले अध्याय में हमने सीखा है कि JOGL का उपयोग करके एक मूल रेखा कैसे बनाई जाती है। हम एक पूर्वनिर्धारित क्षेत्र को पास करके रेखाएँ बनाते हैं,Gl_linesto glBegin () विधि।

यह अध्याय glBegin () विधि और GL_Lines का उपयोग करके त्रिकोण, रोम्बस और एक घर जैसी आकृतियों को बनाने के लिए उदाहरण प्रदान करता है।

हमें GL_LINES का उपयोग करके एक त्रिभुज बनाने के लिए एक कार्यक्रम के माध्यम से जाने -

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;

import javax.swing.JFrame;

public class Triangle implements GLEventListener{

   @Override
   public void display(GLAutoDrawable drawable) {
      final GL2 gl = drawable.getGL().getGL2();
      gl.glBegin (GL2.GL_LINES);
   
      //drawing the base
      gl.glBegin (GL2.GL_LINES);
      gl.glVertex3f(-0.50f, -0.50f, 0);
      gl.glVertex3f(0.50f, -0.50f, 0);
      gl.glEnd();
   
      //drawing the right edge
      gl.glBegin (GL2.GL_LINES);
      gl.glVertex3f(0f, 0.50f, 0);
      gl.glVertex3f(-0.50f, -0.50f, 0);
      gl.glEnd();
   
      //drawing the lft edge
      gl.glBegin (GL2.GL_LINES);
      gl.glVertex3f(0f, 0.50f, 0);
      gl.glVertex3f(0.50f, -0.50f, 0);
      gl.glEnd();
      gl.glFlush();
   }
   
   @Override
   public void dispose(GLAutoDrawable arg0) {
      //method body
   }
   
   @Override
   public void init(GLAutoDrawable arg0) {
      // method body
   }
   
   @Override
   public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
      // method body
   }
   
   public static void main(String[] args) {
      
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);
   
      // The canvas
      final GLCanvas glcanvas = new GLCanvas(capabilities);
      Triangle l = new Triangle();
      glcanvas.addGLEventListener(l);
      glcanvas.setSize(400, 400);
   
      //creating frame
      final JFrame frame = new JFrame ("Triangle");
   
      //adding canvas to frame
      frame.getContentPane().add(glcanvas);
          
      frame.setSize(frame.getContentPane().getPreferredSize());
      frame.setVisible(true);
      
   }//end of main
	
}//end of classimport javax.media.opengl.GL2;

यदि आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है। यह GL_LINES ऑफ़ का उपयोग करके खींची गई एक त्रिकोण दिखाता हैglBegin() तरीका।

आइए हम GL_LINES का उपयोग करते हुए एक समभुज बनाने के लिए एक कार्यक्रम के माध्यम से चलते हैं -

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;

import javax.swing.JFrame;

public class Rhombus implements GLEventListener{

   @Override
   public void display( GLAutoDrawable drawable ) {
      final GL2 gl = drawable.getGL().getGL2();
      
      //edge1  
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( 0.0f,0.75f,0 );
      gl.glVertex3f( -0.75f,0f,0 );
      gl.glEnd();
      
      //edge2
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( -0.75f,0f,0 );
      gl.glVertex3f( 0f,-0.75f, 0 );
      gl.glEnd();
      
      //edge3
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( 0f,-0.75f, 0 );
      gl.glVertex3f( 0.75f,0f, 0 );
      gl.glEnd();
      
      //edge4
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( 0.75f,0f, 0 );
      gl.glVertex3f( 0.0f,0.75f,0 );
      gl.glEnd();
      gl.glFlush();
   }
	
   @Override
   public void dispose( GLAutoDrawable arg0 ) {
      //method body
   }
	
   @Override
   public void init(GLAutoDrawable arg0 ) {
      // method body
   }
	
   @Override
   public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
      // method body
   }
	
   public static void main( String[] args ) {
	
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get( GLProfile.GL2 );
      GLCapabilities capabilities = new GLCapabilities(profile);
      
      // The canvas
      final GLCanvas glcanvas = new GLCanvas( capabilities );
      Rhombus rhombus = new Rhombus();
      glcanvas.addGLEventListener( rhombus );
      glcanvas.setSize( 400, 400 );
      
      //creating frame
      final JFrame frame = new JFrame ( "Rhombus" );
      
      //adding canvas to frame
      frame.getContentPane().add( glcanvas );
      frame.setSize(frame.getContentPane().getPreferredSize() );
      frame.setVisible( true );
   }
	
}

यदि आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो आपको निम्न आउटपुट मिलते हैं। यह GL_LINES के उपयोग से उत्पन्न एक प्रकंद दिखाता हैglBegin() तरीका।

हमें GL_LINES का उपयोग करके एक घर बनाने के लिए एक कार्यक्रम के माध्यम से जाने -

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;

import javax.swing.JFrame;

public class House implements GLEventListener{

   @Override
   public void display( GLAutoDrawable drawable ) {
      final GL2 gl = drawable.getGL().getGL2();
      
      //drawing top
      gl.glBegin ( GL2.GL_LINES );
      gl.glVertex3f( -0.3f, 0.3f, 0 );
      gl.glVertex3f( 0.3f,0.3f, 0 );
      gl.glEnd();
      
      //drawing bottom
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( -0.3f,-0.3f, 0 );
      gl.glVertex3f( 0.3f,-0.3f, 0 );
      gl.glEnd();
      
      //drawing the right edge
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( -0.3f,0.3f, 0 );
      gl.glVertex3f( -0.3f,-0.3f, 0 );
      gl.glEnd();
      
      //drawing the left edge
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( 0.3f,0.3f,0 );
      gl.glVertex3f( 0.3f,-0.3f,0 );
      gl.glEnd();
      
      //building roof
      //building lft dia
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( 0f,0.6f, 0 );
      gl.glVertex3f( -0.3f,0.3f, 0 );
      gl.glEnd();
      
      //building rt dia
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( 0f,0.6f, 0 );
      gl.glVertex3f( 0.3f,0.3f, 0 );
      gl.glEnd();
      
      //building door
      //drawing top
      gl.glBegin ( GL2.GL_LINES );
      gl.glVertex3f( -0.05f, 0.05f, 0 );
      gl.glVertex3f( 0.05f, 0.05f, 0 );
      gl.glEnd();
      
      //drawing the left edge
      gl.glBegin ( GL2.GL_LINES );
      gl.glVertex3f( -0.05f, 0.05f, 0 );
      gl.glVertex3f( -0.05f, -0.3f, 0 );
      gl.glEnd();
      
      //drawing the right edge
      gl.glBegin ( GL2.GL_LINES );
      gl.glVertex3f( 0.05f, 0.05f, 0 );
      gl.glVertex3f( 0.05f, -0.3f, 0 );
      gl.glEnd();
   }
      
   @Override
   public void dispose( GLAutoDrawable arg0 ) {
      //method body
   }
   
   @Override
   public void init( GLAutoDrawable arg0 ) {
      // method body
   }       
   
   @Override
   public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
      // method body
   }
	
   public static void main( String[] args ) {
   
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get( GLProfile.GL2 );
      GLCapabilities capabilities = new GLCapabilities(profile);
   
      // The canvas
      final GLCanvas glcanvas = new GLCanvas( capabilities );
      House house = new House();
      glcanvas.addGLEventListener( house );
      glcanvas.setSize(400, 400);
   
      //creating frame
      final JFrame frame = new JFrame( "House" );
   
      //adding canvas to frame
      frame.getContentPane().add( glcanvas );
      frame.setSize(frame.getContentPane().getPreferredSize() );
      frame.setVisible( true );
      
   }//end of main
	
}//end of class

यदि आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो आपको निम्न आउटपुट मिलते हैं। यह GL_LINES () विधि का उपयोग करके उत्पन्न एक गृह आरेख दिखाता है।

पिछले अध्यायों में हमने सीखा है कि JOGL का उपयोग करके रेखा, त्रिकोण, रोम्बस जैसी आकृतियाँ कैसे बनाई जाती हैं। हम एक पूर्वनिर्धारित क्षेत्र को पास करके रेखाएँ बनाते हैं,Gl_linesto glBegin () विधि।

के आलावा GL_LINES, को glBegin()विधि आठ और मापदंडों को स्वीकार करती है। आप उन्हें विभिन्न आकृतियों को आकर्षित करने के लिए उपयोग कर सकते हैं। इन्हें GL_LINES के समान उपयोग किया जाता है।

निम्न तालिका से पता चलता है glBegin() उनके विवरण के साथ विधि पैरामीटर -

अनु क्रमांक पैरामीटर और विवरण
1

GL_LINES

एक स्वतंत्र रेखा खंड के रूप में प्रत्येक जोड़ी को जोड़ देता है।

2

GL_LINE_STRIP

पहले शीर्ष से अंतिम तक लाइन खंडों का एक जुड़ा हुआ समूह खींचता है।

3

GL_LINE_LOOP

पहले खंड से अंतिम तक, फिर से पहले पर वापस सेगमेंट के एक जुड़े हुए समूह को खींचता है।

4

GL_TRIANGLES

प्रत्येक त्रिभुज को एक स्वतंत्र त्रिकोण के रूप में मानता है।

5

GL_TRIANGLE_STRIP

त्रिभुजों का एक जुड़ा हुआ समूह बनाता है। पहले दो शीर्षकों के बाद प्रस्तुत प्रत्येक शीर्ष के लिए एक त्रिकोण परिभाषित किया गया है।

6

GL_TRIANGLE_FAN

त्रिभुजों का एक जुड़ा हुआ समूह बनाता है। पहले दो शीर्षकों के बाद प्रस्तुत प्रत्येक शीर्ष के लिए एक त्रिकोण परिभाषित किया गया है।

7

GL_QUADS

एक स्वतंत्र चतुर्भुज के रूप में चार कोने के प्रत्येक समूह को मानते हैं।

8

GL_QUAD_STRIP

चतुर्भुज का एक जुड़ा हुआ समूह बनाता है। पहली जोड़ी के बाद प्रस्तुत प्रत्येक जोड़ी के लिए एक चतुर्भुज परिभाषित किया गया है।

9

GL_POLYGON

एकल, उत्तल बहुभुज बनाता है। कार्यक्षेत्र 1,…, इस बहुभुज को परिभाषित करते हैं।

आइए हम कुछ उदाहरणों का उपयोग करते हुए देखें glBegin() मापदंडों।

रेखा पट्टी खींचने का कार्यक्रम

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;

import javax.swing.JFrame;

public class LineStrip implements GLEventListener{

   @Override
   public void display(GLAutoDrawable drawable) {
   
      final GL2 gl = drawable.getGL().getGL2();
		
      gl.glBegin (GL2.GL_LINE_STRIP);
      gl.glVertex3f(-0.50f,-0.75f, 0);
      gl.glVertex3f(0.7f,0.5f, 0);
      gl.glVertex3f(0.70f,-0.70f, 0);
      gl.glVertex3f(0f,0.5f, 0);
      gl.glEnd();
   }
   
   @Override
   public void dispose(GLAutoDrawable arg0) {
      //method body
   }
   
   @Override
   public void init(GLAutoDrawable arg0) {
      // method body
   }
   
   @Override
   public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
      // method body
   }
   
   public static void main(String[] args) {
   
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);
      
      // The canvas
      final GLCanvas glcanvas = new GLCanvas(capabilities);
      LineStrip r = new LineStrip();
      glcanvas.addGLEventListener(r);
      glcanvas.setSize(400, 400);
      
      //creating frame
      final JFrame frame = new JFrame ("LineStrip");
      
      //adding canvas to frame
      frame.getContentPane().add(glcanvas);
            
      frame.setSize(frame.getContentPane().getPreferredSize());
      frame.setVisible(true);
      
   }//end of main
	
}//end of classimport javax.media.opengl.GL2;

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

लाइन लूप ड्रा करने के लिए डिस्प्ले () विधि के लिए कोड स्निपेट

public void display(GLAutoDrawable drawable) {

   final GL2 gl = drawable.getGL().getGL2();
   
   gl.glBegin (GL2.GL_LINE_LOOP);
   
   gl.glVertex3f( -0.50f, -0.75f, 0);
   gl.glVertex3f(0.7f, .5f, 0);
   gl.glVertex3f(0.70f, -0.70f, 0);
   gl.glVertex3f(0f, 0.5f, 0);
   
   gl.glEnd();
}

यदि आप प्रतिस्थापित करते हैं display() उपरोक्त कोड के साथ बुनियादी टेम्पलेट कार्यक्रमों में से किसी की विधि, इसे संकलित और निष्पादित करना, निम्नलिखित आउटपुट उत्पन्न होता है -

GL_TRIANGLES का उपयोग करके एक त्रिभुज बनाने के लिए प्रदर्शन के लिए कोड स्निपेट () विधि

public void display(GLAutoDrawable drawable) {

   final GL2 gl = drawable.getGL().getGL2();
   
   gl.glBegin(GL2.GL_TRIANGLES);        // Drawing Using Triangles
   
   gl.glVertex3f(0.5f,0.7f,0.0f);       // Top
   gl.glVertex3f(-0.2f,-0.50f,0.0f);    // Bottom Left
   gl.glVertex3f(0.5f,-0.5f,0.0f);      // Bottom Right
   
   gl.glEnd();
}

यदि आप प्रतिस्थापित करते हैं display() उपरोक्त कोड के साथ बुनियादी टेम्पलेट कार्यक्रमों में से किसी की विधि, इसे संकलित और निष्पादित करना, निम्नलिखित आउटपुट उत्पन्न होता है -

प्रदर्शन के लिए कोड स्निपेट () एक त्रिभुज पट्टी खींचने की विधि

public void display(GLAutoDrawable drawable) {

   final GL2 gl = drawable.getGL().getGL2();
   
   gl.glBegin (GL2.GL_TRIANGLE_STRIP);
   
   gl.glVertex3f(0f,0.5f,0);
   gl.glVertex3f(-0.50f,-0.75f,0);
   gl.glVertex3f(0.28f,0.06f,0);
   gl.glVertex3f(0.7f,0.5f,0);
   gl.glVertex3f(0.7f,-0.7f,0);
   
   gl.glEnd();
}

यदि आप प्रतिस्थापित करते हैं display() उपरोक्त कोड के साथ बुनियादी टेम्पलेट कार्यक्रमों में से किसी की विधि, इसे संकलित और निष्पादित करें, निम्न आउटपुट उत्पन्न होता है -

चतुर्भुज बनाने के लिए कोड स्निपेट डिस्प्ले () विधि के लिए

public void display(GLAutoDrawable drawable) {

   final GL2 gl = drawable.getGL().getGL2();
   
   gl.glBegin(GL2.GL_QUADS);
   
   gl.glVertex3f( 0.0f,0.75f,0);
   gl.glVertex3f(-0.75f,0f,0);
   gl.glVertex3f(0f,-0.75f,0);
   gl.glVertex3f(0.75f,0f,0);
   
   gl.glEnd();
}

यदि आप प्रतिस्थापित करते हैं display() उपरोक्त कोड के साथ बुनियादी टेम्पलेट कार्यक्रमों में से किसी की विधि, इसे संकलित और निष्पादित करना, निम्नलिखित आउटपुट उत्पन्न होता है -

बहुभुज बनाने के लिए कोड स्निपेट डिस्प्ले () विधि के लिए

public void display(GLAutoDrawable drawable) {

   final GL2 gl = drawable.getGL().getGL2();
   
   gl.glBegin(GL2.GL_POLYGON);
   
   gl.glVertex3f(0f,0.5f,0f);
   gl.glVertex3f(-0.5f,0.2f,0f);
   gl.glVertex3f(-0.5f,-0.2f,0f);
   gl.glVertex3f(0f,-0.5f,0f);
   gl.glVertex3f(0f,0.5f,0f);
   gl.glVertex3f(0.5f,0.2f,0f);
   gl.glVertex3f(0.5f,-0.2f,0f);
   gl.glVertex3f(0f,-0.5f,0f);
   
   gl.glEnd();
}

यदि आप प्रतिस्थापित करते हैं display() उपरोक्त कोड के साथ बुनियादी टेम्पलेट कार्यक्रमों में से किसी की विधि, इसे संकलित और निष्पादित करना, निम्नलिखित आउटपुट उत्पन्न होता है -

OpenGL अधिक सुविधाएँ प्रदान करता है जैसे ऑब्जेक्ट को रंग लगाना, स्केलिंग, लाइटिंग, ऑब्जेक्ट को घुमाना आदि। इस अध्याय में JOGL का उपयोग करते हुए ऑब्जेक्ट्स पर कुछ परिवर्तनों का वर्णन किया गया है।

विंडो पर किसी ऑब्जेक्ट को ले जाना

पहले के अध्यायों में, हमने एक रेखा खींचने और सरल रेखाओं का उपयोग करके विभिन्न आकृतियों को खींचने के कार्यक्रमों पर चर्चा की। इस तरह से बनाई गई आकृतियाँ खिड़की के भीतर किसी भी स्थान पर प्रदर्शित की जा सकती हैं। यह विधि का उपयोग करके किया जाता हैglTranslatef (float x, float y, float z)

यह विधि किसकी है GLMatrixFunc इंटरफ़ेस, जो में है javax.media.opengl.fixedfunc पैकेज।

GLMatrixFunc इंटरफ़ेस

interface - GLMatrixFunc

package - javax.media.opengl.fixedfunc

निम्न तालिका इस इंटरफ़ेस के कुछ महत्वपूर्ण तरीकों को सूचीबद्ध करती है -

अनु क्रमांक। तरीके और विवरण
1

void glRotatef(float angle, float x, float y, float z)

वर्तमान मैट्रिक्स को घुमाता है।

2

void glScalef(float x, float y, float z)

वर्तमान मैट्रिक्स को स्केल करने के लिए उपयोग किया जाता है।

3

void glTranslatef(float x, float y,float z)

वर्तमान मैट्रिक्स का अनुवाद करने के लिए उपयोग किया जाता है।

4

void glLoadIdentity()

पहचान मैट्रिक्स के साथ वर्तमान मैट्रिक्स को लोड करता है।

glTranslate() विधि समन्वय प्रणाली की उत्पत्ति को उस पैरामीटर (x, y, z) द्वारा निर्दिष्ट बिंदु तक ले जाती है, जिसे पास किया गया है glTranslate() विधि के रूप में

बहस। बचाने और अनियंत्रित समन्वय प्रणाली को पुनर्स्थापित करने के लिए,glPushMatrix() तथा glPopMatrix() विधियों का उपयोग किया जाता है।

gl.glTranslatef(0f, 0f, -2.5f);

जब कभी glTranslate()उपयोग किया जाता है, यह स्क्रीन पर घटक की स्थिति को बदलता है। इसलिएreshape() उसकि विधि GLEventListener इंटरफ़ेस को ओवरराइड किया जाना चाहिए और ओपनजीएल व्यूपोर्ट और प्रोजेक्शन मैट्रिक्स को आरंभीकृत किया जाना चाहिए।

निम्न कोड एक पोर्ट और प्रक्षेपण मैट्रिक्स को शुरू करने के लिए टेम्पलेट दिखाता है -

public void reshape(GLAutoDrawable drawable, int x,  int y, int width, int height) { 
  
   // TODO Auto-generated method stub 
   final GL2 gl = drawable.getGL().getGL2();  
            
   // get the OpenGL 2 graphics object   
   if(height <=0) height = 1; 
       
   //preventing devided by 0 exception height = 1; 
   final float h = (float) width / (float) height; 
            
   // display area to cover the entire window 
   gl.glViewport(0, 0, width, height); 
            
   //transforming projection matrix 
   gl.glMatrixMode(GL2.GL_PROJECTION); 
   gl.glLoadIdentity(); 
   glu.gluPerspective(45.0f, h, 1.0, 20.0); 
      
   //transforming model view gl.glLoadIdentity(); 
   gl.glMatrixMode(GL2.GL_MODELVIEW); 
   gl.glLoadIdentity(); 
}

यह अध्याय आपको सिखाता है कि JOGL का उपयोग करके वस्तुओं पर रंग कैसे लगाया जाए। किसी वस्तु पर रंग लगाने के लिए, विधि का उपयोग करेंglColor() का GL2। नीचे दिए गए glColor विधि का उपयोग करने के लिए वाक्यविन्यास है।

वाक्य - विन्यास

gl.glColorXY(1f,0f,0f);

कहाँ पे,

  • एक्स इस्तेमाल किए गए रंगों की संख्या को दर्शाता है, 3 (लाल, हरा, नीला) या 4 (लाल, हरा, नीला, अल्फा)। विभिन्न रंगों के संयोजन प्राप्त करने के लिए, इन रंगों के मूल्यों को मापदंडों के रूप में पारित किया जाता है। उस क्रम में रंग मापदंडों का क्रम बनाए रखा जाना चाहिए।

    Example

    यदि आप (1, 0, 0) के रूप में रंग मान पास करते हैं, तो आपको लाल रंग मिलता है। इसी तरह (1, 1, 0) आपको पीला रंग देता है।

  • Y डेटा प्रकार को दर्शाता है जो बाइट (b), डबल (d), फ्लोट (f), int (i), शॉर्ट (s), ubyte (ub), uint (ui), और ushort (us) जैसे मापदंडों को स्वीकार करता है। ।

gl.glColor3f(1f,0f,0f);   //gives us red          
gl.glColor3f(0f,1f,0f);   //gives us green            
gl.glColor3f(0f,0f,1f);   //gives us blue

त्रिकोण के मामले में, आप प्रत्येक शीर्ष के लिए अलग-अलग रंग लागू कर सकते हैं।

हमें एक त्रिकोण पर रंग लगाने के लिए कार्यक्रम के माध्यम से जाने -

import javax.media.opengl.GL2; 
import javax.media.opengl.GLAutoDrawable; 
import javax.media.opengl.GLCapabilities; 
import javax.media.opengl.GLEventListener; 
import javax.media.opengl.GLProfile; 
import javax.media.opengl.awt.GLCanvas; 

import javax.swing.JFrame; 
 
public class TriangleColor implements GLEventListener { 

   @Override 
   public void display( GLAutoDrawable drawable ) { 
   
      final GL2 gl = drawable.getGL().getGL2(); 
      gl.glBegin( GL2.GL_TRIANGLES );  
      
      // Drawing Using Triangles 
    
      gl.glColor3f( 1.0f, 0.0f, 0.0f );   // Red 
      gl.glVertex3f( 0.5f,0.7f,0.0f );    // Top 
		
      gl.glColor3f( 0.0f,1.0f,0.0f );     // green 
      gl.glVertex3f( -0.2f,-0.50f,0.0f ); // Bottom Left 
		
      gl.glColor3f( 0.0f,0.0f,1.0f );     // blue 
      gl.glVertex3f( 0.5f,-0.5f,0.0f );   // Bottom Right 
		
      gl.glEnd();         
   } 
   
   @Override 
   public void dispose( GLAutoDrawable arg0 ) { 
      //method body 
   } 
   
   @Override 
   public void init( GLAutoDrawable arg0 ) { 
      // method body    
   }
   
   @Override 
   public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) { 
      // method body 
   } 
   
   public static void main( String[] args ) {    
   
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get( GLProfile.GL2 ); 
      GLCapabilities capabilities = new GLCapabilities(profile);
          
      // The canvas  
      final GLCanvas glcanvas = new GLCanvas( capabilities ); 
      TriangleColor triangle = new TriangleColor(); 
      glcanvas.addGLEventListener( triangle ); 
      glcanvas.setSize( 400, 400 );   
      
      //creating frame 
      final JFrame frame = new JFrame (" Colored Triangle"); 
          
      //adding canvas to it 
      frame.getContentPane().add( glcanvas ); 
      frame.setSize( frame.getContentPane().getPreferredSize()); 
      frame.setVisible( true );   
      
   } //end of main
	
} //end of class

जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो आपको निम्नलिखित रंगीन त्रिकोण मिलते हैं -

एक बहुभुज के लिए रंग लागू करना

आइए हम कार्यक्रम के माध्यम से बहुभुज में रंग लागू करते हैं -

import javax.media.opengl.GL2; 
import javax.media.opengl.GLAutoDrawable; 
import javax.media.opengl.GLCapabilities; 
import javax.media.opengl.GLEventListener; 
import javax.media.opengl.GLProfile; 
import javax.media.opengl.awt.GLCanvas; 

import javax.swing.JFrame; 

public class PolygonColor implements GLEventListener { 

   @Override 
   public void display( GLAutoDrawable drawable ) { 
   
      final GL2 gl = drawable.getGL().getGL2(); 
      gl.glColor3f( 1f,0f,0f ); //applying red  
  
      gl.glBegin( GL2.GL_POLYGON ); 
      
      gl.glVertex3f( 0f,0.5f,0f  ); 
      gl.glVertex3f( -0.5f,0.2f,0f ); 
      gl.glVertex3f( -0.5f,-0.2f,0f ); 
      gl.glVertex3f( 0f,-0.5f,0f ); 
      gl.glVertex3f( 0f,0.5f,0f ); 
      gl.glVertex3f( 0.5f,0.2f,0f ); 
      gl.glVertex3f( 0.5f,-0.2f,0f ); 
      gl.glVertex3f( 0f,-0.5f,0f ); 
      
      gl.glEnd(); 
   }
   
   @Override 
   public void dispose( GLAutoDrawable arg0 ) { 
      //method body 
   } 
   
   @Override 
   public void init( GLAutoDrawable arg0 ) {   
      // method body 
   } 
   
   @Override 
   public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {    
      // method body 
   } 
   
   public static void main( String[] args ) { 
   
      //getting the capabilities object of GL2 profile  
      final GLProfile profile = GLProfile.get( GLProfile.GL2 ); 
      GLCapabilities capabilities = new GLCapabilities(profile); 
      
      // The canvas  
      final GLCanvas glcanvas = new GLCanvas( capabilities ); 
      PolygonColor polygon = new PolygonColor(); 
      glcanvas.addGLEventListener( polygon ); 
      glcanvas.setSize( 400, 400 ); 
      
      //creating frame 
      final JFrame frame = new JFrame ( "Colored Polygon" ); 
      
      //adding canvas to frame 
      frame.getContentPane().add( glcanvas ); 
      frame.setSize(frame.getContentPane().getPreferredSize() ); 
      frame.setVisible( true );    
      
   } //end of main 
	
 } //end of class

जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो आपको निम्नलिखित रंगीन बहुभुज मिलते हैं -

यह अध्याय आपको JOGL का उपयोग करके किसी वस्तु के आकार को बढ़ाने या घटाने का तरीका सिखाता है।

का उपयोग करके किसी वस्तु को स्केलिंग किया जाता है glScalef(float x, float y, float z) उसकि विधि GLMatrixFuncइंटरफेस। यह विधि तीन फ्लोटिंग पॉइंट पैरामीटर को स्वीकार करती है, जिसके उपयोग से हम क्रमशः x, y और z axes के साथ स्केल कारकों को निर्दिष्ट करते हैं।

उदाहरण के लिए, निम्नलिखित कार्यक्रम में, एक त्रिकोण 50% तक कम हो जाता है। यहां, मान 50 को सभी अक्षों के साथ पैरामीटर के रूप में पारित किया गया है।

हमें प्रोग्राम के माध्यम से एक त्रिकोण बनाने के लिए जाना -

import javax.media.opengl.GL2; 
import javax.media.opengl.GLAutoDrawable; 
import javax.media.opengl.GLCapabilities; 
import javax.media.opengl.GLEventListener; 
import javax.media.opengl.GLProfile; 
import javax.media.opengl.awt.GLCanvas; 

import javax.swing.JFrame;
 
public class Scaling implements GLEventListener {
 
   @Override 
	
   public void display( GLAutoDrawable drawable ) { 
   
      final GL2 gl = drawable.getGL().getGL2(); 
      gl.glScalef( 0.50f,0.25f,0.50f ); 
      gl.glBegin( GL2.GL_TRIANGLES );
		
      // Drawing Using Triangles 
      gl.glColor3f( 1.0f, 0.0f, 0.0f );   // Red 
      gl.glVertex3f( 0.5f,0.7f,0.0f );    // Top 
		
      gl.glColor3f( 0.0f,1.0f,0.0f );     // blue 
      gl.glVertex3f( -0.2f,-0.50f,0.0f ); // Bottom Left 
		
      gl.glColor3f( 0.0f,0.0f,1.0f );     // green 
      gl.glVertex3f( 0.5f,-0.5f,0.0f );   // Bottom Right 
		
      gl.glEnd(); 
   }
   
   @Override 
   public void dispose( GLAutoDrawable arg0 ) { 
      //method body 
   } 
   
   @Override 
   public void init( GLAutoDrawable arg0 ) { 
      // method body 
   } 
   
   @Override 
   public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) { 
      // method body 
   }
   
   public static void main( String[] args ) {   
   
      //getting the capabilities object of GL2 profile 
      final GLProfile profile = GLProfile.get( GLProfile.GL2 ); 
      GLCapabilities capabilities = new GLCapabilities(profile);
        
      // The canvas  
      final GLCanvas glcanvas = new GLCanvas( capabilities ); 
      Scaling scaling = new Scaling(); 
      glcanvas.addGLEventListener( scaling ); 
      glcanvas.setSize( 400, 400 );  

      //creating frame 
      final JFrame frame  = new JFrame (" Dimnished Triangle (Scaling )");   

      //adding canvas to it 
      frame.getContentPane().add(glcanvas); 
      frame.setSize(frame.getContentPane().getPreferredSize()); 
      frame.setVisible(true);         
      
   } //end of main 
	
} //end of classimport javax.media.opengl.GL2;

उपरोक्त कार्यक्रम को संकलित करने और निष्पादित करने पर, हमें निम्नलिखित आउटपुट मिलते हैं। यहां, आप त्रिभुज.राजवा द्वारा निर्मित मूल त्रिकोण की तुलना में एक कम त्रिकोण का निरीक्षण कर सकते हैं -

इस अध्याय में हमने आपको JOGL का उपयोग करके किसी ऑब्जेक्ट को घुमाने का तरीका समझाया। वस्तुओं का रोटेशन तीन एक्सिस में से किसी एक के साथ किया जा सकता हैglRotatef(float angle, float x, float y, float z) उसकि विधि GLMatrixFuncइंटरफेस। आपको इस विधि के मापदंडों के रूप में रोटेशन और x, y, z axes के कोण को पास करना होगा।

निम्नलिखित चरण आपको किसी वस्तु को सफलतापूर्वक घुमाने के लिए निर्देशित करते हैं -

  • शुरू में रंगीन बफ़र और डेप्थ बफ़र का उपयोग करके साफ़ करें gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT)तरीका। यह विधि ऑब्जेक्ट की पिछली स्थिति को मिटा देती है और दृश्य को स्पष्ट करती है।

  • का उपयोग कर प्रक्षेपण मैट्रिक्स रीसेट करें glLoadIdentity() तरीका।

एनिमेटर क्लास को इंस्टेंट करें और एनिमेटर का उपयोग करके एनिमेटर को शुरू करें start() तरीका।

एफपीएसएनीमेटर क्लास

नीचे FPSAnimator वर्ग के विभिन्न कंस्ट्रक्टरों को दिया गया है।

अनु क्रमांक। तरीके और विवरण
1

FPSAnimator(GLAutoDrawable drawable, int fps)

यह एक दिए गए लक्ष्य फ़्रेम-प्रति-सेकंड मान के साथ एक FPSAnimator बनाता है और चेतन के लिए एक प्रारंभिक drawable है।

2

FPSAnimator(GLAutoDrawable drawable, int fps, boolean cheduleAtFixedRate)

यह एक दिए गए लक्ष्य फ़्रेम-प्रति-सेकंड मान के साथ एक FPSAimimator बनाता है, जो चेतन के लिए एक प्रारंभिक योग्‍य है, और यह दर्शाता है कि निश्चित दर निर्धारण का उपयोग करना है या नहीं।

3

FPSAnimator(int fps)

यह एक दिए गए लक्ष्य फ़्रेम-प्रति-सेकंड मान के साथ एक FPSAimimator बनाता है।

4 यह एक दिए गए लक्ष्य फ़्रेम-प्रति-सेकंड मान के साथ एक FPSAnimator बनाता है और यह दर्शाता है कि निश्चित दर निर्धारण का उपयोग करना है।

यह एक दिए गए लक्ष्य फ़्रेम-प्रति-सेकंड मान के साथ एक FPSAnimator बनाता है और यह दर्शाता है कि निश्चित दर निर्धारण का उपयोग करना है।

start() तथा stop()इस वर्ग में दो महत्वपूर्ण विधियां हैं। निम्नलिखित कार्यक्रम से पता चलता है कि एफपीएसएनीमेटर वर्ग का उपयोग करके एक त्रिकोण को कैसे घुमाया जाए -

import javax.media.opengl.GL2; 
import javax.media.opengl.GLAutoDrawable; 
import javax.media.opengl.GLCapabilities; 
import javax.media.opengl.GLEventListener; 
import javax.media.opengl.GLProfile; 
import javax.media.opengl.awt.GLCanvas; 

import javax.swing.JFrame; 

import com.jogamp.opengl.util.FPSAnimator; 

public class TriangleRotation implements GLEventListener { 
   private float rtri;  //for angle of rotation
      
   @Override 
   public void display( GLAutoDrawable drawable ) {
   
      final GL2 gl = drawable.getGL().getGL2(); 
      gl.glClear (GL2.GL_COLOR_BUFFER_BIT |  GL2.GL_DEPTH_BUFFER_BIT );  
      
      // Clear The Screen And The Depth Buffer 
      gl.glLoadIdentity();  // Reset The View     
              
      //triangle rotation      
      gl.glRotatef( rtri, 0.0f, 1.0f, 0.0f );  
              
      // Drawing Using Triangles 
      gl.glBegin( GL2.GL_TRIANGLES );          
      
      gl.glColor3f( 1.0f, 0.0f, 0.0f );   // Red 
      gl.glVertex3f( 0.5f,0.7f,0.0f );    // Top 
      gl.glColor3f( 0.0f,1.0f,0.0f );     // blue 
      gl.glVertex3f( -0.2f,-0.50f,0.0f ); // Bottom Left 
      gl.glColor3f( 0.0f,0.0f,1.0f );     // green 
      gl.glVertex3f( 0.5f,-0.5f,0.0f );   // Bottom Right 
      
      gl.glEnd();    
      gl.glFlush(); 
      
      rtri +=0.2f;  //assigning the angle               
   } 
	
   @Override 
   public void dispose( GLAutoDrawable arg0 ) { 
      //method body 
   } 
   
   @Override 
   public void init( GLAutoDrawable arg0 ) { 
      // method body 
   }
   
   @Override 
   public void reshape( GLAutoDrawable drawable, int x, int y, int width, int height ) { 
   
      public static void main( String[] args ) {
		
         //getting the capabilities object of GL2 profile
         final GLProfile profile  = GLProfile.get(GLProfile.GL2 ); 
         GLCapabilities capabilities  = new GLCapabilities( profile );

         // The canvas  
         final GLCanvas glcanvas = new GLCanvas( capabilities); 
         TriangleRotation triangle = new TriangleRotation(); 
         glcanvas.addGLEventListener( triangle ); 
         glcanvas.setSize( 400, 400 );  

         // creating frame 
         final JFrame frame = new JFrame ("Rotating Triangle");

         // adding canvas to it 
         frame.getContentPane().add( glcanvas ); 
         frame.setSize(frame.getContentPane() .getPreferredSize());                 
         frame.setVisible( true ); 
                
         //Instantiating and Initiating Animator 
         final FPSAnimator animator = new FPSAnimator(glcanvas, 300,true); 
         animator.start(); 
      }
		
   } //end of main
	
} //end of class

यदि आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित आउटपुट उत्पन्न करता है। यहां, आप एक्स-एक्सिस के चारों ओर रंगीन त्रिकोण को घुमाते हुए विभिन्न स्नैपशॉट देख सकते हैं।

यह अध्याय आपको बताता है कि JOGL का उपयोग करके किसी ऑब्जेक्ट पर प्रकाश प्रभाव कैसे लागू किया जाए।

प्रकाश व्यवस्था सेट करने के लिए, प्रारंभ में प्रकाश व्यवस्था का उपयोग कर सक्षम करें glEnable()तरीका। फिर वस्तुओं का उपयोग करते हुए प्रकाश व्यवस्था लागू करेंglLightfv(int light, int pname, float[] params, int params_offset) उसकि विधि GLLightingFuncइंटरफेस। इस विधि में चार पैरामीटर होते हैं।

निम्न तालिका के मापदंडों का वर्णन करता है gllightfv() तरीका।

अनु क्रमांक। पैरामीटर नाम और विवरण
1

Light

एक प्रकाश निर्दिष्ट करता है। रोशनी की संख्या कार्यान्वयन पर निर्भर करती है, लेकिन कम से कम आठ रोशनी का समर्थन किया जाता है। यह दस मानों को स्वीकार करता है, उन मापदंडों की चर्चा नीचे दी गई लाइट सोर्स पैरामीटर्स नामक एक अलग तालिका में की गई है।

2

Pname

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

3

Params

प्रकाश स्रोत प्रकाश के पैरामीटर pname के लिए सेट मान या मान के लिए एक सूचक निर्दिष्ट करता है ।

4

Light source parameter

आप नीचे दिए गए प्रकाश स्रोत मापदंडों में से किसी का उपयोग कर सकते हैं।

प्रकाश स्रोत मापदंडों

अनु क्रमांक। पैरामीटर और विवरण
1

GL_AMBIENT

इसमें ऐसे पैरामीटर होते हैं जो प्रकाश की परिवेश तीव्रता को निर्दिष्ट करते हैं।

2

GL_DIFFUSE

इसमें ऐसे पैरामीटर शामिल हैं जो प्रकाश की प्रसार तीव्रता को निर्दिष्ट करते हैं।

3

GL_SPECULAR

इसमें ऐसे पैरामीटर शामिल हैं जो प्रकाश की स्पेकुलर तीव्रता को निर्दिष्ट करते हैं।

4

GL_POSITION

इसमें चार पूर्णांक या फ्लोटिंग-पॉइंट मान शामिल हैं जो सजातीय वस्तु निर्देशांक में प्रकाश की स्थिति को निर्दिष्ट करते हैं।

5

GL_SPOT_DIRECTION

इसमें ऐसे पैरामीटर होते हैं जो सजातीय वस्तु निर्देशांक में प्रकाश की दिशा निर्दिष्ट करते हैं।

6

GL_SPOT_EXPONENT

इसके पैरामीटर प्रकाश की तीव्रता वितरण को निर्दिष्ट करते हैं।

7

GL_SPOT_CUTOFF

इसका एकल पैरामीटर प्रकाश के अधिकतम प्रसार कोण को निर्दिष्ट करता है।

8

GL_CONSTANT_ATTENUATION or GL_LINEAR_ATTENUATION or GL_QUADRATIC_ATTENUATION

आप इन क्षीणन कारकों में से किसी का उपयोग कर सकते हैं, जो एक एकल मूल्य द्वारा दर्शाया गया है।

प्रकाश व्यवस्था सक्षम या अक्षम है glEnable() तथा glDisable () तर्क के साथ तरीके GL_LIGHTING

प्रकाश व्यवस्था के लिए निम्न टेम्पलेट दिया गया है -

gl.glEnable(GL2.GL_LIGHTING); 
gl.glEnable(GL2.GL_LIGHT0);  
gl.glEnable(GL2.GL_NORMALIZE); 

float[] ambientLight = { 0.1f, 0.f, 0.f,0f };  // weak RED ambient 
gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambientLight, 0); 

float[] diffuseLight = { 1f,2f,1f,0f };  // multicolor diffuse 
gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuseLight, 0);

प्रकाश को एक घूर्णन बहुभुज पर लागू करना

एक घूर्णन बहुभुज में प्रकाश लगाने के लिए दिए गए चरणों का पालन करें।

बहुभुज () विधि का उपयोग करके बहुभुज को घुमाएं

gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT); 
  
// Clear The Screen And The Depth Buffer  
gl.glLoadIdentity();  
                 
// Reset The View  
gl.glRotatef(rpoly, 0.0f, 1.0f, 0.0f);

आइए हम एक घूर्णन बहुभुज पर प्रकाश लागू करने के लिए कार्यक्रम के माध्यम से चलते हैं -

import javax.media.opengl.GL2; 
import javax.media.opengl.GLAutoDrawable; 
import javax.media.opengl.GLCapabilities; 
import javax.media.opengl.GLEventListener; 
import javax.media.opengl.GLProfile; 
import javax.media.opengl.awt.GLCanvas; 

import javax.swing.JFrame; 

import com.jogamp.opengl.util.FPSAnimator; 
 
public class PolygonLighting implements GLEventListener { 
   private float rpoly;
	
   @Override 
	
   public void display( GLAutoDrawable drawable ) {
   
      final GL2 gl = drawable.getGL().getGL2(); 
      gl.glColor3f(1f,0f,0f); //applying red
      
      // Clear The Screen And The Depth Buffer 
      gl.glClear( GL2.GL_COLOR_BUFFER_BIT |  
      GL2.GL_DEPTH_BUFFER_BIT );   
      gl.glLoadIdentity();       // Reset The View    
      gl.glRotatef( rpoly, 0.0f, 1.0f, 0.0f ); 
		
      gl.glBegin( GL2.GL_POLYGON ); 
      
      gl.glVertex3f( 0f,0.5f,0f ); 
      gl.glVertex3f( -0.5f,0.2f,0f ); 
      gl.glVertex3f( -0.5f,-0.2f,0f ); 
      gl.glVertex3f( 0f,-0.5f,0f ); 
      gl.glVertex3f( 0f,0.5f,0f ); 
      gl.glVertex3f( 0.5f,0.2f,0f ); 
      gl.glVertex3f( 0.5f,-0.2f,0f ); 
      gl.glVertex3f( 0f,-0.5f,0f ); 
      
      gl.glEnd(); 
		
      gl.glFlush(); 
      
      rpoly += 0.2f;  //assigning the angle 
      
      gl.glEnable( GL2.GL_LIGHTING );  
      gl.glEnable( GL2.GL_LIGHT0 );  
      gl.glEnable( GL2.GL_NORMALIZE );  

      // weak RED ambient 
      float[] ambientLight = { 0.1f, 0.f, 0.f,0f };  
      gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambient-Light, 0);  

      // multicolor diffuse 
      float[] diffuseLight = { 1f,2f,1f,0f };  
      gl.glLightfv( GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuse-Light, 0 ); 
   }  
      
   @Override 
   public void dispose( GLAutoDrawable arg0 ) { 
      //method body  
   } 
  
   @Override 
   public void init( GLAutoDrawable arg0 ) { 
      // method body     
   } 
	
   @Override 
   public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) { 
      // method body 
   } 
	
   public static void main( String[] args ) { 
   
      //getting the capabilities object of GL2 profile 
      final GLProfile profile = GLProfile.get( GLProfile.GL2 ); 
      GLCapabilities capabilities = new GLCapabilities( profile);

      // The canvas  
      final GLCanvas glcanvas = new GLCanvas( capabilities ); 
      PolygonLighting polygonlighting = new PolygonLighting(); 
      glcanvas.addGLEventListener( polygonlighting ); 
      glcanvas.setSize( 400, 400 ); 

      //creating frame 
      final JFrame frame = new JFrame (" Polygon lighting ");  

      //adding canvas to it 
      frame.getContentPane().add( glcanvas ); 
      frame.setSize( frame.getContentPane().getPreferredSize()); 
      frame.setVisible( true );  
                    
      //Instantiating and Initiating Animator 
      final FPSAnimator animator = new FPSAnimator(glcanvas, 300,true ); 
      animator.start();                     
      
   } //end of main 
	
} //end of class

यदि आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित आउटपुट उत्पन्न करता है। यहां, आप प्रकाश के साथ एक घूर्णन बहुभुज के विभिन्न स्नैपशॉट देख सकते हैं।

पिछले अध्यायों में हमने देखा है कि 2d ऑब्जेक्ट कैसे बनाएं, उस पर प्रभाव लागू करें और ऑब्जेक्ट को रूपांतरित करें। यह अध्याय आपको सिखाता है कि कैसे 3 आयाम और कुछ आकृतियों के साथ एक रेखा खींचना है।

आइए हम z- अक्ष के साथ एक सरल रेखा बनाते हैं और 2D और 3D लाइनों के बीच का अंतर देखते हैं। पहले एक सरल रेखा खींचें, फिर दूसरी पंक्ति 3 इकाइयों को खिड़की में खींचें।

आइए हम एक 3 डी लाइन खींचने के लिए कार्यक्रम के माध्यम से चलते हैं -

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;

import javax.swing.JFrame;
   
public class Line3d implements GLEventListener {
   private GLU glu = new GLU();
	
   @Override
   
   public void display( GLAutoDrawable drawable ) {
      final GL2 gl = drawable.getGL().getGL2();
      gl.glTranslatef( 0f, 0f, -2.5f );
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( -0.75f,0f,0 );
      gl.glVertex3f( 0f,-0.75f, 0 );
      gl.glEnd();
      
      //3d line
      gl.glBegin( GL2.GL_LINES );
      gl.glVertex3f( -0.75f,0f,3f );// 3 units into the window
      gl.glVertex3f( 0f,-0.75f,3f );
      gl.glEnd();
   }
   
   @Override
   public void dispose( GLAutoDrawable arg0 ) {
      //method body
   }
   
   @Override
   public void init( GLAutoDrawable arg0 ) {
      // method body
   }
   
   @Override
   public void reshape( GLAutoDrawable drawable, int x, int y, int width, int height ) {
	
      GL2 gl = drawable.getGL().getGL2();
      
      if( height <= 0 )
         height = 1;
			
      final float h = ( float ) width / ( float ) height;
      gl.glViewport( 0, 0, width, height );
      gl.glMatrixMode( GL2.GL_PROJECTION );
      gl.glLoadIdentity();
		
      glu.gluPerspective( 45.0f, h, 1.0, 20.0 );
      gl.glMatrixMode( GL2.GL_MODELVIEW );
      gl.glLoadIdentity();
   }
   
   public static void main( String[] args ) {
	
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get( GLProfile.GL2 );
      GLCapabilities capabilities = new GLCapabilities(profile);
          
      // The canvas
      final GLCanvas glcanvas = new GLCanvas( capabilities );
      Line3d line3d = new Line3d();
      glcanvas.addGLEventListener( line3d );
      glcanvas.setSize( 400, 400 );
       
      //creating frame
      final JFrame frame = new JFrame (" 3d line");
          
      //adding canvas to it
      frame.getContentPane().add( glcanvas );
      frame.setSize(frame.getContentPane().getPreferredSize() );
      frame.setVisible( true );
   }//end of main
	
}//end of class

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

3 डी आकृतियों को z शून्य के गैर-शून्य मान देकर तैयार किया जा सकता है glVertex3f()विधि, जो उपरोक्त दृश्य उत्पन्न करती है। अब शेष रेखाओं के जुड़ने से 3 डी बढ़त बनेगी।

अब उसी तरह से हमें तीसरे आयाम के साथ बढ़त विकसित करने दें।

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;

import javax.swing.JFrame;

public class Edge1 implements GLEventListener {
   private GLU glu = new GLU();
	
   @Override
   public void display(GLAutoDrawable drawable) {
   
      // TODO Auto-generated method stub
      final GL2 gl = drawable.getGL().getGL2();
      gl.glTranslatef(0f, 0f, -2.5f);
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(-0.75f,0f,0);
      gl.glVertex3f(0f,-0.75f, 0);
      gl.glEnd();

      //3d line
      gl.glBegin(GL2.GL_LINES);

      //3 units in to the window
      gl.glVertex3f(-0.75f,0f,3f);
      gl.glVertex3f(0f,-0.75f,3f);
      gl.glEnd();

      //top
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(-0.75f,0f,0);
      gl.glVertex3f(-0.75f,0f,3f);
      gl.glEnd();

      //bottom
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0f,-0.75f, 0);
      gl.glVertex3f(0f,-0.75f,3f);
      gl.glEnd();
   }

   @Override
   public void dispose(GLAutoDrawable arg0) {
      //method body
   }
	
   @Override
   public void init(GLAutoDrawable arg0) {
      // method body
   }
   
   @Override
   public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
	
      // TODO Auto-generated method stubfinal
      GL2 gl = drawable.getGL().getGL2();
      if(height <= 0)
         height = 1;
			
      final float h = (float) width / (float) height;
      gl.glViewport(0, 0, width, height);
      gl.glMatrixMode(GL2.GL_PROJECTION);
      gl.glLoadIdentity();
		
      glu.gluPerspective(45.0f, h, 1.0, 20.0);
      gl.glMatrixMode(GL2.GL_MODELVIEW);
      gl.glLoadIdentity();

   }
   
   public static void main(String[] args) {
   
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);

      // The canvas
      final GLCanvas glcanvas = new GLCanvas(capabilities);
      Edge1 b = new Edge1();
      glcanvas.addGLEventListener(b);
      glcanvas.setSize(400, 400);

      //creating frame
      final JFrame frame = new JFrame (" 3d edge");

      //adding canvas to it
      frame.getContentPane().add(glcanvas);
      frame.setSize(frame.getContentPane().getPreferredSize());
      frame.setVisible(true);
   }//end of main
	
}//end of class

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

उसी तरह, किसी भी 2D चतुर्भुज के संगत किनारों पर 3D किनारों को विकसित करने और आसन्न कोने में शामिल होने से, आप 3D चतुर्भुज प्राप्त कर सकते हैं।

नीचे दिए गए JOGL का उपयोग करके एक समभुज बनाने का कार्यक्रम है।

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;

import javax.swing.JFrame;

public class Rhombus implements GLEventListener {
   private GLU glu = new GLU();
    
   @Override
   public void display(GLAutoDrawable drawable) {
	
      final GL2 gl = drawable.getGL().getGL2();
      gl.glTranslatef(0f, 0f, -2.5f);

      //drawing edge1.....
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(-0.75f,0f,0);
      gl.glVertex3f(0f,-0.75f, 0);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(-0.75f,0f,3f); // 3 units into the window
      gl.glVertex3f(0f,-0.75f,3f);
      gl.glEnd();

      //top
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(-0.75f,0f,0);
      gl.glVertex3f(-0.75f,0f,3f);
      gl.glEnd();

      // bottom
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0f,-0.75f, 0);
      gl.glVertex3f(0f,-0.75f,3f);
      gl.glEnd();
   
      // edge 2....
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0f,-0.75f, 0);
      gl.glVertex3f(0.75f,0f, 0);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0f,-0.75f, 3f);
      gl.glVertex3f(0.75f,0f, 3f);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0f,-0.75f, 0);
      gl.glVertex3f(0f,-0.75f, 3f);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0.75f,0f, 0);
      gl.glVertex3f(0.75f,0f, 3f);
      gl.glEnd();

      //Edge 3.............
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f( 0.0f,0.75f,0);
      gl.glVertex3f(-0.75f,0f,0);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f( 0.0f,0.75f,3f);
      gl.glVertex3f(-0.75f,0f,3f);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f( 0.0f,0.75f,0);
      gl.glVertex3f( 0.0f,0.75f,3f);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(-0.75f,0f,0);
      gl.glVertex3f(-0.75f,0f,3f);
      gl.glEnd();

      //final edge
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0.75f,0f, 0);
      gl.glVertex3f( 0.0f,0.75f,0);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0.75f,0f,3f);
      gl.glVertex3f( 0.0f,0.75f,3f);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f(0.75f,0f, 0);
      gl.glVertex3f(0.75f,0f,3f);
      gl.glEnd();
		
      gl.glBegin(GL2.GL_LINES);
      gl.glVertex3f( 0.0f,0.75f,0);
      gl.glVertex3f( 0.0f,0.75f,3f);
      gl.glEnd();
   }
   
   @Override
   public void dispose(GLAutoDrawable arg0) {
      //method body
   }
	
   @Override
   public void init(GLAutoDrawable arg0) {
      // method body
   }
	
   @Override
   public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
   
      // TODO Auto-generated method stub final
      GL2 gl = drawable.getGL().getGL2();
      if(height lt;= 0)
         height = 1;
			
      final float h = (float) width / (float) height;
      gl.glViewport(3, 6, width, height);
      gl.glMatrixMode(GL2.GL_PROJECTION);
      gl.glLoadIdentity();
		
      glu.gluPerspective(45.0f, h, 1.0, 20.0);
      gl.glMatrixMode(GL2.GL_MODELVIEW);
      gl.glLoadIdentity();
   }
   
   public static void main(String[] args) {
	
      //getting the capabilities object of GL2 profile
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);

      // The canvas
      final GLCanvas glcanvas = new GLCanvas(capabilities);
      Rhombus b = new Rhombus();
      glcanvas.addGLEventListener(b);
      glcanvas.setSize(400, 400);

      //creating frame
      final JFrame frame = new JFrame (" Rhombus 3d");

      //adding canvas to it
      frame.getContentPane().add(glcanvas);
      frame.setSize(frame.getContentPane().getPreferredSize());
      frame.setVisible(true);
   }//end of main
	
}//end of classimport javax.media.opengl.GL2;

जब आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है। यह 3 डी लाइनों का उपयोग करके एक रोम्बस दिखाया गया है।

के पूर्वनिर्धारित मापदंडों glBegin() 3 डी आकृतियों को खींचने के लिए विधि का उपयोग किया जा सकता है।

पिछले अध्याय में हमने देखा है कि 3D आकृतियों को कैसे बनाया जाता है, यह अध्याय आपको सिखाता है कि 3D त्रिभुज कैसे बनाएं और इसे कैसे घुमाएँ।

नीचे दिए गए कार्यक्रम में एक 3 डी त्रिकोण को इसे घुमाने के लिए है।

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;

import javax.swing.JFrame;

import com.jogamp.opengl.util.FPSAnimator;

public class Triangle3d implements GLEventListener {

   private GLU glu = new GLU();
   private float rtri = 0.0f;
      
   @Override
   public void display(GLAutoDrawable drawable) {
      final GL2 gl = drawable.getGL().getGL2();

      // Clear The Screen And The Depth Buffer
      gl.glClear( GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT );
      gl.glLoadIdentity(); // Reset The View
      gl.glTranslatef( -0.5f, 0.0f, -6.0f ); // Move the triangle
      gl.glRotatef( rtri, 0.0f, 1.0f, 0.0f );
      gl.glBegin( GL2.GL_TRIANGLES ); 
        
      //drawing triangle in all dimensions
      // Front
      gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
      gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top Of Triangle (Front)
		
      gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
      gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Left Of Triangle (Front)
		
      gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
      gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Right Of Triangle (Front)
        
      // Right
      gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
      gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top Of Triangle (Right)
		
      gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
      gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Left Of Triangle (Right)
		
      gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
      gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Right Of Triangle (Right)
        
      // Left
      gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
      gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top Of Triangle (Back)
		
      gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
      gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Left Of Triangle (Back)
		
      gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
      gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Right Of Triangle (Back)
        
      //left
      gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Red
      gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top Of Triangle (Left)
		
      gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
      gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Left Of Triangle (Left)
		
      gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
      gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Right Of Triangle (Left)
		
      gl.glEnd(); // Done Drawing 3d triangle (Pyramid)
      gl.glFlush();
      rtri += 0.2f;
   }
   
   @Override
   public void dispose( GLAutoDrawable drawable ) {
      //method body
   }
   
   @Override
   public void init( GLAutoDrawable drawable ) {
      //method body
   }
   
   @Override
   public void reshape( GLAutoDrawable drawable, int x, int y, int width, int height ) {
	
      // TODO Auto-generated method stub
      final GL2 gl = drawable.getGL().getGL2();
      if(height lt;=;)
         height = 1;
			
      final float h = ( float ) width / ( float ) height;
      gl.glViewport( 0, 0, width, height );
      gl.glMatrixMode( GL2.GL_PROJECTION );
      gl.glLoadIdentity();
		
      glu.gluPerspective( 45.0f, h, 1.0, 20.0 );
      gl.glMatrixMode( GL2.GL_MODELVIEW );
      gl.glLoadIdentity();
   }
   
   public static void main( String[] args ) {
   
      // TODO Auto-generated method stub
      final GLProfile profile = GLProfile.get( GLProfile.GL2 );
      GLCapabilities capabilities = new GLCapabilities( profile );
         
      // The canvas
      final GLCanvas glcanvas = new GLCanvas( capabilities );
      Triangle3d triangle = new Triangle3d();
		
      glcanvas.addGLEventListener( triangle );
      glcanvas.setSize( 400, 400 );
		
      final JFrame frame = new JFrame ( "3d Triangle (shallow)" );
		
      frame.getContentPane().add( glcanvas );
      frame.setSize( frame.getContentPane().getPreferredSize() );
      frame.setVisible( true );
		
      final FPSAnimator animator = new FPSAnimator(glcanvas,300,true);
      animator.start();
   }
	
}

जब आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है। यहां, आपके पास घूर्णन 3D त्रिभुज का स्नैपशॉट है। चूंकि इस कार्यक्रम में गहराई परीक्षण शामिल नहीं है, त्रिकोण खोखले उत्पन्न होता है।

त्रिकोण को ठोस बनाने के लिए, आपको उपयोग करके गहराई परीक्षण सक्षम करने की आवश्यकता है glEnable(GL_DEPTH_TEST)। गहराई बफ़र को सक्षम करने से आपको एक रिक्त स्क्रीन मिलती है। इसका उपयोग करके रंग को साफ करके साफ किया जा सकता हैglClear(GL_COLOR_BUFFERBIT | GL_DEPTH_BUFFER_BIT)तरीका। Init () विधि या में गहराई परीक्षण सक्षम करने के लिएglDisplay() विधि, निम्नलिखित कोड लिखें -

public void init(GLAutoDrawable drawable) {
   final GL2 gl = drawable.getGL().getGL2();
	
   gl.glShadeModel(GL2.GL_SMOOTH);
   gl.glClearColor(0f, 0f, 0f, 0f);
   gl.glClearDepth(1.0f);
   gl.glEnable(GL2.GL_DEPTH_TEST);
   gl.glDepthFunc(GL2.GL_LEQUAL);
   gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST);
 }

नीचे गहराई से परीक्षण के साथ एक 3 डी त्रिभुज बनाने का कार्यक्रम दिया गया है।

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;

import javax.swing.JFrame;

import com.jogamp.opengl.util.FPSAnimator;

public class Triangledepthtest implements GLEventListener {

   private GLU glu = new GLU();
   private float rtri = 0.0f; 
	
   @Override
   public void display( GLAutoDrawable drawable ) {
	
      final GL2 gl = drawable.getGL().getGL2();
		
      gl.glShadeModel( GL2.GL_SMOOTH );
      gl.glClearColor( 0f, 0f, 0f, 0f );
      gl.glClearDepth( 1.0f );
      gl.glEnable( GL2.GL_DEPTH_TEST );
      gl.glDepthFunc( GL2.GL_LEQUAL );
      gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST);

      // Clear The Screen And The Depth Buffer
      gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT); 
      gl.glLoadIdentity(); // Reset The View
      gl.glTranslatef( -0.5f,0.0f,-6.0f ); // Move the triangle
      gl.glRotatef( rtri, 0.0f, 1.0f, 0.0f );
      gl.glBegin( GL2.GL_TRIANGLES ); 

      //drawing triangle in all dimensions
      //front
      gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
      gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top
		
      gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
      gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Left
		
      gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
      gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Right)

      //right
      gl.glColor3f( 1.0f, 0.0f, 0.0f );
      gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top
		
      gl.glColor3f( 0.0f, 0.0f, 1.0f );
      gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Left
		
      gl.glColor3f( 0.0f, 1.0f, 0.0f );
      gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Right

      //left
      gl.glColor3f( 1.0f, 0.0f, 0.0f );
      gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top
		
      gl.glColor3f( 0.0f, 1.0f, 0.0f );
      gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Left 
		
      gl.glColor3f( 0.0f, 0.0f, 1.0f );
      gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Right 

      //top
      gl.glColor3f( 0.0f, 1.0f, 0.0f );
      gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top
		
      gl.glColor3f( 0.0f, 0.0f, 1.0f );
      gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Left
		
      gl.glColor3f( 0.0f, 1.0f, 0.0f );
      gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Right
		
      gl.glEnd(); // Done Drawing 3d triangle (Pyramid)

      gl.glFlush();
      rtri += 0.2f;
   }
      
   @Override
   public void dispose( GLAutoDrawable drawable ) {
   }
   
   @Override
   public void init( GLAutoDrawable drawable ) {
	
      final GL2 gl = drawable.getGL().getGL2();
		
      gl.glShadeModel( GL2.GL_SMOOTH );
      gl.glClearColor( 0f, 0f, 0f, 0f );
      gl.glClearDepth( 1.0f );
      gl.glEnable( GL2.GL_DEPTH_TEST );
      gl.glDepthFunc( GL2.GL_LEQUAL );
      gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST );
   }
   
   @Override
   public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height ) {
	
      // TODO Auto-generated method stub
      final GL2 gl = drawable.getGL().getGL2();
      if( height <= 0 ) 
         height = 1;
			
      final float h = ( float ) width / ( float ) height;
      gl.glViewport( 0, 0, width, height );
      gl.glMatrixMode( GL2.GL_PROJECTION );
      gl.glLoadIdentity();
		
      glu.gluPerspective( 45.0f, h, 1.0, 20.0 );
      gl.glMatrixMode( GL2.GL_MODELVIEW );
      gl.glLoadIdentity();
   }
      
   public static void main( String[] args ) {
	
      // TODO Auto-generated method stub
      final GLProfile profile = GLProfile.get( GLProfile.GL2 );
      GLCapabilities capabilities = new GLCapabilities( profile );
		
      // The canvas
      final GLCanvas glcanvas = new GLCanvas( capabilities );
      Triangledepthtest triangledepthtest = new Triangledepthtest();
		
      glcanvas.addGLEventListener( triangledepthtest );
      glcanvas.setSize( 400, 400 );
		
      final JFrame frame = new JFrame ( "3d Triangle (solid)" );
      frame.getContentPane().add(glcanvas);
      frame.setSize( frame.getContentPane().getPreferredSize() );
      frame.setVisible( true );
      final FPSAnimator animator = new FPSAnimator( glcanvas, 300,true);
		
      animator.start();
   }
	
}

जब आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है।

यहां, आप एक घूर्णन 3D त्रिभुज के स्नैपशॉट देख सकते हैं। चूंकि इस कार्यक्रम में गहराई परीक्षण के लिए कोड शामिल है, त्रिकोण ठोस उत्पन्न होता है।

पिछले अध्यायों में हमने देखा है कि 3 डी त्रिभुज कैसे खींचना है और इसे कैसे घुमाना है। अब इस अध्याय में आप सीख सकते हैं कि एक 3 डी क्यूब, इसे कैसे घुमाएं, इस पर एक छवि कैसे संलग्न करें। उसी तरह, यह अध्याय एक 3 डी घन खींचने और उस पर रंग लगाने और उसमें छवि संलग्न करने के लिए उदाहरण प्रदान करता है।

नीचे एक 3 डी क्यूब खींचने और उस पर रंग लगाने का कार्यक्रम दिया गया है।

import java.awt.DisplayMode;
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;

import javax.swing.JFrame;

import com.jogamp.opengl.util.FPSAnimator;

public class Cube implements GLEventListener {

   public static DisplayMode dm, dm_old;
   private GLU glu = new GLU();
   private float rquad = 0.0f;
      
   @Override
   public void display( GLAutoDrawable drawable ) {
	
      final GL2 gl = drawable.getGL().getGL2();
      gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT );
      gl.glLoadIdentity();
      gl.glTranslatef( 0f, 0f, -5.0f ); 

      // Rotate The Cube On X, Y & Z
      gl.glRotatef(rquad, 1.0f, 1.0f, 1.0f); 
 
      //giving different colors to different sides
      gl.glBegin(GL2.GL_QUADS); // Start Drawing The Cube
      gl.glColor3f(1f,0f,0f); //red color
      gl.glVertex3f(1.0f, 1.0f, -1.0f); // Top Right Of The Quad (Top)
      gl.glVertex3f( -1.0f, 1.0f, -1.0f); // Top Left Of The Quad (Top)
      gl.glVertex3f( -1.0f, 1.0f, 1.0f ); // Bottom Left Of The Quad (Top)
      gl.glVertex3f( 1.0f, 1.0f, 1.0f ); // Bottom Right Of The Quad (Top)
		
      gl.glColor3f( 0f,1f,0f ); //green color
      gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Top Right Of The Quad
      gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Top Left Of The Quad
      gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Bottom Left Of The Quad
      gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Bottom Right Of The Quad 

      gl.glColor3f( 0f,0f,1f ); //blue color
      gl.glVertex3f( 1.0f, 1.0f, 1.0f ); // Top Right Of The Quad (Front)
      gl.glVertex3f( -1.0f, 1.0f, 1.0f ); // Top Left Of The Quad (Front)
      gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Bottom Left Of The Quad
      gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Bottom Right Of The Quad 

      gl.glColor3f( 1f,1f,0f ); //yellow (red + green)
      gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Bottom Left Of The Quad
      gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Bottom Right Of The Quad
      gl.glVertex3f( -1.0f, 1.0f, -1.0f ); // Top Right Of The Quad (Back)
      gl.glVertex3f( 1.0f, 1.0f, -1.0f ); // Top Left Of The Quad (Back)

      gl.glColor3f( 1f,0f,1f ); //purple (red + green)
      gl.glVertex3f( -1.0f, 1.0f, 1.0f ); // Top Right Of The Quad (Left)
      gl.glVertex3f( -1.0f, 1.0f, -1.0f ); // Top Left Of The Quad (Left)
      gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Bottom Left Of The Quad
      gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Bottom Right Of The Quad 

      gl.glColor3f( 0f,1f, 1f ); //sky blue (blue +green)
      gl.glVertex3f( 1.0f, 1.0f, -1.0f ); // Top Right Of The Quad (Right)
      gl.glVertex3f( 1.0f, 1.0f, 1.0f ); // Top Left Of The Quad
      gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Bottom Left Of The Quad
      gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Bottom Right Of The Quad
      gl.glEnd(); // Done Drawing The Quad
      gl.glFlush();
      rquad -= 0.15f;
   }
   
   @Override
   public void dispose( GLAutoDrawable drawable ) {
      // TODO Auto-generated method stub
   }
   
   @Override
   public void init( GLAutoDrawable drawable ) {
	
      final GL2 gl = drawable.getGL().getGL2();
      gl.glShadeModel( GL2.GL_SMOOTH );
      gl.glClearColor( 0f, 0f, 0f, 0f );
      gl.glClearDepth( 1.0f );
      gl.glEnable( GL2.GL_DEPTH_TEST );
      gl.glDepthFunc( GL2.GL_LEQUAL );
      gl.glHint( GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST );
   }
      
   @Override
   public void reshape( GLAutoDrawable drawable, int x, int y, int width, int height ) {
	
      // TODO Auto-generated method stub
      final GL2 gl = drawable.getGL().getGL2();
      if( height lt;= 0 )
         height = 1;
			
      final float h = ( float ) width / ( float ) height;
      gl.glViewport( 0, 0, width, height );
      gl.glMatrixMode( GL2.GL_PROJECTION );
      gl.glLoadIdentity();
		
      glu.gluPerspective( 45.0f, h, 1.0, 20.0 );
      gl.glMatrixMode( GL2.GL_MODELVIEW );
      gl.glLoadIdentity();
   }
      
   public static void main( String[] args ) {
	
      final GLProfile profile = GLProfile.get( GLProfile.GL2 );
      GLCapabilities capabilities = new GLCapabilities( profile );
      
      // The canvas
      final GLCanvas glcanvas = new GLCanvas( capabilities );
      Cube cube = new Cube();
		
      glcanvas.addGLEventListener( cube );
      glcanvas.setSize( 400, 400 );
		
      final JFrame frame = new JFrame ( " Multicolored cube" );
      frame.getContentPane().add( glcanvas );
      frame.setSize( frame.getContentPane().getPreferredSize() );
      frame.setVisible( true );
      final FPSAnimator animator = new FPSAnimator(glcanvas, 300,true);
		
      animator.start();
   }
	
}

जब आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है। यह एक रंगीन 3 डी क्यूब दिखाता है।

घन पर बनावट लागू करना

एक घन में बनावट लागू करने के लिए निम्नलिखित चरण दिए गए हैं -

  • आप क्यूब का उपयोग करके आवश्यक बनावट को बांध सकते हैं gl.glBindTexture(GL2.GL_TEXTURE_2D.texture) ड्रा करने योग्य इंटरफ़ेस की विधि।

  • इस पद्धति के साथ बनावट (इंट) तर्क की आवश्यकता होती है GL2.GL_TEXTURE_2D(int)

  • इससे पहले कि आप निष्पादित करें Display(), आपको बनावट चर बनाने की आवश्यकता है

  • में init() विधि या की प्रारंभिक लाइनों में glDisplay() विधि, बनावट सक्षम करें using gl.glEnable(GL2.GL_TEXTURE_2D) तरीका।

  • बनावट ऑब्जेक्ट बनाएं, जिसे पैरामीटर के रूप में एक फ़ाइल ऑब्जेक्ट की आवश्यकता होती है, जो बदले में ऑब्जेक्ट के लिए बनावट के रूप में उपयोग की जाने वाली छवि के पथ की आवश्यकता होती है।

File file = new File(“c:\\pictures\\boy.jpg”);
Texture t = textureIO.newTexture(file, true);
texture = t.getTextureObject(gl);
  • 'फ़ाइल नहीं मिली' अपवाद को हैंडल करें

नीचे दिए गए एक क्यूब पर छवि संलग्न करने का कार्यक्रम है।

import java.awt.DisplayMode;

import java.io.File;
import java.io.IOException;

import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;

import javax.swing.JFrame;

import com.jogamp.opengl.util.FPSAnimator;
import com.jogamp.opengl.util.texture.Texture;
import com.jogamp.opengl.util.texture.TextureIO;

public class CubeTexture implements GLEventListener {

   public static DisplayMode dm, dm_old;
   private GLU glu = new GLU();
   private float xrot,yrot,zrot;
   private int texture;
   
   @Override
   public void display(GLAutoDrawable drawable) {
   
      // TODO Auto-generated method stub
      final GL2 gl = drawable.getGL().getGL2();
      gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
      gl.glLoadIdentity(); // Reset The View
      gl.glTranslatef(0f, 0f, -5.0f);
		
      gl.glRotatef(xrot, 1.0f, 1.0f, 1.0f);
      gl.glRotatef(yrot, 0.0f, 1.0f, 0.0f);
      gl.glRotatef(zrot, 0.0f, 0.0f, 1.0f);
		
      gl.glBindTexture(GL2.GL_TEXTURE_2D, texture);
      gl.glBegin(GL2.GL_QUADS);

      // Front Face
      gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, 1.0f);
      gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, 1.0f);
      gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, 1.0f);
      gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, 1.0f);

      // Back Face
      gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, -1.0f);
      gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, -1.0f);
      gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, -1.0f);
      gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, -1.0f);

      // Top Face
      gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, -1.0f);
      gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f(-1.0f, 1.0f, 1.0f);
      gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f( 1.0f, 1.0f, 1.0f);
      gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, -1.0f);

      // Bottom Face
      gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f(-1.0f, -1.0f, -1.0f);
      gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f( 1.0f, -1.0f, -1.0f);
      gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, 1.0f);
      gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, 1.0f);

      // Right face
      gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, -1.0f);
      gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, -1.0f);
      gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, 1.0f);
      gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, 1.0f);

      // Left Face
      gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, -1.0f);
      gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, 1.0f);
      gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, 1.0f);
      gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, -1.0f);
      gl.glEnd();
      gl.glFlush();

      //change the speeds here
      xrot += .1f;
      yrot += .1f;
      zrot += .1f;
   }
   
   @Override
   public void dispose(GLAutoDrawable drawable) {
      // method body
   }
   
   @Override
   public void init(GLAutoDrawable drawable) {
	
      final GL2 gl = drawable.getGL().getGL2();
		
      gl.glShadeModel(GL2.GL_SMOOTH);
      gl.glClearColor(0f, 0f, 0f, 0f);
      gl.glClearDepth(1.0f);
      gl.glEnable(GL2.GL_DEPTH_TEST);
      gl.glDepthFunc(GL2.GL_LEQUAL);
      gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST);
      
      //
      gl.glEnable(GL2.GL_TEXTURE_2D);
      try{
		
         File im = new File("E:\\office\\boy.jpg ");
         Texture t = TextureIO.newTexture(im, true);
         texture= t.getTextureObject(gl);
          
      }catch(IOException e){
         e.printStackTrace();
      }
   }
      
   @Override
   public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
   
      // TODO Auto-generated method stub
      final GL2 gl = drawable.getGL().getGL2();
      if(height lt;= 0)
         height = 1;
			
      final float h = (float) width / (float) height;
      gl.glViewport(0, 0, width, height);
      gl.glMatrixMode(GL2.GL_PROJECTION);
      gl.glLoadIdentity();
		
      glu.gluPerspective(45.0f, h, 1.0, 20.0);
      gl.glMatrixMode(GL2.GL_MODELVIEW);
      gl.glLoadIdentity();
   }
   
   public static void main(String[] args) {
   
      // TODO Auto-generated method stub
      final GLProfile profile = GLProfile.get(GLProfile.GL2);
      GLCapabilities capabilities = new GLCapabilities(profile);
      
      // The canvas
      final GLCanvas glcanvas = new GLCanvas(capabilities);
      CubeTexture r = new CubeTexture();
		
      glcanvas.addGLEventListener(r);
      glcanvas.setSize(400, 400);
		
      final JFrame frame = new JFrame (" Textured Cube");
      frame.getContentPane().add(glcanvas);
      frame.setSize(frame.getContentPane().getPreferredSize());
      frame.setVisible(true);
      final FPSAnimator animator = new FPSAnimator(glcanvas, 300, true);
		
      animator.start();
   }
	
}

जब आप उपरोक्त प्रोग्राम को संकलित और निष्पादित करते हैं, तो निम्न आउटपुट उत्पन्न होता है। आप उस पर लागू वांछित बनावट के साथ एक 3 डी क्यूब देख सकते हैं।

GPU - ग्राफिकल प्रोसेसिंग यूनिट, यह एक विशेष इलेक्ट्रॉनिक उपकरण है जो छवियों के प्रतिपादन को तेज करता है।

JNI- जावा नेटिव इंटरफ़ेस। जिसका उपयोग करते हुए, जावा देशी तरीकों का उपयोग करता है।

Model - वे मूल ग्राफिक्स आदिम से निर्मित वस्तुएं हैं जैसे कि बिंदु, रेखा और बहुभुज।

Pixel - स्क्रीन पर दिखाई देने वाली सबसे छोटी इकाई।

Projection - दो-आयामी विमान में किसी वस्तु के निर्देशांक को मैप करने की विधि को प्रक्षेपण कहा जाता है।

Projection matrix - यह 2 डी सतह पर किसी वस्तु का रैखिक परिवर्तन है।

Rendering - एक प्रक्रिया जिसके द्वारा कंप्यूटर मॉडल से चित्र बनाता है।

Viewport - एक व्यूपोर्ट कंप्यूटर ग्राफिक्स में स्क्रीन पर देखने का क्षेत्र है।