从应用程序转到相机拍照并存储在数据库的列中
Posted
技术标签:
【中文标题】从应用程序转到相机拍照并存储在数据库的列中【英文标题】:Go from application to camera take photo and store in a column in database 【发布时间】:2012-01-17 10:51:30 【问题描述】:我有一个要求,我想从我的应用程序转到相机,然后拍摄的照片应该存储在数据库中,然后我想从数据库中显示列表视图中的列数据和其他数据。我对列表视图有一个想法,使用图像视图等......我只是不知道从哪里开始访问相机并将其存储到数据库中的列?有什么技巧,甚至是我可以查看的教程,这会有所帮助吗?
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 卡?
谢谢,
斯蒂芬
【问题讨论】:
【参考方案1】:开始here 以了解如何使用相机,然后阅读this page 以了解如何使用SQLite
数据库。
【讨论】:
【参考方案2】:通过以下链接。它是从您的应用程序中捕获图像的一个很好的例子: Capture image from your app using camera
一旦你有了捕获图像的路径,你就可以将它保存在你的数据库中。
【讨论】:
嗯,好吧,我创建了我自己的 API.. 使用相机.. 我意识到这是将图像保存到 sd 卡.. 所以有没有办法可以稍微调整一下以添加图像改为数据库?【参考方案3】:首先将拍摄的图片保存在设备的缓存中,将此保存的图像转换为 ByteArray 并将其保存在数据库中。在后台线程中执行此操作,以免干扰 UI 线程。 图像保存到数据库后,不要忘记从缓存中删除该图像。
或者尝试直接将这个传递的字节数组保存到你的数据库中
values.put(MyBaseColumn.MyTable.ImageColumn, data);
并将这些数据插入到您的数据库中。
希望这会奏效。
通过link 这将有助于将图像保存在数据库中
【讨论】:
以上是关于从应用程序转到相机拍照并存储在数据库的列中的主要内容,如果未能解决你的问题,请参考以下文章
Winforms C#:从远程计算机文件夹获取图像并加载到 DataTable 的列中