जावाएफएक्स - 2 डी आकार

पिछले अध्याय में, हमने JavaFX के मूल एप्लिकेशन को देखा है, जहाँ हमने सीखा कि कैसे एक खाली विंडो तैयार की जाए और JavaFX के XY विमान पर एक रेखा कैसे खींची जाए। रेखा के अतिरिक्त, हम कई अन्य 2D आकृतियाँ भी बना सकते हैं।

2 डी आकार

सामान्य तौर पर, एक 2 डी आकार एक ज्यामितीय आकृति है जिसे एक्सवाई विमान पर खींचा जा सकता है, इनमें रेखा, आयत, वृत्त आदि शामिल हैं।

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

  • पूर्वनिर्धारित आकृतियाँ जैसे रेखा, आयत, वृत्त, दीर्घवृत्त, बहुभुज, बहुभुज, घन वक्र, चतुर्थ वक्र, चाप।

  • पथ तत्व जैसे कि मूवमेंटो पाथ एलिमेंट, लाइन, हॉरिजॉन्टल लाइन, वर्टिकल लाइन, क्यूबिक कर्व, क्वाड्रेटिक कर्व, आर्क।

  • इनके अतिरिक्त, आप SVG पथ को पार्स करके 2 डी आकार भी बना सकते हैं।

उपर्युक्त 2 डी आकार में से प्रत्येक को एक वर्ग द्वारा दर्शाया गया है और ये सभी वर्ग पैकेज के हैं javafx.scene.shape। नाम का वर्गShape जावाएफएक्स में सभी 2-आयामी आकृतियों का आधार वर्ग है।

2 डी आकार बनाना

एक चार्ट बनाने के लिए, आपको निम्न करना होगा -

  • आवश्यक आकार के संबंधित वर्ग को तुरंत लिखें।
  • आकृति के गुणों को निर्धारित करें।
  • समूह में आकृति ऑब्जेक्ट जोड़ें।

रिस्पांसिबल क्लास को इंस्टेंट करना

2 डायमेंशनल शेप बनाने के लिए, सबसे पहले आपको इसकी संबंधित क्लास को तुरंत इंट्रोड्यूस करना होगा।

उदाहरण के लिए, यदि आप एक लाइन बनाना चाहते हैं, तो आपको निम्न के रूप में लाइन नाम के वर्ग को तुरंत भरने की आवश्यकता है -

Line line = new Line();

आकृति के गुण सेट करना

कक्षा को तुरंत करने के बाद, आपको सेटर विधियों का उपयोग करके आकार के लिए गुण सेट करने की आवश्यकता है।

उदाहरण के लिए, एक रेखा खींचने के लिए आपको इसके बिंदु के आरंभ बिंदु और अंतिम बिंदु के x और y निर्देशांक को पास करना होगा। आप इन मूल्यों को उनके संबंधित सेटर तरीकों का उपयोग करके निर्दिष्ट कर सकते हैं -

//Setting the Properties of the Line 
line.setStartX(150.0f); 
line.setStartY(140.0f);         
line.setEndX(450.0f); 
line.setEndY(140.0f);

समूह में आकार वस्तु जोड़ना

अंत में, आपको आकृति के ऑब्जेक्ट को निर्माता के पैरामीटर के रूप में पास करके समूह में जोड़ना होगा जैसा कि नीचे दिखाया गया है।

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

निम्न तालिका आपको JavaFX द्वारा प्रदान की गई विभिन्न आकृतियों (वर्गों) की सूची देती है।

S.No आकार और विवरण
1 लाइन

एक रेखा दो बिंदुओं को मिलाने वाली एक ज्यामितीय संरचना है। Line पैकेज की कक्षा javafx.scene.shape XY विमान में एक लाइन का प्रतिनिधित्व करता है।

2 आयत

सामान्य तौर पर, एक आयत एक चार-तरफा बहुभुज होता है जिसमें सभी आंतरिक कोणों के साथ समानांतर और समवर्ती पक्षों के दो जोड़े होते हैं। जावाएफएक्स में, एक आयत नाम के एक वर्ग द्वारा दर्शाया गया हैRectangle। यह वर्ग पैकेज का हैjavafx.scene.shape

3 गोलाकार आयत

JavaFX में, आप आयत को या तो नुकीले किनारों से या धनुषाकार किनारों से खींच सकते हैं और धनुषाकार किनारों के साथ एक गोल आयत के रूप में जाना जाता है।

4 वृत्त

एक सर्कल एक बंद लूप बनाने वाली रेखा है, जिसके प्रत्येक बिंदु पर केंद्र बिंदु से एक निश्चित दूरी है। जावाएफएक्स में, एक सर्कल का प्रतिनिधित्व एक वर्ग द्वारा किया जाता है जिसका नाम हैCircle। यह वर्ग पैकेज का हैjavafx.scene.shape

5 अंडाकार

एक दीर्घवृत्त को दो बिंदुओं द्वारा परिभाषित किया जाता है, प्रत्येक को फोकस कहा जाता है। यदि दीर्घवृत्त पर कोई बिंदु लिया जाता है, तो फ़ोकस पॉइंट के लिए दूरी का योग स्थिर होता है। दीर्घवृत्त का आकार इन दो दूरियों के योग से निर्धारित होता है।

जावाएफएक्स में, एक दीर्घवृत्त का प्रतिनिधित्व एक वर्ग द्वारा किया जाता है जिसका नाम है Ellipse। यह वर्ग पैकेज का हैjavafx.scene.shape

6 बहुभुज

एक बंद आकार जो कई कोपलर लाइन खंडों से बनता है जो अंत से अंत तक जुड़ा हुआ है। जावाएफएक्स में, बहुभुज का प्रतिनिधित्व एक वर्ग द्वारा किया जाता है जिसका नाम हैPolygon। यह वर्ग पैकेज का हैjavafx.scene.shape

7 पॉलीलाइन

एक पॉलीलाइन एक बहुभुज है सिवाय इसके कि एक पॉलीलाइन अंत में बंद नहीं है। या, एक या एक से अधिक सेगमेंट से बना निरंतर लाइन। जावाएफएक्स में, एक पॉलीलाइन नाम के एक वर्ग द्वारा दर्शाया गया हैPolygon। यह वर्ग पैकेज का हैjavafx.scene.shape

8 घन वक्र

एक क्यूबिक वक्र XY विमान में एक बेजियर पैरामीट्रिक वक्र है जो डिग्री 3 का एक वक्र है। JavaFX में, क्यूबिक कर्व को एक वर्ग द्वारा दर्शाया गया है जिसका नाम है CubicCurve। यह वर्ग पैकेज का हैjavafx.scene.shape

9 QuadCurve

एक द्विघात वक्र XY विमान में एक बेजियर पैरामीट्रिक वक्र है जो डिग्री 2 का एक वक्र है। JavaFX में, QuadCurve को QuadCurve नामक एक वर्ग द्वारा दर्शाया गया है। यह वर्ग पैकेज का हैjavafx.scene.shape

10 आर्क

एक चाप एक वक्र का हिस्सा है। JavaFX में, एक आर्क को एक वर्ग द्वारा दर्शाया जाता है जिसका नाम हैArc। यह वर्ग पैकेज का है -javafx.scene.shape

आर्क के प्रकार

इसके अतिरिक्त हम तीन प्रकार के आर्क आकर्षित कर सकते हैं Open, Chord, Round

1 1 SVGPath

जावाएफएक्स में, हम एसवीजी पथों को पार्स करके चित्र बना सकते हैं। इस तरह की आकृतियों को नामांकित वर्ग द्वारा दर्शाया जाता हैSVGPath। यह वर्ग पैकेज का हैjavafx.scene.shape। इस वर्ग के नाम पर एक संपत्ति हैcontentस्ट्रिंग डेटाटाइप की। यह एसवीजी पथ एन्कोडेड स्ट्रिंग का प्रतिनिधित्व करता है, जिसमें से छवि खींची जानी चाहिए।

पाथ क्लास के माध्यम से अधिक आकृतियाँ बनाना

पिछले खंड में, हमने देखा है कि कैसे तात्कालिक कक्षाओं द्वारा और संबंधित मापदंडों को निर्धारित करके कुछ सरल पूर्वनिर्धारित आकृतियों को आकर्षित करना है।

लेकिन, बस इन पूर्वनिर्धारित आकृतियों के द्वारा प्रदान की गई आदिमताओं के अलावा जटिल आकार बनाने के लिए पर्याप्त नहीं हैं javafx.shape package

उदाहरण के लिए, यदि आप निम्न चित्र में दिखाए अनुसार चित्रमय तत्व खींचना चाहते हैं, तो आप उन सरल आकृतियों पर भरोसा नहीं कर सकते।

द पाथ क्लास

ऐसी जटिल संरचनाओं को आकर्षित करने के लिए जावाएफ़एक्स नामक एक वर्ग प्रदान करता है Path। यह वर्ग किसी आकृति की ज्यामितीय रूपरेखा का प्रतिनिधित्व करता है।

यह एक अवलोकनीय सूची से जुड़ा हुआ है जो विभिन्न धारण करता है Path Elements जैसे कि MoveTo, LineTo, HlineTo, VlineTo, ArcTo, QuadCurveTo, CubicCurveTo।

त्वरित करने पर, यह वर्ग दिए गए पथ तत्वों के आधार पर एक पथ का निर्माण करता है।

आप इस वर्ग के लिए पथ तत्वों को पास कर सकते हैं, जबकि इसे निम्न प्रकार से बदल सकते हैं

Path myshape = new Path(pathElement1, pathElement2, pathElement3);

या, आप अवलोकन सूची प्राप्त कर सकते हैं और उपयोग करने वाले सभी पथ तत्वों को जोड़ सकते हैं addAll() विधि इस प्रकार है -

Path myshape = new Path(); 
myshape.getElements().addAll(pathElement1, pathElement2, pathElement3);

आप ऐड () विधि का उपयोग करके व्यक्तिगत रूप से तत्व भी जोड़ सकते हैं -

Path myshape = new Path(); 
myshape.getElements().add(pathElement1);

पथ तत्व के लिए कदम

पथ तत्व MoveToपथ की वर्तमान स्थिति को एक निर्दिष्ट बिंदु पर ले जाने के लिए उपयोग किया जाता है। इसका उपयोग आम तौर पर पथ तत्वों का उपयोग करके तैयार की गई आकृति के शुरुआती बिंदु को सेट करने के लिए किया जाता है।

इसका प्रतिनिधित्व एक वर्ग द्वारा किया जाता है LineTo पैकेज का javafx.scene.shape। इसमें डबल डेटाटाइप के 2 गुण हैं -

  • X - x उस बिंदु का समन्वय करता है, जिस पर वर्तमान स्थिति से एक रेखा खींची जानी है।

  • Y - y उस बिंदु का समन्वय करता है जिस पर एक रेखा को वर्तमान स्थिति से खींचना है।

आप MoveTo क्लास को तुरंत इंस्टाल करके और नए बिंदु के x, y निर्देशांक जैसे पथ तत्व के लिए एक चाल बना सकते हैं: -

MoveTo moveTo = new MoveTo(x, y);

यदि आप कंस्ट्रक्टर को कोई मान नहीं देते हैं, तो नया बिंदु (0,0) पर सेट हो जाएगा।

आप अपने संबंधित सेटर विधियों का उपयोग करते हुए मानों को x, y समन्वय में भी सेट कर सकते हैं -

setX(value); 
setY(value);

उदाहरण - एक जटिल पथ खींचना

इस उदाहरण में, हम यह दिखाएंगे कि निम्न आकृति का उपयोग कैसे करें Path, MoveTo तथा Line कक्षाएं।

इस कोड को नाम वाली फ़ाइल में सहेजें ComplexShape.java

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.stage.Stage; 
import javafx.scene.shape.LineTo; 
import javafx.scene.shape.MoveTo; 
import javafx.scene.shape.Path; 
         
public class ComplexShape extends Application { 
   @Override 
   public void start(Stage stage) { 
      //Creating a Path 
      Path path = new Path(); 
       
      //Moving to the starting point 
      MoveTo moveTo = new MoveTo(108, 71); 
        
      //Creating 1st line 
      LineTo line1 = new LineTo(321, 161);  
       
      //Creating 2nd line 
      LineTo line2 = new LineTo(126,232);       
       
      //Creating 3rd line 
      LineTo line3 = new LineTo(232,52);  
       
      //Creating 4th line 
      LineTo line4 = new LineTo(269, 250);   
       
      //Creating 4th line 
      LineTo line5 = new LineTo(108, 71);  
       
      //Adding all the elements to the path 
      path.getElements().add(moveTo); 
      path.getElements().addAll(line1, line2, line3, line4, line5);        
         
      //Creating a Group object  
      Group root = new Group(path); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Drawing an arc through a path");
      
      //Adding scene to the stage 
      stage.setScene(scene);
      
      //Displaying the contents of the stage 
      stage.show();         
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

निम्न कमांड का उपयोग करके कमांड प्रॉम्प्ट से सहेजे गए जावा फ़ाइल को संकलित और निष्पादित करें।

javac ComplexShape.java 
java ComplexShape

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

JavaFX द्वारा प्रदान किए गए विभिन्न पथ तत्व (कक्षाएं) निम्नलिखित हैं। ये कक्षाएं पैकेज में मौजूद हैंjavafx.shape। इन सभी वर्गों को वर्ग विरासत में मिला हैPathElement

S.No आकार और विवरण
1 LineTo

पथ तत्व lineवर्तमान स्थिति से निर्दिष्ट निर्देशांक में एक बिंदु पर एक सीधी रेखा खींचने के लिए उपयोग किया जाता है। इसका प्रतिनिधित्व एक वर्ग द्वारा किया जाता हैLineTo। यह वर्ग पैकेज का हैjavafx.scene.shape

2 HlineTo

पथ तत्व HLineToवर्तमान स्थिति से निर्दिष्ट निर्देशांक में एक बिंदु पर एक क्षैतिज रेखा खींचने के लिए उपयोग किया जाता है। इसका प्रतिनिधित्व एक वर्ग द्वारा किया जाता हैHLineTo। यह वर्ग पैकेज का हैjavafx.scene.shape

3 VLineTo

पथ तत्व vertical lineवर्तमान स्थिति से निर्दिष्ट निर्देशांक में एक बिंदु तक एक ऊर्ध्वाधर रेखा खींचने के लिए उपयोग किया जाता है। इसका प्रतिनिधित्व एक वर्ग द्वारा किया जाता हैVLineTo। यह वर्ग पैकेज का हैjavafx.scene.shape

4 QuadCurveTo

पथ तत्व द्विघात वक्र को खींचने के लिए उपयोग किया जाता है quadratic curveवर्तमान स्थिति से निर्दिष्ट निर्देशांक में एक बिंदु पर। इसका प्रतिनिधित्व एक वर्ग द्वारा किया जाता हैQuadraticCurveTo। यह वर्ग पैकेज का हैjavafx.scene.shape

5 CubicCurveTo

पथ तत्व cubic curveवर्तमान स्थिति से निर्दिष्ट निर्देशांक में एक बिंदु तक एक घन वक्र खींचने के लिए उपयोग किया जाता है। इसका प्रतिनिधित्व एक वर्ग द्वारा किया जाता हैCubicCurveTo। यह वर्ग पैकेज का हैjavafx.scene.shape

6 ArcTo

पथ तत्व Arcवर्तमान स्थिति से निर्दिष्ट निर्देशांक में एक बिंदु पर एक चाप खींचने के लिए उपयोग किया जाता है। इसका प्रतिनिधित्व एक वर्ग द्वारा किया जाता हैArcTo। यह वर्ग पैकेज का हैjavafx.scene.shape

2 डी वस्तुओं के गुण

सभी 2-आयामी वस्तुओं के लिए, आप विभिन्न गुणों को भर सकते हैं जैसे भरण, आघात, स्ट्रोक, आदि। निम्न खंड में 2 डी वस्तुओं के विभिन्न गुणों की चर्चा की गई है।

  • स्ट्रोक का प्रकार
  • रेखा की चौड़ाई
  • भर दे
  • Stroke
  • स्ट्रोक की रेखा
  • स्ट्रोक मैटर लिमिट
  • स्ट्रोक लाइन कैप
  • Smooth

2 डी वस्तुओं पर संचालन

यदि हम एक समूह में एक से अधिक आकार जोड़ते हैं, तो पहले आकार को दूसरे के द्वारा ओवरलैप किया जाता है जैसा कि नीचे दिखाया गया है।

परिवर्तनों (घुमाएँ, पैमाने, अनुवाद, इत्यादि), संक्रमण (एनिमेशन) के अलावा, आप 3 डी संचालन पर तीन ऑपरेशन भी कर सकते हैं, जैसे - Union, Subtraction तथा Intersection

S.No ऑपरेशन का वर्णन
1 संघ संचालन

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

2 चौराहे का संचालन

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

3 घटाव संचालन

यह ऑपरेशन इनपुट के रूप में दो या अधिक आकार लेता है। फिर, यह दूसरे के अतिव्यापी क्षेत्र को छोड़कर पहली आकृति का क्षेत्र लौटाता है।