我建议您放弃的方法,这将不适用于大量图像,并且您已经在线程上进行了大量工作来处理。永远不要在sqllite中存储像这样的图像。您只需要将位图转换为具有唯一名称或可以相同(取决于您的用例)的文件,然后就可以将该文件保存在app目录中,并将文件路径保存在数据库中。这里有一些代码可以帮助您。
File pictureFile = getOutputMediaFile(getActivity(), MEDIA_TYPE_IMAGE); if (pictureFile == null) { return; } Bitmap bitmap =BitmapFactory.depreByteArray(data,0,data.length); FileOutputStream fos = new FileOutputStream(pictureFile); bitmap.compress(Bitmap.CompressFormat.JPEG, 100, fos); fos.flush(); fos.close();私有文件getOutputMediaFile(Context context,int m){
File mediaStorageDir = context.getFilesDir(); if (!mediaStorageDir.exists()) { if (!mediaStorageDir.mkdirs()) { Log.d("Fade", "failed to create directory"); return null; } } // Create a media file name String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss") .format(new Date()); File mediaFile=new File(mediaStorageDir.getPath()+File.separator + "IMG_" + timeStamp + ".JPG"); return mediaFile;}现在您已经有了文件,现在您可以将文件路径存储在数据库中,并且在需要时始终可以使用glide从存储中获取文件。这也将使您的数据库快速查询。
这样,您就不需要在gradle或其他任何地方进行任何更改。试试这个。



