الميزات الجديدة في WebGPU (Chrome 116)

François Beaufort
François Beaufort

دمج WebCodecs

تعرض WebGPU واجهة برمجة تطبيقات لإنشاء "زخرفة خارجية" معتمة. الكائنات من HTMLVideoElement إلى importExternalTexture(). يمكنك استخدام هذه العناصر لأخذ عينات من إطارات الفيديو بفعالية، ويمكن أن يتم ذلك باستخدام بيانات نموذج اللون YUV مباشرةً.

ومع ذلك، لم تسمح مواصفات WebGPU الأوّلية بإنشاء عناصر GPUExternalTexture من كائنات WebCodecs VideoFrame. وتكمن أهمية هذه الإمكانية في تطبيقات معالجة الفيديو المتقدمة التي تستخدم WebCodecs حاليًا وتريد دمج WebGPU في مسار معالجة الفيديو. تضيف عملية دمج WebCodecs إمكانية استخدام VideoFrame كمصدر لمكالمة GPUExternalTexture ومكالمة copyExternalImageToTexture(). اطّلِع على المثال التالي وإدخال chromestatus.

// Access the GPU device.
const adapter = await navigator.gpu.requestAdapter();
const device = await adapter.requestDevice();

// Create VideoFrame from HTMLVideoElement.
const video = document.querySelector("video");
const videoFrame = new VideoFrame(video);

// Create texture from VideoFrame.
const texture = device.importExternalTexture({ source: videoFrame });
// TODO: Use texture in bind group creation.

يمكنك الاطّلاع على النموذج التجريبي تحميل الفيديو باستخدام WebCodecs لتشغيله.

تم إرجاع الجهاز المفقود من خلال requestDevice() مهايئ GPU.

إذا تعذّر تنفيذ طريقة requestDevice() على GPUAdapter لأنه سبق استخدامها لإنشاء GPUDevice، يتم استيفاؤها الآن من خلال وضع علامة GPUDevice على الفور على أنّها مفقودة، بدلاً من إرجاع وعود تم رفضه باستخدام null. يُرجى الاطّلاع على issue chromium:1234617.

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

// New! The promise is not rejected anymore with null.
const device2 = await adapter.requestDevice();
// And the device is immediately marked as lost.
const info = await device2.lost;

الحفاظ على سلاسة تشغيل الفيديو في حال استدعاء الدالة importExternalTexture()

عند استدعاء importExternalTexture() من خلال HTMLVideoElement، لا يتم تقييد تشغيل الفيديو المرتبط عندما لا يكون الفيديو مرئيًا في إطار العرض. يُرجى الاطّلاع على issue chromium:1425252.

مطابقة المواصفات

الوسيطة message في الدالة الإنشائية GPUPipelineError() اختيارية. راجِع تغيير chromium:4613967.

يتم تنشيط خطأ عند استدعاء createShaderModule() إذا كان مصدر WGSL code يحتوي على \0. راجِع عدد الفجر:1345.

الحد الأقصى التلقائي لمستوى التفاصيل (lodMaxClamp) المستخدَم عند تحليل عيّنات باستخدام createSampler() هو 32. راجِع تغيير chromium:4608063.

تحسين تجربة المطوّرين

يتم عرض رسالة في وحدة تحكّم JavaScript في "أدوات مطوري البرامج" لتذكير المطوّرين عند استخدامهم WebGPU على منصة غير متوافقة. راجِع تغيير chromium:4589369.

تظهر رسائل خطأ التحقق من المخزن المؤقت على الفور في وحدة تحكم JavaScript في "أدوات مطوري البرامج" عند تعذُّر استخدام getMappedRange() بدون إجبار المطوّرين على إرسال الأوامر إلى قائمة الانتظار. راجِع تغيير chromium:4597950.

لقطة شاشة لوحدة تحكّم JavaScript في "أدوات مطوري البرامج" تعرض رسالة خطأ بشأن التحقّق من المخزن المؤقت
رسالة خطأ في التحقق من المخزن المؤقت في وحدة تحكم JavaScript في "أدوات مطوري البرامج".

آخر أخبار الفجر

تمت إعادة تسمية مفتاح تصحيح الأخطاء في "disallow_unsafe_apis" إلى "allow_unsafe_apis" وتمّ إيقافه كإعداد تلقائي. ويعمل مفتاح التبديل هذا على منع أخطاء التحقُّق من نقاط الدخول إلى واجهة برمجة التطبيقات أو مجموعات المَعلمات التي لا تعتبر آمنة بعد. ويمكن أن تكون مفيدة لتصحيح الأخطاء. راجِع عدد الفجر:1685.

تمّت إزالة السمة source المتوقّفة نهائيًا في wgpu::ShaderModuleWGSLDescriptor لصالح code. راجِع change dawn:130321.

تم تنفيذ طريقة wgpu::RenderBundle::SetLabel() غير المتوفّرة. راجِع change dawn:134502.

يمكن للتطبيقات طلب واجهة خلفية معيّنة عند الحصول على محوّل يتضمّن الخيار "wgpu::RequestAdapterOptionsBackendType". راجِع المثال أدناه واصدر سمة dawn:1875.

wgpu::RequestAdapterOptionsBackendType backendTypeOptions = {};
backendTypeOptions.backendType = wgpu::BackendType::D3D12;

wgpu::RequestAdapterOptions options = {};
options.nextInChain = &backendTypeOptions;

// Request D3D12 adapter.
myInstance.RequestAdapter(&options, myCallback, myUserData);

تمت إضافة طريقة SwapChain::GetCurrentTexture() جديدة مع استخدامات إضافية لزخارف سلسلة التبديل ليكون بالإمكان استخدام عنصر wgpu::Texture المردود في النسخ. راجِع المثال أدناه واصدِر الفجر:1551.

wgpu::SwapChain swapchain = myDevice.CreateSwapChain(mySurface, &myDesc);
swapchain.GetCurrentTexture();
swapchain.Present();

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

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

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

الإصدار 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 من Chrome