انتقل إلى المحتوى

ثري.جي إس

هذه المقالة يتيمة. ساعد بإضافة وصلة إليها في مقالة متعلقة بها
هذه المقالة أو أجزاء منها بحاجة لإعادة كتابة.
من ويكيبيديا، الموسوعة الحرة

ثري.جي إس (بالإنجليزية: Three.js)‏ هي مكتبة جافاسكريبت تستخدم مع متصفحات الويب وواجهة برمجة تطبيقات (API) ولإنشاء رسومات كمبيوتر متحركة ثلاثية الأبعاد وعرضها في مستعرض ويب باستخدام ويب جي إل . الكود الأصلي موجود في مستودع على غيت هاب .[6]

نظرة عامة

[عدل]

تسمح ثري.جي إس بإنشاء رسوم متحركة ثلاثية الأبعاد يتم تسريعها باستخدام وحدة المعالجة الرسومية (GPU) باستخدام لغة جافاسكريبت كجزء من موقع ويب دون الاعتماد على المكونات الإضافية للمتصفح .[7][8] هذا ممكن بسبب ظهور تقنية الـوب جي إل، [9] وهو واجهة برمجة تطبيقات ( API ) رسومية منخفضة المستوى تم إنشاؤها خصيصًا للويب.[10]

تتيح المكتبات عالية المستوى مثل ثري.جي إس أو GLGE و سين جي إس و فيلو جي إل وغيرها الكثير إمكانية تأليف رسوم متحركة معقدة ثلاثية الأبعاد للكمبيوتر لعرضها في المتصفح دون بذل الجهد المطلوب لتطبيق تقليدي مستقل أو إضافة للمتصفح.[11]

التاريخ

[عدل]

تم إصدار ثري.جي إس لأول مرة بواسطة ريكاردو كابيلو على غيت هاب في أبريل 2010. يمكن إرجاع أصول المكتبة إلى مشاركته في الديموسين في أوائل القرن الحادي والعشرين.[12] تم تطوير الكود في الأصل بلغة أكشن سكربت التي يستخدمها أدوبي فلاش، ثم تم نقله لاحقًا إلى جاقا سكريبت في عام 2009. في ذهن كابيبلو ، كانت هناك نقطتان قويتان بررتا تخليه عن أكشن سكريبت: أولاً، قدمت جافا سكريبت استقلالية أكبر للنظام الأساسي. ثانيًا، لن تحتاج التطبيقات المكتوبة بلغة جافاسكريبت إلى أن يجمعها المطور مسبقًا، على عكس تطبيقات فلاش.

تشمل المساهمات الإضافية من كابيلو تصميم آبي، وكانفا رينديرير، وSVGRenderer، كونها مسؤولة عن دمج الـ Commits من قبل المساهمين المختلفين في المشروع.

مع ظهور وب جي إل، تمكن بول برنت من تنفيذ تقنية العرض الجديدة بسهولة تامة حيث تم تصميم ثري.جي إس باستخدام كود العرض كـمودل وليس كإضافة جوهره.[13] بدأ Branislav Uličný ، أحد المساهمين الأوائل، بـ ثري.جي إس في عام 2010 بعد أن نشر عددًا من عروض وب جي إل التوضيحية على موقعه الخاص. لقد أراد إمكانات عارض وب جي إل في ثري.جي إس لتتجاوز قدرات CanvasRenderer أو SVGRenderer.[13] تشمل مساهماته الرئيسية بشكل عام المواد والتظليل والمعالجة اللاحقة.

بعد فترة وجيزة من تقديم وب جي إل 1.0 على فايروفوكس 4 في مارس 2011 ، انضم جوشوا كو. قام ببناء أول عرض توضيحي لـ ثري.جي إس للنص ثلاثي الأبعاد في سبتمبر 2011.[14] غالبًا ما تتعلق مساهماته بتوليد الهندسة.

لدى ثري.جي إس أكثر من 1500 مساهم على غيت هاب.[15]

الميزات

[عدل]

يتضمن ثري.جي إس الميزات التالية:[16]

  • التأثيرات.
  • المشاهد: إضافة وإزالة الكائنات في وقت التشغيل ؛ ضباب
  • الكاميرات: المنظور والحركات. وحدات التحكم: كرة التتبع و FPS والمسار والمزيد
  • الرسوم المتحركة: التركيبات ، الحركية إلى الأمام ، الحركية العكسية ، التحويل ، والإطار الرئيسي
  • الأضواء: الأضواء المحيطة ، والاتجاه ، والنقطة ، والنقطة ؛ الظلال: يلقي ويستقبل
  • المواد: لامبرت وفونج والتظليل الناعم والقوام والمزيد
  • Shaders: الوصول إلى إمكانات OpenGL Shading Language ( GLSL ) الكاملة: توهج العدسة ، وتمرير العمق ، ومكتبة ما بعد المعالجة الشاملة
  • الكائنات: الشبكات والجزيئات والعفاريت والخطوط والشرائط والعظام والمزيد - كل ذلك بمستوى التفاصيل
  • الهندسة: المستوى ، المكعب ، الكرة ، الحلقة ، النص ثلاثي الأبعاد ، والمزيد ؛ المعدلات: مخرطة ، بثق ، وأنبوب
  • برامج تحميل البيانات: ثنائي ، وصورة ، و JSON ، ومشهد
  • الأدوات المساعدة: مجموعة كاملة من وظائف الوقت والرياضيات ثلاثية الأبعاد بما في ذلك frustum ، و matrix ، و quaternion ، و UVs ، والمزيد
  • التصدير والاستيراد: أدوات مساعدة لإنشاء ملفات JSON متوافقة مع Three.js من الداخل: Blender و openCTM و FBX و Max و OBJ
  • الدعم: وثائق API قيد الإنشاء. المنتدى العام وويكي يعملان بشكل كامل.
  • أمثلة: أكثر من 150 ملفًا من أمثلة الترميز بالإضافة إلى الخطوط والنماذج والأنسجة والأصوات وملفات الدعم الأخرى
  • تصحيح الأخطاء: Stats.js ، [17] WebGL Inspector ، [18] Three.js Inspector [19]
  • الواقع الافتراضي والواقع المعزز عبر WebXR [20]

يعمل Three.js في جميع المتصفحات التي يدعمها WebGL 1.0.

يتم توفير Three.js بموجب ترخيص MIT .

أنظر أيضا

[عدل]

مراجع

[عدل]
  1. ^ ا ب "Three.js/license". github.com/mrdoob. مؤرشف من الأصل في 2023-03-18. اطلع عليه بتاريخ 2012-05-20.
  2. ^ ا ب وصلة مرجع: https://api.github.com/repos/mrdoob/three.js. الوصول: 30 يوليو 2018.
  3. ^ ا ب الوصول: 3 أغسطس 2022. وصلة مرجع: https://registry.npmjs.org/three.
  4. ^ ا ب "npmjs". اطلع عليه بتاريخ 2023-04-09.
  5. ^ ا ب "Release 161". 31 يناير 2024. اطلع عليه بتاريخ 2024-02-20.
  6. ^ Mr.doob (4 مارس 2021)، mrdoob/three.js، مؤرشف من الأصل في 2023-01-08، اطلع عليه بتاريخ 2021-03-04
  7. ^ O3D
  8. ^ يونيتي (محرك ألعاب)
  9. ^ "Khronos Releases Final WebGL 1.0 Specification". Khronos Group. 3 مارس 2011. مؤرشف من الأصل في 2023-01-27. اطلع عليه بتاريخ 2012-06-02.
  10. ^ "WebGL". The Khronos Group (بالإنجليزية). 19 Jul 2011. Archived from the original on 2023-01-17. Retrieved 2022-01-22.
  11. ^ Crossley، Rob (11 يناير 2010). "Study: Average dev costs as high as $28m". Intent Media Ltd. مؤرشف من الأصل في 2010-01-13. اطلع عليه بتاريخ 2012-06-02.
  12. ^ NVScene. "NVScene 2015 Session: Reinventing The Wheel - One Last Time (Ricardo Cabello)". YouTube. مؤرشف من الأصل في 2023-01-27.
  13. ^ ا ب "Three.js White Paper". Github.com. 21 مايو 2012. مؤرشف من الأصل في 2021-09-28. اطلع عليه بتاريخ 2013-05-09.
  14. ^ "Three.js White Paper". Github.com. 21 مايو 2012. مؤرشف من الأصل في 2021-09-28. اطلع عليه بتاريخ 2013-05-09.
  15. ^ Mr.doob (3 أغسطس 2020)، mrdoob/three.js، مؤرشف من الأصل في 2023-01-08، اطلع عليه بتاريخ 2020-08-03
  16. ^ mrdoob (26 نوفمبر 2012). "Features mrdoob/three.js Wiki GitHub". Github.com. مؤرشف من الأصل في 2021-03-08. اطلع عليه بتاريخ 2013-05-09.
  17. ^ "Stats.js". Github.com. مؤرشف من الأصل في 2023-03-12. اطلع عليه بتاريخ 2013-05-09.
  18. ^ "WebGL Inspector". Benvanik.github.com. مؤرشف من الأصل في 2023-03-14. اطلع عليه بتاريخ 2013-05-09.
  19. ^ "Three.js Inspector Labs". Zz85.github.com. مؤرشف من الأصل في 2023-01-27. اطلع عليه بتاريخ 2013-05-09.
  20. ^ "three.js examples". threejs.org. مؤرشف من الأصل في 2023-03-15.

قراءة متعمقة

[عدل]

روابط خارجية

[عدل]