الميزات الجديدة في WebGPU (الإصدار 139 من Chrome)

François Beaufort
François Beaufort

تاريخ النشر: 30 يوليو 2025

إتاحة بنية ثلاثية الأبعاد بتنسيقات BC وASTC المضغوطة

تضيف ميزتا "texture-compression-bc-sliced-3d" و"texture-compression-astc-sliced-3d" في WebGPU إمكانية استخدام بنى ثلاثية الأبعاد بتنسيقات Block Compression (BC) وAdaptive Scalable Texture Compression (ASTC). يتيح لك ذلك الاستفادة من إمكانات الضغط الفعّالة لتنسيقات BC وASTC لبيانات النسيج الحجمي، ما يوفّر تخفيضات كبيرة في مساحة الذاكرة ومتطلبات النطاق الترددي بدون فقدان كبير في الجودة المرئية. ويُعدّ ذلك مفيدًا بشكل خاص في مجالات مثل التصور العلمي والتصوير الطبي وتقنيات العرض المتقدّمة.

يتحقّق مقتطف الرمز التالي مما إذا كان المحوّل يتوافق مع مواد العرض الثلاثية الأبعاد بتنسيقات مضغوطة من نوع BC وASTC، ويطلب جهازًا يتضمّن هذه الميزات إذا كانت متاحة.

const adapter = await navigator.gpu.requestAdapter();

const requiredFeatures = [];
if (adapter?.features.has("texture-compression-bc-sliced-3d")) {
  requiredFeatures.push(
    "texture-compression-bc",
    "texture-compression-bc-sliced-3d",
  );
}
if (adapter?.features.has("texture-compression-astc-sliced-3d")) {
  requiredFeatures.push(
    "texture-compression-astc",
    "texture-compression-astc-sliced-3d",
  );
}
const device = await adapter?.requestDevice({ requiredFeatures });

// Later on...
if (device.features.has("texture-compression-astc-sliced-3d")) {
  // Create a 3D texture using ASTC compression
} else if (device.features.has("texture-compression-bc-sliced-3d")) {
  // Create a 3D texture using BC compression
} else {
  // Fallback: Create an uncompressed 3D texture
}

يمكنك استكشاف عمليات فحص ثلاثية الأبعاد للدماغ من خلال الاطّلاع على Volume Rendering - Texture 3D WebGPU sample والاطّلاع على إدخال chromestatus.

عمليات فحص ثلاثية الأبعاد للدماغ معروضة باستخدام WebGPU
صورة لفحص الدماغ من بنية ثلاثية الأبعاد بتنسيق مضغوط ASTC

ميزة "الميزات الأساسية والحدود" الجديدة

سيتم طرح ميزة "core-features-and-limits" جديدة لوضع التوافق القادم مع WebGPU. تشير هذه الميزة إلى أنّ المحوّل أو الجهاز يتوافق مع الميزات الأساسية وحدود مواصفات WebGPU. إنّ WebGPU "الأساسية" هي الإصدار الوحيد المتاح في الوقت الحالي، لذا يجب أن تتضمّن جميع عمليات تنفيذ WebGPU "core-features-and-limits" في الميزات المتوافقة.

في المستقبل، عند طرح وضع التوافق مع WebGPU، قد لا يتضمّن المحوّل أو الجهاز هذه الميزة للإشارة إلى أنّه محوّل أو جهاز متوافق وليس أساسيًا. عند تفعيل هذا الخيار على أحد الأجهزة، ستتم إزالة جميع القيود المفروضة على وضع التوافق (الميزات والحدود).

للحصول على شرح تفصيلي وطريقة الاستخدام في وضع التوافق مع WebGPU، يُرجى الرجوع إلى المستند التوضيحي والقسم التالي. يمكنك الاطّلاع على المشكلة 418025721.

مرحلة التجربة والتقييم لوضع التوافق مع WebGPU

‫WebGPU هي واجهة برمجة تطبيقات قوية مصمَّمة للرسومات الحديثة، وتتوافق مع تكنولوجيات مثل Vulkan وMetal وDirect3D 12. ومع ذلك، لا يزال عدد كبير من الأجهزة غير متوافق مع واجهات برمجة التطبيقات الأحدث هذه. على سبيل المثال، على أجهزة Windows، لا يتوفّر الإصدار 11.1 من Direct3D أو إصدار أحدث لدى% 31 من مستخدمي Chrome. على أجهزة Android، لا يتوفّر الإصدار 1.1 من Vulkan لدى% 15 من مستخدمي Android، بما في ذلك% 10 من المستخدمين الذين لا يتوفّر لديهم Vulkan على الإطلاق.

ويشكّل ذلك تحديًا للمطوّرين الذين يريدون زيادة مدى وصول تطبيقاتهم إلى أقصى حد. وغالبًا ما يضطرون إلى تطوير عمليات تنفيذ متعددة (على سبيل المثال، WebGPU وWebGL)، أو قبول جمهور أكثر محدودية باستخدام WebGPU الأساسية، أو الالتزام باستخدام WebGL، ما يؤدي إلى عدم الاستفادة من ميزات WebGPU المتقدّمة، مثل الحوسبة على وحدة معالجة الرسومات.

تمثيل مرئي لوضع التوافق في WebGPU
توسيع نطاق وضع التوافق مع WebGPU:

يوفّر وضع التوافق مع WebGPU حلاً من خلال توفير إصدار من واجهة برمجة التطبيقات WebGPU يمكن تفعيله، وهو إصدار مقيّد قليلاً. تم تصميم هذا الوضع لتشغيل واجهات برمجة التطبيقات القديمة للرسومات، مثل OpenGL ES 3.1 وDirect3D11، ما يؤدي إلى توسيع نطاق وصول تطبيقك بشكل كبير إلى الأجهزة التي لا تتوافق مع واجهات برمجة التطبيقات الحديثة والصريحة للرسومات التي تتطلّبها WebGPU الأساسية.

بما أنّ وضع التوافق هو مجموعة فرعية من WebGPU، فإنّ التطبيقات التي تم إنشاؤها باستخدام هذا الوضع هي أيضًا تطبيقات "أساسية" صالحة من WebGPU. وهذا يعني أنّها ستعمل بسلاسة حتى على المتصفّحات التي لا تتوافق تحديدًا مع وضع التوافق.

بالنسبة إلى العديد من التطبيقات الأساسية، يكون تفعيل وضع التوافق بسيطًا مثل تمرير featureLevel: "compatibility" عند طلب requestAdapter(). وقد تتطلّب التطبيقات الأكثر تعقيدًا إجراء تعديلات بسيطة لتناسب قيود الوضع. يُعدّ نموذج إنشاء Mipmap باستخدام WebGPU مثالاً جيدًا.

// Request a GPUAdapter in compatibility mode
const adapter = await navigator.gpu.requestAdapter({
  featureLevel: "compatibility",
});

const hasCore = adapter?.features.has("core-features-and-limits");
const device = await adapter?.requestDevice({
  requiredFeatures: (hasCore ? ["core-features-and-limits"] : []),
});

if (device?.features.has("core-features-and-limits")) {
  // Compatibility mode restrictions will apply
}

تفعيل الميزة

بشكلٍ تلقائي، لا يكون وضع التوافق مع WebGPU مفعّلاً في Chrome، ولكن يمكن تجربته في الإصدار 139 من Chrome من خلال تفعيل الوظيفة بشكلٍ صريح. يمكنك تفعيلها محليًا من خلال تفعيل العلامة "ميزات تجريبية لمنصة الويب" على chrome://flags/#enable-experimental-web-platform-features.

لإتاحة هذه الميزة لجميع زوّار تطبيقك، يتم حاليًا إجراء تجربة أصل من المقرر أن تنتهي في الإصدار 145 من Chrome (في 21 أبريل 2026). للمشاركة في التجربة، يُرجى الرجوع إلى المشاركة بدء استخدام التجارب الأصلية.

إشعارات الفجر

تمت إضافة وسيطة message إلى الدالة WGPUQueueWorkDoneCallback لتكون أكثر اتساقًا مع دوال رد الاتصال الأخرى التي تتضمّن حالة أيضًا. يمكنك الاطّلاع على طلب السحب الخاص بعناوين WebGPU.

عند ربط emdawnwebgpu بـ -sSHARED_MEMORY، يتم أيضًا تجميع ملف webgpu.cpp باستخدام هذه العلامة. راجِع Dawn CL 244075.

هذا يشمل بعض النقاط الرئيسية فقط. اطّلِع على القائمة الشاملة لعمليات الإيداع.

الميزات الجديدة في WebGPU

قائمة بكل ما تم تناوله في سلسلة الميزات الجديدة في WebGPU

Chrome 140

‫Chrome 139

‫Chrome 138

‫Chrome 137

Chrome 136

Chrome 135

Chrome 134

Chrome 133

‫Chrome 132

Chrome 131

Chrome 130

Chrome 129

Chrome 128

Chrome 127

‫Chrome 126

‫Chrome 125

Chrome 124

Chrome 123

‫Chrome 122

Chrome 121

‫Chrome 120

‫Chrome 119

Chrome 118

Chrome 117

Chrome 116

Chrome 115

Chrome 114

Chrome 113