android从电话相册中获取图片并将其存储在sqlite数据库中

时间:2020-08-02 20:27:14

标签: java android android-sqlite

我正在开发一个应用程序,用户可以从手机的相册中选择图像并将其存储在sqlite数据库中的表中,我在这里看到过很多有关此问题的帖子,但无法理解解决方案(它们都没有用对我来说),在我的活动中,我有一个imageview,单击该图标将打开相册并允许用户选择图像,还有一个按钮,单击该按钮会将图像存储在sqlite数据库中,我可以选择图片,但是之后我被卡住了,我在我的代码中找到了这个方法:

public void getImage(View view) throws IOException {
        ImageView v=(ImageView)view;
        Intent photoPickerIntent = new Intent(Intent.ACTION_PICK);
        photoPickerIntent.setType("image/*");
        startActivityForResult(photoPickerIntent,1);
    }


    public void onActivityResult(int reqCode, int resultCode, Intent data) {
        super.onActivityResult(reqCode, resultCode, data);
        if (resultCode == RESULT_OK) {
            try {
                final Uri imageUri = data.getData();
                final InputStream imageStream = getContext().getContentResolver().openInputStream(imageUri);
                final Bitmap selectedImage = BitmapFactory.decodeStream(imageStream);
                image.setImageBitmap(selectedImage);
            } catch (FileNotFoundException e) {
                e.printStackTrace();

            }
        }
    }

现在我该怎么办才能将图像存储在数据库中?

1 个答案:

答案 0 :(得分:1)

如果您确定图像不会从内部存储中删除,则可以保存图像路径。如果要保存图像数据,可以执行以下操作。

用于选择图像

private void selectImage() {
     Intent intent = new Intent();
     intent.setType("image/*");
     intent.setAction(Intent.ACTION_GET_CONTENT);
     startActivityForResult(intent, IMAGE_REQ);
}

在onActivityResult中,来自Intent数据...

public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        if (requestCode == IMAGE_REQ && resultCode == Activity.RESULT_OK && data != null) {
            Uri path = data.getData();
            try {
                bitmap = MediaStore.Images.Media.getBitmap(getContext().getContentResolver(), path);
                Bitmap.createScaledBitmap(bitmap, 150, 150, true);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

从位图获取字节[]

public static byte[] getByteArrayFromBitmap(Bitmap bitmap) {
        if(bitmap == null) return null;

        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
        bitmap.compress(Bitmap.CompressFormat.JPEG, 50, byteArrayOutputStream);

        return byteArrayOutputStream.toByteArray();
    }

然后将字节[]保存为sqlite中的blob

用于将图像获取为位图

public static Bitmap getBitmapFromByteArray(byte[] blob){
        if(blob == null) return null;

        Bitmap bitmap = BitmapFactory.decodeByteArray(blob, 0, blob.length);
        return bitmap;
    }