Q: Should I use DataWedge or EMDK for my app?
A: For apps that require barcode scanning, Zebra strongly recommends DataWedge, particularly since it is a simpler approach to app development. DataWedge provides a quick and easy way to add data capture capabilities to an existing app and comes preinstalled on all Zebra devices. DataWedge can be used by configuring the UI without any coding required. Alternatively, all functions can be controlled programmatically through Android intents. See the DataWedge vs. EMDK feature comparison chart and the Get Started guide for more information.
Q: How do I configure DataWedge to capture data in an app without any coding?
A: DataWedge can be configured through the UI to capture data, process data based on specific requirements, and output data into any associated app or activity with the use of profiles. When DataWedge is invoked to scan and acquire data, the profile which the app is associated to formats or appends the data as specified, and then passes the data to the associated foreground app. Follow the procedure to create a new profile. For more information, refer to the Profiles section and Get Started guide.
Q: How do I integrate scanning within my app?
A: There are two intent-based interfaces into the scanner:
- Using a generic Android intent to acquire scanned data - This eliminates the need to use DataWedge APIs to capture data. Refer to the tutorial which walks through how to receive scanned barcode data into an app.
- Using DataWedge APIs to control the scanner - Provides the ability to programmatically control, modify and query the DataWedge configuration settings and operations through Android intents. This allows new or existing Android apps to be easily modified to acquire data using Zebra devices without concern of the underlying hardware. Refer to Get Started guide and sample demo apps.
See our blog post on how to interface the scanner through DataWedge.
Q: Scanning works in DWDemo but not in my own app. What am I doing wrong?
A: By default, the DWDemo profile is built-in to send scanned data via intent to the DWDemo app. A profile would need to be configured for your app to receive the scanned data. Make sure the profile is configured with the appropriate input (e.g. Barcode input) and output (e.g. Intent or Keystroke output). See Managing Profiles on how to accomplish this.
Q: I can scan barcodes but they are not sent to my app. What am I doing wrong?
A: It is likely either a profile is not associated with your app or the profile input/output is not configured properly. DataWedge is using the default profile (Profile0) to perform the scan, which allows the scan beam to appear. However, if improperly configured, it does not know how to output the data captured. Either create a profile and associate it with your app with the appropriate configurations or configure the default profile (Profile0) with the proper input/output to capture the scanned data.
Q: How do I temporarily suspend scanning in my DataWedge app?
A: There are two methods to temporarily disable the barcode scanner in an app using the Scanner Input Plugin:
- Enable / Disable - can be called at any time
- Suspend / Resume - much quicker but can be called only when the scanner is in the
SCANNING
orWAITING
state. The scanner state can be retrieved using Get Scanner Status or Register for Notification.
For more information and sample code, visit our blog on how to quickly suspend scanning in your app with DataWedge.
Q: How do I mass deploy my DataWedge settings and configurations?
A: Once DataWedge is set up and configured as desired on a device, settings can be saved to a file and distributed to other devices either manually or using a Mobile Device Management (MDM) system. There are two files that can be exported:
- Config – contains DataWedge settings, including all profiles and related configurations, and saves them to ‘datawedge.db’.
- Profile – contains individual profile settings, including how to capture, process, and output data acquired, and sames them to ‘dwprofile_[profileName].db’, where [profileName] is the name of the profile. See Mass Deployment for more information.
Q: How can I determine which features are supported with the specific DataWedge version on my device?
A: Once a version is selected from the version selector dropdown in the DataWedge tile from the main TechDocs page, subsequent navigation to related DataWedge pages displays information specific to that version.
DataWedge version selector
The selected version is also reflected in the URL. See Which Version is Installed to check for the DataWedge version running on the device.
Q: Does DW support NFC?
A: No, NFC is supported with EMDK for Android with Secure NFC or Android’s NFC API.
Q: Can I test my scanning app on an emulator?
A: Zebra recommends testing apps on the actual hardware. When this is not possible, adb shell commands can be used to simulate data captured by DataWedge that is sent to the device when scanning barcodes. Refer to this related blog post for more details.
Q: Can DataWedge APIs control data capture in real-time?
A: Yes, DataWedge APIs provide dynamic control over data capture whether via scanner, magnetic stripe reader, RFID, serial/USB port, SimulScan, or voice.
Related Guides: