Android开发:调用camera API 创建MediaRecorder
本文出自 “whithin's” 博客,请务必保留此出处http://whithin.blog.51cto.com/690417/1063573
1. add below three permission into AndroidManifest.xml file
<uses-permissionandroid:name= "android.permission.CAMERA"/>
<uses-permissionandroid:name= "android.permission.RECORD_AUDIO"/>
<uses-permissionandroid:name= "android.permission.WRITE_EXTERNAL_STORAGE"/>
2. get a camera instance
/** A safe way to get an instance of the Camera object. */
publicstatic Camera getCameraInstance(){
Camera c = null;
try {
c = Camera. open(); // attempt to get a Camera instance
}
catch (Exception e){
// Camera is not available (in use or does not exist)
}
return c; // returns null if camera is unavailable
}
publicclass CameraPreview extends SurfaceView implements SurfaceHolder.Callback {
private SurfaceHolder mHolder;
private Camera mCamera;
String TAG="CAMERAAPI";
public CameraPreview(Context context, Camera camera) {
super(context);
mCamera = camera;
// Install a SurfaceHolder.Callback so we get notified when the
// underlying surface is created and destroyed.
mHolder = getHolder();
mHolder.addCallback( this);
// deprecated setting, but required on Android versions prior to 3.0
mHolder. setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
}
publicvoid surfaceCreated(SurfaceHolder holder) {
// The Surface has been created, now tell the camera where to draw the preview.
try {
mCamera.setPreviewDisplay(holder);
mCamera.startPreview();
} catch (IOException e) {
Log. d(TAG, "Error setting camera preview: " + e.getMessage());
}
}
publicvoid surfaceDestroyed(SurfaceHolder holder) {
// empty. Take care of releasing the Camera preview in your activity.
}
publicvoid surfaceChanged(SurfaceHolder holder, int format, int w, int h) {
// If your preview can change or rotate, take care of those events here.
// Make sure to stop the preview before resizing or reformatting it.
if (mHolder .getSurface() == null){
// preview surface does not exist
return;
}
// stop preview before making changes
try {
mCamera.stopPreview();
} catch (Exception e){
// ignore: tried to stop a non-existent preview
}
// set preview size and make any resize, rotate or
// reformatting changes here
// start preview with new settings
try {
mCamera.setPreviewDisplay( mHolder);
mCamera.startPreview();
} catch (Exception e){
Log. d(TAG, "Error starting camera preview: " + e.getMessage());
}
}
}
privateboolean prepareVideoRecorder(){
mCamera = getCameraInstance();
mMediaRecorder = new MediaRecorder();
// Step 1: Unlock and set camera to MediaRecorder
mCamera.unlock();
mMediaRecorder.setCamera(mCamera );
// Step 2: Set sources
mMediaRecorder.setAudioSource(MediaRecorder.AudioSource.CAMCORDER);
mMediaRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
// Step 3: Set a CamcorderProfile (requires API Level 8 or higher)
mMediaRecorder.setProfile(CamcorderProfile.get(CamcorderProfile. QUALITY_HIGH));
// Step 4: Set output file
mMediaRecorder.setOutputFile(getOutputMediaFile( MEDIA_TYPE_VIDEO).toString());
// Step 5: Set the preview output
mMediaRecorder.setPreviewDisplay(mPreview .getHolder().getSurface());
// Step 6: Prepare configured MediaRecorder
try {
mMediaRecorder.prepare();
} catch (IllegalStateException e) {
Log. d(TAG, "IllegalStateException preparing MediaRecorder: " + e.getMessage());
releaseMediaRecorder();
returnfalse ;
} catch (IOException e) {
Log. d(TAG, "IOException preparing MediaRecorder: " + e.getMessage());
releaseMediaRecorder();
returnfalse ;
}
returntrue ;
}
publicclass MediaRecorderActivity extends Activity {
publicstaticfinalint MEDIA_TYPE_IMAGE = 1;
publicstaticfinalint MEDIA_TYPE_VIDEO = 2;
private Camera mCamera;
private CameraPreview mPreview;
private MediaRecorder mMediaRecorder;
String TAG="CAMERAAPI";
boolean isRecording=false ;
@Override
publicvoid onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout. main);
mCamera = getCameraInstance();
// // Create our Preview view and set it as the content of our activity.
mPreview = new CameraPreview(this, mCamera);
FrameLayout preview = (FrameLayout) findViewById(R.id. camera_preview);
preview.addView( mPreview);
Button captureButton = (Button) findViewById(id. button_capture);
captureButton.setOnClickListener( new CaptureButtonOnClickListener());
}
publicclass CaptureButtonOnClickListener implements View.OnClickListener{
publicvoid onClick(View v) {
Button captureButton = (Button)v;
if (isRecording ) {
// stop recording and release camera
mMediaRecorder.stop(); // stop the recording
releaseMediaRecorder(); // release the MediaRecorder object
mCamera.lock(); // take camera access back from MediaRecorder
// inform the user that recording has stopped
captureButton.setText( "Capture");
isRecording = false ;
} else {
try{
// initialize video camera
if (prepareVideoRecorder()) {
// Camera is available and unlocked, MediaRecorder is prepared,
// now you can start recording
mMediaRecorder.start();
// inform the user that recording has started
captureButton.setText( "Stop");
isRecording = true ;
} else {
// prepare didn't work, release the camera
releaseMediaRecorder();
// inform user
}
} catch(Exception ex){
System. out.println(ex.toString());
ex.printStackTrace();
}
}
}
}
/** A safe way to get an instance of the Camera object. */
publicstatic Camera getCameraInstance(){
Camera c = null;
try {
c = Camera. open(); // attempt to get a Camera instance
}
catch (Exception e){
// Camera is not available (in use or does not exist)
}
return c; // returns null if camera is unavailable
}
/** Create a File for saving an p_w_picpath or video */
privatestatic File getOutputMediaFile(int type){
// To be safe, you should check that the SDCard is mounted
// using Environment.getExternalStorageState() before doing this.
File mediaStorageDir = new File(Environment.getExternalStoragePublicDirectory(
Environment. DIRECTORY_PICTURES), "MyCameraApp" );
// This location works best if you want the created p_w_picpaths to be shared
// between applications and persist after your app has been uninstalled.
// Create the storage directory if it does not exist
if (! mediaStorageDir.exists()){
if (! mediaStorageDir.mkdirs()){
Log. d("MyCameraApp", "failed to create directory");
returnnull ;
}
}
// Create a media file name
String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss" ).format(new Date());
File mediaFile;
if (type == MEDIA_TYPE_IMAGE){
mediaFile = new File(mediaStorageDir.getPath() + File.separator +
"IMG_"+ timeStamp + ".jpg" );
} elseif (type == MEDIA_TYPE_VIDEO) {
mediaFile = new File(mediaStorageDir.getPath() + File.separator +
"VID_"+ timeStamp + ".mp4" );
} else {
returnnull ;
}
return mediaFile;
}
@Override
protectedvoid onPause() {
super.onPause();
releaseMediaRecorder(); // if you are using MediaRecorder, release it first
releaseCamera(); // release the camera immediately on pause event
}
privatevoid releaseCamera(){
if (mCamera != null){
mCamera.release(); // release the camera for other applications
mCamera = null;
}
}
privatevoid releaseMediaRecorder(){
if (mMediaRecorder != null) {
mMediaRecorder.reset(); // clear recorder configuration
mMediaRecorder.release(); // release the recorder object
mMediaRecorder = null ;
mCamera.lock(); // lock camera for later use
}
}
}
本文出自 “whithin's” 博客,请务必保留此出处http://whithin.blog.51cto.com/690417/1063573
转载于:https://blog.51cto.com/yuzuolin/1330360
Android开发:调用camera API 创建MediaRecorder相关推荐
- Android开发规范:API接口安全设计规范
公众号[国民程序员]回馈粉丝福利: 现金红包和送书活动火热进行中,点击参与! 我的新书<Android App开发入门与实战>已于2020年8月由人民邮电出版社出版,欢迎购买. 书籍详情请 ...
- Android开发 调用系统相机相册图片功能,解决小米手机拍照或者图片横竖相反问题,及小米手机相册图片路径问题
Android开发 调用系统相机相册图片功能,解决小米手机拍照或者图片横竖相反问题,及小米手机相册图片路径问题 1.调用相机,兼容7.0 AndroidManifest配置 <providera ...
- 调用Camera API实现自己的拍照和摄像程序
参考博客: http://www.cnblogs.com/franksunny/archive/2011/11/17/2252926.html 根据Camera API实现自己的拍照和摄像程序 通过上 ...
- Android 开发多摄像头 API
这篇博客是对我们的 Android 开发者峰会 2018 演讲 的补充,是与来自合作伙伴开发者团队中的 Vinit Modi.Android Camera PM 和 Emilie Roberts 合作 ...
- Android开发--调用系统邮件
Android系统的开源性使其在当前智能手机市场占据绝对优势,同时也产生了各种各样的机型和系统.这使得我们Android开发人员需要根据不同的机型和系统去做对应的适配. 正文 本篇所述需求为调用本地邮 ...
- Android开发之高德API篇:2、高德API线路规划
TIME:2020年7月6日 2.高德API线路规划----步行线路规划 前言: step1 工程配置 step2 整体实现过程 step3 具体实现过程 总结 附上源码 前言: 该篇博客主要是介绍高 ...
- Android之调用第三方API导航(高德,百度,google)
一:效果图(点击路线调用API) 二:实现步骤: 1.判断是否安装各个地图软件 /*** 判断是否安装目标应用** @param packageName 目标应用安装后的包名* @return 是否已 ...
- Android开发技巧——Camera拍照功能
本篇是我对开发项目的拍照功能过程中,对Camera拍照使用的总结.由于camera2是在api level 21(5.0.1)才引入的,而Camera到6.0仍可使用,所以暂未考虑camera2. 文 ...
- Android编译调用FFmpeg API,自己写方法,编译so库
作者:谭东 时间:2017年9月19日 环境:Windows 8.1专业版 NDK版本:android-ndk-r14b FFmpeg版本:FFmpeg 3.0.2 "Einstein&qu ...
最新文章
- ToDictionary的用法
- 面向对象的 JavaScript 编程及其 Scope 处理
- java 日期的加减_用java实现日期类的加减
- 一个方框,文字在边框上
- CowNew开源-sql解析引擎和cownewsql阶段成果汇报
- 在GWT中序列化/反序列化Json
- 玩转Jquery中的动画效果(animate方法)
- eureka-7-多网卡下的ip选择
- 细粒度图像分类_1.1、 图片分类
- android 会话 java_java – Android会话管理
- 几何常用算法与判断线段相交【转】
- 什么是 Service Mesh?
- ubuntu命令行语法_Linux中重定向命令行的总结(ubuntu学习第三讲)
- Modules Of YoloV5 Architecture
- Android界面绘制流程--------How Android Draws Views
- java实践_java基础实践
- 系统学习深度学习(三十)--BiLSTM
- 学生信息的顺序表存储
- Sql server 双机热备份数据库
- 网络棋牌游戏成为网游主流力量