আমি কীভাবে আইওএস এ বারকোড স্ক্যান করতে পারি?


189

আমি কীভাবে আইফোন এবং / বা আইপ্যাডে বারকোডগুলি সহজভাবে স্ক্যান করতে পারি?


7
দুঃখের বিষয়, আইকন ক্যামেরাটি বারকোডগুলি পড়ার জন্য বর্তমানে ভয়ানক, কারণ এটির লেন্স focus শুভ হোক যদিও!
অ্যালাস্টার স্টুয়ার্ট

1
শুধু এই সমস্যাটি সমাধান করা হয়েছে তাই আমার পর্যবেক্ষণগুলি লিখবে। আমি কয়েকটি বিকল্প পরীক্ষা করেছি। আরএসবারকোডস সুইফট - সংহত করা সহজ ছিল, তবে খুব খারাপ অভিনয় ছিল। জেডবারএসডিকে - প্রয়োগ করাও সহজ ছিল, কীভাবে এটি খুঁজে পেতে গুগল অনুসন্ধান করেছিলেন কিছু কিছু লোক। তবে সত্যিই ভাল পারফরম্যান্স ছিল (ডেটাম্যাট্রিক্স এবং অন্যান্য বিরল কোডগুলি স্ক্যান করেনি) বারকোড / কিউআর কোডের জন্য সত্যই ভাল কাজ করে। তবে স্ক্যান্ডিটই ছিল তাদের সবার সেরা। সুপার দ্রুত, সমস্ত কিছু স্ক্যান করে। দু: খজনকভাবে অনেক খরচ হয়।
কাটাফালকাস

উত্তর:


82

আমরা আইফোনের জন্য 'বারকোডস' অ্যাপ্লিকেশন তৈরি করেছি। এটি কিউআর কোডগুলি ডিকোড করতে পারে। সোর্স কোডটি জেক্সিং প্রকল্প থেকে পাওয়া যায় ; বিশেষত, আপনি আইফোন ক্লায়েন্ট এবং কোর লাইব্রেরির আংশিক সি ++ বন্দরটি একবার দেখতে চান । বন্দরটি সামান্য পুরানো, জাভা কোডটির ০.৯ প্রকাশের দিক থেকে, তবে এখনও যুক্তিসঙ্গতভাবে ভালভাবে কাজ করা উচিত।

আপনার যদি 1 ডি ফর্ম্যাটগুলির মতো অন্য ফর্ম্যাটগুলি স্ক্যান করতে হয় তবে আপনি এই প্রকল্পের মধ্যে জাভা কোডের বন্দরটি C ++ এ চালিয়ে যেতে পারেন।

সম্পাদনা: iphoneপ্রকল্পের বারকোড এবং কোডটি ২০১৪ সালের শুরুতে অবসর নিয়েছিল ।


এটি কী ধরণের লাইসেন্স ব্যবহার করে তা শান করুন। আমি একটি অর্থের বিনিময়ে অ্যাপ তৈরি করতে চাই যা জবারটি ব্যবহার করে। লাইসেন্স চুক্তির আওতায় কি তা সম্ভব?
রাদু

1
কেবল স্পষ্ট করে বলতে গেলে, এই সময়ে, আইফোনে জেডএক্সিং কেবল কিউআর কোড সমর্থন করে?
রিফাক্স

আমি বিশ্বাস করি যে আরও কিছু সি ++ এ পোর্ট করা হয়েছে, তবে দুর্ভাগ্যক্রমে বন্দরটি জাভা কোডটির একটি মোটামুটি ও পুরানো প্রতিধ্বনি। সুতরাং, হ্যাঁ আরও সমর্থিত যদিও সম্ভবত ভাল না।
শন

আইফোনের জন্য জেডএক্সিং-এ এখনও 1.7 ভেরি দ্বারা মেমরি ফাঁস রয়েছে।
ইউন লি

আমি জেডএক্সিংয়ের গিটের সমস্যা তালিকা থেকে বুঝতে পারি যে আমরা কেবল ল্যান্ডস্কেপ মোডে বারকোড স্ক্যান করতে পারি।
সাগ্রিয়ান

81

জেডবার কিউআর কোড এবং ইসিএন / আইএসবিএন কোড পড়ে এবং এলজিপিএল ভি 2 লাইসেন্সের অধীনে উপলব্ধ Check


5
আংশিকভাবে সঠিক. ZBar.app অ্যাপাচি লাইসেন্স (সংস্করণ 2.0) এর আওতায় লাইসেন্সযুক্ত , যদিও লাইব্রেরিটি এলজিপিএল ভি 2 এর আওতায় লাইসেন্সযুক্ত।
শান

3
দুঃখের সাথে লাইসেন্সটির জন্য আপনার অ্যাপ্লিকেশনটির অবজেক্ট ফাইলগুলি যারা তাদের জন্য অনুরোধ করেছে তাদের সাথে ভাগ করে নেওয়া দরকার .. zbar.sourceforge.net/iphone/sdkdoc/licensing.html দেখুন
বেন ক্লেটন

1
@ বেনক্লেটন অ্যাপটির অবজেক্ট ফাইলগুলি ভাগ করে নেওয়ার অর্থ কী?
ডিজেল

@ ওডেলিয়া কেওকে এক্সকোড দ্বারা উত্পাদিত হিসাবে .o ফাইলগুলি প্রেরণ করা, তাত্ত্বিকভাবে তাদের আপনার অ্যাপ তৈরির অনুমতি দেয়। আমি এটি করতে অবশ্যই খুশি নই (বিশেষত আমার ক্লায়েন্টদের জন্য) তাই জেডবার আমাদের কাছে প্রশ্নের বাইরে। জেডবার লাইসেন্সিং পৃষ্ঠাটি পরামর্শ দেয় আপনার কেবল 'আশা করি কেউ তাদের অনুরোধ করবেন না!'
বেন ক্লেটন

@ বেনক্লেটন এ। বি। ধন্যবাদ কেউ যদি নতুন সংস্করণ ডাউনলোড করার জন্য ইতিমধ্যে ডাউনলোড করা অ্যাপ ব্যবহারকারীদের কাছে জিজ্ঞাসা করে এবং তাদের প্রয়োজন হয় তবে আমি উপাদানটি পরিবর্তন করতে পারি। এইটুকু কি যথেষ্ট? সি। সুতরাং আপনি কোন লাইব্রেরি ব্যবহার করছেন?
দেজেল

56

আপনার প্রকাশের মতো iOS7আর কোনও বাহ্যিক কাঠামো বা লাইব্রেরি ব্যবহার করার দরকার নেই। এভিফাউন্ডেশন সহ আইওএস ইকোসিস্টেম এখন কিউআর থেকে ইউএনসিতে ইউপিসিতে প্রায় প্রতিটি কোড স্ক্যান করতে সম্পূর্ণ সমর্থন করে।

শুধু কটাক্ষপাত আছে টেক নোট এবং AV ফাউন্ডেশন প্রোগ্রামিং গাইড। AVMetadataObjectTypeQRCodeতোমার বন্ধু.

এখানে একটি দুর্দান্ত টিউটোরিয়াল রয়েছে যা এটি পর্যায়ক্রমে দেখায়: আইফোন কিউআর কোড স্ক্যান গ্রন্থাগার আইওএস 7

কীভাবে এটি সেট আপ করবেন তার সামান্য উদাহরণ:

#pragma mark -
#pragma mark AVFoundationScanSetup

- (void) setupScanner;
{
    self.device = [AVCaptureDevice defaultDeviceWithMediaType:AVMediaTypeVideo];

    self.input = [AVCaptureDeviceInput deviceInputWithDevice:self.device error:nil];

    self.session = [[AVCaptureSession alloc] init];

    self.output = [[AVCaptureMetadataOutput alloc] init];
    [self.session addOutput:self.output];
    [self.session addInput:self.input];

    [self.output setMetadataObjectsDelegate:self queue:dispatch_get_main_queue()];
    self.output.metadataObjectTypes = @[AVMetadataObjectTypeQRCode];

    self.preview = [AVCaptureVideoPreviewLayer layerWithSession:self.session];
    self.preview.videoGravity = AVLayerVideoGravityResizeAspectFill;
    self.preview.frame = CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height);

    AVCaptureConnection *con = self.preview.connection;

    con.videoOrientation = AVCaptureVideoOrientationLandscapeLeft;

    [self.view.layer insertSublayer:self.preview atIndex:0];
}

1
আপনি যদি iOS8 এ চিত্র থেকে বারকোড সনাক্ত করতে চান তবে এই টিউটোরিয়ালটি সহায়ক হতে পারে।
এনএসডেভোপার

আমি দেখতে পেয়েছি startRunningযে কাউকে সহায়তা করে সে ক্ষেত্রে উপরের কোডটি পেতে আমাকে অধিবেশনটিতে ফোন করতে হয়েছিল :)
ক্রিস

13

আইকন 4 ক্যামেরা বারকোড করার ক্যাপাবলের চেয়ে বেশি। জেব্রা ক্রসিং বারকোড লাইব্রেরিতে গিথুব জক্সিং-আইফোনে একটি কাঁটাচামচ রয়েছে । এটি ওপেন সোর্স।


1
আপনার পোস্টটি বোঝা যাচ্ছে যে জেডএক্সিংয়ের এই বন্দরটি কেবল কিউআরকোডের চেয়ে বেশি স্ক্যান করতে পারে? এটাই কি?
রিফাক্স

4
এই সমস্যাটি দ্বারা ইঙ্গিত হিসাবে গিথুব
জোশ ব্রাউন


10

দুটি বড় গ্রন্থাগার রয়েছে:

  • জাভাতে লেখা একটি লাইব্রেরি জেডএক্সিং করা এবং তারপরে উদ্দেশ্য সি / সি ++ (কেবল কিউআর কোড) এ পোর্ট করা। এবং ওবিজেসি-তে অন্য একটি বন্দর সম্পন্ন হয়েছে, দ্য লেভেলআপ: জেডএক্সিংওবিজেসি

  • সিবার ভিত্তিতে বার কোডগুলি পড়ার জন্য একটি ওপেন সোর্স সফটওয়্যার জেডবার

আমার পরীক্ষাগুলি অনুসারে জেডবার কমপক্ষে আইফোনে জেডএক্সিংয়ের চেয়ে অনেক বেশি নির্ভুল এবং দ্রুত


আমার কাছে মনে হয় জেডএক্সিং ওবিজেসি এখন পর্যন্ত সর্বাধিক ভোট দিয়ে শীর্ষে ঠেলা উচিত। আমি এটি এখনও ব্যবহার করি নি , তবে বিবরণটি জানায় যে এটি জেডএক্সিং ২.০ এর সাথে সাম্য।
শাওলো

জেডবার লাইসেন্সের জন্য আপনাকে ব্যবহারকারীদের কাছে অবজেক্ট ফাইলগুলি সরবরাহ করা প্রয়োজন, যাতে তারা এটি চালাতে পারে এবং তাদের লাইব্রেরিটিও পরিবর্তন করতে পারে।
দেজেল

আমি ZXingObjC
দেজেল


7

আপনি নীচের দিকে সুইফট 4 এবং এক্সকোড 9 ব্যবহার করে অন্য একটি নেটিভ আইওএস সমাধান খুঁজে পেতে পারেন । AVFoundationএই সমাধানে ব্যবহৃত নেটিভ কাঠামো।

প্রথম অংশটি একটি সাবক্লাস UIViewControllerযা সম্পর্কিত সেটআপ এবং হ্যান্ডলারের জন্য রয়েছে AVCaptureSession

import UIKit
import AVFoundation

class BarCodeScannerViewController: UIViewController {

    let captureSession = AVCaptureSession()
    var videoPreviewLayer: AVCaptureVideoPreviewLayer!
    var initialized = false

    let barCodeTypes = [AVMetadataObject.ObjectType.upce,
                        AVMetadataObject.ObjectType.code39,
                        AVMetadataObject.ObjectType.code39Mod43,
                        AVMetadataObject.ObjectType.code93,
                        AVMetadataObject.ObjectType.code128,
                        AVMetadataObject.ObjectType.ean8,
                        AVMetadataObject.ObjectType.ean13,
                        AVMetadataObject.ObjectType.aztec,
                        AVMetadataObject.ObjectType.pdf417,
                        AVMetadataObject.ObjectType.itf14,
                        AVMetadataObject.ObjectType.dataMatrix,
                        AVMetadataObject.ObjectType.interleaved2of5,
                        AVMetadataObject.ObjectType.qr]

    override func viewDidAppear(_ animated: Bool) {
        super.viewDidAppear(animated)
        setupCapture()
        // set observer for UIApplicationWillEnterForeground, so we know when to start the capture session again
        NotificationCenter.default.addObserver(self,
                                           selector: #selector(willEnterForeground),
                                           name: .UIApplicationWillEnterForeground,
                                           object: nil)
    }

    override func viewWillDisappear(_ animated: Bool) {
        super.viewWillDisappear(animated)
        // this view is no longer topmost in the app, so we don't need a callback if we return to the app.
        NotificationCenter.default.removeObserver(self,
                                              name: .UIApplicationWillEnterForeground,
                                              object: nil)
    }

    // This is called when we return from another app to the scanner view
    @objc func willEnterForeground() {
        setupCapture()
    }

    func setupCapture() {
        var success = false
        var accessDenied = false
        var accessRequested = false

        let authorizationStatus = AVCaptureDevice.authorizationStatus(for: .video)
        if authorizationStatus == .notDetermined {
            // permission dialog not yet presented, request authorization
            accessRequested = true
            AVCaptureDevice.requestAccess(for: .video,
                                      completionHandler: { (granted:Bool) -> Void in
                                          self.setupCapture();
            })
            return
        }
        if authorizationStatus == .restricted || authorizationStatus == .denied {
            accessDenied = true
        }
        if initialized {
            success = true
        } else {
            let deviceDiscoverySession = AVCaptureDevice.DiscoverySession(deviceTypes: [.builtInWideAngleCamera,
                                                                                        .builtInTelephotoCamera,
                                                                                        .builtInDualCamera],
                                                                          mediaType: .video,
                                                                          position: .unspecified)

            if let captureDevice = deviceDiscoverySession.devices.first {
                do {
                    let videoInput = try AVCaptureDeviceInput(device: captureDevice)
                    captureSession.addInput(videoInput)
                    success = true
                } catch {
                    NSLog("Cannot construct capture device input")
                }
            } else {
                NSLog("Cannot get capture device")
            }
        }
        if success {
            DispatchQueue.global().async {
                self.captureSession.startRunning()
                DispatchQueue.main.async {
                    let captureMetadataOutput = AVCaptureMetadataOutput()
                    self.captureSession.addOutput(captureMetadataOutput)
                    let newSerialQueue = DispatchQueue(label: "barCodeScannerQueue") // in iOS 11 you can use main queue
                    captureMetadataOutput.setMetadataObjectsDelegate(self, queue: newSerialQueue)
                    captureMetadataOutput.metadataObjectTypes = self.barCodeTypes
                    self.videoPreviewLayer = AVCaptureVideoPreviewLayer(session: self.captureSession)
                    self.videoPreviewLayer.videoGravity = .resizeAspectFill
                    self.videoPreviewLayer.frame = self.view.layer.bounds
                    self.view.layer.addSublayer(self.videoPreviewLayer)
                } 
            }
            initialized = true
        } else {
            // Only show a dialog if we have not just asked the user for permission to use the camera.  Asking permission
            // sends its own dialog to th user
            if !accessRequested {
                // Generic message if we cannot figure out why we cannot establish a camera session
                var message = "Cannot access camera to scan bar codes"
                #if (arch(i386) || arch(x86_64)) && (!os(macOS))
                    message = "You are running on the simulator, which does not hae a camera device.  Try this on a real iOS device."
                #endif
                if accessDenied {
                    message = "You have denied this app permission to access to the camera.  Please go to settings and enable camera access permission to be able to scan bar codes"
                }
                let alertPrompt = UIAlertController(title: "Cannot access camera", message: message, preferredStyle: .alert)
                let confirmAction = UIAlertAction(title: "OK", style: .default, handler: { (action) -> Void in
                    self.navigationController?.popViewController(animated: true)
                })
                alertPrompt.addAction(confirmAction)
                self.present(alertPrompt, animated: true, completion: nil)
            }
        }
    }

    func handleCapturedOutput(metadataObjects: [AVMetadataObject]) {
        if metadataObjects.count == 0 {
            return
        }

        guard let metadataObject = metadataObjects.first as? AVMetadataMachineReadableCodeObject else {
            return
        }

        if barCodeTypes.contains(metadataObject.type) {
            if let metaDataString = metadataObject.stringValue {
                captureSession.stopRunning()
                displayResult(code: metaDataString)
                return
            }
        }
    }

    func displayResult(code: String) {
        let alertPrompt = UIAlertController(title: "Bar code detected", message: code, preferredStyle: .alert)
        if let url = URL(string: code) {
            let confirmAction = UIAlertAction(title: "Launch URL", style: .default, handler: { (action) -> Void in
                UIApplication.shared.open(url, options: [:], completionHandler: { (result) in
                    if result {
                        NSLog("opened url")
                    } else {
                        let alertPrompt = UIAlertController(title: "Cannot open url", message: nil, preferredStyle: .alert)
                        let confirmAction = UIAlertAction(title: "OK", style: .default, handler: { (action) -> Void in
                        })
                        alertPrompt.addAction(confirmAction)
                        self.present(alertPrompt, animated: true, completion: {
                            self.setupCapture()
                        })
                    }
                })        
            })
            alertPrompt.addAction(confirmAction)
        }
        let cancelAction = UIAlertAction(title: "Cancel", style: .cancel, handler: { (action) -> Void in
            self.setupCapture()
        })
        alertPrompt.addAction(cancelAction)
        present(alertPrompt, animated: true, completion: nil)
    }

}

দ্বিতীয় অংশটি হ'ল আমাদের UIViewControllerসাবক্লাসের এক্সটেনশন AVCaptureMetadataOutputObjectsDelegateযেখানে আমরা ক্যাপচারিত আউটপুটগুলি ধরি।

extension BarCodeScannerViewController: AVCaptureMetadataOutputObjectsDelegate {

    func metadataOutput(_ output: AVCaptureMetadataOutput, didOutput metadataObjects: [AVMetadataObject], from connection: AVCaptureConnection) {
        handleCapturedOutput(metadataObjects: metadataObjects)
    }

}

সুইফটের জন্য আপডেট 4.2

.UIApplicationWillEnterForegroundহিসাবে পরিবর্তন UIApplication.willEnterForegroundNotification


এটি কি পণ্যের নাম, আকার, দাম, পণ্যের url, মুদ্রা, স্টোরের নাম দেবে? অথবা এটি কেবলমাত্র আবদুল্লাহসেলেক বারকোড নম্বর দেবে
আর মোহন

@ আর.মোহন এটি আপনার পড়া বারকোডের সাথে সম্পর্কিত। দয়া করে AVCaptureMetadataOutput এবং AVMetadataMachineReadableCodeObject পরীক্ষা করুন এবং হ্যান্ডেলক্যাপচারড আউটপুট ফাংশনের metadataObjectsভিতরে পড়ার চেষ্টা করুন ।
আবদুল্লাহসেলেক

ঠিক আছে, চেষ্টা করবে। জবাবের জন্য আপনাকে ধন্যবাদ আব্দুল্লাহসেলেক
আর মোহন

5

এটি সাহায্য করবে কিনা তা নিশ্চিত নয় তবে এখানে ওপেন সোর্স কিউআর কোড লাইব্রেরির লিঙ্ক । আপনি দেখতে পাচ্ছেন যে কয়েক জন ইতিমধ্যে আইফোনটির জন্য অ্যাপ্লিকেশন তৈরি করতে এটি ব্যবহার করেছেন।

উইকিপিডিয়ায় কিউআর কোডগুলি কী তা ব্যাখ্যা করে একটি নিবন্ধ রয়েছে । আমার মতে কিউআর কোডগুলি স্ট্যান্ডার্ড বারকোডের তুলনায় অনেক বেশি ফিট যেখানে আইফোনটি এই ধরণের বাস্তবায়নের জন্য ডিজাইন করা হয়েছিল বলে মনে হয়।


5

যদি আইপ্যাড 2 বা আইপড টাচের জন্য সমর্থনটি আপনার অ্যাপ্লিকেশনের জন্য গুরুত্বপূর্ণ হয়, আমি একটি বারকোড স্ক্যানার এসডিকে বেছে নেব যা ঝাপসা চিত্রগুলিতে বারকোডগুলি ডিকোড করতে পারে, যেমন আইওএস এবং অ্যান্ড্রয়েডের জন্য আমাদের স্ক্যান্ডিট বারকোড স্ক্যানার এসডিকে । ব্লোরি বারকোড চিত্রগুলি ডিকোডিং অটোফোকাস ক্যামেরাযুক্ত ফোনেও সহায়ক কারণ ব্যবহারকারীকে অটোফোকাসটি কিক করতে অপেক্ষা করতে হবে না।

স্ক্যান্ডিট একটি নিখরচায় কমিউনিটি মূল্য পরিকল্পনার সাথে আসে এবং এর মধ্যে এমন একটি পণ্য এপিআই রয়েছে যা বারকোড সংখ্যাগুলিকে পণ্যের নামে রূপান্তর করা সহজ করে তোলে।

(অস্বীকৃতি: আমি স্ক্যান্ডিটের সহ-প্রতিষ্ঠাতা)


4

এই অ্যাপ্লিকেশনটির সাথে আপনার অভিজ্ঞতা কেমন? আমার জন্য একটি সাধারণ ডেটাম্যাট্রিক্স বারকোড ডিকোড করতে 10 বা তার বেশি সময় লাগে!
iamj4de


1
ডাইরেক্ট লিঙ্ক (আমি মনে করি না গুগল এটি কিছুক্ষণের জন্য অদৃশ্য হয়ে যাবে) কোড. google.com/p/barcodeapp

কেউ কি জানেন যে অ্যাপস্টোরে স্টেফানের অ্যাপের অফিশিয়াল নাম কী? আমি আসল কোডটিতে ডুব দেওয়ার আগে এটি ডাউনলোড করতে চাই।
ম্যাকুটান

3

আইফোন ক্যামেরার সমস্যাটি হ'ল প্রথম মডেলগুলির (যার মধ্যে প্রচুর টন রয়েছে) একটি ফিক্সড ফোকাস ক্যামেরা থাকে যা 2 ফুটের নীচে দূরত্বের জন্য ছবিতে নজর দিতে পারে না। চিত্রগুলি অস্পষ্ট এবং বিকৃত এবং বেশি দূর থেকে নেওয়া হলে বারকোড থেকে পর্যাপ্ত বিবরণ / তথ্য নেই।

কয়েকটি সংস্থা আইফোন অ্যাপ্লিকেশনগুলি তৈরি করেছে যা উন্নত ডি-ব্লারিং প্রযুক্তি ব্যবহার করে এটির জন্য উপযুক্ত হতে পারে। অ্যাপল অ্যাপ স্টোরটিতে আপনি যে অ্যাপ্লিকেশনগুলি পেতে পারেন তা: পিক 2 শপ, রেডলেজার এবং শপস্যাভি av সমস্ত সংস্থা ঘোষণা করেছে যে তাদের কাছে এসডিকেও রয়েছে - কিছু বিনামূল্যে বা খুব পছন্দসই শর্তে, এটি পরীক্ষা করে দেখুন।


আমি একটি 3G আইফোন দিয়ে শপস্যাভি ব্যবহার করার চেষ্টা করেছি। এটি মজাদার, তবে খুব ঘন ঘন ক্র্যাশ হয় এবং খুব পরিষ্কার, সমতল বারকোডগুলি পড়ার খুব, খুব কঠিন সময়ও রয়েছে।
জেমস মুর

1
এবং আমি কেবল পিক 2 শপ চেষ্টা করেছি। আমার বাগদত্তের উদ্ধৃতি: "এটি কীভাবে আমাদের জীবনকে আরও সহজ করে তুলবে?" এটি একটি দুর্দান্ত অ্যাপ্লিকেশন, তবে যতদূর আমি বলতে পারি এটি কোনও বারকোডটি পড়তে সক্ষম নয়।
জেমস মুর

আপনি কোন ফর্ম্যাটটি পড়ার চেষ্টা করেছিলেন? EAN স্ক্যান করতে আমি pic2shop ব্যবহার করার চেষ্টা করেছি এবং এটি খুব ভালভাবে কাজ করে। লাইসেন্স ফি যদিও রেডলেজারের চেয়েও বেশি ব্যয়বহুল।
iamj4de

2

সঙ্গে সুইফট 5 এটি দ্রুত সহজ এবং সুপার এর !!

আপনার কেবল কোকো পোড যুক্ত করতে হবে "বারকোডস্ক্যানার" এখানে পূর্ণ কোড

source 'https://github.com/CocoaPods/Specs.git' 
platform :ios, '12.0' 
target 'Simple BarcodeScanner' 
do   
pod 'BarcodeScanner' 
end

আপনার .plist ফাইলে ক্যামেরার অনুমতি যুক্ত করার বিষয়টি নিশ্চিত করুন

<key>NSCameraUsageDescription</key>
<string>Camera usage description</string>

এবং স্ক্যানার যুক্ত করুন এবং এইভাবে আপনার ভিউকন্ট্রোলারের ফলাফল হ্যান্ডেল করুন

import UIKit
import BarcodeScanner

class ViewController: UIViewController, BarcodeScannerCodeDelegate, BarcodeScannerErrorDelegate, BarcodeScannerDismissalDelegate {

    override func viewDidLoad() {
        super.viewDidLoad()

        let viewController = BarcodeScannerViewController()
        viewController.codeDelegate = self
        viewController.errorDelegate = self
        viewController.dismissalDelegate = self

        present(viewController, animated: true, completion: nil)
    }

    func scanner(_ controller: BarcodeScannerViewController, didCaptureCode code: String, type: String) {
        print("Product's Bar code is :", code)
        controller.dismiss(animated: true, completion: nil)
    }

    func scanner(_ controller: BarcodeScannerViewController, didReceiveError error: Error) {
        print(error)
    }

    func scannerDidDismiss(_ controller: BarcodeScannerViewController) {
        controller.dismiss(animated: true, completion: nil)
    }
}

এখনও এবং কোনও প্রশ্ন বা চ্যালেঞ্জ, সম্পূর্ণ উত্স কোড সহ এখানে নমুনা অ্যাপ্লিকেশন চেক করুন



1

আমি বিশ্বাস করি এটি এভিফ্রেমওয়ার্ক ব্যবহার করে করা যেতে পারে, এটি করার জন্য এখানে নমুনা কোড is

import UIKit
import AVFoundation

class ViewController: UIViewController, AVCaptureMetadataOutputObjectsDelegate
{

    @IBOutlet weak var lblQRCodeResult: UILabel!
    @IBOutlet weak var lblQRCodeLabel: UILabel!

    var objCaptureSession:AVCaptureSession?
    var objCaptureVideoPreviewLayer:AVCaptureVideoPreviewLayer?
    var vwQRCode:UIView?

    override func viewDidLoad() {
        super.viewDidLoad()
        self.configureVideoCapture()
        self.addVideoPreviewLayer()
        self.initializeQRView()
    }

    func configureVideoCapture() {
        let objCaptureDevice = AVCaptureDevice.defaultDeviceWithMediaType(AVMediaTypeVideo)
        var error:NSError?
        let objCaptureDeviceInput: AnyObject!
        do {
            objCaptureDeviceInput = try AVCaptureDeviceInput(device: objCaptureDevice) as AVCaptureDeviceInput

        } catch let error1 as NSError {
            error = error1
            objCaptureDeviceInput = nil
        }
        objCaptureSession = AVCaptureSession()
        objCaptureSession?.addInput(objCaptureDeviceInput as! AVCaptureInput)
        let objCaptureMetadataOutput = AVCaptureMetadataOutput()
        objCaptureSession?.addOutput(objCaptureMetadataOutput)
        objCaptureMetadataOutput.setMetadataObjectsDelegate(self, queue: dispatch_get_main_queue())
        objCaptureMetadataOutput.metadataObjectTypes = [AVMetadataObjectTypeQRCode]
    }

    func addVideoPreviewLayer() {
        objCaptureVideoPreviewLayer = AVCaptureVideoPreviewLayer(session: objCaptureSession)
        objCaptureVideoPreviewLayer?.videoGravity = AVLayerVideoGravityResizeAspectFill
        objCaptureVideoPreviewLayer?.frame = view.layer.bounds
        self.view.layer.addSublayer(objCaptureVideoPreviewLayer!)
        objCaptureSession?.startRunning()
        self.view.bringSubviewToFront(lblQRCodeResult)
        self.view.bringSubviewToFront(lblQRCodeLabel)
    }

    func initializeQRView() {
        vwQRCode = UIView()
        vwQRCode?.layer.borderColor = UIColor.redColor().CGColor
        vwQRCode?.layer.borderWidth = 5
        self.view.addSubview(vwQRCode!)
        self.view.bringSubviewToFront(vwQRCode!)
    }

    func captureOutput(captureOutput: AVCaptureOutput!, didOutputMetadataObjects metadataObjects: [AnyObject]!, fromConnection connection: AVCaptureConnection!) {
        if metadataObjects == nil || metadataObjects.count == 0 {
            vwQRCode?.frame = CGRectZero
            lblQRCodeResult.text = "QR Code wans't found"
            return
        }
        let objMetadataMachineReadableCodeObject = metadataObjects[0] as! AVMetadataMachineReadableCodeObject
        if objMetadataMachineReadableCodeObject.type == AVMetadataObjectTypeQRCode {
            let objBarCode = objCaptureVideoPreviewLayer?.transformedMetadataObjectForMetadataObject(objMetadataMachineReadableCodeObject as AVMetadataMachineReadableCodeObject) as! AVMetadataMachineReadableCodeObject
            vwQRCode?.frame = objBarCode.bounds;
            if objMetadataMachineReadableCodeObject.stringValue != nil {
                lblQRCodeResult.text = objMetadataMachineReadableCodeObject.stringValue
            }
        }
    }
}

1

এখানে সহজ কোড:

func scanbarcode()
{
    view.backgroundColor = UIColor.blackColor()
    captureSession = AVCaptureSession()

    let videoCaptureDevice = AVCaptureDevice.defaultDeviceWithMediaType(AVMediaTypeVideo)
    let videoInput: AVCaptureDeviceInput

    do {
        videoInput = try AVCaptureDeviceInput(device: videoCaptureDevice)
    } catch {
        return
    }

    if (captureSession.canAddInput(videoInput)) {
        captureSession.addInput(videoInput)
    } else {
        failed();
        return;
    }

    let metadataOutput = AVCaptureMetadataOutput()

    if (captureSession.canAddOutput(metadataOutput)) {
        captureSession.addOutput(metadataOutput)

        metadataOutput.setMetadataObjectsDelegate(self, queue: dispatch_get_main_queue())
        metadataOutput.metadataObjectTypes = [AVMetadataObjectTypeEAN8Code, AVMetadataObjectTypeEAN13Code, AVMetadataObjectTypePDF417Code]
    } else {
        failed()
        return
    }

    previewLayer = AVCaptureVideoPreviewLayer(session: captureSession);
    previewLayer.frame = view.layer.bounds;
    previewLayer.videoGravity = AVLayerVideoGravityResizeAspectFill;
    view.layer.addSublayer(previewLayer);
    view.addSubview(closeBtn)
    view.addSubview(backimg)

    captureSession.startRunning();

}
override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

func failed() {
    let ac = UIAlertController(title: "Scanning not supported", message: "Your device does not support scanning a code from an item. Please use a device with a camera.", preferredStyle: .Alert)
    ac.addAction(UIAlertAction(title: "OK", style: .Default, handler: nil))
    presentViewController(ac, animated: true, completion: nil)
    captureSession = nil
}

override func viewWillAppear(animated: Bool) {
    super.viewWillAppear(animated)

    if (captureSession?.running == false) {
        captureSession.startRunning();
    }
}

override func viewWillDisappear(animated: Bool) {
    super.viewWillDisappear(animated)

    if (captureSession?.running == true) {
        captureSession.stopRunning();
    }
}

func captureOutput(captureOutput: AVCaptureOutput!, didOutputMetadataObjects metadataObjects: [AnyObject]!, fromConnection connection: AVCaptureConnection!) {
    captureSession.stopRunning()

    if let metadataObject = metadataObjects.first {
        let readableObject = metadataObject as! AVMetadataMachineReadableCodeObject;

        AudioServicesPlaySystemSound(SystemSoundID(kSystemSoundID_Vibrate))
        foundCode(readableObject.stringValue);
    }

   // dismissViewControllerAnimated(true, completion: nil)
}

func foundCode(code: String) {
    var createAccountErrorAlert: UIAlertView = UIAlertView()
    createAccountErrorAlert.delegate = self
    createAccountErrorAlert.title = "Alert"
    createAccountErrorAlert.message = code
    createAccountErrorAlert.addButtonWithTitle("ok")
    createAccountErrorAlert.addButtonWithTitle("Retry")
    createAccountErrorAlert.show()
    NSUserDefaults.standardUserDefaults().setObject(code, forKey: "barcode")
    NSUserDefaults.standardUserDefaults().synchronize()
    ItemBarcode = code
    print(code)
}

override func prefersStatusBarHidden() -> Bool {
    return true
}

override func supportedInterfaceOrientations() -> UIInterfaceOrientationMask {
    return .Portrait
}

1

আপনি যদি সুইফট 4 দিয়ে আইওএস> 10.2 এর জন্য বিকাশ করছেন তবে আপনি আমার সমাধানটি চেষ্টা করতে পারেন। আমি এই এবং এই টিউটোরিয়ালটি মিশ্রিত করে একটি ভিউ কন্ট্রোলার নিয়ে এসেছি যা একটি কিউআর কোড স্ক্যান করে print()এটি আউট করে। ক্যামেরা লাইট টগল করতে আমার আমার ইউআইতে একটি স্যুইচও রয়েছে, পাশাপাশি সহায়ক হতে পারে। আপাতত আমি কেবল এটি একটি আইফোন এসইতে পরীক্ষা করেছি, দয়া করে এটি আমাকে নতুন আইফোনে কাজ না করে তা আমাকে জানান।

আপনি এখানে যান:

import UIKit
import AVFoundation

class QRCodeScanner: UIViewController, AVCaptureMetadataOutputObjectsDelegate {

    let captureSession: AVCaptureSession = AVCaptureSession()
    var videoPreviewLayer: AVCaptureVideoPreviewLayer?
    let qrCodeFrameView: UIView = UIView()
    var captureDevice: AVCaptureDevice?

    override func viewDidLoad() {
        // Get the back-facing camera for capturing videos
        let deviceDiscoverySession = AVCaptureDevice.DiscoverySession(deviceTypes: [.builtInWideAngleCamera, .builtInDualCamera], mediaType: AVMediaType.video, position: .back)

        captureDevice = deviceDiscoverySession.devices.first
        if captureDevice == nil {
            print("Failed to get the camera device")
            return
        }

        do {
            // Get an instance of the AVCaptureDeviceInput class using the previous device object.
            let input = try AVCaptureDeviceInput(device: captureDevice!)

            // Set the input device on the capture session.
            captureSession.addInput(input)

            // Initialize a AVCaptureMetadataOutput object and set it as the output device to the capture session.
            let captureMetadataOutput = AVCaptureMetadataOutput()
            captureSession.addOutput(captureMetadataOutput)

            // Set delegate and use the default dispatch queue to execute the call back
            captureMetadataOutput.setMetadataObjectsDelegate(self, queue: DispatchQueue.main)
            captureMetadataOutput.metadataObjectTypes = [AVMetadataObject.ObjectType.qr]

            // Initialize the video preview layer and add it as a sublayer to the viewPreview view's layer.

            videoPreviewLayer = AVCaptureVideoPreviewLayer(session: captureSession)

            if let videoPreviewLayer = videoPreviewLayer {
                videoPreviewLayer.videoGravity = AVLayerVideoGravity.resizeAspectFill
                videoPreviewLayer.frame = view.layer.bounds
                view.layer.addSublayer(videoPreviewLayer)

                // Start video capture.
                captureSession.startRunning()

                if let hasFlash = captureDevice?.hasFlash, let hasTorch = captureDevice?.hasTorch {
                    if hasFlash && hasTorch {
                        view.bringSubview(toFront: bottomBar)
                        try captureDevice?.lockForConfiguration()
                    }
                }
            }

            // QR Code Overlay
            qrCodeFrameView.layer.borderColor = UIColor.green.cgColor
            qrCodeFrameView.layer.borderWidth = 2
            view.addSubview(qrCodeFrameView)
            view.bringSubview(toFront: qrCodeFrameView)

        } catch {
            // If any error occurs, simply print it out and don't continue any more.
            print("Error: \(error)")
            return
        }
    }

    // MARK: Buttons and Switch

    @IBAction func switchFlashChanged(_ sender: UISwitch) {
        do {
            if sender.isOn {
                captureDevice?.torchMode = .on
            } else {
                captureDevice?.torchMode = .off
            }
        }
    }

    // MARK: AVCaptureMetadataOutputObjectsDelegate

    func metadataOutput(_ output: AVCaptureMetadataOutput, didOutput metadataObjects: [AVMetadataObject], from connection: AVCaptureConnection) {

        // Check if the metadataObjects array is not nil and it contains at least one object.
        if metadataObjects.count == 0 {
            qrCodeFrameView.frame = CGRect.zero
            return
        }

        // Get the metadata object.
        let metadataObj = metadataObjects[0] as! AVMetadataMachineReadableCodeObject

        if metadataObj.type == AVMetadataObject.ObjectType.qr {
            // If the found metadata is equal to the QR code metadata then update the status label's text and set the bounds
            let barCodeObject = videoPreviewLayer?.transformedMetadataObject(for: metadataObj)
            qrCodeFrameView.frame = barCodeObject!.bounds

            print("QR Code: \(metadataObj.stringValue)")
        }
    }
}

0

কখনও কখনও এটি কিউআর কোড উত্পন্ন করতেও কার্যকর হতে পারে । এর জন্য একটি চমত্কার সি লাইব্রেরি রয়েছে যা একটি কবজির মতো কাজ করে। এটাকে লাইবক্রেনকোড বলা হয় । এরপরে কিউআর কোড প্রদর্শনের জন্য একটি কাস্টম ভিউ লেখা এতটা কঠিন নয় এবং কোয়ার্টজকোরের বুনিয়াদী বোঝার সাথে করা যেতে পারে।


কীভাবে আপনি এটি কোনও আইওএস এক্সকোড প্রকল্পে অন্তর্ভুক্ত করবেন সে সম্পর্কে কোনও টিউটোরিয়াল জানেন?
জেমস

কোয়ার্টকোর ব্যবহার করে আপনি কীভাবে ভিউ তৈরি করেছেন তা ভাগ করে নিতে কি আপত্তি হবে? একটি বড়
টাইমসেভার হবে

সেটা ঠিক. তবে, নিশ্চিত হয়ে নিন যে আপনি সফ্টওয়্যার লাইসেন্সের সাথে অনুগত, লাইব্রেরিটি প্রকাশিত হয়েছে।
গরিলাপ্যাচ

এই প্রশ্নটি প্রজন্মের নয়, স্বীকৃতির বিষয়ে।
MonsieurDart

0

আপনি কিউআর কোড এবং ইসিএন / আইএসবিএন কোডগুলি পড়তে ZBarSDK পরীক্ষা করতে পারেন নীচের কোডটি একীভূত করা সহজ।

- (void)scanBarcodeWithZBarScanner
  {
// ADD: present a barcode reader that scans from the camera feed
ZBarReaderViewController *reader = [ZBarReaderViewController new];
reader.readerDelegate = self;
reader.supportedOrientationsMask = ZBarOrientationMaskAll;

ZBarImageScanner *scanner = reader.scanner;
// TODO: (optional) additional reader configuration here

// EXAMPLE: disable rarely used I2/5 to improve performance
 [scanner setSymbology: ZBAR_I25
               config: ZBAR_CFG_ENABLE
                   to: 0];

//Get the return value from controller
[reader setReturnBlock:^(BOOL value) {

}

এবং didFinishPickingMediaWithInfo এ আমরা বার কোড মান পাই।

    - (void) imagePickerController: (UIImagePickerController*) reader
   didFinishPickingMediaWithInfo: (NSDictionary*) info
   {
    // ADD: get the decode results
    id<NSFastEnumeration> results =
    [info objectForKey: ZBarReaderControllerResults];
    ZBarSymbol *symbol = nil;
    for(symbol in results)
    // EXAMPLE: just grab the first barcode
    break;

    // EXAMPLE: do something useful with the barcode data
    barcodeValue = symbol.data;

    // EXAMPLE: do something useful with the barcode image
    barcodeImage =   [info objectForKey:UIImagePickerControllerOriginalImage];
    [_barcodeIV setImage:barcodeImage];

    //set the values for to TextFields
    [self setBarcodeValue:YES];

    // ADD: dismiss the controller (NB dismiss from the *reader*!)
    [reader dismissViewControllerAnimated:YES completion:nil];
   }
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.