react-native-webgpu 0.5.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +20 -0
- package/README.md +319 -0
- package/android/CMakeLists.txt +108 -0
- package/android/build.gradle +138 -0
- package/android/cpp/AndroidPlatformContext.h +207 -0
- package/android/cpp/cpp-adapter.cpp +71 -0
- package/android/src/main/AndroidManifest.xml +3 -0
- package/android/src/main/java/com/webgpu/WebGPUAHBView.java +298 -0
- package/android/src/main/java/com/webgpu/WebGPUAPI.java +20 -0
- package/android/src/main/java/com/webgpu/WebGPUBaseView.java +61 -0
- package/android/src/main/java/com/webgpu/WebGPUModule.java +50 -0
- package/android/src/main/java/com/webgpu/WebGPUSurfaceView.java +41 -0
- package/android/src/main/java/com/webgpu/WebGPUSurfaceViewWithSC.java +79 -0
- package/android/src/main/java/com/webgpu/WebGPUTextureView.java +46 -0
- package/android/src/main/java/com/webgpu/WebGPUView.java +108 -0
- package/android/src/main/java/com/webgpu/WebGPUViewManager.java +38 -0
- package/android/src/main/java/com/webgpu/WebGPUViewPackage.java +50 -0
- package/android/src/newarch/com/webgpu/WebGPUViewManagerSpec.java +24 -0
- package/apple/ApplePlatformContext.h +31 -0
- package/apple/ApplePlatformContext.mm +157 -0
- package/apple/MetalView.h +13 -0
- package/apple/MetalView.mm +50 -0
- package/apple/RNWGUIKit.h +16 -0
- package/apple/WebGPUModule.h +13 -0
- package/apple/WebGPUModule.mm +89 -0
- package/apple/WebGPUView.h +12 -0
- package/apple/WebGPUView.mm +66 -0
- package/cpp/WGPULogger.h +100 -0
- package/cpp/dawn_logging.cpp +119 -0
- package/cpp/jsi/EnumMapper.h +45 -0
- package/cpp/jsi/JSIConverter.h +473 -0
- package/cpp/jsi/NativeObject.h +607 -0
- package/cpp/jsi/Promise.cpp +44 -0
- package/cpp/jsi/Promise.h +35 -0
- package/cpp/jsi/RuntimeAwareCache.cpp +7 -0
- package/cpp/jsi/RuntimeAwareCache.h +100 -0
- package/cpp/jsi/RuntimeLifecycleMonitor.cpp +72 -0
- package/cpp/jsi/RuntimeLifecycleMonitor.h +32 -0
- package/cpp/rnwgpu/ArrayBuffer.h +73 -0
- package/cpp/rnwgpu/PlatformContext.h +46 -0
- package/cpp/rnwgpu/RNWebGPUManager.cpp +225 -0
- package/cpp/rnwgpu/RNWebGPUManager.h +46 -0
- package/cpp/rnwgpu/SurfaceRegistry.h +230 -0
- package/cpp/rnwgpu/api/Canvas.h +57 -0
- package/cpp/rnwgpu/api/Convertors.h +761 -0
- package/cpp/rnwgpu/api/External.h +12 -0
- package/cpp/rnwgpu/api/GPU.cpp +127 -0
- package/cpp/rnwgpu/api/GPU.h +58 -0
- package/cpp/rnwgpu/api/GPUAdapter.cpp +191 -0
- package/cpp/rnwgpu/api/GPUAdapter.h +59 -0
- package/cpp/rnwgpu/api/GPUAdapterInfo.h +57 -0
- package/cpp/rnwgpu/api/GPUBindGroup.cpp +3 -0
- package/cpp/rnwgpu/api/GPUBindGroup.h +51 -0
- package/cpp/rnwgpu/api/GPUBindGroupLayout.h +52 -0
- package/cpp/rnwgpu/api/GPUBuffer.cpp +97 -0
- package/cpp/rnwgpu/api/GPUBuffer.h +87 -0
- package/cpp/rnwgpu/api/GPUCanvasContext.cpp +67 -0
- package/cpp/rnwgpu/api/GPUCanvasContext.h +66 -0
- package/cpp/rnwgpu/api/GPUCommandBuffer.h +45 -0
- package/cpp/rnwgpu/api/GPUCommandEncoder.cpp +179 -0
- package/cpp/rnwgpu/api/GPUCommandEncoder.h +111 -0
- package/cpp/rnwgpu/api/GPUCompilationInfo.h +79 -0
- package/cpp/rnwgpu/api/GPUCompilationMessage.h +36 -0
- package/cpp/rnwgpu/api/GPUComputePassEncoder.cpp +60 -0
- package/cpp/rnwgpu/api/GPUComputePassEncoder.h +85 -0
- package/cpp/rnwgpu/api/GPUComputePipeline.cpp +12 -0
- package/cpp/rnwgpu/api/GPUComputePipeline.h +60 -0
- package/cpp/rnwgpu/api/GPUDevice.cpp +492 -0
- package/cpp/rnwgpu/api/GPUDevice.h +259 -0
- package/cpp/rnwgpu/api/GPUDeviceLostInfo.cpp +7 -0
- package/cpp/rnwgpu/api/GPUDeviceLostInfo.h +40 -0
- package/cpp/rnwgpu/api/GPUError.h +35 -0
- package/cpp/rnwgpu/api/GPUExtent3D.h +66 -0
- package/cpp/rnwgpu/api/GPUExternalTexture.h +45 -0
- package/cpp/rnwgpu/api/GPUFeatures.h +203 -0
- package/cpp/rnwgpu/api/GPUInternalError.h +31 -0
- package/cpp/rnwgpu/api/GPUOrigin2D.h +55 -0
- package/cpp/rnwgpu/api/GPUOrigin3D.h +62 -0
- package/cpp/rnwgpu/api/GPUOutOfMemoryError.h +33 -0
- package/cpp/rnwgpu/api/GPUPipelineLayout.h +45 -0
- package/cpp/rnwgpu/api/GPUQuerySet.cpp +11 -0
- package/cpp/rnwgpu/api/GPUQuerySet.h +73 -0
- package/cpp/rnwgpu/api/GPUQueue.cpp +169 -0
- package/cpp/rnwgpu/api/GPUQueue.h +81 -0
- package/cpp/rnwgpu/api/GPURenderBundle.h +44 -0
- package/cpp/rnwgpu/api/GPURenderBundleEncoder.cpp +131 -0
- package/cpp/rnwgpu/api/GPURenderBundleEncoder.h +110 -0
- package/cpp/rnwgpu/api/GPURenderPassEncoder.cpp +165 -0
- package/cpp/rnwgpu/api/GPURenderPassEncoder.h +130 -0
- package/cpp/rnwgpu/api/GPURenderPipeline.cpp +13 -0
- package/cpp/rnwgpu/api/GPURenderPipeline.h +61 -0
- package/cpp/rnwgpu/api/GPUSampler.h +44 -0
- package/cpp/rnwgpu/api/GPUShaderModule.cpp +51 -0
- package/cpp/rnwgpu/api/GPUShaderModule.h +66 -0
- package/cpp/rnwgpu/api/GPUSupportedLimits.cpp +129 -0
- package/cpp/rnwgpu/api/GPUSupportedLimits.h +131 -0
- package/cpp/rnwgpu/api/GPUTexture.cpp +47 -0
- package/cpp/rnwgpu/api/GPUTexture.h +162 -0
- package/cpp/rnwgpu/api/GPUTextureView.h +44 -0
- package/cpp/rnwgpu/api/GPUUncapturedErrorEvent.h +71 -0
- package/cpp/rnwgpu/api/GPUValidationError.h +32 -0
- package/cpp/rnwgpu/api/ImageBitmap.h +40 -0
- package/cpp/rnwgpu/api/RNWebGPU.h +199 -0
- package/cpp/rnwgpu/api/descriptors/GPUBindGroupDescriptor.h +65 -0
- package/cpp/rnwgpu/api/descriptors/GPUBindGroupEntry.h +78 -0
- package/cpp/rnwgpu/api/descriptors/GPUBindGroupLayoutDescriptor.h +57 -0
- package/cpp/rnwgpu/api/descriptors/GPUBindGroupLayoutEntry.h +98 -0
- package/cpp/rnwgpu/api/descriptors/GPUBlendComponent.h +58 -0
- package/cpp/rnwgpu/api/descriptors/GPUBlendState.h +53 -0
- package/cpp/rnwgpu/api/descriptors/GPUBufferBinding.h +57 -0
- package/cpp/rnwgpu/api/descriptors/GPUBufferBindingLayout.h +57 -0
- package/cpp/rnwgpu/api/descriptors/GPUBufferDescriptor.h +60 -0
- package/cpp/rnwgpu/api/descriptors/GPUBufferUsage.h +39 -0
- package/cpp/rnwgpu/api/descriptors/GPUCanvasConfiguration.h +76 -0
- package/cpp/rnwgpu/api/descriptors/GPUColor.h +67 -0
- package/cpp/rnwgpu/api/descriptors/GPUColorTargetState.h +59 -0
- package/cpp/rnwgpu/api/descriptors/GPUColorWrite.h +29 -0
- package/cpp/rnwgpu/api/descriptors/GPUCommandBufferDescriptor.h +46 -0
- package/cpp/rnwgpu/api/descriptors/GPUCommandEncoderDescriptor.h +46 -0
- package/cpp/rnwgpu/api/descriptors/GPUComputePassDescriptor.h +57 -0
- package/cpp/rnwgpu/api/descriptors/GPUComputePassTimestampWrites.h +59 -0
- package/cpp/rnwgpu/api/descriptors/GPUComputePipelineDescriptor.h +68 -0
- package/cpp/rnwgpu/api/descriptors/GPUDepthStencilState.h +104 -0
- package/cpp/rnwgpu/api/descriptors/GPUDeviceDescriptor.h +100 -0
- package/cpp/rnwgpu/api/descriptors/GPUExternalTextureBindingLayout.h +39 -0
- package/cpp/rnwgpu/api/descriptors/GPUExternalTextureDescriptor.h +80 -0
- package/cpp/rnwgpu/api/descriptors/GPUFragmentState.h +74 -0
- package/cpp/rnwgpu/api/descriptors/GPUImageCopyBuffer.h +63 -0
- package/cpp/rnwgpu/api/descriptors/GPUImageCopyExternalImage.h +63 -0
- package/cpp/rnwgpu/api/descriptors/GPUImageCopyTexture.h +66 -0
- package/cpp/rnwgpu/api/descriptors/GPUImageCopyTextureTagged.h +82 -0
- package/cpp/rnwgpu/api/descriptors/GPUImageDataLayout.h +55 -0
- package/cpp/rnwgpu/api/descriptors/GPUMapMode.h +22 -0
- package/cpp/rnwgpu/api/descriptors/GPUMultisampleState.h +55 -0
- package/cpp/rnwgpu/api/descriptors/GPUPipelineLayoutDescriptor.h +58 -0
- package/cpp/rnwgpu/api/descriptors/GPUPrimitiveState.h +70 -0
- package/cpp/rnwgpu/api/descriptors/GPUProgrammableStage.h +62 -0
- package/cpp/rnwgpu/api/descriptors/GPUQuerySetDescriptor.h +56 -0
- package/cpp/rnwgpu/api/descriptors/GPUQueueDescriptor.h +44 -0
- package/cpp/rnwgpu/api/descriptors/GPURenderBundleDescriptor.h +46 -0
- package/cpp/rnwgpu/api/descriptors/GPURenderBundleEncoderDescriptor.h +81 -0
- package/cpp/rnwgpu/api/descriptors/GPURenderPassColorAttachment.h +82 -0
- package/cpp/rnwgpu/api/descriptors/GPURenderPassDepthStencilAttachment.h +102 -0
- package/cpp/rnwgpu/api/descriptors/GPURenderPassDescriptor.h +93 -0
- package/cpp/rnwgpu/api/descriptors/GPURenderPassTimestampWrites.h +59 -0
- package/cpp/rnwgpu/api/descriptors/GPURenderPipelineDescriptor.h +104 -0
- package/cpp/rnwgpu/api/descriptors/GPURequestAdapterOptions.h +52 -0
- package/cpp/rnwgpu/api/descriptors/GPUSamplerBindingLayout.h +46 -0
- package/cpp/rnwgpu/api/descriptors/GPUSamplerDescriptor.h +111 -0
- package/cpp/rnwgpu/api/descriptors/GPUShaderModuleCompilationHint.h +61 -0
- package/cpp/rnwgpu/api/descriptors/GPUShaderModuleDescriptor.h +63 -0
- package/cpp/rnwgpu/api/descriptors/GPUShaderStage.h +25 -0
- package/cpp/rnwgpu/api/descriptors/GPUStencilFaceState.h +65 -0
- package/cpp/rnwgpu/api/descriptors/GPUStorageTextureBindingLayout.h +60 -0
- package/cpp/rnwgpu/api/descriptors/GPUTextureBindingLayout.h +60 -0
- package/cpp/rnwgpu/api/descriptors/GPUTextureDescriptor.h +92 -0
- package/cpp/rnwgpu/api/descriptors/GPUTextureUsage.h +29 -0
- package/cpp/rnwgpu/api/descriptors/GPUTextureViewDescriptor.h +92 -0
- package/cpp/rnwgpu/api/descriptors/GPUUncapturedErrorEventInit.h +65 -0
- package/cpp/rnwgpu/api/descriptors/GPUVertexAttribute.h +54 -0
- package/cpp/rnwgpu/api/descriptors/GPUVertexBufferLayout.h +63 -0
- package/cpp/rnwgpu/api/descriptors/GPUVertexState.h +74 -0
- package/cpp/rnwgpu/api/descriptors/Unions.h +1969 -0
- package/cpp/rnwgpu/async/AsyncDispatcher.h +28 -0
- package/cpp/rnwgpu/async/AsyncRunner.cpp +215 -0
- package/cpp/rnwgpu/async/AsyncRunner.h +53 -0
- package/cpp/rnwgpu/async/AsyncTaskHandle.cpp +181 -0
- package/cpp/rnwgpu/async/AsyncTaskHandle.h +55 -0
- package/cpp/rnwgpu/async/JSIMicrotaskDispatcher.cpp +23 -0
- package/cpp/rnwgpu/async/JSIMicrotaskDispatcher.h +22 -0
- package/cpp/webgpu/webgpu.h +4918 -0
- package/cpp/webgpu/webgpu_cpp.h +10294 -0
- package/cpp/webgpu/webgpu_cpp_chained_struct.h +57 -0
- package/cpp/webgpu/webgpu_cpp_print.h +2755 -0
- package/cpp/webgpu/webgpu_enum_class_bitmasks.h +161 -0
- package/lib/commonjs/Canvas.js +55 -0
- package/lib/commonjs/Canvas.js.map +1 -0
- package/lib/commonjs/NativeWebGPUModule.js +10 -0
- package/lib/commonjs/NativeWebGPUModule.js.map +1 -0
- package/lib/commonjs/Offscreen.js +103 -0
- package/lib/commonjs/Offscreen.js.map +1 -0
- package/lib/commonjs/WebGPUViewNativeComponent.js +10 -0
- package/lib/commonjs/WebGPUViewNativeComponent.js.map +1 -0
- package/lib/commonjs/WebGPUViewNativeComponent.web.js +103 -0
- package/lib/commonjs/WebGPUViewNativeComponent.web.js.map +1 -0
- package/lib/commonjs/WebPolyfillGPUModule.js +40 -0
- package/lib/commonjs/WebPolyfillGPUModule.js.map +1 -0
- package/lib/commonjs/external/ModuleProxy.js +36 -0
- package/lib/commonjs/external/ModuleProxy.js.map +1 -0
- package/lib/commonjs/external/index.js +17 -0
- package/lib/commonjs/external/index.js.map +1 -0
- package/lib/commonjs/external/reanimated/ReanimatedProxy.js +18 -0
- package/lib/commonjs/external/reanimated/ReanimatedProxy.js.map +1 -0
- package/lib/commonjs/external/reanimated/index.js +21 -0
- package/lib/commonjs/external/reanimated/index.js.map +1 -0
- package/lib/commonjs/external/reanimated/registerWebGPUForReanimated.js +49 -0
- package/lib/commonjs/external/reanimated/registerWebGPUForReanimated.js.map +1 -0
- package/lib/commonjs/hooks.js +83 -0
- package/lib/commonjs/hooks.js.map +1 -0
- package/lib/commonjs/index.js +17 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/commonjs/main/index.js +91 -0
- package/lib/commonjs/main/index.js.map +1 -0
- package/lib/commonjs/main/index.web.js +51 -0
- package/lib/commonjs/main/index.web.js.map +1 -0
- package/lib/commonjs/types.js +2 -0
- package/lib/commonjs/types.js.map +1 -0
- package/lib/commonjs/utils.js +11 -0
- package/lib/commonjs/utils.js.map +1 -0
- package/lib/module/Canvas.js +46 -0
- package/lib/module/Canvas.js.map +1 -0
- package/lib/module/NativeWebGPUModule.js +4 -0
- package/lib/module/NativeWebGPUModule.js.map +1 -0
- package/lib/module/Offscreen.js +96 -0
- package/lib/module/Offscreen.js.map +1 -0
- package/lib/module/WebGPUViewNativeComponent.js +4 -0
- package/lib/module/WebGPUViewNativeComponent.js.map +1 -0
- package/lib/module/WebGPUViewNativeComponent.web.js +96 -0
- package/lib/module/WebGPUViewNativeComponent.web.js.map +1 -0
- package/lib/module/WebPolyfillGPUModule.js +38 -0
- package/lib/module/WebPolyfillGPUModule.js.map +1 -0
- package/lib/module/external/ModuleProxy.js +28 -0
- package/lib/module/external/ModuleProxy.js.map +1 -0
- package/lib/module/external/index.js +2 -0
- package/lib/module/external/index.js.map +1 -0
- package/lib/module/external/reanimated/ReanimatedProxy.js +12 -0
- package/lib/module/external/reanimated/ReanimatedProxy.js.map +1 -0
- package/lib/module/external/reanimated/index.js +3 -0
- package/lib/module/external/reanimated/index.js.map +1 -0
- package/lib/module/external/reanimated/registerWebGPUForReanimated.js +42 -0
- package/lib/module/external/reanimated/registerWebGPUForReanimated.js.map +1 -0
- package/lib/module/hooks.js +70 -0
- package/lib/module/hooks.js.map +1 -0
- package/lib/module/index.js +5 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/main/index.js +33 -0
- package/lib/module/main/index.js.map +1 -0
- package/lib/module/main/index.web.js +8 -0
- package/lib/module/main/index.web.js.map +1 -0
- package/lib/module/types.js +2 -0
- package/lib/module/types.js.map +1 -0
- package/lib/module/utils.js +5 -0
- package/lib/module/utils.js.map +1 -0
- package/lib/typescript/babel.config.d.ts +3 -0
- package/lib/typescript/babel.config.d.ts.map +1 -0
- package/lib/typescript/eslint.config.d.mts +3 -0
- package/lib/typescript/eslint.config.d.mts.map +1 -0
- package/lib/typescript/jest.config.d.ts +9 -0
- package/lib/typescript/jest.config.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/Canvas.d.ts +7 -0
- package/lib/typescript/lib/commonjs/Canvas.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/NativeWebGPUModule.d.ts +5 -0
- package/lib/typescript/lib/commonjs/NativeWebGPUModule.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/Offscreen.d.ts +26 -0
- package/lib/typescript/lib/commonjs/Offscreen.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/WebGPUViewNativeComponent.d.ts +5 -0
- package/lib/typescript/lib/commonjs/WebGPUViewNativeComponent.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/WebGPUViewNativeComponent.web.d.ts +4 -0
- package/lib/typescript/lib/commonjs/WebGPUViewNativeComponent.web.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/WebPolyfillGPUModule.d.ts +2 -0
- package/lib/typescript/lib/commonjs/WebPolyfillGPUModule.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/external/ModuleProxy.d.ts +12 -0
- package/lib/typescript/lib/commonjs/external/ModuleProxy.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/external/index.d.ts +2 -0
- package/lib/typescript/lib/commonjs/external/index.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/external/reanimated/ReanimatedProxy.d.ts +6 -0
- package/lib/typescript/lib/commonjs/external/reanimated/ReanimatedProxy.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/external/reanimated/index.d.ts +4 -0
- package/lib/typescript/lib/commonjs/external/reanimated/index.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/external/reanimated/registerWebGPUForReanimated.d.ts +9 -0
- package/lib/typescript/lib/commonjs/external/reanimated/registerWebGPUForReanimated.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/hooks.d.ts +18 -0
- package/lib/typescript/lib/commonjs/hooks.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/index.d.ts +2 -0
- package/lib/typescript/lib/commonjs/index.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/main/index.d.ts +3 -0
- package/lib/typescript/lib/commonjs/main/index.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/main/index.web.d.ts +2 -0
- package/lib/typescript/lib/commonjs/main/index.web.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/types.d.ts +1 -0
- package/lib/typescript/lib/commonjs/types.d.ts.map +1 -0
- package/lib/typescript/lib/commonjs/utils.d.ts +3 -0
- package/lib/typescript/lib/commonjs/utils.d.ts.map +1 -0
- package/lib/typescript/lib/module/Canvas.d.ts +8 -0
- package/lib/typescript/lib/module/Canvas.d.ts.map +1 -0
- package/lib/typescript/lib/module/NativeWebGPUModule.d.ts +3 -0
- package/lib/typescript/lib/module/NativeWebGPUModule.d.ts.map +1 -0
- package/lib/typescript/lib/module/Offscreen.d.ts +25 -0
- package/lib/typescript/lib/module/Offscreen.d.ts.map +1 -0
- package/lib/typescript/lib/module/WebGPUViewNativeComponent.d.ts +3 -0
- package/lib/typescript/lib/module/WebGPUViewNativeComponent.d.ts.map +1 -0
- package/lib/typescript/lib/module/WebGPUViewNativeComponent.web.d.ts +3 -0
- package/lib/typescript/lib/module/WebGPUViewNativeComponent.web.d.ts.map +1 -0
- package/lib/typescript/lib/module/WebPolyfillGPUModule.d.ts +2 -0
- package/lib/typescript/lib/module/WebPolyfillGPUModule.d.ts.map +1 -0
- package/lib/typescript/lib/module/external/ModuleProxy.d.ts +7 -0
- package/lib/typescript/lib/module/external/ModuleProxy.d.ts.map +1 -0
- package/lib/typescript/lib/module/external/index.d.ts +2 -0
- package/lib/typescript/lib/module/external/index.d.ts.map +1 -0
- package/lib/typescript/lib/module/external/reanimated/ReanimatedProxy.d.ts +5 -0
- package/lib/typescript/lib/module/external/reanimated/ReanimatedProxy.d.ts.map +1 -0
- package/lib/typescript/lib/module/external/reanimated/index.d.ts +3 -0
- package/lib/typescript/lib/module/external/reanimated/index.d.ts.map +1 -0
- package/lib/typescript/lib/module/external/reanimated/registerWebGPUForReanimated.d.ts +2 -0
- package/lib/typescript/lib/module/external/reanimated/registerWebGPUForReanimated.d.ts.map +1 -0
- package/lib/typescript/lib/module/hooks.d.ts +18 -0
- package/lib/typescript/lib/module/hooks.d.ts.map +1 -0
- package/lib/typescript/lib/module/index.d.ts +2 -0
- package/lib/typescript/lib/module/index.d.ts.map +1 -0
- package/lib/typescript/lib/module/main/index.d.ts +6 -0
- package/lib/typescript/lib/module/main/index.d.ts.map +1 -0
- package/lib/typescript/lib/module/main/index.web.d.ts +5 -0
- package/lib/typescript/lib/module/main/index.web.d.ts.map +1 -0
- package/lib/typescript/lib/module/types.d.ts +1 -0
- package/lib/typescript/lib/module/types.d.ts.map +1 -0
- package/lib/typescript/lib/module/utils.d.ts +2 -0
- package/lib/typescript/lib/module/utils.d.ts.map +1 -0
- package/lib/typescript/src/Canvas.d.ts +35 -0
- package/lib/typescript/src/Canvas.d.ts.map +1 -0
- package/lib/typescript/src/NativeWebGPUModule.d.ts +7 -0
- package/lib/typescript/src/NativeWebGPUModule.d.ts.map +1 -0
- package/lib/typescript/src/Offscreen.d.ts +30 -0
- package/lib/typescript/src/Offscreen.d.ts.map +1 -0
- package/lib/typescript/src/WebGPUViewNativeComponent.d.ts +9 -0
- package/lib/typescript/src/WebGPUViewNativeComponent.d.ts.map +1 -0
- package/lib/typescript/src/WebGPUViewNativeComponent.web.d.ts +9 -0
- package/lib/typescript/src/WebGPUViewNativeComponent.web.d.ts.map +1 -0
- package/lib/typescript/src/WebPolyfillGPUModule.d.ts +2 -0
- package/lib/typescript/src/WebPolyfillGPUModule.d.ts.map +1 -0
- package/lib/typescript/src/external/ModuleProxy.d.ts +11 -0
- package/lib/typescript/src/external/ModuleProxy.d.ts.map +1 -0
- package/lib/typescript/src/external/index.d.ts +2 -0
- package/lib/typescript/src/external/index.d.ts.map +1 -0
- package/lib/typescript/src/external/reanimated/ReanimatedProxy.d.ts +4 -0
- package/lib/typescript/src/external/reanimated/ReanimatedProxy.d.ts.map +1 -0
- package/lib/typescript/src/external/reanimated/index.d.ts +3 -0
- package/lib/typescript/src/external/reanimated/index.d.ts.map +1 -0
- package/lib/typescript/src/external/reanimated/registerWebGPUForReanimated.d.ts +8 -0
- package/lib/typescript/src/external/reanimated/registerWebGPUForReanimated.d.ts.map +1 -0
- package/lib/typescript/src/hooks.d.ts +27 -0
- package/lib/typescript/src/hooks.d.ts.map +1 -0
- package/lib/typescript/src/index.d.ts +18 -0
- package/lib/typescript/src/index.d.ts.map +1 -0
- package/lib/typescript/src/main/index.d.ts +6 -0
- package/lib/typescript/src/main/index.d.ts.map +1 -0
- package/lib/typescript/src/main/index.web.d.ts +6 -0
- package/lib/typescript/src/main/index.web.d.ts.map +1 -0
- package/lib/typescript/src/types.d.ts +19 -0
- package/lib/typescript/src/types.d.ts.map +1 -0
- package/lib/typescript/src/utils.d.ts +2 -0
- package/lib/typescript/src/utils.d.ts.map +1 -0
- package/libs/android/arm64-v8a/libwebgpu_dawn.so +0 -0
- package/libs/android/armeabi-v7a/libwebgpu_dawn.so +0 -0
- package/libs/android/x86/libwebgpu_dawn.so +0 -0
- package/libs/android/x86_64/libwebgpu_dawn.so +0 -0
- package/libs/apple/libwebgpu_dawn.xcframework/Info.plist +59 -0
- package/libs/apple/libwebgpu_dawn.xcframework/ios-arm64/libwebgpu_dawn.a +0 -0
- package/libs/apple/libwebgpu_dawn.xcframework/ios-arm64_x86_64-simulator/libwebgpu_dawn.a +0 -0
- package/libs/apple/libwebgpu_dawn.xcframework/macos-arm64_x86_64/libwebgpu_dawn.a +0 -0
- package/package.json +139 -0
- package/react-native-wgpu.podspec +47 -0
- package/src/Canvas.tsx +91 -0
- package/src/NativeWebGPUModule.ts +9 -0
- package/src/Offscreen.ts +113 -0
- package/src/WebGPUViewNativeComponent.ts +11 -0
- package/src/WebGPUViewNativeComponent.web.ts +113 -0
- package/src/WebPolyfillGPUModule.ts +53 -0
- package/src/external/ModuleProxy.ts +30 -0
- package/src/external/index.ts +1 -0
- package/src/external/reanimated/ReanimatedProxy.ts +19 -0
- package/src/external/reanimated/index.ts +2 -0
- package/src/external/reanimated/registerWebGPUForReanimated.ts +43 -0
- package/src/hooks.tsx +93 -0
- package/src/index.tsx +31 -0
- package/src/main/index.tsx +40 -0
- package/src/main/index.web.tsx +8 -0
- package/src/types.ts +20 -0
- package/src/utils.ts +4 -0
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <android/bitmap.h>
|
|
4
|
+
#include <jni.h>
|
|
5
|
+
|
|
6
|
+
#include <functional>
|
|
7
|
+
#include <memory>
|
|
8
|
+
#include <string>
|
|
9
|
+
#include <thread>
|
|
10
|
+
#include <vector>
|
|
11
|
+
|
|
12
|
+
#include "webgpu/webgpu_cpp.h"
|
|
13
|
+
|
|
14
|
+
#include "PlatformContext.h"
|
|
15
|
+
#include "RNWebGPUManager.h"
|
|
16
|
+
|
|
17
|
+
namespace rnwgpu {
|
|
18
|
+
|
|
19
|
+
namespace jsi = facebook::jsi;
|
|
20
|
+
namespace jni = facebook::jni;
|
|
21
|
+
|
|
22
|
+
class AndroidPlatformContext : public PlatformContext {
|
|
23
|
+
private:
|
|
24
|
+
jobject _blobModule;
|
|
25
|
+
|
|
26
|
+
std::vector<uint8_t> resolveBlob(JNIEnv *env, const std::string &blobId,
|
|
27
|
+
double offset, double size) {
|
|
28
|
+
if (!_blobModule) {
|
|
29
|
+
throw std::runtime_error("BlobModule instance is null");
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
jclass blobModuleClass = env->GetObjectClass(_blobModule);
|
|
33
|
+
if (!blobModuleClass) {
|
|
34
|
+
throw std::runtime_error("Couldn't find BlobModule class");
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
jmethodID resolveMethod = env->GetMethodID(blobModuleClass, "resolve",
|
|
38
|
+
"(Ljava/lang/String;II)[B");
|
|
39
|
+
env->DeleteLocalRef(blobModuleClass);
|
|
40
|
+
|
|
41
|
+
if (!resolveMethod) {
|
|
42
|
+
throw std::runtime_error("Couldn't find resolve method in BlobModule");
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
jstring jBlobId = env->NewStringUTF(blobId.c_str());
|
|
46
|
+
jbyteArray blobData = (jbyteArray)env->CallObjectMethod(
|
|
47
|
+
_blobModule, resolveMethod, jBlobId, static_cast<jint>(offset),
|
|
48
|
+
static_cast<jint>(size));
|
|
49
|
+
env->DeleteLocalRef(jBlobId);
|
|
50
|
+
|
|
51
|
+
if (!blobData) {
|
|
52
|
+
throw std::runtime_error("Couldn't retrieve blob data");
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
jsize len = env->GetArrayLength(blobData);
|
|
56
|
+
std::vector<uint8_t> data(len);
|
|
57
|
+
env->GetByteArrayRegion(blobData, 0, len,
|
|
58
|
+
reinterpret_cast<jbyte *>(data.data()));
|
|
59
|
+
env->DeleteLocalRef(blobData);
|
|
60
|
+
return data;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
public:
|
|
64
|
+
explicit AndroidPlatformContext(jobject blobModule)
|
|
65
|
+
: _blobModule(blobModule) {}
|
|
66
|
+
~AndroidPlatformContext() {
|
|
67
|
+
if (_blobModule) {
|
|
68
|
+
JNIEnv *env = facebook::jni::Environment::current();
|
|
69
|
+
env->DeleteGlobalRef(_blobModule);
|
|
70
|
+
_blobModule = nullptr;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
wgpu::Surface makeSurface(wgpu::Instance instance, void *window, int width,
|
|
75
|
+
int height) override {
|
|
76
|
+
wgpu::SurfaceSourceAndroidNativeWindow androidSurfaceDesc;
|
|
77
|
+
androidSurfaceDesc.window = reinterpret_cast<ANativeWindow *>(window);
|
|
78
|
+
wgpu::SurfaceDescriptor surfaceDescriptor;
|
|
79
|
+
surfaceDescriptor.nextInChain = &androidSurfaceDesc;
|
|
80
|
+
return instance.CreateSurface(&surfaceDescriptor);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
ImageData createImageBitmap(std::string blobId, double offset,
|
|
84
|
+
double size) override {
|
|
85
|
+
jni::Environment::ensureCurrentThreadIsAttached();
|
|
86
|
+
|
|
87
|
+
JNIEnv *env = facebook::jni::Environment::current();
|
|
88
|
+
if (!env) {
|
|
89
|
+
throw std::runtime_error("Couldn't get JNI environment");
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
auto data = resolveBlob(env, blobId, offset, size);
|
|
93
|
+
return createImageBitmapFromData(data);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
void
|
|
97
|
+
createImageBitmapAsync(std::string blobId, double offset, double size,
|
|
98
|
+
std::function<void(ImageData)> onSuccess,
|
|
99
|
+
std::function<void(std::string)> onError) override {
|
|
100
|
+
std::thread([this, blobId = std::move(blobId), offset, size,
|
|
101
|
+
onSuccess = std::move(onSuccess),
|
|
102
|
+
onError = std::move(onError)]() {
|
|
103
|
+
jni::Environment::ensureCurrentThreadIsAttached();
|
|
104
|
+
try {
|
|
105
|
+
JNIEnv *env = facebook::jni::Environment::current();
|
|
106
|
+
if (!env) {
|
|
107
|
+
throw std::runtime_error("Couldn't get JNI environment");
|
|
108
|
+
}
|
|
109
|
+
auto data = resolveBlob(env, blobId, offset, size);
|
|
110
|
+
auto result = createImageBitmapFromData(data);
|
|
111
|
+
onSuccess(std::move(result));
|
|
112
|
+
} catch (const std::exception &e) {
|
|
113
|
+
onError(e.what());
|
|
114
|
+
}
|
|
115
|
+
}).detach();
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
ImageData createImageBitmapFromData(std::span<const uint8_t> data) override {
|
|
119
|
+
jni::Environment::ensureCurrentThreadIsAttached();
|
|
120
|
+
|
|
121
|
+
JNIEnv *env = facebook::jni::Environment::current();
|
|
122
|
+
if (!env) {
|
|
123
|
+
throw std::runtime_error("Couldn't get JNI environment");
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
// Create jbyteArray from the raw bytes
|
|
127
|
+
jbyteArray byteArray = env->NewByteArray(static_cast<jsize>(data.size()));
|
|
128
|
+
if (!byteArray) {
|
|
129
|
+
throw std::runtime_error("Couldn't allocate byte array");
|
|
130
|
+
}
|
|
131
|
+
env->SetByteArrayRegion(byteArray, 0, static_cast<jsize>(data.size()),
|
|
132
|
+
reinterpret_cast<const jbyte *>(data.data()));
|
|
133
|
+
|
|
134
|
+
// Decode via BitmapFactory
|
|
135
|
+
jclass bitmapFactoryClass =
|
|
136
|
+
env->FindClass("android/graphics/BitmapFactory");
|
|
137
|
+
if (!bitmapFactoryClass) {
|
|
138
|
+
env->DeleteLocalRef(byteArray);
|
|
139
|
+
throw std::runtime_error("Couldn't find BitmapFactory class");
|
|
140
|
+
}
|
|
141
|
+
jmethodID decodeByteArrayMethod =
|
|
142
|
+
env->GetStaticMethodID(bitmapFactoryClass, "decodeByteArray",
|
|
143
|
+
"([BII)Landroid/graphics/Bitmap;");
|
|
144
|
+
if (!decodeByteArrayMethod) {
|
|
145
|
+
env->DeleteLocalRef(byteArray);
|
|
146
|
+
env->DeleteLocalRef(bitmapFactoryClass);
|
|
147
|
+
throw std::runtime_error("Couldn't find decodeByteArray method");
|
|
148
|
+
}
|
|
149
|
+
jint length = static_cast<jint>(data.size());
|
|
150
|
+
jobject bitmap = env->CallStaticObjectMethod(
|
|
151
|
+
bitmapFactoryClass, decodeByteArrayMethod, byteArray, 0, length);
|
|
152
|
+
env->DeleteLocalRef(bitmapFactoryClass);
|
|
153
|
+
|
|
154
|
+
if (!bitmap) {
|
|
155
|
+
env->DeleteLocalRef(byteArray);
|
|
156
|
+
throw std::runtime_error("Couldn't decode image");
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
AndroidBitmapInfo bitmapInfo;
|
|
160
|
+
if (AndroidBitmap_getInfo(env, bitmap, &bitmapInfo) !=
|
|
161
|
+
ANDROID_BITMAP_RESULT_SUCCESS) {
|
|
162
|
+
env->DeleteLocalRef(byteArray);
|
|
163
|
+
env->DeleteLocalRef(bitmap);
|
|
164
|
+
throw std::runtime_error("Couldn't get bitmap info");
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
void *bitmapPixels;
|
|
168
|
+
if (AndroidBitmap_lockPixels(env, bitmap, &bitmapPixels) !=
|
|
169
|
+
ANDROID_BITMAP_RESULT_SUCCESS) {
|
|
170
|
+
env->DeleteLocalRef(byteArray);
|
|
171
|
+
env->DeleteLocalRef(bitmap);
|
|
172
|
+
throw std::runtime_error("Couldn't lock bitmap pixels");
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
ImageData result;
|
|
176
|
+
result.width = static_cast<int>(bitmapInfo.width);
|
|
177
|
+
result.height = static_cast<int>(bitmapInfo.height);
|
|
178
|
+
result.data.resize(bitmapInfo.height * bitmapInfo.stride);
|
|
179
|
+
memcpy(result.data.data(), bitmapPixels, result.data.size());
|
|
180
|
+
|
|
181
|
+
AndroidBitmap_unlockPixels(env, bitmap);
|
|
182
|
+
|
|
183
|
+
env->DeleteLocalRef(byteArray);
|
|
184
|
+
env->DeleteLocalRef(bitmap);
|
|
185
|
+
|
|
186
|
+
return result;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
void createImageBitmapFromDataAsync(
|
|
190
|
+
std::span<const uint8_t> data, std::function<void(ImageData)> onSuccess,
|
|
191
|
+
std::function<void(std::string)> onError) override {
|
|
192
|
+
std::thread([this,
|
|
193
|
+
ownedData = std::vector<uint8_t>(data.begin(), data.end()),
|
|
194
|
+
onSuccess = std::move(onSuccess),
|
|
195
|
+
onError = std::move(onError)]() mutable {
|
|
196
|
+
jni::Environment::ensureCurrentThreadIsAttached();
|
|
197
|
+
try {
|
|
198
|
+
auto result = createImageBitmapFromData(ownedData);
|
|
199
|
+
onSuccess(std::move(result));
|
|
200
|
+
} catch (const std::exception &e) {
|
|
201
|
+
onError(e.what());
|
|
202
|
+
}
|
|
203
|
+
}).detach();
|
|
204
|
+
}
|
|
205
|
+
};
|
|
206
|
+
|
|
207
|
+
} // namespace rnwgpu
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
#include <memory>
|
|
2
|
+
#include <unordered_map>
|
|
3
|
+
|
|
4
|
+
#include <fbjni/fbjni.h>
|
|
5
|
+
#include <jni.h>
|
|
6
|
+
#include <jsi/jsi.h>
|
|
7
|
+
|
|
8
|
+
#include <ReactCommon/CallInvokerHolder.h>
|
|
9
|
+
#include <android/native_window_jni.h>
|
|
10
|
+
#include <webgpu/webgpu_cpp.h>
|
|
11
|
+
|
|
12
|
+
#include "AndroidPlatformContext.h"
|
|
13
|
+
#include "GPUCanvasContext.h"
|
|
14
|
+
#include "RNWebGPUManager.h"
|
|
15
|
+
|
|
16
|
+
#define LOG_TAG "WebGPUModule"
|
|
17
|
+
|
|
18
|
+
std::shared_ptr<rnwgpu::RNWebGPUManager> manager;
|
|
19
|
+
|
|
20
|
+
extern "C" JNIEXPORT void JNICALL Java_com_webgpu_WebGPUModule_initializeNative(
|
|
21
|
+
JNIEnv *env, jobject /* this */, jlong jsRuntime,
|
|
22
|
+
jobject jsCallInvokerHolder, jobject blobModule) {
|
|
23
|
+
auto runtime = reinterpret_cast<facebook::jsi::Runtime *>(jsRuntime);
|
|
24
|
+
jobject globalBlobModule = env->NewGlobalRef(blobModule);
|
|
25
|
+
auto jsCallInvoker{
|
|
26
|
+
facebook::jni::alias_ref<facebook::react::CallInvokerHolder::javaobject>{
|
|
27
|
+
reinterpret_cast<facebook::react::CallInvokerHolder::javaobject>(
|
|
28
|
+
jsCallInvokerHolder)} -> cthis()
|
|
29
|
+
->getCallInvoker()};
|
|
30
|
+
auto platformContext =
|
|
31
|
+
std::make_shared<rnwgpu::AndroidPlatformContext>(globalBlobModule);
|
|
32
|
+
manager = std::make_shared<rnwgpu::RNWebGPUManager>(runtime, jsCallInvoker,
|
|
33
|
+
platformContext);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
extern "C" JNIEXPORT void JNICALL Java_com_webgpu_WebGPUView_onSurfaceChanged(
|
|
37
|
+
JNIEnv *env, jobject thiz, jobject surface, jint contextId, jfloat width,
|
|
38
|
+
jfloat height) {
|
|
39
|
+
auto ®istry = rnwgpu::SurfaceRegistry::getInstance();
|
|
40
|
+
registry.getSurfaceInfo(contextId)->resize(static_cast<int>(width),
|
|
41
|
+
static_cast<int>(height));
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
extern "C" JNIEXPORT void JNICALL Java_com_webgpu_WebGPUView_onSurfaceCreate(
|
|
45
|
+
JNIEnv *env, jobject thiz, jobject jSurface, jint contextId, jfloat width,
|
|
46
|
+
jfloat height) {
|
|
47
|
+
auto window = ANativeWindow_fromSurface(env, jSurface);
|
|
48
|
+
// ANativeWindow_acquire(window);
|
|
49
|
+
auto ®istry = rnwgpu::SurfaceRegistry::getInstance();
|
|
50
|
+
auto gpu = manager->_gpu;
|
|
51
|
+
auto surface = manager->_platformContext->makeSurface(
|
|
52
|
+
gpu, window, static_cast<int>(width), static_cast<int>(height));
|
|
53
|
+
registry
|
|
54
|
+
.getSurfaceInfoOrCreate(contextId, gpu, static_cast<int>(width),
|
|
55
|
+
static_cast<int>(height))
|
|
56
|
+
->switchToOnscreen(window, surface);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
extern "C" JNIEXPORT void JNICALL
|
|
60
|
+
Java_com_webgpu_WebGPUView_switchToOffscreenSurface(JNIEnv *env, jobject thiz,
|
|
61
|
+
jint contextId) {
|
|
62
|
+
auto ®istry = rnwgpu::SurfaceRegistry::getInstance();
|
|
63
|
+
auto nativeSurface = registry.getSurfaceInfo(contextId)->switchToOffscreen();
|
|
64
|
+
// ANativeWindow_release(reinterpret_cast<ANativeWindow *>(nativeSurface));
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
extern "C" JNIEXPORT void JNICALL Java_com_webgpu_WebGPUView_onSurfaceDestroy(
|
|
68
|
+
JNIEnv *env, jobject thiz, jint contextId) {
|
|
69
|
+
auto ®istry = rnwgpu::SurfaceRegistry::getInstance();
|
|
70
|
+
registry.removeSurfaceInfo(contextId);
|
|
71
|
+
}
|
|
@@ -0,0 +1,298 @@
|
|
|
1
|
+
package com.webgpu;
|
|
2
|
+
|
|
3
|
+
import android.annotation.SuppressLint;
|
|
4
|
+
import android.content.Context;
|
|
5
|
+
import android.graphics.Bitmap;
|
|
6
|
+
import android.graphics.Canvas;
|
|
7
|
+
import android.graphics.Paint;
|
|
8
|
+
import android.graphics.PixelFormat;
|
|
9
|
+
import android.graphics.Rect;
|
|
10
|
+
import android.hardware.HardwareBuffer;
|
|
11
|
+
import android.media.Image;
|
|
12
|
+
import android.media.ImageReader;
|
|
13
|
+
import android.os.Build;
|
|
14
|
+
import android.os.Handler;
|
|
15
|
+
import android.os.Looper;
|
|
16
|
+
import android.view.Surface;
|
|
17
|
+
import android.view.View;
|
|
18
|
+
|
|
19
|
+
import androidx.annotation.NonNull;
|
|
20
|
+
import androidx.annotation.RequiresApi;
|
|
21
|
+
|
|
22
|
+
import java.nio.ByteBuffer;
|
|
23
|
+
|
|
24
|
+
@RequiresApi(api = Build.VERSION_CODES.Q)
|
|
25
|
+
@SuppressLint("ViewConstructor")
|
|
26
|
+
public class WebGPUAHBView extends View implements ImageReader.OnImageAvailableListener {
|
|
27
|
+
|
|
28
|
+
private static final int MAX_IMAGES = 3;
|
|
29
|
+
private static final String TAG = "WebGPUAHBView";
|
|
30
|
+
|
|
31
|
+
private final WebGPUAPI mApi;
|
|
32
|
+
private ImageReader mImageReader;
|
|
33
|
+
private Surface mSurface;
|
|
34
|
+
private Image mCurrentImage;
|
|
35
|
+
private Bitmap mCachedBitmap;
|
|
36
|
+
private final Paint mPaint;
|
|
37
|
+
private final Handler mHandler;
|
|
38
|
+
private final Object mImageLock = new Object();
|
|
39
|
+
private boolean mSurfaceCreated = false;
|
|
40
|
+
private int mConfiguredWidth = 0;
|
|
41
|
+
private int mConfiguredHeight = 0;
|
|
42
|
+
|
|
43
|
+
public WebGPUAHBView(Context context, WebGPUAPI api) {
|
|
44
|
+
super(context);
|
|
45
|
+
mApi = api;
|
|
46
|
+
mPaint = new Paint(Paint.FILTER_BITMAP_FLAG);
|
|
47
|
+
mHandler = new Handler(Looper.getMainLooper());
|
|
48
|
+
|
|
49
|
+
// Enable hardware acceleration for this view
|
|
50
|
+
setLayerType(LAYER_TYPE_HARDWARE, null);
|
|
51
|
+
|
|
52
|
+
// Make sure we get drawn
|
|
53
|
+
setWillNotDraw(false);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
@Override
|
|
57
|
+
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
|
|
58
|
+
super.onSizeChanged(w, h, oldw, oldh);
|
|
59
|
+
|
|
60
|
+
if (w > 0 && h > 0) {
|
|
61
|
+
// Recreate ImageReader with new dimensions
|
|
62
|
+
setupImageReader(w, h);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
private void setupImageReader(int width, int height) {
|
|
67
|
+
// Don't recreate if dimensions haven't changed
|
|
68
|
+
if (width == mConfiguredWidth && height == mConfiguredHeight && mImageReader != null) {
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// Clean up previous ImageReader
|
|
73
|
+
cleanupImageReader();
|
|
74
|
+
|
|
75
|
+
try {
|
|
76
|
+
// Create ImageReader with HardwareBuffer support
|
|
77
|
+
mImageReader = ImageReader.newInstance(
|
|
78
|
+
width,
|
|
79
|
+
height,
|
|
80
|
+
PixelFormat.RGBA_8888,
|
|
81
|
+
MAX_IMAGES,
|
|
82
|
+
HardwareBuffer.USAGE_GPU_SAMPLED_IMAGE |
|
|
83
|
+
HardwareBuffer.USAGE_GPU_COLOR_OUTPUT |
|
|
84
|
+
HardwareBuffer.USAGE_COMPOSER_OVERLAY |
|
|
85
|
+
HardwareBuffer.USAGE_CPU_READ_RARELY // For fallback to Bitmap if needed
|
|
86
|
+
);
|
|
87
|
+
|
|
88
|
+
mImageReader.setOnImageAvailableListener(this, mHandler);
|
|
89
|
+
|
|
90
|
+
// Get the Surface for WebGPU to render to
|
|
91
|
+
mSurface = mImageReader.getSurface();
|
|
92
|
+
|
|
93
|
+
mConfiguredWidth = width;
|
|
94
|
+
mConfiguredHeight = height;
|
|
95
|
+
|
|
96
|
+
// Notify WebGPU about the new surface
|
|
97
|
+
if (!mSurfaceCreated) {
|
|
98
|
+
mApi.surfaceCreated(mSurface);
|
|
99
|
+
mSurfaceCreated = true;
|
|
100
|
+
} else {
|
|
101
|
+
mApi.surfaceChanged(mSurface);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
} catch (Exception e) {
|
|
105
|
+
e.printStackTrace();
|
|
106
|
+
// Fallback to offscreen if ImageReader creation fails
|
|
107
|
+
mApi.surfaceOffscreen();
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
@Override
|
|
112
|
+
public void onImageAvailable(ImageReader reader) {
|
|
113
|
+
synchronized (mImageLock) {
|
|
114
|
+
// Close previous image if exists
|
|
115
|
+
if (mCurrentImage != null) {
|
|
116
|
+
mCurrentImage.close();
|
|
117
|
+
mCurrentImage = null;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
try {
|
|
121
|
+
// Get the latest image
|
|
122
|
+
mCurrentImage = reader.acquireLatestImage();
|
|
123
|
+
|
|
124
|
+
if (mCurrentImage != null) {
|
|
125
|
+
// Request a redraw on the UI thread
|
|
126
|
+
postInvalidateOnAnimation();
|
|
127
|
+
}
|
|
128
|
+
} catch (Exception e) {
|
|
129
|
+
e.printStackTrace();
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
@Override
|
|
135
|
+
protected void onDraw(Canvas canvas) {
|
|
136
|
+
super.onDraw(canvas);
|
|
137
|
+
|
|
138
|
+
synchronized (mImageLock) {
|
|
139
|
+
if (mCurrentImage == null) {
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
try {
|
|
144
|
+
// Try to use HardwareBuffer directly (most efficient path)
|
|
145
|
+
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
|
|
146
|
+
HardwareBuffer hardwareBuffer = mCurrentImage.getHardwareBuffer();
|
|
147
|
+
|
|
148
|
+
if (hardwareBuffer != null) {
|
|
149
|
+
// Draw using HardwareBuffer
|
|
150
|
+
drawHardwareBuffer(canvas, hardwareBuffer);
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
// Fallback: Convert Image to Bitmap
|
|
156
|
+
drawImageAsBitmap(canvas, mCurrentImage);
|
|
157
|
+
|
|
158
|
+
} catch (Exception e) {
|
|
159
|
+
e.printStackTrace();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
private void drawHardwareBuffer(Canvas canvas, HardwareBuffer hardwareBuffer) {
|
|
165
|
+
// On Android Q+, we can create a Bitmap from HardwareBuffer
|
|
166
|
+
try {
|
|
167
|
+
// Create or reuse bitmap with matching dimensions
|
|
168
|
+
if (mCachedBitmap == null ||
|
|
169
|
+
mCachedBitmap.getWidth() != hardwareBuffer.getWidth() ||
|
|
170
|
+
mCachedBitmap.getHeight() != hardwareBuffer.getHeight()) {
|
|
171
|
+
|
|
172
|
+
if (mCachedBitmap != null) {
|
|
173
|
+
mCachedBitmap.recycle();
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
// Create a hardware-backed Bitmap from the HardwareBuffer
|
|
177
|
+
mCachedBitmap = Bitmap.wrapHardwareBuffer(hardwareBuffer, null);
|
|
178
|
+
} else {
|
|
179
|
+
// Reuse existing bitmap and update with new HardwareBuffer content
|
|
180
|
+
mCachedBitmap = Bitmap.wrapHardwareBuffer(hardwareBuffer, null);
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
if (mCachedBitmap != null) {
|
|
184
|
+
// Draw the bitmap to canvas
|
|
185
|
+
canvas.drawBitmap(mCachedBitmap, 0, 0, mPaint);
|
|
186
|
+
}
|
|
187
|
+
} catch (Exception e) {
|
|
188
|
+
e.printStackTrace();
|
|
189
|
+
// Fallback to Image-based rendering
|
|
190
|
+
drawImageAsBitmap(canvas, mCurrentImage);
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
private void drawImageAsBitmap(Canvas canvas, Image image) {
|
|
195
|
+
// Fallback method: manually convert Image to Bitmap
|
|
196
|
+
if (image.getFormat() != PixelFormat.RGBA_8888) {
|
|
197
|
+
return;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
Image.Plane[] planes = image.getPlanes();
|
|
201
|
+
if (planes.length == 0) {
|
|
202
|
+
return;
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
ByteBuffer buffer = planes[0].getBuffer();
|
|
206
|
+
int pixelStride = planes[0].getPixelStride();
|
|
207
|
+
int rowStride = planes[0].getRowStride();
|
|
208
|
+
int rowPadding = rowStride - pixelStride * image.getWidth();
|
|
209
|
+
|
|
210
|
+
// Create or reuse bitmap
|
|
211
|
+
int bitmapWidth = image.getWidth() + rowPadding / pixelStride;
|
|
212
|
+
if (mCachedBitmap == null ||
|
|
213
|
+
mCachedBitmap.getWidth() != bitmapWidth ||
|
|
214
|
+
mCachedBitmap.getHeight() != image.getHeight()) {
|
|
215
|
+
|
|
216
|
+
if (mCachedBitmap != null) {
|
|
217
|
+
mCachedBitmap.recycle();
|
|
218
|
+
}
|
|
219
|
+
mCachedBitmap = Bitmap.createBitmap(
|
|
220
|
+
bitmapWidth,
|
|
221
|
+
image.getHeight(),
|
|
222
|
+
Bitmap.Config.ARGB_8888
|
|
223
|
+
);
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
mCachedBitmap.copyPixelsFromBuffer(buffer);
|
|
227
|
+
|
|
228
|
+
// Draw only the valid portion (without padding)
|
|
229
|
+
Rect src = new Rect(0, 0, image.getWidth(), image.getHeight());
|
|
230
|
+
Rect dst = new Rect(0, 0, getWidth(), getHeight());
|
|
231
|
+
canvas.drawBitmap(mCachedBitmap, src, dst, mPaint);
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
private void cleanupImageReader() {
|
|
235
|
+
synchronized (mImageLock) {
|
|
236
|
+
if (mCurrentImage != null) {
|
|
237
|
+
mCurrentImage.close();
|
|
238
|
+
mCurrentImage = null;
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
if (mImageReader != null) {
|
|
242
|
+
mImageReader.close();
|
|
243
|
+
mImageReader = null;
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
if (mSurface != null) {
|
|
247
|
+
mSurface.release();
|
|
248
|
+
mSurface = null;
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
@Override
|
|
254
|
+
protected void onDetachedFromWindow() {
|
|
255
|
+
super.onDetachedFromWindow();
|
|
256
|
+
|
|
257
|
+
// Notify WebGPU that surface is being destroyed
|
|
258
|
+
if (mSurfaceCreated) {
|
|
259
|
+
mApi.surfaceDestroyed();
|
|
260
|
+
mSurfaceCreated = false;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
// Clean up resources
|
|
264
|
+
cleanupImageReader();
|
|
265
|
+
|
|
266
|
+
if (mCachedBitmap != null) {
|
|
267
|
+
mCachedBitmap.recycle();
|
|
268
|
+
mCachedBitmap = null;
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
@Override
|
|
273
|
+
protected void onAttachedToWindow() {
|
|
274
|
+
super.onAttachedToWindow();
|
|
275
|
+
|
|
276
|
+
// Re-setup if we have valid dimensions
|
|
277
|
+
if (getWidth() > 0 && getHeight() > 0) {
|
|
278
|
+
setupImageReader(getWidth(), getHeight());
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
@Override
|
|
283
|
+
public void setAlpha(float alpha) {
|
|
284
|
+
super.setAlpha(alpha);
|
|
285
|
+
mPaint.setAlpha((int) (alpha * 255));
|
|
286
|
+
invalidate();
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
@Override
|
|
290
|
+
protected void onVisibilityChanged(@NonNull View changedView, int visibility) {
|
|
291
|
+
super.onVisibilityChanged(changedView, visibility);
|
|
292
|
+
|
|
293
|
+
if (visibility == VISIBLE && mSurface == null && getWidth() > 0 && getHeight() > 0) {
|
|
294
|
+
// Re-create surface if needed when becoming visible
|
|
295
|
+
setupImageReader(getWidth(), getHeight());
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
package com.webgpu;
|
|
2
|
+
|
|
3
|
+
import android.view.Surface;
|
|
4
|
+
|
|
5
|
+
import com.facebook.proguard.annotations.DoNotStrip;
|
|
6
|
+
|
|
7
|
+
public interface WebGPUAPI {
|
|
8
|
+
|
|
9
|
+
void surfaceCreated(
|
|
10
|
+
Surface surface
|
|
11
|
+
);
|
|
12
|
+
|
|
13
|
+
void surfaceChanged(
|
|
14
|
+
Surface surface
|
|
15
|
+
);
|
|
16
|
+
|
|
17
|
+
void surfaceDestroyed();
|
|
18
|
+
|
|
19
|
+
void surfaceOffscreen();
|
|
20
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
package com.webgpu;
|
|
2
|
+
|
|
3
|
+
import android.content.Context;
|
|
4
|
+
import android.view.Surface;
|
|
5
|
+
import android.view.View;
|
|
6
|
+
import com.facebook.proguard.annotations.DoNotStrip;
|
|
7
|
+
|
|
8
|
+
public abstract class WebGPUBaseView extends View {
|
|
9
|
+
protected Integer mContextId;
|
|
10
|
+
|
|
11
|
+
public WebGPUBaseView(Context context, Integer contextId) {
|
|
12
|
+
super(context);
|
|
13
|
+
mContextId = contextId;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
protected void handleSurfaceCreate(Surface surface) {
|
|
17
|
+
float density = getResources().getDisplayMetrics().density;
|
|
18
|
+
float scaledWidth = getWidth() / density;
|
|
19
|
+
float scaledHeight = getHeight() / density;
|
|
20
|
+
onSurfaceCreate(surface, mContextId, scaledWidth, scaledHeight);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
protected void handleSurfaceChanged(Surface surface) {
|
|
24
|
+
float density = getResources().getDisplayMetrics().density;
|
|
25
|
+
float scaledWidth = getWidth() / density;
|
|
26
|
+
float scaledHeight = getHeight() / density;
|
|
27
|
+
onSurfaceChanged(surface, mContextId, scaledWidth, scaledHeight);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
protected void handleSurfaceDestroyed() {
|
|
31
|
+
onSurfaceDestroy(mContextId);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
@Override
|
|
35
|
+
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
|
|
36
|
+
super.onLayout(changed, left, top, right, bottom);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
@DoNotStrip
|
|
41
|
+
private native void onSurfaceCreate(
|
|
42
|
+
Surface surface,
|
|
43
|
+
int contextId,
|
|
44
|
+
float width,
|
|
45
|
+
float height
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
@DoNotStrip
|
|
49
|
+
private native void onSurfaceChanged(
|
|
50
|
+
Surface surface,
|
|
51
|
+
int contextId,
|
|
52
|
+
float width,
|
|
53
|
+
float height
|
|
54
|
+
);
|
|
55
|
+
|
|
56
|
+
@DoNotStrip
|
|
57
|
+
private native void onSurfaceDestroy(int contextId);
|
|
58
|
+
|
|
59
|
+
@DoNotStrip
|
|
60
|
+
protected native void switchToOffscreenSurface(int contextId);
|
|
61
|
+
}
|