sqlite 从应用程序到相机拍摄照片并存储在数据库中的列中

ux6nzvsh  于 2023-04-21  发布在  SQLite
关注(0)|答案(3)|浏览(270)

我有一个要求,我想从我的应用程序到相机,然后照片应该存储在数据库中,然后从数据库中,我想显示列数据与其他数据的列表视图内。我有一个关于列表视图的想法,使用图像视图等...我只是不知道从哪里开始关于访问相机和存储到数据库中的一列??任何提示,甚至一个教程,我可以看看这将是有帮助的?

public class CameraAPI extends Activity implements SurfaceHolder.Callback{

public Camera camera;
MediaRecorder mediaRecorder;


public void onCreate (Bundle savedInstanceState){

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

    SurfaceView surface = (SurfaceView)findViewById(R.id.acccam);
    SurfaceHolder holder = surface.getHolder();
    holder.addCallback(this);
    holder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
}

        public void tackPhoto(View view){
            takePicture();

    }



public void surfaceChanged(SurfaceHolder holder, int format, int width,
        int height) {
    // TODO Auto-generated method stub

}


public void surfaceCreated(SurfaceHolder holder) {
    // TODO Auto-generated method stub
    if (mediaRecorder == null){
        try{
            camera = camera.open();
            camera.setPreviewDisplay(holder);
            camera.startPreview();

        }catch (IOException e){
            Log.d("CAMERA", e.getMessage());
        }

    }
}


public void surfaceDestroyed(SurfaceHolder holder) {
    // TODO Auto-generated method stub
    camera.stopPreview();
    camera.release();
}

public void takePicture(){
    camera.takePicture(shutterCallback, rawCallback, jpegCallback);

}

ShutterCallback shutterCallback= new ShutterCallback()
{
    public void onShutter(){

    }
};

    PictureCallback rawCallback = new PictureCallback(){
        public void onPictureTaken(byte[] data, Camera camera){

        }
    };

    PictureCallback jpegCallback = new PictureCallback(){
        public void onPictureTaken(byte[] data, Camera camera){
            FileOutputStream outStream = null;
            try{
                outStream = new FileOutputStream("/sdcard/Image.jpg");
                outStream.write(data);
                outStream.close();
            } catch (FileNotFoundException e){
                Log.d("CAMERA", e.getMessage());
            } catch (IOException e){
                Log.d("CAMERA", e.getMessage());
            }
        }
};
}

这是我的相机API代码...有没有任何调整,然后添加到数据库,而不是到SD卡?
谢谢
斯特凡

bqujaahr

bqujaahr1#

1.首先将拍摄的照片保存在设备的缓存内存中,将此保存的图像转换为ByteArray并将其保存在数据库中。在后台线程中执行此操作,以便UI线程不受干扰。一旦您的图像保存在数据库中,请不要忘记从缓存中删除该图像。
1.或者尝试直接将此传递的字节数组保存到数据库中
values.put(MyBaseColumn.MyTable.ImageColumn,data);
并将此数据插入数据库。
希望这能起作用。
通过link,这将有助于将图像保存在数据库中

ercv8c1e

ercv8c1e2#

开始here以参考如何使用相机,然后阅读此页面以了解如何使用SQLite数据库。

pbgvytdp

pbgvytdp3#

浏览下面的链接。这是一个从应用程序捕获图像的好例子:Capture image from your app using camera
一旦你有了捕获图像的路径,你就可以将其保存在数据库中。

相关问题