react-native-rectangle-doc-scanner 7.26.0 → 7.27.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.
@@ -564,27 +564,25 @@ class CameraController(
564
564
  )
565
565
 
566
566
  val matrix = Matrix()
567
- val isSwapped = rotation == Surface.ROTATION_90 || rotation == Surface.ROTATION_270
568
- val bufferWidth = if (isSwapped) preview.height.toFloat() else preview.width.toFloat()
569
- val bufferHeight = if (isSwapped) preview.width.toFloat() else preview.height.toFloat()
570
567
  val viewRect = RectF(0f, 0f, viewWidth, viewHeight)
571
- val bufferRect = RectF(0f, 0f, bufferWidth, bufferHeight)
568
+ val bufferRect = RectF(0f, 0f, preview.height.toFloat(), preview.width.toFloat())
572
569
  val centerX = viewRect.centerX()
573
570
  val centerY = viewRect.centerY()
574
571
 
575
- // Use uniform scaling to avoid stretching; then center-crop to fill.
576
- matrix.setRectToRect(bufferRect, viewRect, Matrix.ScaleToFit.CENTER)
577
- val scale = max(viewWidth / bufferWidth, viewHeight / bufferHeight)
578
- matrix.postScale(scale, scale, centerX, centerY)
579
-
580
- if (rotation != Surface.ROTATION_0) {
581
- val rotateDegrees = when (rotation) {
582
- Surface.ROTATION_90 -> -90f
583
- Surface.ROTATION_180 -> 180f
584
- Surface.ROTATION_270 -> 90f
585
- else -> 0f
586
- }
587
- matrix.postRotate(rotateDegrees, centerX, centerY)
572
+ if (rotation == Surface.ROTATION_90 || rotation == Surface.ROTATION_270) {
573
+ bufferRect.offset(centerX - bufferRect.centerX(), centerY - bufferRect.centerY())
574
+ matrix.setRectToRect(viewRect, bufferRect, Matrix.ScaleToFit.FILL)
575
+ val scale = max(viewHeight / preview.height.toFloat(), viewWidth / preview.width.toFloat())
576
+ matrix.postScale(scale, scale, centerX, centerY)
577
+ matrix.postRotate(90f * (rotation - 2), centerX, centerY)
578
+ } else if (rotation == Surface.ROTATION_180) {
579
+ matrix.postRotate(180f, centerX, centerY)
580
+ } else {
581
+ val scale = max(viewWidth / preview.width.toFloat(), viewHeight / preview.height.toFloat())
582
+ val scaledWidth = preview.width.toFloat() * scale
583
+ val scaledHeight = preview.height.toFloat() * scale
584
+ matrix.setScale(scale, scale)
585
+ matrix.postTranslate((viewWidth - scaledWidth) / 2f, (viewHeight - scaledHeight) / 2f)
588
586
  }
589
587
 
590
588
  previewView.setTransform(matrix)
@@ -627,7 +627,18 @@ const NativeScanner = (0, react_1.forwardRef)(({ onCapture, overlayColor = DEFAU
627
627
  }, [capture]);
628
628
  const handleRectangleDetect = (0, react_1.useCallback)((event) => {
629
629
  const rectangleCoordinates = normalizeRectangle(event.rectangleCoordinates ?? null);
630
- const rectangleOnScreen = normalizeRectangle(event.rectangleOnScreen ?? null);
630
+ let rectangleOnScreen = normalizeRectangle(event.rectangleOnScreen ?? null);
631
+ const density = react_native_1.PixelRatio.get();
632
+ if (react_native_1.Platform.OS === 'android' &&
633
+ rectangleCoordinates &&
634
+ event.imageSize &&
635
+ event.previewSize &&
636
+ event.imageSize.width &&
637
+ event.imageSize.height &&
638
+ event.previewSize.width &&
639
+ event.previewSize.height) {
640
+ rectangleOnScreen = mapRectangleToView(rectangleCoordinates, event.imageSize.width, event.imageSize.height, event.previewSize.width, event.previewSize.height, density);
641
+ }
631
642
  const payload = {
632
643
  ...event,
633
644
  rectangleCoordinates,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-native-rectangle-doc-scanner",
3
- "version": "7.26.0",
3
+ "version": "7.27.0",
4
4
  "description": "Native-backed document scanner for React Native with customizable overlays.",
5
5
  "license": "MIT",
6
6
  "main": "dist/index.js",
@@ -874,7 +874,28 @@ const NativeScanner = forwardRef<DocScannerHandle, Props>(
874
874
  const handleRectangleDetect = useCallback(
875
875
  (event: RectangleEventPayload) => {
876
876
  const rectangleCoordinates = normalizeRectangle(event.rectangleCoordinates ?? null);
877
- const rectangleOnScreen = normalizeRectangle(event.rectangleOnScreen ?? null);
877
+ let rectangleOnScreen = normalizeRectangle(event.rectangleOnScreen ?? null);
878
+ const density = PixelRatio.get();
879
+
880
+ if (
881
+ Platform.OS === 'android' &&
882
+ rectangleCoordinates &&
883
+ event.imageSize &&
884
+ event.previewSize &&
885
+ event.imageSize.width &&
886
+ event.imageSize.height &&
887
+ event.previewSize.width &&
888
+ event.previewSize.height
889
+ ) {
890
+ rectangleOnScreen = mapRectangleToView(
891
+ rectangleCoordinates,
892
+ event.imageSize.width,
893
+ event.imageSize.height,
894
+ event.previewSize.width,
895
+ event.previewSize.height,
896
+ density,
897
+ );
898
+ }
878
899
 
879
900
  const payload: RectangleDetectEvent = {
880
901
  ...event,