JOGL - बुनियादी टेम्पलेट के लिए एपीआई
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) यह विधि दी गई श्रोता को इस आकर्षित करने योग्य कतार के दिए गए सूचकांक में जोड़ती है। |