Zxing应用程序和SQLite数据库 [英] Zxing app and SQLite database
本文介绍了Zxing应用程序和SQLite数据库的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我按照网上的教程,创造了扫描吧codeS和使用ZXing库QR code的应用程序,并存储所有的数据库中的信息。我跟着一步一步做的事,但在我的code .The数据不能存储在数据库中,并保持强制关闭
Calledspot_pay.java
包com.example.zxing_android_products;
进口的java.math.BigDecimal;
进口android.os.Bundle;
进口android.app.Activity;
进口android.content.Intent;
进口android.view.Menu;
进口android.view.MenuItem;
进口android.view.View;
进口android.view.View.OnClickListener;
进口android.widget.Button;
进口android.support.v4.app.NavUtils;
公共类Calledspot_pay延伸活动{
@覆盖
公共无效的onCreate(包savedInstanceState){
super.onCreate(savedInstanceState);
的setContentView(R.layout.activity_calledspot_pay);
按钮Add按钮=(按钮)findViewById(R.id.addMenuButton);
addButton.setOnClickListener(新OnClickListener(){
公共无效的onClick(视图v){
startActivity(新意图(Calledspot_pay。这,AddProduct.class));
}
});
}
静态final类ProductData {
串吧code;
字符串格式;
字符串称号;
BigDecimal的价格;
}
}
ProductDatabase.java
包com.example.zxing_android_products;
进口的java.math.BigDecimal;
进口com.example.zxing_android_products.Calledspot_pay.ProductData;
进口android.content.ContentValues;
进口android.content.Context;
进口android.database.sqlite.SQLiteDatabase;
进口android.database.sqlite.SQLiteDatabase.CursorFactory;
进口android.database.sqlite.SQLiteOpenHelper;
进口android.util.Log;
公共类ProductDatabase {
私有静态最后弦乐PRODUCT_TABLE =产品;
私有静态最后弦乐DATABASE_NAME =spot_pay.db;
私有静态最终诠释DATABASE_VERSION = 1;
私有静态最后的BigDecimal ONE_HUNDRED = NULL;
私人SQLiteDatabase分贝;
私有静态类ProductDatabaseHelper扩展SQLiteOpenHelper {
私有静态最后字符串变量= NULL;
公共ProductDatabaseHelper(上下文的背景下){
超(背景下,DATABASE_NAME,空,DATABASE_VERSION);
// TODO自动生成构造函数存根
}
@覆盖
公共无效的onCreate(SQLiteDatabase DB){
StringBuilder的SQL =新的StringBuilder();
sql.append(创建表).append(PRODUCT_TABLE)
。附加(( )
.append(_id整数主键)
.append(栏code文本)
.append(格式文本)
.append(标题文本)
.append(价格货币)
。附加() );
db.execSQL(sql.toString());
Log.d(TAG,PRODUCT_TABLE +创建表);
}
@覆盖
公共无效onUpgrade(SQLiteDatabase分贝,INT oldVersion,诠释静态网页){
db.execSQL(+ PRODUCT_TABLE如果存在删除表);
的onCreate(DB);
}
}
公共ProductDatabase(上下文的背景下){
ProductDatabaseHelper帮手=新ProductDatabaseHelper(上下文);
DB = helper.getWritableDatabase();
}
公共布尔插入(ProductData产品){
ContentValues瓦尔斯=新ContentValues();
vals.put(栏code,product.bar code);
vals.put(格式,product.format);
vals.put(标题,product.title);
vals.put(价格,product.price.multiply(ONE_HUNDRED).longValue());
返回db.insert(PRODUCT_TABLE,空,丘壑)!= -1;
}
}
AddProduct.java
包com.example.zxing_android_products;
进口的java.math.BigDecimal;
进口com.example.zxing_android_products.Calledspot_pay.ProductData;
进口android.app.Activity;
进口android.app.AlertDialog;
进口android.content.Context;
进口android.content.DialogInterface;
进口android.content.Intent;
进口android.os.Bundle;
进口android.view.View;
进口android.view.View.OnClickListener;
进口android.widget.Button;
进口android.widget.EditText;
进口android.widget.TextView;
公共类AddProduct扩展活动实现OnClickListener {
私有静态最终诠释REQUEST_BAR code = 0;
私有静态最后ProductData mProductData =新ProductData();
EditText上毫巴codeEDIT;
的EditText mFormatEdit;
的EditText mTitleEdit;
的EditText mPriceEdit;
私人按钮mScanButton;
私人按钮mAddButton;
//私人ProductDatabase mProductDb;
ProductDatabase mProductDb;
@覆盖
保护无效的onCreate(包savedInstanceState){
// TODO自动生成方法存根
super.onCreate(savedInstanceState);
的setContentView(R.layout.add_product);
毫巴codeEDIT =(EditText上)findViewById(R.id.bar codeEDIT);
mFormatEdit =(EditText上)findViewById(R.id. codeFormatEdit);
mTitleEdit =(EditText上)findViewById(R.id.titleEdit);
mPriceEdit =(EditText上)findViewById(R.id.priceEdit);
mScanButton =(按钮)findViewById(R.id.scanButton);
mScanButton.setOnClickListener(本);
mAddButton =(按钮)findViewById(R.id.addButton);
mAddButton.setOnClickListener(本);
mProductDb =新ProductDatabase(本); //尚未显示
}
公共无效的onClick(视图v){
// TODO自动生成方法存根
开关(v.getId()){
案例R.id.scanButton:
意向意图=新的意图(com.google.zxing.client.android.SCAN);
intent.putExtra(SCAN_MODE,PRODUCT_MODE);
startActivityForResult(意向,REQUEST_BAR code);
打破;
案例R.id.addButton:
串吧code =毫巴codeEdit.getText()的toString()。
。字符串格式= mFormatEdit.getText()的toString();
。字符串title = mTitleEdit.getText()的toString();
串价格= mPriceEdit.getText()的toString()。
字符串错误= validateFields(巴code,格式,名称,价格);
如果(errors.length()大于0){
showInfoDialog(这一点,请修复错误,错误);
} 其他 {
mProductData.bar code =吧code;
mProductData.format =格式;
mProductData.title =称号;
mProductData.price =新的BigDecimal(价格);
mProductDb.insert(mProductData);
showInfoDialog(这一点,成功,产品保存成功);
resetForm();
}
打破;
}
}
私人无效showInfoDialog(上下文的背景下,标题字符串,字符串信息){
新AlertDialog.Builder(上下文)
.setMessage(资料图)
.setTitle(标题)
.setPositiveButton(OK,新DialogInterface.OnClickListener(){
公共无效的onClick(DialogInterface对话,诠释它){
dialog.dismiss();
}
})。显示();
}
私人无效resetForm(){
// TODO自动生成方法存根
毫巴codeEdit.getText()清()。
mFormatEdit.getText()清()。
mTitleEdit.getText()清()。
mPriceEdit.getText()清()。
}
公共无效onActivityResult(INT申请code,INT结果code,意图意图){
如果(要求code == REQUEST_BAR code){
如果(结果code == RESULT_OK){
串吧code = intent.getStringExtra(SCAN_RESULT);
毫巴codeEdit.setText(酒吧code);
字符串格式= intent.getStringExtra(SCAN_RESULT_FORMAT);
mFormatEdit.setText(格式);
}否则,如果(结果code == RESULT_CANCELED){
完();
}
}
}
私有静态字符串validateFields(字符串吧code,字符串格式,
标题字符串,字符串价格){
StringBuilder的错误=新的StringBuilder();
如果(巴code.matches(^ \\ S * $)){
errors.append(酒吧code所需的\ n);
}
如果(format.matches(^ \\ S * $)){
errors.append(格式所需的\ n);
}
如果(title.matches(^ \\ S * $)){
errors.append(标题所需的\ n);
}
如果(price.matches(!^ - ?。?\\ D +(\\ D +)$)){
errors.append(极品数值价格\ N);
}
返回errors.toString();
}
}
任何人有什么错误?
10月10号至十七日:21:37.746:D / AndroidRuntime(18643):关闭虚拟机
10月10号至17日:21:37.746:W / dalvikvm(18643):主题ID = 3:线程退出与未捕获的异常(组= 0x4001b188)
10月10号至17日:21:37.746:E / AndroidRuntime(18643):未捕获的处理程序:螺纹主力退出,由于未捕获的异常
10月10号至17日:21:37.767:E / AndroidRuntime(18643):显示java.lang.NullPointerException
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在java.math.BigDecimal.multiply(BigDecimal.java:1025)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在com.example.zxing_android_products.ProductDatabase.insert(ProductDatabase.java:69)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在com.example.zxing_android_products.AddProduct.onClick(AddProduct.java:74)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.View.performClick(View.java:2364)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.View.onTouchEvent(View.java:4179)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.widget.TextView.onTouchEvent(TextView.java:6541)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.View.dispatchTouchEvent(View.java:3709)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1659)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.app.Activity.dispatchTouchEvent(Activity.java:2061)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在com.android.internal.policy.impl.PhoneWindow $ DecorView.dispatchTouchEvent(PhoneWindow.java:1643)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.view.ViewRoot.handleMessage(ViewRoot.java:1691)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.os.Handler.dispatchMessage(Handler.java:99)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.os.Looper.loop(Looper.java:123)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在android.app.ActivityThread.main(ActivityThread.java:4363)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在java.lang.reflect.Method.invokeNative(本机方法)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在java.lang.reflect.Method.invoke(Method.java:521)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:860)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
10月10号至17日:21:37.767:E / AndroidRuntime(18643):在dalvik.system.NativeStart.main(本机方法)
10月10号至17日:21:37.776:I / dalvikvm(18643):主题ID = 7:反应信号3
10月10号至17日:21:37.776:E / dalvikvm(18643):无法打开堆栈跟踪文件/data/anr/traces.txt':权限被拒绝
10月10号至17日:21:39.636:I /流程(18643):发送信号。 PID:18643 SIG:9
解决方案
你的 ONE_HUNDRED
变量为null。
私有静态最后的BigDecimal ONE_HUNDRED = NULL;
您可以试试:
私有静态最后的BigDecimal ONE_HUNDRED =新的BigDecimal(100);
i follow the tutorial online , created an app for scanning barcodes and QR code using the ZXing library, and store all the information inside the database . I follow step by step to do it ,but something in my code .The data cannot store in database , and keep force close
Calledspot_pay.java
package com.example.zxing_android_products;
import java.math.BigDecimal;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.support.v4.app.NavUtils;
public class Calledspot_pay extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_calledspot_pay);
Button addButton=(Button)findViewById(R.id.addMenuButton);
addButton.setOnClickListener (new OnClickListener(){
public void onClick (View v){
startActivity(new Intent(Calledspot_pay .this, AddProduct.class));
}
});
}
static final class ProductData {
String barcode;
String format;
String title;
BigDecimal price;
}
}
ProductDatabase.java
package com.example.zxing_android_products;
import java.math.BigDecimal;
import com.example.zxing_android_products.Calledspot_pay.ProductData;
import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
public class ProductDatabase {
private static final String PRODUCT_TABLE="products";
private static final String DATABASE_NAME="spot_pay.db";
private static final int DATABASE_VERSION=1;
private static final BigDecimal ONE_HUNDRED = null;
private SQLiteDatabase db;
private static class ProductDatabaseHelper extends SQLiteOpenHelper {
private static final String TAG = null;
public ProductDatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
// TODO Auto-generated constructor stub
}
@Override
public void onCreate(SQLiteDatabase db) {
StringBuilder sql = new StringBuilder();
sql.append("create table ").append(PRODUCT_TABLE)
.append("( ")
.append(" _id integer primary key,")
.append(" barcode text,")
.append(" format text,")
.append(" title text,")
.append(" price currency")
.append(") ");
db.execSQL(sql.toString());
Log.d(TAG, PRODUCT_TABLE + "table created");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("drop table if exists " + PRODUCT_TABLE);
onCreate(db);
}
}
public ProductDatabase(Context context) {
ProductDatabaseHelper helper = new ProductDatabaseHelper(context);
db = helper.getWritableDatabase();
}
public boolean insert(ProductData product) {
ContentValues vals = new ContentValues();
vals.put("barcode", product.barcode);
vals.put("format", product.format);
vals.put("title", product.title);
vals.put("price", product.price.multiply(ONE_HUNDRED).longValue());
return db.insert(PRODUCT_TABLE, null, vals) != -1;
}
}
AddProduct.java
package com.example.zxing_android_products;
import java.math.BigDecimal;
import com.example.zxing_android_products.Calledspot_pay.ProductData;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
public class AddProduct extends Activity implements OnClickListener{
private static final int REQUEST_BARCODE=0;
private static final ProductData mProductData=new ProductData();
EditText mBarcodeEdit;
EditText mFormatEdit;
EditText mTitleEdit;
EditText mPriceEdit;
private Button mScanButton;
private Button mAddButton;
//private ProductDatabase mProductDb;
ProductDatabase mProductDb;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.add_product);
mBarcodeEdit = (EditText) findViewById(R.id.barcodeEdit);
mFormatEdit = (EditText) findViewById(R.id.codeFormatEdit);
mTitleEdit = (EditText) findViewById(R.id.titleEdit);
mPriceEdit = (EditText) findViewById(R.id.priceEdit);
mScanButton = (Button) findViewById(R.id.scanButton);
mScanButton.setOnClickListener(this);
mAddButton = (Button) findViewById(R.id.addButton);
mAddButton.setOnClickListener(this);
mProductDb = new ProductDatabase(this); // not yet shown
}
public void onClick(View v) {
// TODO Auto-generated method stub
switch (v.getId()) {
case R.id.scanButton:
Intent intent = new Intent("com.google.zxing.client.android.SCAN");
intent.putExtra("SCAN_MODE", "PRODUCT_MODE");
startActivityForResult(intent, REQUEST_BARCODE);
break;
case R.id.addButton:
String barcode = mBarcodeEdit.getText().toString();
String format = mFormatEdit.getText().toString();
String title = mTitleEdit.getText().toString();
String price = mPriceEdit.getText().toString();
String errors = validateFields(barcode, format, title, price);
if (errors.length() > 0) {
showInfoDialog(this, "Please fix errors", errors);
} else {
mProductData.barcode = barcode;
mProductData.format = format;
mProductData.title = title;
mProductData.price = new BigDecimal(price);
mProductDb.insert(mProductData);
showInfoDialog(this, "Success", "Product saved successfully");
resetForm();
}
break;
}
}
private void showInfoDialog(Context context, String title, String information) {
new AlertDialog.Builder (context)
.setMessage(information)
.setTitle(title)
.setPositiveButton("OK", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
}).show();
}
private void resetForm() {
// TODO Auto-generated method stub
mBarcodeEdit.getText().clear();
mFormatEdit.getText().clear();
mTitleEdit.getText().clear();
mPriceEdit.getText().clear();
}
public void onActivityResult(int requestCode, int resultCode, Intent intent) {
if (requestCode == REQUEST_BARCODE) {
if (resultCode == RESULT_OK) {
String barcode = intent.getStringExtra("SCAN_RESULT");
mBarcodeEdit.setText(barcode);
String format = intent.getStringExtra("SCAN_RESULT_FORMAT");
mFormatEdit.setText(format);
} else if (resultCode == RESULT_CANCELED) {
finish();
}
}
}
private static String validateFields(String barcode, String format,
String title, String price) {
StringBuilder errors = new StringBuilder();
if (barcode.matches("^\\s*$")) {
errors.append("Barcode required\n");
}
if (format.matches("^\\s*$")) {
errors.append("Format required\n");
}
if (title.matches("^\\s*$")) {
errors.append("Title required\n");
}
if (!price.matches("^-?\\d+(.\\d+)?$")) {
errors.append("Need numeric price\n");
}
return errors.toString();
}
}
anybody what is the error ?
10-17 10:21:37.746: D/AndroidRuntime(18643): Shutting down VM
10-17 10:21:37.746: W/dalvikvm(18643): threadid=3: thread exiting with uncaught exception (group=0x4001b188)
10-17 10:21:37.746: E/AndroidRuntime(18643): Uncaught handler: thread main exiting due to uncaught exception
10-17 10:21:37.767: E/AndroidRuntime(18643): java.lang.NullPointerException
10-17 10:21:37.767: E/AndroidRuntime(18643): at java.math.BigDecimal.multiply(BigDecimal.java:1025)
10-17 10:21:37.767: E/AndroidRuntime(18643): at com.example.zxing_android_products.ProductDatabase.insert(ProductDatabase.java:69)
10-17 10:21:37.767: E/AndroidRuntime(18643): at com.example.zxing_android_products.AddProduct.onClick(AddProduct.java:74)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.View.performClick(View.java:2364)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.View.onTouchEvent(View.java:4179)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.widget.TextView.onTouchEvent(TextView.java:6541)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.View.dispatchTouchEvent(View.java:3709)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
10-17 10:21:37.767: E/AndroidRuntime(18643): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1659)
10-17 10:21:37.767: E/AndroidRuntime(18643): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.app.Activity.dispatchTouchEvent(Activity.java:2061)
10-17 10:21:37.767: E/AndroidRuntime(18643): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1643)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.view.ViewRoot.handleMessage(ViewRoot.java:1691)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.os.Handler.dispatchMessage(Handler.java:99)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.os.Looper.loop(Looper.java:123)
10-17 10:21:37.767: E/AndroidRuntime(18643): at android.app.ActivityThread.main(ActivityThread.java:4363)
10-17 10:21:37.767: E/AndroidRuntime(18643): at java.lang.reflect.Method.invokeNative(Native Method)
10-17 10:21:37.767: E/AndroidRuntime(18643): at java.lang.reflect.Method.invoke(Method.java:521)
10-17 10:21:37.767: E/AndroidRuntime(18643): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
10-17 10:21:37.767: E/AndroidRuntime(18643): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
10-17 10:21:37.767: E/AndroidRuntime(18643): at dalvik.system.NativeStart.main(Native Method)
10-17 10:21:37.776: I/dalvikvm(18643): threadid=7: reacting to signal 3
10-17 10:21:37.776: E/dalvikvm(18643): Unable to open stack trace file '/data/anr/traces.txt': Permission denied
10-17 10:21:39.636: I/Process(18643): Sending signal. PID: 18643 SIG: 9
解决方案
your ONE_HUNDRED
variable is null.
private static final BigDecimal ONE_HUNDRED = null;
You can try:
private static final BigDecimal ONE_HUNDRED = new BigDecimal(100);
这篇关于Zxing应用程序和SQLite数据库的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文