जावाएफएक्स - 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 | घटाव संचालन यह ऑपरेशन इनपुट के रूप में दो या अधिक आकार लेता है। फिर, यह दूसरे के अतिव्यापी क्षेत्र को छोड़कर पहली आकृति का क्षेत्र लौटाता है। |