react-native-rectangle-doc-scanner 7.1.0 → 7.2.0
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/android/build.gradle
CHANGED
|
@@ -48,10 +48,10 @@ android {
|
|
|
48
48
|
main {
|
|
49
49
|
java.srcDirs += 'src/main/kotlin'
|
|
50
50
|
java.srcDirs += 'src/common/kotlin'
|
|
51
|
+
// Always include camera2 sources (for fallback when VisionCamera is not used at runtime)
|
|
52
|
+
java.srcDirs += 'src/camera2/kotlin'
|
|
51
53
|
if (hasVisionCamera) {
|
|
52
54
|
java.srcDirs += 'src/visioncamera/kotlin'
|
|
53
|
-
} else {
|
|
54
|
-
java.srcDirs += 'src/camera2/kotlin'
|
|
55
55
|
}
|
|
56
56
|
}
|
|
57
57
|
}
|
|
@@ -77,20 +77,18 @@ dependencies {
|
|
|
77
77
|
implementation 'androidx.core:core-ktx:1.10.1'
|
|
78
78
|
implementation 'androidx.appcompat:appcompat:1.6.1'
|
|
79
79
|
|
|
80
|
-
// CameraX
|
|
80
|
+
// CameraX dependencies (always included for Camera2 fallback and ImageProxy support)
|
|
81
81
|
def camerax_version = "1.3.0"
|
|
82
82
|
implementation "androidx.camera:camera-core:${camerax_version}"
|
|
83
|
+
implementation "androidx.camera:camera-camera2:${camerax_version}"
|
|
84
|
+
implementation "androidx.camera:camera-lifecycle:${camerax_version}"
|
|
85
|
+
implementation "androidx.camera:camera-view:${camerax_version}"
|
|
86
|
+
|
|
87
|
+
// ML Kit object detection for live rectangle hints (Camera2 mode)
|
|
88
|
+
implementation 'com.google.mlkit:object-detection:17.0.1'
|
|
83
89
|
|
|
84
90
|
if (hasVisionCamera) {
|
|
85
91
|
// VisionCamera mode - include VisionCamera dependency
|
|
86
92
|
implementation project(':react-native-vision-camera')
|
|
87
|
-
} else {
|
|
88
|
-
// Camera2 mode - include additional CameraX and ML Kit dependencies
|
|
89
|
-
implementation "androidx.camera:camera-camera2:${camerax_version}"
|
|
90
|
-
implementation "androidx.camera:camera-lifecycle:${camerax_version}"
|
|
91
|
-
implementation "androidx.camera:camera-view:${camerax_version}"
|
|
92
|
-
|
|
93
|
-
// ML Kit object detection for live rectangle hints
|
|
94
|
-
implementation 'com.google.mlkit:object-detection:17.0.1'
|
|
95
93
|
}
|
|
96
94
|
}
|
|
@@ -43,22 +43,15 @@ class DocumentScannerModule(reactContext: ReactApplicationContext) :
|
|
|
43
43
|
try {
|
|
44
44
|
val view = uiManager.resolveView(tag)
|
|
45
45
|
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
} else {
|
|
56
|
-
Log.e(TAG, "View with tag $tag is not DocumentScannerView: ${view?.javaClass?.simpleName}")
|
|
57
|
-
promise.reject("INVALID_VIEW", "View is not a DocumentScannerView")
|
|
58
|
-
}
|
|
59
|
-
} catch (e: ClassNotFoundException) {
|
|
60
|
-
Log.e(TAG, "DocumentScannerView not available (VisionCamera mode)", e)
|
|
61
|
-
promise.reject("VIEW_NOT_AVAILABLE", "Camera2 views not available in VisionCamera mode")
|
|
46
|
+
if (view is DocumentScannerView) {
|
|
47
|
+
Log.d(TAG, "Found DocumentScannerView, triggering capture with promise")
|
|
48
|
+
|
|
49
|
+
// Pass promise to view so it can be resolved when capture completes
|
|
50
|
+
// This matches iOS behavior where promise is resolved with actual image data
|
|
51
|
+
view.captureWithPromise(promise)
|
|
52
|
+
} else {
|
|
53
|
+
Log.e(TAG, "View with tag $tag is not DocumentScannerView: ${view?.javaClass?.simpleName}")
|
|
54
|
+
promise.reject("INVALID_VIEW", "View is not a DocumentScannerView")
|
|
62
55
|
}
|
|
63
56
|
} catch (e: Exception) {
|
|
64
57
|
Log.e(TAG, "Error resolving view", e)
|
package/android/src/main/kotlin/com/reactnativerectangledocscanner/DocumentScannerPackage.kt
CHANGED
|
@@ -19,28 +19,11 @@ class DocumentScannerPackage : ReactPackage {
|
|
|
19
19
|
}
|
|
20
20
|
|
|
21
21
|
override fun createViewManagers(reactContext: ReactApplicationContext): List<ViewManager<*, *>> {
|
|
22
|
-
//
|
|
23
|
-
return
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
} catch (e: ClassNotFoundException) {
|
|
28
|
-
// VisionCamera not available, register Camera2 view managers using reflection
|
|
29
|
-
try {
|
|
30
|
-
val viewManagers = mutableListOf<ViewManager<*, *>>()
|
|
31
|
-
|
|
32
|
-
val docScannerViewManagerClass = Class.forName("com.reactnativerectangledocscanner.DocumentScannerViewManager")
|
|
33
|
-
val cameraViewManagerClass = Class.forName("com.reactnativerectangledocscanner.CameraViewManager")
|
|
34
|
-
|
|
35
|
-
viewManagers.add(docScannerViewManagerClass.newInstance() as ViewManager<*, *>)
|
|
36
|
-
viewManagers.add(cameraViewManagerClass.newInstance() as ViewManager<*, *>)
|
|
37
|
-
|
|
38
|
-
viewManagers
|
|
39
|
-
} catch (e: Exception) {
|
|
40
|
-
Log.e(TAG, "Failed to instantiate Camera2 view managers", e)
|
|
41
|
-
emptyList()
|
|
42
|
-
}
|
|
43
|
-
}
|
|
22
|
+
// Always register Camera2 view managers for fallback support
|
|
23
|
+
return listOf(
|
|
24
|
+
DocumentScannerViewManager(),
|
|
25
|
+
CameraViewManager()
|
|
26
|
+
)
|
|
44
27
|
}
|
|
45
28
|
|
|
46
29
|
private fun registerVisionCameraPlugin() {
|