2016-04-22 6 views
1

Я пытаюсь создать приложение, в котором пользователь загружает изображение, и он сохраняется в базе данных SQLite. Пока мне удалось загрузить изображение в приложение во время выполнения учебника, однако я не уверен, что делать, чтобы сохранить его в SQLite, чтобы при закрытии и открытии операции изображение осталось там.Как загрузить изображение в базу данных SQLite?

Мой код:

public class Getimg2 extends Activity implements View.OnClickListener{ 



    private static final int RESULT_LOAD_IMAGE =1; 
    ImageView ImageUp; 
    Button BtnUp; 
    Button Confirm; 
    SQLiteDatabase db; 

    @Override 
     protected void onCreate(Bundle savedInstanceState) {        
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.diary_edit); 


     ImageUp = (ImageView) findViewById (R.id.imageUp); 
    BtnUp = (Button) findViewById (R.id.btnUp); 
    Confirm =(Button) findViewById (R.id.confirm) ; 

     ImageUp.setOnClickListener(this); 
     BtnUp.setOnClickListener(this); 
     Confirm.setOnClickListener(this); 
    } 

    @Override 
      public void onClick(View v){   

     switch(v.getId()) { 

     case R.id.imageUp:      

       Intent galleryIntent = new Intent (Intent.ACTION_PICK,MediaStore.Images.Media.EXTERNAL_CONTENT_URI); 
       startActivityForResult(galleryIntent,RESULT_LOAD_IMAGE); 

      break; 

      case R.id.btnUp: 

       Bitmap image =((BitmapDrawable)ImageUp.getDrawable()).getBitmap(); 

       break; 

      case R.id.confirm: 

       //save image to sql? 

       Cursor c =dba.rawQuery("select * from tb", null); 
    if (c.moveToNext()) 

       break; 
      } 


      } 
    @Override 
      protected void onActivityResult(int requestCode , int resultCode, Intent data){ 
       super.onActivityResult(requestCode, resultCode, data); 
       if (requestCode == RESULT_LOAD_IMAGE && resultCode == RESULT_OK && data !=null){ 
        Uri selectedImage =data.getData(); 
        ImageUp.setImageURI(selectedImage); 

       } 

      } 

      private class UploadImage extends AsyncTask<Void,Void ,Void >{  

       Bitmap image; 
       String name; 


       public UploadImage(Bitmap image,String name){     

        this.image = image; 
        this.name = name; 

       } 

      @Override 
       protected Void doInBackground(Void... params) {    
        // TODO Auto-generated method stub 

        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); 
        image.compress(Bitmap.CompressFormat.JPEG, 100, byteArrayOutputStream); 
        String encodedImage = Base64.encodeToString(byteArrayOutputStream.toByteArray(),Base64.DEFAULT); 
    }}} 

ответ

2

Сохранение таких больших элементов в базе данных не правильный подход. Сохраните файл в частной файловой системе приложения, а затем сохраните путь к файлу в базе данных.