Android 使用zxing条形码扫描仪创建产品数据库向数据库添加数据问题

Android 使用zxing条形码扫描仪创建产品数据库向数据库添加数据问题,android,database,sqlite,zxing,barcode-scanner,Android,Database,Sqlite,Zxing,Barcode Scanner,嘿,我在创建Android应用程序方面有点在行,这只是我的第二个。我需要创建一个应用程序来扫描条形码并将信息保存到数据库中 如本文所述,我使用zxing条形码扫描仪和Sqllite数据库创建了一个产品数据库。但是,当我在填写产品表单后单击“添加产品”按钮时。弹出一个消息框,说我的应用程序不幸停止了。扫描和填充工作正常,但我认为数据库操作不起作用 以下是我的页面,用于添加产品表单和数据库操作 StartMenu.java package com.example.barcodedatabaseapp

嘿,我在创建Android应用程序方面有点在行,这只是我的第二个。我需要创建一个应用程序来扫描条形码并将信息保存到数据库中

如本文所述,我使用zxing条形码扫描仪和Sqllite数据库创建了一个产品数据库。但是,当我在填写产品表单后单击“添加产品”按钮时。弹出一个消息框,说我的应用程序不幸停止了。扫描和填充工作正常,但我认为数据库操作不起作用

以下是我的页面,用于添加产品表单和数据库操作

StartMenu.java

package com.example.barcodedatabaseapp;

import java.math.BigDecimal;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class StartMenu extends Activity {

    static final class ProductData {
        String barcode;
        String format;
        String title;
        String Others;
        BigDecimal Price;
        }

        @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_start_menu);
        Button addButton=(Button) findViewById(R.id.button1);
        addButton.setOnClickListener(new OnClickListener(){
                public void onClick(View v)
                {
                startActivity(new Intent(StartMenu.this,AddProduct.class));
                }

            });

    }


}
AddProduct.java

package com.example.barcodedatabaseapp;

import java.math.BigDecimal;

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 com.example.barcodeda  tabaseapp.StartMenu.ProductData;

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;
    ProductDatabase mProductDb;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_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.addButton2);
        mAddButton.setOnClickListener(this);

}
  public void onClick(View v) {

               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.addButton2:
                    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() {
                      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();
    }
}
ProductDatabase.java

package com.example.barcodedatabaseapp;

import java.math.BigDecimal;

import com.example.barcodedatabaseapp.StartMenu.ProductData;

import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
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 =new BigDecimal(100);

          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);

                }

                @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;
            }
        }
xml文件中有关于硬编码文本字符串的警告,但eclipse中没有错误

这是logcat,请注意我的模拟器无法识别我的网络摄像头,我填写了在我兄弟的Nexus10上运行的表格

06-06 09:26:42.840: E/AndroidRuntime(825): FATAL EXCEPTION: main
06-06 09:26:42.840: E/AndroidRuntime(825): android.content.ActivityNotFoundException: No Activity found to handle Intent { act=com.google.zxing.client.android.SCAN (has extras) }
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1622)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.app.Instrumentation.execStartActivity(Instrumentation.java:1417)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.app.Activity.startActivityForResult(Activity.java:3370)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.app.Activity.startActivityForResult(Activity.java:3331)
06-06 09:26:42.840: E/AndroidRuntime(825):  at com.example.barcodedatabaseapp.AddProduct.onClick(AddProduct.java:51)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.view.View.performClick(View.java:4202)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.view.View$PerformClick.run(View.java:17340)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.os.Handler.handleCallback(Handler.java:725)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.os.Handler.dispatchMessage(Handler.java:92)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.os.Looper.loop(Looper.java:137)
06-06 09:26:42.840: E/AndroidRuntime(825):  at android.app.ActivityThread.main(ActivityThread.java:5039)
06-06 09:26:42.840: E/AndroidRuntime(825):  at java.lang.reflect.Method.invokeNative(Native Method)
06-06 09:26:42.840: E/AndroidRuntime(825):  at java.lang.reflect.Method.invoke(Method.java:511)
06-06 09:26:42.840: E/AndroidRuntime(825):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
06-06 09:26:42.840: E/AndroidRuntime(825):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
06-06 09:26:42.840: E/AndroidRuntime(825):  at dalvik.system.NativeStart.main(Native Method)


您没有在活动的
onCreate
中初始化
MPProductDB

mProductDb = new ProductDatabase(this);

LogCat怎么说?我没有在模拟器上运行它,因为它无法识别扫描仪所需的网络摄像头。我在我的Nexus10平板电脑上运行它,症状如我所说。在实际设备上运行总是更好!看起来你没有使用ZXIng库。带进来真的很容易。看看这个链接:@CaseyB:我发布了logcat部分,同样在阅读了我的代码之后,我认为它与AddProduct.java的else块和insert有关statements@CaseyB:我正在使用Zxing库,它扫描代码并填充前2个字段。我在tabet上测试了它,就像我说的,它使用Zxing摄像头屏幕,所以我知道它可以工作。谢谢,我知道它很简单,但我不知道是什么。当我使用SQLiteBrowser和emulator时,我可以查看数据库,但我想在我的S III迷你手机或Nexus 10平板电脑上查看文件,我必须在运行eclipse的avd(用于手机)时连接它们,对吗?然后是通常的步骤。另外,如果可能的话,我希望以表单或列表的形式显示此数据库数据。有什么建议吗?据我手下的人说,我现在需要一个代码来检查扫描的项目是否已经输入到数据库中,如果已经输入,则会弹出一条消息而不添加到数据库中,我正在寻找SQLite命令,该命令将在已经创建的表中执行此操作。请在StackOverflow上对此提出一个新问题。
mProductDb = new ProductDatabase(this);