从Android相册和相机中获取图片并将其存储在SQLite数据库中。

7

我有一个应用程序,用户可以通过点击ImageView并设置图像或通过从相机拍摄新照片来添加图像。我想将设置的图像存储到SQLite数据库中。

**AddkeyEventdetail.java**



  package com.example.kidsfinal;

    import java.util.Calendar;

    import android.app.DatePickerDialog;
    import android.app.Dialog;
    import android.content.Intent;
    import android.database.Cursor;
    import android.graphics.Bitmap;
    import android.graphics.BitmapFactory;
    import android.net.Uri;
    import android.os.Bundle;
    import android.provider.MediaStore;
    import android.support.v4.app.DialogFragment;
    import android.util.Log;
    import android.view.View;
    import android.widget.Button;
    import android.widget.DatePicker;
    import android.widget.EditText;
    import android.widget.ImageView;
    import android.widget.Spinner;
    import android.widget.TextView;

    import com.example.slidingmenuexample.R;

    public class AddChildHoodEventActivity extends SmartActivity {

        ImageView ivChildPics;
        EditText edtEventDate, edtEventDetails;
        Button btnEventDetailSubmit, btnopenCamera;
        Spinner spinnerSelectChild;
        Bitmap bmp;

        Calendar calendar = Calendar.getInstance();
        int mDay = calendar.get(Calendar.DAY_OF_MONTH), mMonth = calendar
                .get(Calendar.MONTH), mYear = calendar.get(Calendar.YEAR) - 1;

        @Override
        public void onCreate(Bundle arg0) {
            // TODO Auto-generated method stub
            super.onCreate(arg0);
            setContentView(R.layout.addchildhoodevents);
            createDrawer();
            initComponent();
            prepareView();
            setOnListener();
        }

        private void initComponent() {
            // TODO Auto-generated method stub
            ivChildPics = (ImageView) findViewById(R.id.kids_addkeyevent_imageview_childpics);
            edtEventDate = (EditText) findViewById(R.id.kids_addkeyevent_edt_addkeyevent);
            edtEventDetails = (EditText) findViewById(R.id.kids_addkeyevent_edt_eventdetails);
            btnEventDetailSubmit = (Button) findViewById(R.id.kids_addkeyevent_btn_submit);
            btnopenCamera = (Button) findViewById(R.id.kids_addkeyevent_btn_opencamera);
        }

        private void prepareView() {

        }

        private void setOnListener() {

            ivChildPics.setOnClickListener(new View.OnClickListener() {

                @Override
                public void onClick(View v) {

                    openGallery();

                }

                private void openGallery() {
                    Intent opengallery = new Intent(Intent.ACTION_GET_CONTENT);
                    opengallery.setType("Image/");
                    startActivityForResult(opengallery, 1);
                }
            });

            btnopenCamera.setOnClickListener(new View.OnClickListener() {

                @Override
                public void onClick(View v) {
                    OpenCamera();
                }

                private void OpenCamera() {
                    Intent openCam = new Intent(
                            "android.media.action.IMAGE_CAPTURE");
                    startActivityForResult(openCam, 0);

                }
            });



        @Override
        protected void onActivityResult(int requestCode, int resultCode, Intent data) {
            super.onActivityResult(requestCode, resultCode, data);
            if (requestCode == 0 && resultCode == RESULT_OK) {
                if (data != null) {

                    bmp = (Bitmap) data.getExtras().get("data");

                    ivChildPics.setImageBitmap(bmp); /*
                                                     * this is image view where you
                                                     * want to set image
                                                     */

                    Log.d("camera ---- > ", "" + data.getExtras().get("data"));

                }
            }

            else {
                Uri selectedImage = data.getData();

                String[] filePathColumn = { MediaStore.Images.Media.DATA };
                Cursor cursor = getContentResolver().query(selectedImage,
                        filePathColumn, null, null, null);
                cursor.moveToFirst();
                int columnIndex = cursor.getColumnIndex(filePathColumn[0]);
                String filePath = cursor.getString(columnIndex);
                cursor.close();

                if (bmp != null && !bmp.isRecycled()) {
                    bmp = null;
                }

                bmp = BitmapFactory.decodeFile(filePath);
                ivChildPics.setBackgroundResource(0);
                ivChildPics.setImageBitmap(bmp);
            }

        }

    }

database.java

公共void insertAddKeyEvent(byte[] childpic,String eventDate,String eventDetails)


此方法用于将子图像、事件日期和事件详细信息插入到数据库中。
{
    ContentValues addkeyValues=new ContentValues();
    addkeyValues.put("CHILDPICS",childpic);
    addkeyValues.put("EVENTDATE", eventDate);
    addkeyValues.put("EVENTDETAILS", eventDetails);

    parentmaster.insert("ADDKEYEVENT",null,addkeyValues);



}

在SQLite中将图像设置为BLOB还是只链接到存储中的图像? - Suvitruf - Andrei Apanasik
我正在寻找代码,但是我已经搜索了很多代码,但是没有找到,所以请问您能否给我一些建议? - user5111
我已经编写了数据库的代码,还有打开相机和打开图库的代码。 - user5111
我已经分享了我的代码,请给我提建议。 - user5111
1个回答

3

按照以下方式将您的Bitmap转换为byte[]

ByteArrayOutputStream baos = new ByteArrayOutputStream();
bitmap.compress(CompressFormat.JPEG, 100, baos);
byte[] imageData = baos.toByteArray();

byte[] 添加到数据库中的 BLOB 字段。


ivChildPics.setImageBitmap(bmp); 之后。 - Apoorv
对于画廊,我应该做同样的事情吗? - user5111
如果您可以在您的“ImageView”中看到图像,则返回已翻译的文本:“是”。 - Apoorv
图片将以什么形式存储在数据库中?它会是图片路径吗? - user5111
不,如果您想要检索它,它将被存储为“BLOB”,您需要以“byte []”的形式获取它。 - Apoorv

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接