Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/211.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/image/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 使用照相机拍摄照片并将其存储在sqlite数据库中_Android_Image_Sqlite_Camera - Fatal编程技术网

Android 使用照相机拍摄照片并将其存储在sqlite数据库中

Android 使用照相机拍摄照片并将其存储在sqlite数据库中,android,image,sqlite,camera,Android,Image,Sqlite,Camera,我是android新手。我创建了一个应用程序,用于使用android手机拍照,并将照片保存到Sqlite数据库中。但这段代码没有运行。我无法在程序中找到错误。请帮帮我 public class MainActivity extends Activity { private static final int CAMERA_REQUEST = 0; public ImageView imageView; @Override protected void onC

我是android新手。我创建了一个应用程序,用于使用android手机拍照,并将照片保存到Sqlite数据库中。但这段代码没有运行。我无法在程序中找到错误。请帮帮我

public class MainActivity extends Activity {

    private static final int CAMERA_REQUEST = 0; 
    public ImageView imageView; 

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        imageView =(ImageView) findViewById(R.id.image);
         Button B = (Button) this.findViewById(R.id.camera);

         B.setOnClickListener(new View.OnClickListener(){

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                Intent cameraIntent = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE); 
                startActivityForResult(cameraIntent, CAMERA_REQUEST); 
            }

         });

    }


     protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
          ImageHelper help= new ImageHelper(this);
            if (requestCode == CAMERA_REQUEST) {  
                Bitmap photo = (Bitmap) data.getExtras().get("data");   
                imageView.setImageBitmap(photo);  
                ByteArrayOutputStream out=new ByteArrayOutputStream();
                photo.compress(Bitmap.CompressFormat.PNG,100,out);
                byte ByteArr[]=out.toByteArray();
                help.insert(ByteArr);
            }
     }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

} 
数据库代码

public class ImageHelper extends SQLiteOpenHelper {


private static final String DATABASE_NAME="image";
private static final int DATABASE_VERSION=1;

public ImageHelper(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
    // TODO Auto-generated constructor stub
}

@Override
public void onCreate(SQLiteDatabase db) {
    // TODO Auto-generated method stub
    db.execSQL("CREATE TABLE Image(_id INTEGER PRIMARY KEY AUTOINCREMENT,imageblob BLOB);");
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // TODO Auto-generated method stub

}

public Cursor getAll() {                               
    return(getReadableDatabase().rawQuery("SELECT imageblob FROM Image",null));
}      

public void insert(byte Byte[]){
     ContentValues cv=new ContentValues();
     cv.put("imageblob",Byte);
    Log.e("inserted","inserted");
    getWritableDatabase().insert("image","imageblob",cv);

}


public byte[] getImage(Cursor c)
{
   return(c.getBlob(1));
}
}

使用LogCat会更容易说。。。错误是什么

这不是问题,但我建议您在sqlite数据库中将图像URI存储为字符串,而不是字节数组

要从字节数组获取URI,请执行以下操作:

        String path = Images.Media.insertImage(getContentResolver(), ImageInByte,
                "title", null);

        Uri imageUri = Uri.parse(path);

        String uriString = uriMyLogo.toString() ;
以及从URI获取图像

                Uri imageUri = Uri.parse(uriString);

                Bitmap image = null;
                try {
                    image = Media.getBitmap(this.getContentResolver(), imageUri );
                } catch (FileNotFoundException e) {
                    e.printStackTrace();
                } catch (IOException e) {
                    e.printStackTrace();
                }