إعلان
دورة تطوير التطبيقات باستخدام لغة JavaScript في هذه الدورة ستتعلم لغة جافا سكريبت, استخدام مكتبة React.js, بناء API الموقع بواسطة Node.js, تطوير تطبيق جوال باستخدام React Native, و في نهاية الدورة ستتعلم تطوير تطبيق محادثة شبيه بتطبيق WhatsApp. تعلم الآن
دورة تطوير واجهات المستخدم في هذه الدورة ستتعلم لغة HTML و لغة CSS و لغة JavaScript. من ناحية التطبيق العملي ستتعلم طريقة بناء واجهة متجر إلكتروني مكون من ست صفحات, تحويل خمسة تصاميم PSD إلى صفحات ويب, بناء واجهة مستخدم تشبه موقع يوتيوب, بناء لوحة تحكم إحترافية. تعلم الآن
تطوير تطبيقات باستخدام لغة بايثون في هذه الدورة ستتعلم أساسيات البرمجة بلغة بايثون وصولاً إلى التعامل مع أشهر أطر العمل (Flask و Django) و ستتعلم كيف تبني متجر إلكتروني يمكن للمستخدمين البيع و الشراء من خلاله. تعلم الآن
دورة تطوير تطبيقات الويب باستخدام لغة PHP في هذه الدورة ستتعلم لغة PHP من الصفر, استخدام إطار العمل Laravel بشرح مفصّل و عملي, كيفية تطوير شبكة اجتماعية تشبه Instagram, بناء API لتطبيق جوال وفق أسلوب RESTful, تطوير موقع إعلانات مبوبة, تطوير نظام إدارة محتوى CMS كامل. تعلم الآن
دورة تطوير تطبيقات الويب باستخدام لغة Ruby في هذه الدورة ستتعلم البرمجة بلغة Ruby إنطلاقاً من أبسط المفاهيم وحتى بناء تطبيق حقيقي, إستخدام إطار العمل Ruby on Rails بشرح مفصّل و عملي, بناء تطبيق حقيقي عبارة عن شبكة اجتماعية تشبه تويتر, تطوير مجتمع الكتروني يشبه حسوب I/O. تعلم الآن
دورة علوم الحاسوب هذه الدورة معدة لتكون مدخل لعلوم الحاسوب و لغات البرمجة حيث ستتعرف فيها على أنظمة التشغيل و ستتعمق في نظام لينكس و في كيفية التعامل معه من خلال موجه الأوامر, بالإضافة إلى قواعد البيانات و أساسيات الشبكات و الخوادم و مبادئ الحماية والأمان في الويب. تعلم الآن

    JavaFX مثال حول الكلاس Path و الكلاس PathElement

    في حال كنت تريد بناء شكل معقد لا يشبه أي شكل من الأشكل التي تعلمت طريقة رسمها من الأمثلة السابقة, يمكنك إستخدام الكلاس Path و الكلاسات التي ترث من الكلاس PathElement لرسم الشكل الذي تريده.

    الآن, الشكل الواحد الذي تريد رسمه يمكنك تقسميه لعدة أجزاء مما يجعلك قادر على إعطاء لون خاص لكل جزء في هذا الشكل و إضافة مؤثرات عليه.
    كل جزء تنوي وضعه في الشكل سيكون عبارة عن كائن من الكلاس Path. و أول نقطة تضعها في كل جزء ستكون عبارة عن كائن من الكلاس MoveTo.

    أي خط تنوي وضعه بعد وضع النقطة الأولى, سيكن عبارة عن كائن من إحدى الكلاسات التالية:

    • LineTo: في حال كنت تنوي رسم خط مستقيم.
    • HLineTo: في حال كنت تنوي رسم خط مستقيم أفقي.
    • VLineTo: في حال كنت تنوي رسم خط مستقيم عامودي.
    • QuadCurveTo: في حال كنت تنوي رسم منحنى رباعي.
    • CubicCurveTo: في حال كنت تنوي رسم منحنى مكعب.
    • ArcTo: في حال كنت تنوي رسم خط بيضاوي أو دائري.

    المثال التالي يعلمك طريقة رسم أي شكل تريد و تلوينه, و من ثم إضافته في النافذة.

    مثال

    Main.java
    import javafx.application.Application;
    import javafx.scene.Group;
    import javafx.scene.Scene;
    import javafx.scene.paint.Color;
    import javafx.scene.shape.LineTo;
    import javafx.scene.shape.MoveTo;
    import javafx.scene.shape.Path;
    import javafx.scene.shape.QuadCurveTo;
    import javafx.stage.Stage;
    
    public class Main extends Application {
    
        @Override
        public void start(Stage stage) {
    
    		// و الذي سيمثل الجزء الأعلى الذي ننوي رسمه في النافذة Path هنا قمنا بإنشاء كائن من الكلاس
    		// يمثل النقطة الأولى في هذا الجزء MoveTo بعدها قمنا بإنشاء كائن من الكلاس
    		// يمثل النقطة التي سيقف عندها المنحنى الرباعي و النقطة التي سينجذب إليها في هذا الجزء QuadCurveTo بعدها قمنا بإنشاء كائن من الكلاس
            Path path1 = new Path();
            MoveTo move1 = new MoveTo(150, 100);
            QuadCurveTo quadCurve = new QuadCurveTo();
            quadCurve.setX(250);
            quadCurve.setY(100);
            quadCurve.setControlX(200);
            quadCurve.setControlY(0);
            
    		// أبيض و جعلنا حدوده أكثر سمكاً path1 هنا جعلنا لون داخل الكائن
            path1.setFill(Color.WHITE);
            path1.setStrokeWidth(3);
    
            // حتى نربطهم مع بعض path1 في الكائن quadCurve و move1 هنا قمنا بإضافة الكائنين
            path1.getElements().addAll(move1, quadCurve);
    
    		// و الذي سيمثل الجزء الأسفل الذي ننوي رسمه في النافذة Path هنا قمنا بإنشاء كائن من الكلاس
    		// يمثل النقطة الأولى في هذا الجزء MoveTo بعدها قمنا بإنشاء كائن من الكلاس
    		// يمثل النقاط التي سيقف عندها كل خط مستقيم في هذا الجزء LineTo بعدها قمنا بإنشاء ثلاث كائنات من الكلاس
            Path path2 = new Path();
            MoveTo move2 = new MoveTo(150, 100);
            LineTo line1 = new LineTo(250, 100);
            LineTo line2 = new LineTo(200, 220);
            LineTo line3 = new LineTo(150, 100);
    
            // حتى نربطهم مع بعض path2 في الكائن line3 ,line2 line1 و move2 هنا قمنا بإضافة الكائنان
            path2.getElements().addAll(move2, line1, line2, line3);
            
    		// بني فاتح و جعلنا حدوده أكثر سمكاً path2 هنا جعلنا لون داخل الكائن
            path2.setFill(Color.GOLDENROD);
            path2.setStrokeWidth(3);
    
            // في النافذة Root Node لأننا ننوي جعله الـ Group هنا قمنا بإنشاء كائن من الكلاس
            Group root = new Group();
            
            // root في الكائن svgPath هنا قمنا بإضافة الكائن
            root.getChildren().addAll(path1, path2);
    
            // فيها و تحديد حجمها Node كأول root هنا قمنا بإنشاء محتوى النافذة مع تعيين الكائن
            Scene scene = new Scene(root, 400, 270);
            
    		// أخضر, أي كأننا قمنا بتغيير لون خلفية النافذة scene هنا قمنا بجعل لون الكائن
            scene.setFill(Color.PALEGREEN);
    
            // هنا وضعنا عنوان للنافذة
            stage.setTitle("JavaFX Path & PathElement");
    
            // أي وضعنا محتوى النافذة الذي قمنا بإنشائه للنافذة .stage في كائن الـ scene هنا وضعنا كائن الـ
            stage.setScene(scene);
    
            // هنا قمنا بإظهار النافذة
            stage.show();
    
        }
    
        // هنا قمنا بتشغيل التطبيق
        public static void main(String[] args) {
            launch(args);
        }
    
    }
    		

    ستظهر لك النافذة التالية عند التشغيل.

    مثال حول الكلاس Path و الكلاسات التي ترث من الكلاس PathElement في javafx
    إعلان

    Eqla3Tech.com

    شروحات مكتوبة حول لغات البرمجة و تقنية المعلومات باللغة العربية مقدمة من إقلاع تك.

    لغة جافا لغة ++C قواعد البيانات نظام ويندوز نظام لينكس الشبكات تقنية المعلومات الأمن السيبراني

    الدورات

    أدوات مساعدة

    الأقسام

    دورات
    مقالات أسئلة مشاريع كتب