您好我已创建此方法以执行以下操作:
-it采用位图
- 创建临时文件
- 压缩位图并将其放入临时文件
-open temp file
-read bytes>>>问题在我的代码中
- 在sqlite db中保存这些字节
-restrieve来自sqlite db的字节
- 将这些字节再次设置为图像位图
我知道我知道完全没用,但这是我发现做我想要达到的目标的唯一方法:
- 压缩位图
- 保存到sqlite数据库
所以这是代码。程序只是在in.read(bb)崩溃了:
private void updateBitmapData() {
File file = null;
FileOutputStream stream = null;
try {
file = File.createTempFile("image", null, getBaseContext().getFilesDir());
stream = new FileOutputStream(file);
System.out.println(thumbnail.getRowBytes());
thumbnail.compress(Bitmap.CompressFormat.JPEG, 50, stream);
stream.close();
FileInputStream in=new FileInputStream(file);
byte[] bb = null;
in.read(bb); //crash
in.close();
System.out.println("despues compression"+bb.length);
DBAdapter db=new DBAdapter(getApplicationContext());
db.insertData(bb);
Cursor c=db.getLastImage();
if(c.moveToFirst()){
bb=c.getBlob(0);
}
c.close();
db.close();
im.setImageBitmap(BitmapFactory.decodeByteArray(bb, 0, bb.length));
} catch (FileNotFoundException e) {
e.printStackTrace();
Log.e("NuevaIncidencia", e.getLocalizedMessage());
im.setImageBitmap(thumbnail);
}catch (IOException e1) {
Log.e("NuevaIncidencia", e1.getLocalizedMessage());
e1.printStackTrace();
im.setImageBitmap(thumbnail);
} catch (Exception e2){
e2.printStackTrace();
//Log.e("NuevaIncidencia", e2.getLocalizedMessage());
}
}
我怎么能解决这个问题?感谢
答案 0 :(得分:1)
我猜你有一个NullPointerException,它看起来很正常,因为你调用read时你的缓冲区是null。
您必须使用预期大小实例化缓冲区。
尝试以这种方式初始化字节数组:
byte[] bb = new byte[file.length()];
希望有所帮助
Jokahero