簡體   English   中英

如何將圖像 Uri 或位圖傳遞給 SQLite 數據庫的 int 參數以保存圖像?

[英]how to pass an image Uri or alternatively a bitmap to int parameter of SQLite database to save an image?

我正在從圖庫中拍照並想將其保存到我的 SQLite 數據庫中。 我創建了一個方法insertData(int Image, String Name)在我SQ_Lite_DB它擴展了SQLiteOpenHelper類。

插入數據方法

public boolean insertData(int Image, String Name){
    SQLiteDatabase database = getReadableDatabase();
    ContentValues values = new ContentValues();
    values.put("image",Image);
    values.put("name",Name);

   long id =  database.insert("orders",null,values);
    database.close();
    return id > 0;
}

我在sq-lite class onActivityResult方法中調用此方法

SQLite 類

public class SQLite extends AppCompatActivity {

RecyclerView recyclerView;
Button insertdatabtn;
EditText edittext;


@Override
protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_sqlite);

    insertdatabtn = findViewById(R.id.insertdatabtn);

    new SQ_Lite_DB(SQLite.this).ReadSqliteData(SQLite.this);

    ArrayList<Model> list = new ArrayList<>();
    Adpter adpter = new Adpter(list,SQLite.this);
    recyclerView = findViewById(R.id.recyclerview);

    recyclerView.setAdapter(adpter);
    recyclerView.setLayoutManager(new LinearLayoutManager(this));


    insertdatabtn.setOnClickListener(v->{
        Intent intent = new Intent();
        intent.setAction(Intent.ACTION_GET_CONTENT);
        intent.setType("image/*");
        startActivityForResult(intent,11);});
}

@Override
protected void onActivityResult(int requestCode, int resultCode,Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    edittext = findViewById(R.id.edittext);

    SQ_Lite_DB db = new SQ_Lite_DB(SQLite.this);

    if (resultCode==RESULT_OK&& requestCode==11){

        try {InputStream inputStream = getContentResolver().openInputStream(data.getData());
            Bitmap bitmap = BitmapFactory.decodeStream(inputStream);
            ByteArrayOutputStream baos = new ByteArrayOutputStream();
            bitmap.compress(Bitmap.CompressFormat.PNG,100,baos);

            byte[] img = baos.toByteArray();

           database.inserdata(/*what to put here, a int value needed but I can get uri or bitmap only*/,editText.getText.toString)
        } catch (FileNotFoundException e) {
            e.printStackTrace();
            Toast.makeText(this, e.getMessage(), Toast.LENGTH_SHORT).show();
            Log.d("tag",e.getMessage());
        }
    }
}
}

嘗試使用以下代碼,您可以在表中為 imageUri 再添加一列並保存 imagepath。

button.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Intent photoPickerIntent = new Intent(Intent.ACTION_PICK);
            photoPickerIntent.setType("image/*");
            startActivityForResult(photoPickerIntent, 100);
        }
    });


 //The onActivityResult method will invoke after select image from gallery
 @Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent imageReturnedIntent) {
    super.onActivityResult(requestCode, resultCode, imageReturnedIntent);

    switch (requestCode){
        case 100:
            if(resultCode == RESULT_OK){
                try {
                    final Uri imageUri = imageReturnedIntent.getData();
                   String  imageUri = imageUri.toString();
                } catch (FileNotFoundException e){
                    e.printStackTrace();
                }
            }
     }
  }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM