将图片保存在某个存储位置,并将其路径存储到SQLite数据库表中

时间:2019-03-21 08:51:32

标签: android sqlite android-sqlite java-io android-image

我正在使用SQLite开发应用程序,并且希望能够为用户选择个人资料图片(将保存在本地)。基本上,我有一个裁剪活动,我想选择一张图片,裁剪并压缩它,然后将其保存在手机中的某个存储路径中,该路径不会通过清理缓存而删除,并且在手机图库(重要)。同时,我希望将新路径保存在我的SQLite数据库中,以便可以在需要时将其快速加载到ImageView中。

这是我在测试ImageView中加载,裁剪,压缩和预览图片的代码。

public void chooseProfilePicture(){
        CropImage.activity().setGuidelines(CropImageView.Guidelines.ON).setAspectRatio(1,1).start(this);
    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        if(requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE)
        {
            CropImage.ActivityResult result = CropImage.getActivityResult(data);
            if(resultCode == RESULT_OK)
            {
                assert result != null;
                profileImageURI = result.getUri();
                File thumbnailURI = new File(Objects.requireNonNull(profileImageURI.getPath()));
                try
                {
                    compressedImageFile = new Compressor(activity_user_data.this)
                            .setMaxHeight(400)
                            .setMaxWidth(400)
                            .setQuality(90)
                            .compressToBitmap(thumbnailURI);
                }
                catch (IOException e)
                {
                    e.printStackTrace();
                }
                ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
                compressedImageFile.compress(Bitmap.CompressFormat.JPEG, 90, byteArrayOutputStream);
                profilePicker.setImageBitmap(compressedImageFile);
                isImageSelected = true;
            }
            else
                if(resultCode == CropImage.CROP_IMAGE_ACTIVITY_RESULT_ERROR_CODE)
                {
                    assert result != null;
                    Exception error = result.getError();
                }
            }
        }

0 个答案:

没有答案