i m facing this error while saving image in sqlite database , image size is only 240KB i have gone through some solutions but could not solve this problem my code for saving and getting image in DB
public class MainActivity extends AppCompatActivity {
SQLiteDatabase db;
ImageView img,img_get;
Button btn_save,btn_get;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
img=(ImageView)findViewById(R.id.img_save);
img_get=(ImageView)findViewById(R.id.img_get);
btn_get=(Button)findViewById(R.id.btn_get);
btn_save=(Button)findViewById(R.id.btn_save);
db= openOrCreateDatabase("Mydb", MODE_PRIVATE, null);
db.execSQL("create table if not exists hello(name varchar, a blob)");
btn_save.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
saveimage(v);
}
});
btn_get.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
getimage(v);
}
});
}
public void saveimage(View view)
{
byte[] image=new byte[R.drawable.red];
ContentValues value=new ContentValues();
value.put("name","hatib abrar");
value.put("a",image);
db.insert("hello",null,value);
Toast.makeText(getApplicationContext(),"Saved",Toast.LENGTH_SHORT).show();
}
public void getimage(View view)
{
Cursor c=db.rawQuery("select * from hello",null);
if (c.moveToNext())
{
String name=c.getString(0);
byte[] image=c.getBlob(1);
Bitmap bm= BitmapFactory.decodeByteArray(image,0,image.length);
img_get.setImageBitmap(bm);
Toast.makeText(getApplicationContext(),"Error getting image",Toast.LENGTH_SHORT).show();
}
}
LogCat is showing this error Throwing
OutOfMemoryError "Failed to allocate a 2130837597 byte allocation with 16777216 free bytes and 151MB until OOM" 09-07 09:49:59.651 21823-21823/com.example.e6530.imagesaving D/AndroidRuntime: Shutting down VM 09-07 09:49:59.651 21823-21823/com.example.e6530.imagesaving E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.e6530.imagesaving, PID: 21823 java.lang.OutOfMemoryError: Failed to allocate a 2130837597 byte allocation with 16777216 free bytes and 151MB until OOM at com.example.e6530.imagesaving.MainActivity.saveimage(MainActivity.java:51) at com.example.e6530.imagesaving.MainActivity$1.onClick(MainActivity.java:36) at android.view.View.performClick(View.java:4793) at android.view.View$PerformClick.run(View.java:19971) at android.os.Handler.handleCallback(Handler.java:739) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:135) at android.app.ActivityThread.main(ActivityThread.java:5669) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:960) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)