מה'חדש ב-WebGPU (Chrome {8/}116)

François Beaufort
François Beaufort

שילוב של WebCodecs

‫WebGPU חושף API ליצירת אובייקטים אטומים של 'טקסטורה חיצונית' מ-HTMLVideoElement דרך importExternalTexture(). אפשר להשתמש באובייקטים האלה כדי לדגום את פריים הסרטון בצורה יעילה, אולי בשיטה של 0-copy ישירות מנתוני מודל הצבע 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.

כדאי לעיין בדוגמה הניסיונית Video Uploading with WebCodecs כדי להתנסות בה.

המאפיין isFallbackAdapter של ‎GPUAdapter requestDevice()‎

אם השיטה requestDevice() ב-GPUAdapter נכשלת כי היא כבר שימשה ליצירת GPUDevice, היא תפעל עכשיו עם GPUDevice שמסומן מיד כאבוד, במקום להחזיר אובייקט promise שנדחית עם null. מידע נוסף

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, ההגבלה על הפעלת הווידאו המשויך מוסרת כשהסרטון לא מוצג באזור התצוגה. מידע נוסף

תאימות למפרט

הארגומנט message בבונה GPUPipelineError() הוא אופציונלי. ראו שינוי chromium:4613967.

מופעלת שגיאה כשקוראים ל-createShaderModule() אם המקור של WGSL‏ code מכיל את \0. מידע נוסף

רמת הפירוט המקסימלית שמוגדרת כברירת מחדל (lodMaxClamp) ומשמשת לדגימת טקסטורה באמצעות createSampler() היא 32. אפשר לעיין בשינוי chromium:4608063.

שיפור חוויית המפתחים

אם מפתחים משתמשים ב-WebGPU בפלטפורמה שלא נתמכת, תוצג להם הודעה בלוח Javascript של כלי הפיתוח. פרטים נוספים זמינים בכתובת change chromium:4589369.

הודעות שגיאה של אימות מאגר נתונים זמני מוצגות באופן מיידי במסוף JavaScript של כלי הפיתוח כשפעולת getMappedRange() נכשלת, בלי שהמפתחים נדרשים לשלוח פקודות לתור. ראו שינוי chromium:4597950.

צילום מסך של לוח Javascript בכלי הפיתוח עם הודעת שגיאה באימות המאגר.
הודעת שגיאה באימות המאגר במסוף JavaScript בכלי הפיתוח.

עדכונים של Dawn

המתג של ניפוי הבאגים disallow_unsafe_apis שינה את השם ל-allow_unsafe_apis, וכברירת מחדל הוא מושבת. המתג הזה משבית שגיאות אימות בנקודות כניסה ל-API או בשילובים של פרמטרים שלא נחשבים מאובטחים עדיין. הוא יכול להיות שימושי לניפוי באגים. מידע נוסף

המאפיין wgpu::ShaderModuleWGSLDescriptor שיצא משימוש source הוסר לטובת code. ראו שינוי שחר:130321.

השיטה wgpu::RenderBundle::SetLabel() החסרה יושמה. מידע נוסף

אפליקציות יכולות לבקש קצה עורפי מסוים כשמקבלים מתאם עם האפשרות wgpu::RequestAdapterOptionsBackendType. דוגמה: issue 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 בעותקים. אפשר לעיין בדוגמה שבהמשך ובבעיה dawn:1551.

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

המידע הזה כולל רק נקודות עיקריות. רשימה מלאה של קומיטים

מה חדש ב-WebGPU

רשימה של כל הנושאים שמופיעים בסדרה What's New in WebGPU.

‫Chrome 147-148

Chrome 146

Chrome 145

Chrome 144

Chrome 143

Chrome 142

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