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

François Beaufort
François Beaufort

تاريخ النشر: 25 فبراير 2026

إتاحة وضع التوافق مع WebGPU على OpenGL ES 3.1

مع أنّ WebGPU مصمَّمة لتتوافق مع واجهات برمجة تطبيقات الرسومات الحديثة، مثل Vulkan وMetal وD3D12، يستخدم العديد من المستخدمين أجهزة قديمة لا تتوافق مع هذه المعايير. ولتجاوز هذه المشكلة وضمان إمكانية الوصول إلى WebGPU على نطاق واسع، يقدّم Chrome ميزة جديدة يمكن تفعيلها، وهي "وضع التوافق".

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

بالنسبة إلى العديد من تطبيقات الويب، يمكنك تفعيل وضع التوافق من خلال تمرير featureLevel: "compatibility" عند طلب requestAdapter(). إذا كان جهازك متوافقًا مع Core WebGPU، سيعرض Chrome محوّلاً متوافقًا مع Core، ولكن سيعرف تطبيق الويب أنّه يجب البقاء ضمن حدود التوافق ما لم يفعّل الميزة "core-features-and-limits" (أو يفعّل جميع الميزات المتاحة). قد تتطلّب التطبيقات الأكثر تعقيدًا إجراء تعديلات بسيطة لتناسب قيود الوضع.

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

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

المرفقات المؤقتة

يمكنك استخدام العلامة الجديدة TRANSIENT_ATTACHMENT GPUTextureUsage لإنشاء مرفقات فعّالة من حيث استخدام الذاكرة، ما يتيح بقاء عمليات تمرير العرض في ذاكرة التجانب، وبالتالي تجنُّب نقل البيانات إلى ذاكرة الوصول العشوائي المرئية (VRAM) وتجنُّب تخصيصها لمواد العرض.

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

يوضّح المثال التالي كيفية إنشاء نسيج مؤقت.

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

if ('TRANSIENT_ATTACHMENT' in GPUTextureUsage) {

  const transientTexture = device.createTexture({
    size: [42, 42],
    // The TRANSIENT_ATTACHMENT flag indicates the texture content is temporary,
    // potentially keeping it in fast on-chip memory.
    usage: GPUTextureUsage.RENDER_ATTACHMENT | GPUTextureUsage.TRANSIENT_ATTACHMENT,
    format: 'rgba8unorm',
  });
}

يمكنك الاطّلاع على نموذج Hello Triangle MSAA - WebGPU ونية الشحن.

إضافة WGSL texture_and_sampler_let

تتيح لك إضافة لغة WGSL texture_and_sampler_let تعيين متغيرات خاصة بالنسيج أو أداة أخذ العينات إلى let ضمن برنامج تظليل WGSL. توفّر هذه الميزة حاليًا آلية تسمية بديلة وتستعد لإتاحة استخدام bindless حيث يمكن تخزين الطرق التي تعرض مواد أو أدوات أخذ عينات مباشرةً في متغيرات محلية.

اطّلِع على المثال التالي ونية الشحن.

@group(0) @binding(0) var tex: texture_2d<f32>;
@group(1) @binding(0) var store : texture_storage_2d<r32float, read_write>;

@fragment fn main() {
    let a = tex;
    var res: vec4f = textureLoad(a, vec2i(1i), 0);

    textureStore(store, vec2i(0i), res);
}

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

تتوفّر فئات الحدود الجديدة التالية:

  • يمكن استخدام ما يصل إلى 16 حرفًا. يُرجى الاطّلاع على المشكلة رقم 366151398.maxStorageBuffersPerShaderStage

  • يمكن أن يتضمّن maxSampledTexturesPerShaderStage ما يصل إلى 48 حرفًا. يمكنك الاطّلاع على المشكلة 475255737.

يتم تفعيل عملية التحقّق من صحة SPIR-V تلقائيًا على Android لتوفير طبقة أمان إضافية ومنع عدم استقرار برنامج التشغيل بسبب الإدخال غير الصحيح. اطّلِع على المشكلة 473526182.

يغطي هذا التقرير بعض النقاط البارزة الرئيسية فقط. يمكنك الاطّلاع على قائمة عمليات الدمج الشاملة.

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

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

‫Chrome 149-150

Chrome 147-148

‫Chrome 146

Chrome 145

‫Chrome 144

Chrome 143

الإصدار 142 من Chrome

‫Chrome 141

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