react-native-nitro-ar 2026.2.1
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/README.md +347 -0
- package/app.plugin.js +24 -0
- package/ios/Bridge.h +8 -0
- package/ios/HybridARAnchor.swift +58 -0
- package/ios/HybridARBoundingBoxBuilder.swift +142 -0
- package/ios/HybridARDepthData.swift +138 -0
- package/ios/HybridARFrame.swift +121 -0
- package/ios/HybridARLightEstimate.swift +58 -0
- package/ios/HybridARMeasurement.swift +33 -0
- package/ios/HybridARMeshAnchor.swift +108 -0
- package/ios/HybridARPlaneAnchor.swift +114 -0
- package/ios/HybridARRaycastResult.swift +53 -0
- package/ios/HybridARSession.swift +505 -0
- package/ios/HybridARView.swift +725 -0
- package/ios/HybridARVolume.swift +52 -0
- package/ios/HybridARWorldMap.swift +55 -0
- package/lib/commonjs/index.js +24 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/commonjs/package.json +3 -0
- package/lib/commonjs/specs/ARAnchor.nitro.js +6 -0
- package/lib/commonjs/specs/ARAnchor.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARBoundingBoxBuilder.nitro.js +6 -0
- package/lib/commonjs/specs/ARBoundingBoxBuilder.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARDepthData.nitro.js +6 -0
- package/lib/commonjs/specs/ARDepthData.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARFrame.nitro.js +6 -0
- package/lib/commonjs/specs/ARFrame.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARLightEstimate.nitro.js +6 -0
- package/lib/commonjs/specs/ARLightEstimate.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARMeasurement.nitro.js +6 -0
- package/lib/commonjs/specs/ARMeasurement.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARPlaneAnchor.nitro.js +6 -0
- package/lib/commonjs/specs/ARPlaneAnchor.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARRaycastResult.nitro.js +6 -0
- package/lib/commonjs/specs/ARRaycastResult.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARSceneMesh.nitro.js +6 -0
- package/lib/commonjs/specs/ARSceneMesh.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARSession.nitro.js +6 -0
- package/lib/commonjs/specs/ARSession.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARView.nitro.js +6 -0
- package/lib/commonjs/specs/ARView.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARVolume.nitro.js +6 -0
- package/lib/commonjs/specs/ARVolume.nitro.js.map +1 -0
- package/lib/commonjs/specs/ARWorldMap.nitro.js +6 -0
- package/lib/commonjs/specs/ARWorldMap.nitro.js.map +1 -0
- package/lib/module/index.js +18 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/specs/ARAnchor.nitro.js +4 -0
- package/lib/module/specs/ARAnchor.nitro.js.map +1 -0
- package/lib/module/specs/ARBoundingBoxBuilder.nitro.js +4 -0
- package/lib/module/specs/ARBoundingBoxBuilder.nitro.js.map +1 -0
- package/lib/module/specs/ARDepthData.nitro.js +4 -0
- package/lib/module/specs/ARDepthData.nitro.js.map +1 -0
- package/lib/module/specs/ARFrame.nitro.js +4 -0
- package/lib/module/specs/ARFrame.nitro.js.map +1 -0
- package/lib/module/specs/ARLightEstimate.nitro.js +4 -0
- package/lib/module/specs/ARLightEstimate.nitro.js.map +1 -0
- package/lib/module/specs/ARMeasurement.nitro.js +4 -0
- package/lib/module/specs/ARMeasurement.nitro.js.map +1 -0
- package/lib/module/specs/ARPlaneAnchor.nitro.js +4 -0
- package/lib/module/specs/ARPlaneAnchor.nitro.js.map +1 -0
- package/lib/module/specs/ARRaycastResult.nitro.js +4 -0
- package/lib/module/specs/ARRaycastResult.nitro.js.map +1 -0
- package/lib/module/specs/ARSceneMesh.nitro.js +4 -0
- package/lib/module/specs/ARSceneMesh.nitro.js.map +1 -0
- package/lib/module/specs/ARSession.nitro.js +4 -0
- package/lib/module/specs/ARSession.nitro.js.map +1 -0
- package/lib/module/specs/ARView.nitro.js +4 -0
- package/lib/module/specs/ARView.nitro.js.map +1 -0
- package/lib/module/specs/ARVolume.nitro.js +4 -0
- package/lib/module/specs/ARVolume.nitro.js.map +1 -0
- package/lib/module/specs/ARWorldMap.nitro.js +4 -0
- package/lib/module/specs/ARWorldMap.nitro.js.map +1 -0
- package/lib/typescript/src/index.d.ts +20 -0
- package/lib/typescript/src/index.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARAnchor.nitro.d.ts +18 -0
- package/lib/typescript/src/specs/ARAnchor.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARBoundingBoxBuilder.nitro.d.ts +11 -0
- package/lib/typescript/src/specs/ARBoundingBoxBuilder.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARDepthData.nitro.d.ts +26 -0
- package/lib/typescript/src/specs/ARDepthData.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARFrame.nitro.d.ts +32 -0
- package/lib/typescript/src/specs/ARFrame.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARLightEstimate.nitro.d.ts +18 -0
- package/lib/typescript/src/specs/ARLightEstimate.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARMeasurement.nitro.d.ts +11 -0
- package/lib/typescript/src/specs/ARMeasurement.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARPlaneAnchor.nitro.d.ts +32 -0
- package/lib/typescript/src/specs/ARPlaneAnchor.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARRaycastResult.nitro.d.ts +26 -0
- package/lib/typescript/src/specs/ARRaycastResult.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARSceneMesh.nitro.d.ts +47 -0
- package/lib/typescript/src/specs/ARSceneMesh.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARSession.nitro.d.ts +75 -0
- package/lib/typescript/src/specs/ARSession.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARView.nitro.d.ts +51 -0
- package/lib/typescript/src/specs/ARView.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARVolume.nitro.d.ts +14 -0
- package/lib/typescript/src/specs/ARVolume.nitro.d.ts.map +1 -0
- package/lib/typescript/src/specs/ARWorldMap.nitro.d.ts +17 -0
- package/lib/typescript/src/specs/ARWorldMap.nitro.d.ts.map +1 -0
- package/nitro.json +23 -0
- package/nitrogen/generated/.gitattributes +1 -0
- package/nitrogen/generated/ios/NitroAR+autolinking.rb +60 -0
- package/nitrogen/generated/ios/NitroAR-Swift-Cxx-Bridge.cpp +335 -0
- package/nitrogen/generated/ios/NitroAR-Swift-Cxx-Bridge.hpp +934 -0
- package/nitrogen/generated/ios/NitroAR-Swift-Cxx-Umbrella.hpp +169 -0
- package/nitrogen/generated/ios/NitroARAutolinking.mm +49 -0
- package/nitrogen/generated/ios/NitroARAutolinking.swift +50 -0
- package/nitrogen/generated/ios/c++/HybridARAnchorSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARAnchorSpecSwift.hpp +99 -0
- package/nitrogen/generated/ios/c++/HybridARBoundingBoxBuilderSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARBoundingBoxBuilderSpecSwift.hpp +95 -0
- package/nitrogen/generated/ios/c++/HybridARDepthDataSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARDepthDataSpecSwift.hpp +103 -0
- package/nitrogen/generated/ios/c++/HybridARDirectionalLightEstimateSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARDirectionalLightEstimateSpecSwift.hpp +88 -0
- package/nitrogen/generated/ios/c++/HybridARFrameSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARFrameSpecSwift.hpp +135 -0
- package/nitrogen/generated/ios/c++/HybridARLightEstimateSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARLightEstimateSpecSwift.hpp +80 -0
- package/nitrogen/generated/ios/c++/HybridARMeasurementSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARMeasurementSpecSwift.hpp +90 -0
- package/nitrogen/generated/ios/c++/HybridARMeshAnchorSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARMeshAnchorSpecSwift.hpp +107 -0
- package/nitrogen/generated/ios/c++/HybridARPlaneAnchorSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARPlaneAnchorSpecSwift.hpp +116 -0
- package/nitrogen/generated/ios/c++/HybridARPlaneGeometrySpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARPlaneGeometrySpecSwift.hpp +90 -0
- package/nitrogen/generated/ios/c++/HybridARRaycastResultSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARRaycastResultSpecSwift.hpp +97 -0
- package/nitrogen/generated/ios/c++/HybridARSessionSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARSessionSpecSwift.hpp +296 -0
- package/nitrogen/generated/ios/c++/HybridARViewSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARViewSpecSwift.hpp +243 -0
- package/nitrogen/generated/ios/c++/HybridARVolumeSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARVolumeSpecSwift.hpp +94 -0
- package/nitrogen/generated/ios/c++/HybridARWorldMapSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridARWorldMapSpecSwift.hpp +97 -0
- package/nitrogen/generated/ios/c++/views/HybridARViewComponent.mm +152 -0
- package/nitrogen/generated/ios/swift/ARSessionConfiguration.swift +189 -0
- package/nitrogen/generated/ios/swift/ARViewHitResult.swift +39 -0
- package/nitrogen/generated/ios/swift/CameraPose.swift +46 -0
- package/nitrogen/generated/ios/swift/EnvironmentTexturing.swift +44 -0
- package/nitrogen/generated/ios/swift/Func_void.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_TrackingState_TrackingStateReason.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__exception_ptr.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__shared_ptr_HybridARFrameSpec_.swift +50 -0
- package/nitrogen/generated/ios/swift/Func_void_std__shared_ptr_HybridARWorldMapSpec_.swift +50 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_std__shared_ptr_HybridARAnchorSpec___std__vector_std__shared_ptr_HybridARAnchorSpec___std__vector_std__string_.swift +54 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_std__shared_ptr_HybridARMeshAnchorSpec___std__vector_std__shared_ptr_HybridARMeshAnchorSpec___std__vector_std__string_.swift +54 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_std__shared_ptr_HybridARPlaneAnchorSpec___std__vector_std__shared_ptr_HybridARPlaneAnchorSpec___std__vector_std__string_.swift +54 -0
- package/nitrogen/generated/ios/swift/HybridARAnchorSpec.swift +60 -0
- package/nitrogen/generated/ios/swift/HybridARAnchorSpec_cxx.swift +192 -0
- package/nitrogen/generated/ios/swift/HybridARBoundingBoxBuilderSpec.swift +56 -0
- package/nitrogen/generated/ios/swift/HybridARBoundingBoxBuilderSpec_cxx.swift +161 -0
- package/nitrogen/generated/ios/swift/HybridARDepthDataSpec.swift +59 -0
- package/nitrogen/generated/ios/swift/HybridARDepthDataSpec_cxx.swift +188 -0
- package/nitrogen/generated/ios/swift/HybridARDirectionalLightEstimateSpec.swift +57 -0
- package/nitrogen/generated/ios/swift/HybridARDirectionalLightEstimateSpec_cxx.swift +162 -0
- package/nitrogen/generated/ios/swift/HybridARFrameSpec.swift +65 -0
- package/nitrogen/generated/ios/swift/HybridARFrameSpec_cxx.swift +285 -0
- package/nitrogen/generated/ios/swift/HybridARLightEstimateSpec.swift +56 -0
- package/nitrogen/generated/ios/swift/HybridARLightEstimateSpec_cxx.swift +140 -0
- package/nitrogen/generated/ios/swift/HybridARMeasurementSpec.swift +58 -0
- package/nitrogen/generated/ios/swift/HybridARMeasurementSpec_cxx.swift +160 -0
- package/nitrogen/generated/ios/swift/HybridARMeshAnchorSpec.swift +62 -0
- package/nitrogen/generated/ios/swift/HybridARMeshAnchorSpec_cxx.swift +212 -0
- package/nitrogen/generated/ios/swift/HybridARPlaneAnchorSpec.swift +62 -0
- package/nitrogen/generated/ios/swift/HybridARPlaneAnchorSpec_cxx.swift +209 -0
- package/nitrogen/generated/ios/swift/HybridARPlaneGeometrySpec.swift +58 -0
- package/nitrogen/generated/ios/swift/HybridARPlaneGeometrySpec_cxx.swift +178 -0
- package/nitrogen/generated/ios/swift/HybridARRaycastResultSpec.swift +59 -0
- package/nitrogen/generated/ios/swift/HybridARRaycastResultSpec_cxx.swift +179 -0
- package/nitrogen/generated/ios/swift/HybridARSessionSpec.swift +78 -0
- package/nitrogen/generated/ios/swift/HybridARSessionSpec_cxx.swift +591 -0
- package/nitrogen/generated/ios/swift/HybridARViewSpec.swift +78 -0
- package/nitrogen/generated/ios/swift/HybridARViewSpec_cxx.swift +561 -0
- package/nitrogen/generated/ios/swift/HybridARVolumeSpec.swift +60 -0
- package/nitrogen/generated/ios/swift/HybridARVolumeSpec_cxx.swift +180 -0
- package/nitrogen/generated/ios/swift/HybridARWorldMapSpec.swift +58 -0
- package/nitrogen/generated/ios/swift/HybridARWorldMapSpec_cxx.swift +176 -0
- package/nitrogen/generated/ios/swift/LiDARCapabilities.swift +39 -0
- package/nitrogen/generated/ios/swift/MeshClassification.swift +64 -0
- package/nitrogen/generated/ios/swift/PlaneAlignment.swift +40 -0
- package/nitrogen/generated/ios/swift/PlaneClassification.swift +64 -0
- package/nitrogen/generated/ios/swift/PlaneDetectionMode.swift +40 -0
- package/nitrogen/generated/ios/swift/RaycastAlignment.swift +44 -0
- package/nitrogen/generated/ios/swift/RaycastQuery.swift +44 -0
- package/nitrogen/generated/ios/swift/RaycastTarget.swift +48 -0
- package/nitrogen/generated/ios/swift/SceneReconstructionMode.swift +44 -0
- package/nitrogen/generated/ios/swift/TrackingState.swift +44 -0
- package/nitrogen/generated/ios/swift/TrackingStateReason.swift +52 -0
- package/nitrogen/generated/ios/swift/WorldAlignment.swift +44 -0
- package/nitrogen/generated/ios/swift/WorldMappingStatus.swift +48 -0
- package/nitrogen/generated/shared/c++/ARSessionConfiguration.hpp +132 -0
- package/nitrogen/generated/shared/c++/ARViewHitResult.hpp +91 -0
- package/nitrogen/generated/shared/c++/CameraPose.hpp +87 -0
- package/nitrogen/generated/shared/c++/EnvironmentTexturing.hpp +80 -0
- package/nitrogen/generated/shared/c++/HybridARAnchorSpec.cpp +26 -0
- package/nitrogen/generated/shared/c++/HybridARAnchorSpec.hpp +69 -0
- package/nitrogen/generated/shared/c++/HybridARBoundingBoxBuilderSpec.cpp +23 -0
- package/nitrogen/generated/shared/c++/HybridARBoundingBoxBuilderSpec.hpp +68 -0
- package/nitrogen/generated/shared/c++/HybridARDepthDataSpec.cpp +26 -0
- package/nitrogen/generated/shared/c++/HybridARDepthDataSpec.hpp +66 -0
- package/nitrogen/generated/shared/c++/HybridARDirectionalLightEstimateSpec.cpp +24 -0
- package/nitrogen/generated/shared/c++/HybridARDirectionalLightEstimateSpec.hpp +67 -0
- package/nitrogen/generated/shared/c++/HybridARFrameSpec.cpp +32 -0
- package/nitrogen/generated/shared/c++/HybridARFrameSpec.hpp +83 -0
- package/nitrogen/generated/shared/c++/HybridARLightEstimateSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridARLightEstimateSpec.hpp +63 -0
- package/nitrogen/generated/shared/c++/HybridARMeasurementSpec.cpp +24 -0
- package/nitrogen/generated/shared/c++/HybridARMeasurementSpec.hpp +67 -0
- package/nitrogen/generated/shared/c++/HybridARMeshAnchorSpec.cpp +28 -0
- package/nitrogen/generated/shared/c++/HybridARMeshAnchorSpec.hpp +72 -0
- package/nitrogen/generated/shared/c++/HybridARPlaneAnchorSpec.cpp +28 -0
- package/nitrogen/generated/shared/c++/HybridARPlaneAnchorSpec.hpp +79 -0
- package/nitrogen/generated/shared/c++/HybridARPlaneGeometrySpec.cpp +24 -0
- package/nitrogen/generated/shared/c++/HybridARPlaneGeometrySpec.hpp +65 -0
- package/nitrogen/generated/shared/c++/HybridARRaycastResultSpec.cpp +25 -0
- package/nitrogen/generated/shared/c++/HybridARRaycastResultSpec.hpp +70 -0
- package/nitrogen/generated/shared/c++/HybridARSessionSpec.cpp +45 -0
- package/nitrogen/generated/shared/c++/HybridARSessionSpec.hpp +131 -0
- package/nitrogen/generated/shared/c++/HybridARViewSpec.cpp +55 -0
- package/nitrogen/generated/shared/c++/HybridARViewSpec.hpp +101 -0
- package/nitrogen/generated/shared/c++/HybridARVolumeSpec.cpp +26 -0
- package/nitrogen/generated/shared/c++/HybridARVolumeSpec.hpp +67 -0
- package/nitrogen/generated/shared/c++/HybridARWorldMapSpec.cpp +25 -0
- package/nitrogen/generated/shared/c++/HybridARWorldMapSpec.hpp +66 -0
- package/nitrogen/generated/shared/c++/LiDARCapabilities.hpp +91 -0
- package/nitrogen/generated/shared/c++/MeshClassification.hpp +100 -0
- package/nitrogen/generated/shared/c++/PlaneAlignment.hpp +76 -0
- package/nitrogen/generated/shared/c++/PlaneClassification.hpp +100 -0
- package/nitrogen/generated/shared/c++/PlaneDetectionMode.hpp +76 -0
- package/nitrogen/generated/shared/c++/RaycastAlignment.hpp +80 -0
- package/nitrogen/generated/shared/c++/RaycastQuery.hpp +99 -0
- package/nitrogen/generated/shared/c++/RaycastTarget.hpp +84 -0
- package/nitrogen/generated/shared/c++/SceneReconstructionMode.hpp +80 -0
- package/nitrogen/generated/shared/c++/TrackingState.hpp +80 -0
- package/nitrogen/generated/shared/c++/TrackingStateReason.hpp +88 -0
- package/nitrogen/generated/shared/c++/WorldAlignment.hpp +80 -0
- package/nitrogen/generated/shared/c++/WorldMappingStatus.hpp +84 -0
- package/nitrogen/generated/shared/c++/views/HybridARViewComponent.cpp +182 -0
- package/nitrogen/generated/shared/c++/views/HybridARViewComponent.hpp +120 -0
- package/nitrogen/generated/shared/json/ARViewConfig.json +19 -0
- package/package.json +98 -0
- package/react-native-nitro-ar.podspec +40 -0
- package/src/index.ts +60 -0
- package/src/specs/ARAnchor.nitro.ts +21 -0
- package/src/specs/ARBoundingBoxBuilder.nitro.ts +11 -0
- package/src/specs/ARDepthData.nitro.ts +29 -0
- package/src/specs/ARFrame.nitro.ts +41 -0
- package/src/specs/ARLightEstimate.nitro.ts +20 -0
- package/src/specs/ARMeasurement.nitro.ts +10 -0
- package/src/specs/ARPlaneAnchor.nitro.ts +46 -0
- package/src/specs/ARRaycastResult.nitro.ts +32 -0
- package/src/specs/ARSceneMesh.nitro.ts +63 -0
- package/src/specs/ARSession.nitro.ts +112 -0
- package/src/specs/ARView.nitro.ts +84 -0
- package/src/specs/ARVolume.nitro.ts +15 -0
- package/src/specs/ARWorldMap.nitro.ts +20 -0
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// TrackingStateReason.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/NitroHash.hpp>)
|
|
11
|
+
#include <NitroModules/NitroHash.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
#if __has_include(<NitroModules/JSIConverter.hpp>)
|
|
16
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
17
|
+
#else
|
|
18
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
19
|
+
#endif
|
|
20
|
+
#if __has_include(<NitroModules/NitroDefines.hpp>)
|
|
21
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
22
|
+
#else
|
|
23
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
24
|
+
#endif
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::ar {
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* An enum which can be represented as a JavaScript union (TrackingStateReason).
|
|
30
|
+
*/
|
|
31
|
+
enum class TrackingStateReason {
|
|
32
|
+
NONE SWIFT_NAME(none) = 0,
|
|
33
|
+
INITIALIZING SWIFT_NAME(initializing) = 1,
|
|
34
|
+
EXCESSIVEMOTION SWIFT_NAME(excessivemotion) = 2,
|
|
35
|
+
INSUFFICIENTFEATURES SWIFT_NAME(insufficientfeatures) = 3,
|
|
36
|
+
RELOCALIZING SWIFT_NAME(relocalizing) = 4,
|
|
37
|
+
} CLOSED_ENUM;
|
|
38
|
+
|
|
39
|
+
} // namespace margelo::nitro::ar
|
|
40
|
+
|
|
41
|
+
namespace margelo::nitro {
|
|
42
|
+
|
|
43
|
+
// C++ TrackingStateReason <> JS TrackingStateReason (union)
|
|
44
|
+
template <>
|
|
45
|
+
struct JSIConverter<margelo::nitro::ar::TrackingStateReason> final {
|
|
46
|
+
static inline margelo::nitro::ar::TrackingStateReason fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
|
|
47
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
|
|
48
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
49
|
+
case hashString("none"): return margelo::nitro::ar::TrackingStateReason::NONE;
|
|
50
|
+
case hashString("initializing"): return margelo::nitro::ar::TrackingStateReason::INITIALIZING;
|
|
51
|
+
case hashString("excessiveMotion"): return margelo::nitro::ar::TrackingStateReason::EXCESSIVEMOTION;
|
|
52
|
+
case hashString("insufficientFeatures"): return margelo::nitro::ar::TrackingStateReason::INSUFFICIENTFEATURES;
|
|
53
|
+
case hashString("relocalizing"): return margelo::nitro::ar::TrackingStateReason::RELOCALIZING;
|
|
54
|
+
default: [[unlikely]]
|
|
55
|
+
throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum TrackingStateReason - invalid value!");
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::ar::TrackingStateReason arg) {
|
|
59
|
+
switch (arg) {
|
|
60
|
+
case margelo::nitro::ar::TrackingStateReason::NONE: return JSIConverter<std::string>::toJSI(runtime, "none");
|
|
61
|
+
case margelo::nitro::ar::TrackingStateReason::INITIALIZING: return JSIConverter<std::string>::toJSI(runtime, "initializing");
|
|
62
|
+
case margelo::nitro::ar::TrackingStateReason::EXCESSIVEMOTION: return JSIConverter<std::string>::toJSI(runtime, "excessiveMotion");
|
|
63
|
+
case margelo::nitro::ar::TrackingStateReason::INSUFFICIENTFEATURES: return JSIConverter<std::string>::toJSI(runtime, "insufficientFeatures");
|
|
64
|
+
case margelo::nitro::ar::TrackingStateReason::RELOCALIZING: return JSIConverter<std::string>::toJSI(runtime, "relocalizing");
|
|
65
|
+
default: [[unlikely]]
|
|
66
|
+
throw std::invalid_argument("Cannot convert TrackingStateReason to JS - invalid value: "
|
|
67
|
+
+ std::to_string(static_cast<int>(arg)) + "!");
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
|
|
71
|
+
if (!value.isString()) {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
|
|
75
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
76
|
+
case hashString("none"):
|
|
77
|
+
case hashString("initializing"):
|
|
78
|
+
case hashString("excessiveMotion"):
|
|
79
|
+
case hashString("insufficientFeatures"):
|
|
80
|
+
case hashString("relocalizing"):
|
|
81
|
+
return true;
|
|
82
|
+
default:
|
|
83
|
+
return false;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
} // namespace margelo::nitro
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// WorldAlignment.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/NitroHash.hpp>)
|
|
11
|
+
#include <NitroModules/NitroHash.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
#if __has_include(<NitroModules/JSIConverter.hpp>)
|
|
16
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
17
|
+
#else
|
|
18
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
19
|
+
#endif
|
|
20
|
+
#if __has_include(<NitroModules/NitroDefines.hpp>)
|
|
21
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
22
|
+
#else
|
|
23
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
24
|
+
#endif
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::ar {
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* An enum which can be represented as a JavaScript union (WorldAlignment).
|
|
30
|
+
*/
|
|
31
|
+
enum class WorldAlignment {
|
|
32
|
+
GRAVITY SWIFT_NAME(gravity) = 0,
|
|
33
|
+
GRAVITYANDHEADING SWIFT_NAME(gravityandheading) = 1,
|
|
34
|
+
CAMERA SWIFT_NAME(camera) = 2,
|
|
35
|
+
} CLOSED_ENUM;
|
|
36
|
+
|
|
37
|
+
} // namespace margelo::nitro::ar
|
|
38
|
+
|
|
39
|
+
namespace margelo::nitro {
|
|
40
|
+
|
|
41
|
+
// C++ WorldAlignment <> JS WorldAlignment (union)
|
|
42
|
+
template <>
|
|
43
|
+
struct JSIConverter<margelo::nitro::ar::WorldAlignment> final {
|
|
44
|
+
static inline margelo::nitro::ar::WorldAlignment fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
|
|
45
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
|
|
46
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
47
|
+
case hashString("gravity"): return margelo::nitro::ar::WorldAlignment::GRAVITY;
|
|
48
|
+
case hashString("gravityAndHeading"): return margelo::nitro::ar::WorldAlignment::GRAVITYANDHEADING;
|
|
49
|
+
case hashString("camera"): return margelo::nitro::ar::WorldAlignment::CAMERA;
|
|
50
|
+
default: [[unlikely]]
|
|
51
|
+
throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum WorldAlignment - invalid value!");
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::ar::WorldAlignment arg) {
|
|
55
|
+
switch (arg) {
|
|
56
|
+
case margelo::nitro::ar::WorldAlignment::GRAVITY: return JSIConverter<std::string>::toJSI(runtime, "gravity");
|
|
57
|
+
case margelo::nitro::ar::WorldAlignment::GRAVITYANDHEADING: return JSIConverter<std::string>::toJSI(runtime, "gravityAndHeading");
|
|
58
|
+
case margelo::nitro::ar::WorldAlignment::CAMERA: return JSIConverter<std::string>::toJSI(runtime, "camera");
|
|
59
|
+
default: [[unlikely]]
|
|
60
|
+
throw std::invalid_argument("Cannot convert WorldAlignment to JS - invalid value: "
|
|
61
|
+
+ std::to_string(static_cast<int>(arg)) + "!");
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
|
|
65
|
+
if (!value.isString()) {
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
|
|
69
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
70
|
+
case hashString("gravity"):
|
|
71
|
+
case hashString("gravityAndHeading"):
|
|
72
|
+
case hashString("camera"):
|
|
73
|
+
return true;
|
|
74
|
+
default:
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
} // namespace margelo::nitro
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// WorldMappingStatus.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/NitroHash.hpp>)
|
|
11
|
+
#include <NitroModules/NitroHash.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
#if __has_include(<NitroModules/JSIConverter.hpp>)
|
|
16
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
17
|
+
#else
|
|
18
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
19
|
+
#endif
|
|
20
|
+
#if __has_include(<NitroModules/NitroDefines.hpp>)
|
|
21
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
22
|
+
#else
|
|
23
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
24
|
+
#endif
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::ar {
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* An enum which can be represented as a JavaScript union (WorldMappingStatus).
|
|
30
|
+
*/
|
|
31
|
+
enum class WorldMappingStatus {
|
|
32
|
+
NOTAVAILABLE SWIFT_NAME(notavailable) = 0,
|
|
33
|
+
LIMITED SWIFT_NAME(limited) = 1,
|
|
34
|
+
EXTENDING SWIFT_NAME(extending) = 2,
|
|
35
|
+
MAPPED SWIFT_NAME(mapped) = 3,
|
|
36
|
+
} CLOSED_ENUM;
|
|
37
|
+
|
|
38
|
+
} // namespace margelo::nitro::ar
|
|
39
|
+
|
|
40
|
+
namespace margelo::nitro {
|
|
41
|
+
|
|
42
|
+
// C++ WorldMappingStatus <> JS WorldMappingStatus (union)
|
|
43
|
+
template <>
|
|
44
|
+
struct JSIConverter<margelo::nitro::ar::WorldMappingStatus> final {
|
|
45
|
+
static inline margelo::nitro::ar::WorldMappingStatus fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
|
|
46
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
|
|
47
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
48
|
+
case hashString("notAvailable"): return margelo::nitro::ar::WorldMappingStatus::NOTAVAILABLE;
|
|
49
|
+
case hashString("limited"): return margelo::nitro::ar::WorldMappingStatus::LIMITED;
|
|
50
|
+
case hashString("extending"): return margelo::nitro::ar::WorldMappingStatus::EXTENDING;
|
|
51
|
+
case hashString("mapped"): return margelo::nitro::ar::WorldMappingStatus::MAPPED;
|
|
52
|
+
default: [[unlikely]]
|
|
53
|
+
throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum WorldMappingStatus - invalid value!");
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::ar::WorldMappingStatus arg) {
|
|
57
|
+
switch (arg) {
|
|
58
|
+
case margelo::nitro::ar::WorldMappingStatus::NOTAVAILABLE: return JSIConverter<std::string>::toJSI(runtime, "notAvailable");
|
|
59
|
+
case margelo::nitro::ar::WorldMappingStatus::LIMITED: return JSIConverter<std::string>::toJSI(runtime, "limited");
|
|
60
|
+
case margelo::nitro::ar::WorldMappingStatus::EXTENDING: return JSIConverter<std::string>::toJSI(runtime, "extending");
|
|
61
|
+
case margelo::nitro::ar::WorldMappingStatus::MAPPED: return JSIConverter<std::string>::toJSI(runtime, "mapped");
|
|
62
|
+
default: [[unlikely]]
|
|
63
|
+
throw std::invalid_argument("Cannot convert WorldMappingStatus to JS - invalid value: "
|
|
64
|
+
+ std::to_string(static_cast<int>(arg)) + "!");
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
|
|
68
|
+
if (!value.isString()) {
|
|
69
|
+
return false;
|
|
70
|
+
}
|
|
71
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
|
|
72
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
73
|
+
case hashString("notAvailable"):
|
|
74
|
+
case hashString("limited"):
|
|
75
|
+
case hashString("extending"):
|
|
76
|
+
case hashString("mapped"):
|
|
77
|
+
return true;
|
|
78
|
+
default:
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
} // namespace margelo::nitro
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridARViewComponent.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "HybridARViewComponent.hpp"
|
|
9
|
+
|
|
10
|
+
#include <string>
|
|
11
|
+
#include <exception>
|
|
12
|
+
#include <utility>
|
|
13
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
14
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
15
|
+
#include <NitroModules/PropNameIDCache.hpp>
|
|
16
|
+
#include <react/renderer/core/RawValue.h>
|
|
17
|
+
#include <react/renderer/core/ShadowNode.h>
|
|
18
|
+
#include <react/renderer/core/ComponentDescriptor.h>
|
|
19
|
+
#include <react/renderer/components/view/ViewProps.h>
|
|
20
|
+
|
|
21
|
+
namespace margelo::nitro::ar::views {
|
|
22
|
+
|
|
23
|
+
extern const char HybridARViewComponentName[] = "ARView";
|
|
24
|
+
|
|
25
|
+
HybridARViewProps::HybridARViewProps(const react::PropsParserContext& context,
|
|
26
|
+
const HybridARViewProps& sourceProps,
|
|
27
|
+
const react::RawProps& rawProps):
|
|
28
|
+
react::ViewProps(context, sourceProps, rawProps, filterObjectKeys),
|
|
29
|
+
showDebugOptions([&]() -> CachedProp<std::optional<bool>> {
|
|
30
|
+
try {
|
|
31
|
+
const react::RawValue* rawValue = rawProps.at("showDebugOptions", nullptr, nullptr);
|
|
32
|
+
if (rawValue == nullptr) return sourceProps.showDebugOptions;
|
|
33
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
34
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.showDebugOptions);
|
|
35
|
+
} catch (const std::exception& exc) {
|
|
36
|
+
throw std::runtime_error(std::string("ARView.showDebugOptions: ") + exc.what());
|
|
37
|
+
}
|
|
38
|
+
}()),
|
|
39
|
+
showPlanes([&]() -> CachedProp<std::optional<bool>> {
|
|
40
|
+
try {
|
|
41
|
+
const react::RawValue* rawValue = rawProps.at("showPlanes", nullptr, nullptr);
|
|
42
|
+
if (rawValue == nullptr) return sourceProps.showPlanes;
|
|
43
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
44
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.showPlanes);
|
|
45
|
+
} catch (const std::exception& exc) {
|
|
46
|
+
throw std::runtime_error(std::string("ARView.showPlanes: ") + exc.what());
|
|
47
|
+
}
|
|
48
|
+
}()),
|
|
49
|
+
showFeaturePoints([&]() -> CachedProp<std::optional<bool>> {
|
|
50
|
+
try {
|
|
51
|
+
const react::RawValue* rawValue = rawProps.at("showFeaturePoints", nullptr, nullptr);
|
|
52
|
+
if (rawValue == nullptr) return sourceProps.showFeaturePoints;
|
|
53
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
54
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.showFeaturePoints);
|
|
55
|
+
} catch (const std::exception& exc) {
|
|
56
|
+
throw std::runtime_error(std::string("ARView.showFeaturePoints: ") + exc.what());
|
|
57
|
+
}
|
|
58
|
+
}()),
|
|
59
|
+
showWorldOrigin([&]() -> CachedProp<std::optional<bool>> {
|
|
60
|
+
try {
|
|
61
|
+
const react::RawValue* rawValue = rawProps.at("showWorldOrigin", nullptr, nullptr);
|
|
62
|
+
if (rawValue == nullptr) return sourceProps.showWorldOrigin;
|
|
63
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
64
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.showWorldOrigin);
|
|
65
|
+
} catch (const std::exception& exc) {
|
|
66
|
+
throw std::runtime_error(std::string("ARView.showWorldOrigin: ") + exc.what());
|
|
67
|
+
}
|
|
68
|
+
}()),
|
|
69
|
+
autoenablesDefaultLighting([&]() -> CachedProp<std::optional<bool>> {
|
|
70
|
+
try {
|
|
71
|
+
const react::RawValue* rawValue = rawProps.at("autoenablesDefaultLighting", nullptr, nullptr);
|
|
72
|
+
if (rawValue == nullptr) return sourceProps.autoenablesDefaultLighting;
|
|
73
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
74
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.autoenablesDefaultLighting);
|
|
75
|
+
} catch (const std::exception& exc) {
|
|
76
|
+
throw std::runtime_error(std::string("ARView.autoenablesDefaultLighting: ") + exc.what());
|
|
77
|
+
}
|
|
78
|
+
}()),
|
|
79
|
+
sceneReconstruction([&]() -> CachedProp<std::optional<SceneReconstructionMode>> {
|
|
80
|
+
try {
|
|
81
|
+
const react::RawValue* rawValue = rawProps.at("sceneReconstruction", nullptr, nullptr);
|
|
82
|
+
if (rawValue == nullptr) return sourceProps.sceneReconstruction;
|
|
83
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
84
|
+
return CachedProp<std::optional<SceneReconstructionMode>>::fromRawValue(*runtime, value, sourceProps.sceneReconstruction);
|
|
85
|
+
} catch (const std::exception& exc) {
|
|
86
|
+
throw std::runtime_error(std::string("ARView.sceneReconstruction: ") + exc.what());
|
|
87
|
+
}
|
|
88
|
+
}()),
|
|
89
|
+
showSceneMesh([&]() -> CachedProp<std::optional<bool>> {
|
|
90
|
+
try {
|
|
91
|
+
const react::RawValue* rawValue = rawProps.at("showSceneMesh", nullptr, nullptr);
|
|
92
|
+
if (rawValue == nullptr) return sourceProps.showSceneMesh;
|
|
93
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
94
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.showSceneMesh);
|
|
95
|
+
} catch (const std::exception& exc) {
|
|
96
|
+
throw std::runtime_error(std::string("ARView.showSceneMesh: ") + exc.what());
|
|
97
|
+
}
|
|
98
|
+
}()),
|
|
99
|
+
sceneDepth([&]() -> CachedProp<std::optional<bool>> {
|
|
100
|
+
try {
|
|
101
|
+
const react::RawValue* rawValue = rawProps.at("sceneDepth", nullptr, nullptr);
|
|
102
|
+
if (rawValue == nullptr) return sourceProps.sceneDepth;
|
|
103
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
104
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.sceneDepth);
|
|
105
|
+
} catch (const std::exception& exc) {
|
|
106
|
+
throw std::runtime_error(std::string("ARView.sceneDepth: ") + exc.what());
|
|
107
|
+
}
|
|
108
|
+
}()),
|
|
109
|
+
objectOcclusion([&]() -> CachedProp<std::optional<bool>> {
|
|
110
|
+
try {
|
|
111
|
+
const react::RawValue* rawValue = rawProps.at("objectOcclusion", nullptr, nullptr);
|
|
112
|
+
if (rawValue == nullptr) return sourceProps.objectOcclusion;
|
|
113
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
114
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.objectOcclusion);
|
|
115
|
+
} catch (const std::exception& exc) {
|
|
116
|
+
throw std::runtime_error(std::string("ARView.objectOcclusion: ") + exc.what());
|
|
117
|
+
}
|
|
118
|
+
}()),
|
|
119
|
+
peopleOcclusion([&]() -> CachedProp<std::optional<bool>> {
|
|
120
|
+
try {
|
|
121
|
+
const react::RawValue* rawValue = rawProps.at("peopleOcclusion", nullptr, nullptr);
|
|
122
|
+
if (rawValue == nullptr) return sourceProps.peopleOcclusion;
|
|
123
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
124
|
+
return CachedProp<std::optional<bool>>::fromRawValue(*runtime, value, sourceProps.peopleOcclusion);
|
|
125
|
+
} catch (const std::exception& exc) {
|
|
126
|
+
throw std::runtime_error(std::string("ARView.peopleOcclusion: ") + exc.what());
|
|
127
|
+
}
|
|
128
|
+
}()),
|
|
129
|
+
hybridRef([&]() -> CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridARViewSpec>& /* ref */)>>> {
|
|
130
|
+
try {
|
|
131
|
+
const react::RawValue* rawValue = rawProps.at("hybridRef", nullptr, nullptr);
|
|
132
|
+
if (rawValue == nullptr) return sourceProps.hybridRef;
|
|
133
|
+
const auto& [runtime, value] = (std::pair<jsi::Runtime*, jsi::Value>)*rawValue;
|
|
134
|
+
return CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridARViewSpec>& /* ref */)>>>::fromRawValue(*runtime, value.asObject(*runtime).getProperty(*runtime, PropNameIDCache::get(*runtime, "f")), sourceProps.hybridRef);
|
|
135
|
+
} catch (const std::exception& exc) {
|
|
136
|
+
throw std::runtime_error(std::string("ARView.hybridRef: ") + exc.what());
|
|
137
|
+
}
|
|
138
|
+
}()) { }
|
|
139
|
+
|
|
140
|
+
bool HybridARViewProps::filterObjectKeys(const std::string& propName) {
|
|
141
|
+
switch (hashString(propName)) {
|
|
142
|
+
case hashString("showDebugOptions"): return true;
|
|
143
|
+
case hashString("showPlanes"): return true;
|
|
144
|
+
case hashString("showFeaturePoints"): return true;
|
|
145
|
+
case hashString("showWorldOrigin"): return true;
|
|
146
|
+
case hashString("autoenablesDefaultLighting"): return true;
|
|
147
|
+
case hashString("sceneReconstruction"): return true;
|
|
148
|
+
case hashString("showSceneMesh"): return true;
|
|
149
|
+
case hashString("sceneDepth"): return true;
|
|
150
|
+
case hashString("objectOcclusion"): return true;
|
|
151
|
+
case hashString("peopleOcclusion"): return true;
|
|
152
|
+
case hashString("hybridRef"): return true;
|
|
153
|
+
default: return false;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
HybridARViewComponentDescriptor::HybridARViewComponentDescriptor(const react::ComponentDescriptorParameters& parameters)
|
|
158
|
+
: ConcreteComponentDescriptor(parameters,
|
|
159
|
+
react::RawPropsParser(/* enableJsiParser */ true)) {}
|
|
160
|
+
|
|
161
|
+
std::shared_ptr<const react::Props> HybridARViewComponentDescriptor::cloneProps(const react::PropsParserContext& context,
|
|
162
|
+
const std::shared_ptr<const react::Props>& props,
|
|
163
|
+
react::RawProps rawProps) const {
|
|
164
|
+
// 1. Prepare raw props parser
|
|
165
|
+
rawProps.parse(rawPropsParser_);
|
|
166
|
+
// 2. Copy props with Nitro's cached copy constructor
|
|
167
|
+
return HybridARViewShadowNode::Props(context, /* & */ rawProps, props);
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
#ifdef ANDROID
|
|
171
|
+
void HybridARViewComponentDescriptor::adopt(react::ShadowNode& shadowNode) const {
|
|
172
|
+
// This is called immediately after `ShadowNode` is created, cloned or in progress.
|
|
173
|
+
// On Android, we need to wrap props in our state, which gets routed through Java and later unwrapped in JNI/C++.
|
|
174
|
+
auto& concreteShadowNode = static_cast<HybridARViewShadowNode&>(shadowNode);
|
|
175
|
+
const std::shared_ptr<const HybridARViewProps>& constProps = concreteShadowNode.getConcreteSharedProps();
|
|
176
|
+
const std::shared_ptr<HybridARViewProps>& props = std::const_pointer_cast<HybridARViewProps>(constProps);
|
|
177
|
+
HybridARViewState state{props};
|
|
178
|
+
concreteShadowNode.setStateData(std::move(state));
|
|
179
|
+
}
|
|
180
|
+
#endif
|
|
181
|
+
|
|
182
|
+
} // namespace margelo::nitro::ar::views
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridARViewComponent.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include <optional>
|
|
11
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
12
|
+
#include <NitroModules/NitroHash.hpp>
|
|
13
|
+
#include <NitroModules/CachedProp.hpp>
|
|
14
|
+
#include <react/renderer/core/ConcreteComponentDescriptor.h>
|
|
15
|
+
#include <react/renderer/core/PropsParserContext.h>
|
|
16
|
+
#include <react/renderer/components/view/ConcreteViewShadowNode.h>
|
|
17
|
+
#include <react/renderer/components/view/ViewProps.h>
|
|
18
|
+
|
|
19
|
+
#include <optional>
|
|
20
|
+
#include "SceneReconstructionMode.hpp"
|
|
21
|
+
#include <memory>
|
|
22
|
+
#include "HybridARViewSpec.hpp"
|
|
23
|
+
#include <functional>
|
|
24
|
+
|
|
25
|
+
namespace margelo::nitro::ar::views {
|
|
26
|
+
|
|
27
|
+
using namespace facebook;
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* The name of the actual native View.
|
|
31
|
+
*/
|
|
32
|
+
extern const char HybridARViewComponentName[];
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Props for the "ARView" View.
|
|
36
|
+
*/
|
|
37
|
+
class HybridARViewProps final: public react::ViewProps {
|
|
38
|
+
public:
|
|
39
|
+
HybridARViewProps() = default;
|
|
40
|
+
HybridARViewProps(const react::PropsParserContext& context,
|
|
41
|
+
const HybridARViewProps& sourceProps,
|
|
42
|
+
const react::RawProps& rawProps);
|
|
43
|
+
|
|
44
|
+
public:
|
|
45
|
+
CachedProp<std::optional<bool>> showDebugOptions;
|
|
46
|
+
CachedProp<std::optional<bool>> showPlanes;
|
|
47
|
+
CachedProp<std::optional<bool>> showFeaturePoints;
|
|
48
|
+
CachedProp<std::optional<bool>> showWorldOrigin;
|
|
49
|
+
CachedProp<std::optional<bool>> autoenablesDefaultLighting;
|
|
50
|
+
CachedProp<std::optional<SceneReconstructionMode>> sceneReconstruction;
|
|
51
|
+
CachedProp<std::optional<bool>> showSceneMesh;
|
|
52
|
+
CachedProp<std::optional<bool>> sceneDepth;
|
|
53
|
+
CachedProp<std::optional<bool>> objectOcclusion;
|
|
54
|
+
CachedProp<std::optional<bool>> peopleOcclusion;
|
|
55
|
+
CachedProp<std::optional<std::function<void(const std::shared_ptr<HybridARViewSpec>& /* ref */)>>> hybridRef;
|
|
56
|
+
|
|
57
|
+
private:
|
|
58
|
+
static bool filterObjectKeys(const std::string& propName);
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* State for the "ARView" View.
|
|
63
|
+
*/
|
|
64
|
+
class HybridARViewState final {
|
|
65
|
+
public:
|
|
66
|
+
HybridARViewState() = default;
|
|
67
|
+
explicit HybridARViewState(const std::shared_ptr<HybridARViewProps>& props):
|
|
68
|
+
_props(props) {}
|
|
69
|
+
|
|
70
|
+
public:
|
|
71
|
+
[[nodiscard]]
|
|
72
|
+
const std::shared_ptr<HybridARViewProps>& getProps() const {
|
|
73
|
+
return _props;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
public:
|
|
77
|
+
#ifdef ANDROID
|
|
78
|
+
HybridARViewState(const HybridARViewState& /* previousState */, folly::dynamic /* data */) {}
|
|
79
|
+
folly::dynamic getDynamic() const {
|
|
80
|
+
throw std::runtime_error("HybridARViewState does not support folly!");
|
|
81
|
+
}
|
|
82
|
+
react::MapBuffer getMapBuffer() const {
|
|
83
|
+
throw std::runtime_error("HybridARViewState does not support MapBuffer!");
|
|
84
|
+
};
|
|
85
|
+
#endif
|
|
86
|
+
|
|
87
|
+
private:
|
|
88
|
+
std::shared_ptr<HybridARViewProps> _props;
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* The Shadow Node for the "ARView" View.
|
|
93
|
+
*/
|
|
94
|
+
using HybridARViewShadowNode = react::ConcreteViewShadowNode<HybridARViewComponentName /* "HybridARView" */,
|
|
95
|
+
HybridARViewProps /* custom props */,
|
|
96
|
+
react::ViewEventEmitter /* default */,
|
|
97
|
+
HybridARViewState /* custom state */>;
|
|
98
|
+
|
|
99
|
+
/**
|
|
100
|
+
* The Component Descriptor for the "ARView" View.
|
|
101
|
+
*/
|
|
102
|
+
class HybridARViewComponentDescriptor final: public react::ConcreteComponentDescriptor<HybridARViewShadowNode> {
|
|
103
|
+
public:
|
|
104
|
+
explicit HybridARViewComponentDescriptor(const react::ComponentDescriptorParameters& parameters);
|
|
105
|
+
|
|
106
|
+
public:
|
|
107
|
+
/**
|
|
108
|
+
* A faster path for cloning props - reuses the caching logic from `HybridARViewProps`.
|
|
109
|
+
*/
|
|
110
|
+
std::shared_ptr<const react::Props> cloneProps(const react::PropsParserContext& context,
|
|
111
|
+
const std::shared_ptr<const react::Props>& props,
|
|
112
|
+
react::RawProps rawProps) const override;
|
|
113
|
+
#ifdef ANDROID
|
|
114
|
+
void adopt(react::ShadowNode& shadowNode) const override;
|
|
115
|
+
#endif
|
|
116
|
+
};
|
|
117
|
+
|
|
118
|
+
/* The actual view for "ARView" needs to be implemented in platform-specific code. */
|
|
119
|
+
|
|
120
|
+
} // namespace margelo::nitro::ar::views
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"uiViewClassName": "ARView",
|
|
3
|
+
"supportsRawText": false,
|
|
4
|
+
"bubblingEventTypes": {},
|
|
5
|
+
"directEventTypes": {},
|
|
6
|
+
"validAttributes": {
|
|
7
|
+
"showDebugOptions": true,
|
|
8
|
+
"showPlanes": true,
|
|
9
|
+
"showFeaturePoints": true,
|
|
10
|
+
"showWorldOrigin": true,
|
|
11
|
+
"autoenablesDefaultLighting": true,
|
|
12
|
+
"sceneReconstruction": true,
|
|
13
|
+
"showSceneMesh": true,
|
|
14
|
+
"sceneDepth": true,
|
|
15
|
+
"objectOcclusion": true,
|
|
16
|
+
"peopleOcclusion": true,
|
|
17
|
+
"hybridRef": true
|
|
18
|
+
}
|
|
19
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "react-native-nitro-ar",
|
|
3
|
+
"description": "Nitro module for ARKit (iOS)",
|
|
4
|
+
"version": "2026.02.1",
|
|
5
|
+
"main": "./lib/commonjs/index.js",
|
|
6
|
+
"module": "./lib/module/index.js",
|
|
7
|
+
"types": "./lib/typescript/src/index.d.ts",
|
|
8
|
+
"react-native": "src/index",
|
|
9
|
+
"source": "src/index",
|
|
10
|
+
"expo": {
|
|
11
|
+
"pluginFile": "app.plugin.js"
|
|
12
|
+
},
|
|
13
|
+
"scripts": {
|
|
14
|
+
"format": "bunx biome check --write --no-errors-on-unmatched .",
|
|
15
|
+
"typecheck": "tsc --noEmit",
|
|
16
|
+
"clean": "git clean -dfX",
|
|
17
|
+
"release": "semantic-release",
|
|
18
|
+
"build": "bun run typecheck && bob build",
|
|
19
|
+
"codegen": "nitrogen --logLevel=\"debug\" && bun run build"
|
|
20
|
+
},
|
|
21
|
+
"keywords": [
|
|
22
|
+
"react-native",
|
|
23
|
+
"react-native-nitro-ar",
|
|
24
|
+
"nitro",
|
|
25
|
+
"ar",
|
|
26
|
+
"arkit"
|
|
27
|
+
],
|
|
28
|
+
"files": [
|
|
29
|
+
"src",
|
|
30
|
+
"react-native.config.js",
|
|
31
|
+
"lib",
|
|
32
|
+
"nitrogen",
|
|
33
|
+
"cpp",
|
|
34
|
+
"nitro.json",
|
|
35
|
+
"android/build.gradle",
|
|
36
|
+
"android/fix-prefab.gradle",
|
|
37
|
+
"android/gradle.properties",
|
|
38
|
+
"android/CMakeLists.txt",
|
|
39
|
+
"android/src",
|
|
40
|
+
"ios/**/*.h",
|
|
41
|
+
"ios/**/*.m",
|
|
42
|
+
"ios/**/*.mm",
|
|
43
|
+
"ios/**/*.cpp",
|
|
44
|
+
"ios/**/*.swift",
|
|
45
|
+
"app.plugin.js",
|
|
46
|
+
"*.podspec",
|
|
47
|
+
"README.md"
|
|
48
|
+
],
|
|
49
|
+
"workspaces": [
|
|
50
|
+
"example"
|
|
51
|
+
],
|
|
52
|
+
"repository": {
|
|
53
|
+
"type": "git",
|
|
54
|
+
"url": "https://github.com/vineyardbovines/react-native-nitro-ar.git"
|
|
55
|
+
},
|
|
56
|
+
"author": "Spencer Pope <spencer@thepope.dev>",
|
|
57
|
+
"license": "MIT",
|
|
58
|
+
"bugs": "https://github.com/vineyardbovines/react-native-nitro-ar/issues",
|
|
59
|
+
"homepage": "https://github.com/vineyardbovines/react-native-nitro-ar#readme",
|
|
60
|
+
"publishConfig": {
|
|
61
|
+
"registry": "https://registry.npmjs.org/",
|
|
62
|
+
"access": "public"
|
|
63
|
+
},
|
|
64
|
+
"devDependencies": {
|
|
65
|
+
"@biomejs/biome": "^2.3.13",
|
|
66
|
+
"@vineyardbovines/calver": "^2026.1.1",
|
|
67
|
+
"commitlint": "^20.4.1",
|
|
68
|
+
"lefthook": "^2.0.16",
|
|
69
|
+
"nitrogen": "^0.33.7",
|
|
70
|
+
"react-native-builder-bob": "^0.40.17",
|
|
71
|
+
"release-it": "^19.2.4",
|
|
72
|
+
"typescript": "^5.9.3"
|
|
73
|
+
},
|
|
74
|
+
"dependencies": {},
|
|
75
|
+
"peerDependencies": {
|
|
76
|
+
"react": "*",
|
|
77
|
+
"react-native": "*",
|
|
78
|
+
"react-native-nitro-modules": "*"
|
|
79
|
+
},
|
|
80
|
+
"engines": {
|
|
81
|
+
"node": ">=18"
|
|
82
|
+
},
|
|
83
|
+
"packageManager": "bun@1.2.22",
|
|
84
|
+
"react-native-builder-bob": {
|
|
85
|
+
"source": "src",
|
|
86
|
+
"output": "lib",
|
|
87
|
+
"targets": [
|
|
88
|
+
"commonjs",
|
|
89
|
+
"module",
|
|
90
|
+
[
|
|
91
|
+
"typescript",
|
|
92
|
+
{
|
|
93
|
+
"project": "tsconfig.json"
|
|
94
|
+
}
|
|
95
|
+
]
|
|
96
|
+
]
|
|
97
|
+
}
|
|
98
|
+
}
|