Dev Center
Table of contents

Thanks for downloading Dynamsoft Barcode Reader Package!

Your download will start shortly. If your download does not begin, click here to retry.

Read Barcode from Video Streaming

Configurations on the Camera

Firstly, to decode from video streaming, you have to create a camera module using the Dynamsoft Camera Enhancer. The camera module is responsible for:

  • Capturing the video stream.
  • Displaying the video stream on the UI.
  • Transfer the captured data to the barcode reader for barcode decoding.
  • Android
  • Objective-C
  • Swift
private CameraEnhancer mCamera;
private CaptureVisionRouter mRouter;
@Override
protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.activity_main)
   PermissionUtil.requestCameraPermission(this);
   CameraView cameraView = findViewById(R.id.camera_view);
   mCamera = new CameraEnhancer(cameraView, this);
}
@property (nonatomic, strong) DSCameraView *cameraView;
@property (nonatomic, strong) DSCameraEnhancer *dce;
...
- (void)setUpCamera {
   self.cameraView = [[DSCameraView alloc] initWithFrame:self.view.bounds];
   self.cameraView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
   [self.view insertSubview:self.cameraView atIndex:0];
   self.dce = [[DSCameraEnhancer alloc] init];
   self.dce.cameraView = self.cameraView;
}
class ViewController: UIViewController {
   var cameraView:CameraView!
   let dce = CameraEnhancer()
   func setUpCamera() {
      cameraView = .init(frame: view.bounds)
      cameraView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
      view.insertSubview(cameraView, at: 0)
      dce.cameraView = cameraView
   }
}

Configure CaptureVisionRouter

Create an instance of CaptureVisionRouter and Bind with the CameraEnhancer

Initialize Dynamsoft Barcode Reader and bind the Camera Enhancer to the Barcode Reader. The barcode reader will continuously receive video frames when the video barcode decoding thread is enabled.

  • Android
  • Objective-C
  • Swift
@Override
protected void onCreate(Bundle savedInstanceState) {
   ...
   mRouter = new CaptureVisionRouter(this);
   try {
      mRouter.setInput(mCamera);
   } catch (CaptureVisionRouterException e) {
      throw new RuntimeException(e);
   }
}
@property (nonatomic, strong) DSCaptureVisionRouter *cvr;
...
- (void)setUpDCV {
   self.cvr = [[DSCaptureVisionRouter alloc] init];
   NSError *error;
   [self.cvr setInput:self.dce error:&error];
}
class ViewController: UIViewController {
   let cvr = CaptureVisionRouter()
   func setUpDCV() {
      try! cvr.setInput(dce)
   }
}

Implement the CaptureResult Receiver to Receive the Results

  • Android
  • Objective-C
  • Swift
private CameraEnhancer mCamera;
private CaptureVisionRouter mRouter;
@Override
protected void onCreate(Bundle savedInstanceState) {
   ...
   mRouter.addResultReceiver(new CapturedResultReceiver() {
      @Override
      public void onDecodedBarcodesReceived(DecodedBarcodesResult result) {
         // Add code to do when DecodedBarcodesResult received.
      }
   });
}
// Add CapturedResultReceiver to the ViewController.
@interface ViewController () <DSCapturedResultReceiver>
- (void)setUpDCV {
   ...
   // Add result receiver to the CaptureVisionRouter instance.
   [self.cvr addResultReceiver:self];
}
// Implement onDecodedBarcodesReceived method to receive the barcode decoding result.
- (void)onDecodedBarcodesReceived:(DSDecodedBarcodesResult *)result {
   // Add code to do when DecodedBarcodesResult received.
}
// Add CapturedResultReceiver to the ViewController.
class ViewController: UIViewController, CapturedResultReceiver {
   func setUpDCV() {
      ...
      // Add result receiver to the CaptureVisionRouter instance.
      cvr.addResultReceiver(self)
   }
   // Implement onDecodedBarcodesReceived method to receive the barcode decoding result.
   func onDecodedBarcodesReceived(_ result: DecodedBarcodesResult) {
      // Add code to do when DecodedBarcodesResult received.
   }
}

Control the State of Barcode Decoding

  • Android
  • Objective-C
  • Swift
@Override
public void onResume() {
   try {
      // Open the camera when the activity appear.
      mCamera.open();
   } catch (CameraEnhancerException e) {
      e.printStackTrace();
   }
   // Start the capturing process when the activity appear.
   // You have to specify a template name to start capturing.
   // For example, we use the preset template "ReadBarcodes" to start capturing with the default barcode decoding template.
   mRouter.startCapturing(EnumPresetTemplate.PT_READ_BARCODES, null);
   super.onResume();
}
@Override
public void onPause() {
   try {
      // Close the camera when leaving the activity.
      mCamera.close();
   } catch (CameraEnhancerException e) {
      e.printStackTrace();
   }
   // Stop the capturing process when leaving the activity.
   mRouter.stopCapturing();
   super.onPause();
}
- (void)viewDidLoad {
   [super viewDidLoad];
   [self setUpCamera];
   [self setUpDCV];
}
- (void)viewWillAppear:(BOOL)animated {
   // Open the camera when the view will appear.
   [self.dce open];
   // Start the capturing process when the view will appear.
   // You have to specify a template name to start capturing.
   // For example, we use the preset template "ReadBarcodes" to start capturing with the default barcode decoding template.
   [self.cvr startCapturing:DSPresetTemplateReadBarcodes completionHandler:^(BOOL isSuccess, NSError * _Nullable error) {
      NSAssert((error == nil), error.description);
   }];
   [super viewWillAppear:animated];
}
- (void)viewWillDisappear:(BOOL)animated {
   // Close the camera when the view will disappear.
   [self.dce close];
   // Stop the capturing process when the view will disappear.
   [self.cvr stopCapturing];
   [super viewWillDisappear:animated];
}
override func viewDidLoad() {
   super.viewDidLoad()
   setUpCamera()
   setUpDCV()
}
override func viewWillAppear(_ animated: Bool) {
   // Open the camera when the view will appear.
   dce.open()
   // Start the capturing process when the view will appear.
   // You have to specify a template name to start capturing.
   // For example, we use the preset template "ReadBarcodes" to start capturing with the default barcode decoding template.
   cvr.startCapturing(PresetTemplate.readBarcodes.rawValue) { isSuccess, error in
      if (!isSuccess) {
         if let error = error {
             print("\(error)")
         }
      }
   }
   super.viewWillAppear(animated)
}
override func viewWillDisappear(_ animated: Bool) {
   // Close the camera when the view will disappear.
   dce.close()
   // Stop the capturing process when the view will disappear.
   cvr.stopCapturing()
   super.viewWillDisappear(animated)
}

This page is compatible for:

Version 7.5.0

Is this page helpful?

YesYes NoNo

In this article:

latest version

  • Latest version
  • Version 10.x
    • Version 10.2.0
    • Version 10.0.21
    • Version 10.0.20
    • Version 10.0.10
    • Version 10.0.0
  • Version 9.x
    • Version 9.6.40
    • Version 9.6.33
    • Version 9.6.32
    • Version 9.6.31
    • Version 9.6.30
    • Version 9.6.20
    • Version 9.6.10
    • Version 9.6.0
    • Version 9.4.0
    • Version 9.2.0
    • Version 9.0.0
  • Version 8.x
    • Version 8.8.0
    • Version 8.6.0
    • Version 8.4.0
    • Version 8.2.0
    • Version 8.1.2
    • Version 8.1.0
    • Version 8.0.0
  • Version 7.x
    • Version 7.6.0
    • Version 7.5.0
Change +