수년간의 개발 끝에 Chrome팀은 이제 첫 번째 버전의 WebGPU를 ChromeOS, macOS, Windows의 Chrome에서 기본적으로 사용할 수 있다고 발표했습니다. 자세한 내용은 Chrome에서 제공하는 WebGPU를 참고하세요.
또한 MDN에 WebGPU에 관한 종합 문서를 추가하기 시작했습니다.
이 외에도 다양한 기능이 있습니다.
importExternalTexture()
에서 WebCodecs VideoFrame
소스 사용
WebGPU가 API를 노출하여 불투명한 '외부 텍스처'를 만듭니다. HTMLVideoElement
부터 importExternalTexture()
까지의 객체. 이러한 객체를 사용하여 소스 YUV 데이터에서 직접 0-copy 방식으로 동영상 프레임을 효율적으로 샘플링할 수 있습니다.
하지만 초기 WebGPU 사양에서는 WebCodecs VideoFrame
객체에서 GPUExternalTexture
객체를 만들 수 없습니다. 이 기능은 이미 WebCodecs를 사용하고 있으며 동영상 처리 파이프라인에 WebGPU를 통합하려는 고급 동영상 처리 앱에 중요합니다. 현재 gpuweb/gpuweb#1380 문제에 대한 논의가 진행 중입니다.
기능 사용 설정
기본적으로 이 기능은 Chrome에서 사용 설정되어 있지 않지만 명시적으로 사용 설정하여 Chrome 113에서 실험할 수 있습니다. 'WebGPU 개발자 기능'을 사용 설정하여 로컬에서 활성화할 수 있습니다. 플래그가 chrome://flags/#enable-webgpu-developer-features
에 있습니다.
앱의 모든 방문자에게 이 기능을 사용 설정하기 위해 오리진 트라이얼이 현재 진행 중이며 Chrome 118 (2023년 12월 8일)에 종료되도록 설정되어 있습니다. 무료 체험에 참여하려면 가입하고 HTML 또는 HTTP 헤더에 오리진 트라이얼 토큰이 포함된 메타 요소를 포함하세요. 자세한 내용은 오리진 트라이얼 시작하기 게시물을 참고하세요.
샘플 코드
// 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);
const texture = device.importExternalTexture({ source: videoFrame });
// TODO: Use texture in bind group creation.
WebCodecs로 동영상 업로드 실험용 샘플을 확인해 보세요.
WebGPU의 새로운 기능
WebGPU의 새로운 기능 시리즈에서 다룬 모든 내용 목록
Chrome 128
- 하위 그룹 실험
- 선 및 점의 설정 깊이 바이어스 지원 중단
- preventDefault인 경우 캡처되지 않은 오류 DevTools 경고 숨기기
- WGSL에서는 샘플링을 먼저 보간하고
- Dawn 업데이트
Chrome 127
Chrome 126
Chrome 125
Chrome 124
Chrome 123
- WGSL에서 DP4a 내장 함수 지원
- WGSL의 제한되지 않은 포인터 매개변수
- WGSL에서 복합을 역참조하기 위한 구문 슈가
- 스텐실 및 깊이 측면의 별도 읽기 전용 상태
- Dawn 업데이트
Chrome 122
Chrome 121
- Android에서 WebGPU 지원
- Windows에서 셰이더 컴파일에 FXC 대신 DXC 사용
- 컴퓨팅 및 렌더링 패스의 타임스탬프 쿼리
- 셰이더 모듈의 기본 진입점
- display-p3을 GPUExternalTexture 색상 공간으로 지원
- 메모리 힙 정보
- Dawn 업데이트
Chrome 120
Chrome 119
Chrome 118
copyExternalImageToTexture()
의 HTMLImageElement 및 ImageData 지원- 읽기-쓰기 및 읽기 전용 저장소 텍스처를 실험적으로 지원합니다.
- Dawn 업데이트
Chrome 117
- 꼭짓점 버퍼 설정 해제
- 바인드 그룹 설정 해제
- 기기 분실 시 비동기 파이프라인 생성 시 오류 차단
- SPIR-V 셰이더 모듈 만들기 업데이트
- 개발자 환경 개선
- 자동으로 생성된 레이아웃으로 파이프라인 캐싱
- Dawn 업데이트
Chrome 116
- WebCodecs 통합
- GPUAdapter
requestDevice()
에서 반품한 분실 기기 importExternalTexture()
가 호출되는 경우 동영상을 원활하게 재생합니다.- 사양 적합성
- 개발자 환경 개선
- Dawn 업데이트