我的Android进阶之旅------>Android视频录制小例子
============================首先看看官网上关于视频捕捉的介绍================================
Capturing videos
Video capture using the Android framework requires careful management of the Camera object
and coordination with the MediaRecorder class.
When recording video with Camera,
you must manage the Camera.lock() andCamera.unlock() calls
to allow MediaRecorder access
to the camera hardware, in addition to the Camera.open()and Camera.release() calls.
Note: Starting with Android 4.0 (API level 14), the Camera.lock() and Camera.unlock() calls
are managed for you automatically.
Unlike taking pictures with a device camera, capturing video requires a very particular call order. You must follow a specific order of execution to successfully prepare for and capture video with your application, as detailed below.
- Open Camera - Use the
Camera.open()to
get an instance of the camera object. - Connect Preview - Prepare a live camera image preview by connecting a
SurfaceViewto
the camera usingCamera.setPreviewDisplay(). - Start Preview - Call
Camera.startPreview()to
begin displaying the live camera images. - Start Recording Video - The following steps must be completed in order to successfully record video:
- Unlock the Camera - Unlock the camera for use by
MediaRecorderby
callingCamera.unlock(). - Configure MediaRecorder - Call in the following
MediaRecordermethods in
this order. For more information, see theMediaRecorderreference
documentation.setCamera()-
Set the camera to be used for video capture, use your application's current instance ofCamera.setAudioSource()-
Set the audio source, useMediaRecorder.AudioSource.CAMCORDER.setVideoSource()-
Set the video source, useMediaRecorder.VideoSource.CAMERA.- Set the video output format and encoding. For Android 2.2 (API Level 8) and higher, use the
MediaRecorder.setProfilemethod,
and get a profile instance usingCamcorderProfile.get().
For versions of Android prior to 2.2, you must set the video output format and encoding parameters:setOutputFormat()-
Set the output format, specify the default setting orMediaRecorder.OutputFormat.MPEG_4.setAudioEncoder()-
Set the sound encoding type, specify the default setting orMediaRecorder.AudioEncoder.AMR_NB.setVideoEncoder()-
Set the video encoding type, specify the default setting orMediaRecorder.VideoEncoder.MPEG_4_SP.
setOutputFile()-
Set the output file, usegetOutputMediaFile(MEDIA_TYPE_VIDEO).toString()from the example method in the Saving
Media Files section.setPreviewDisplay()-
Specify theSurfaceViewpreview
layout element for your application. Use the same object you specified for Connect Preview.
Caution: You must call these
MediaRecorderconfiguration
methods in this order, otherwise your application will encounter errors and the recording will fail. - Prepare MediaRecorder - Prepare the
MediaRecorderwith
provided configuration settings by callingMediaRecorder.prepare(). - Start MediaRecorder - Start recording video by calling
MediaRecorder.start().
- Unlock the Camera - Unlock the camera for use by
- Stop Recording Video - Call the following methods in order, to successfully complete a video recording:
- Stop MediaRecorder - Stop recording video by calling
MediaRecorder.stop(). - Reset MediaRecorder - Optionally, remove the configuration settings from the recorder by calling
MediaRecorder.reset(). - Release MediaRecorder - Release the
MediaRecorderby
callingMediaRecorder.release(). - Lock the Camera - Lock the camera so that future
MediaRecordersessions
can use it by callingCamera.lock().
Starting with Android 4.0 (API level 14), this call is not required unless theMediaRecorder.prepare()call
fails.
- Stop MediaRecorder - Stop recording video by calling
- Stop the Preview - When your activity has finished using the camera, stop the preview using
Camera.stopPreview(). - Release Camera - Release the camera so that other applications can use it by calling
Camera.release().
Note: It is possible to use MediaRecorder without
creating a camera preview first and skip the first few steps of this process. However, since users typically prefer to see a preview before starting a recording, that process is not discussed here.
Tip: If your application is typically used for recording video, set setRecordingHint(boolean) to true prior
to starting your preview. This setting can help reduce the time it takes to start recording.
============================再看看官网上关于音频捕捉的介绍================================
Audio Capture
The Android multimedia framework includes support for capturing and encoding a variety of common audio formats, so that you can easily integrate audio into your applications. You can record audio using the MediaRecorder APIs
if supported by the device hardware.
This document shows you how to write an application that captures audio from a device microphone, save the audio and play it back.
Note: The Android Emulator does not have the ability to capture audio, but actual devices are likely to provide these capabilities.
Performing Audio Capture
Audio capture from the device is a bit more complicated than audio and video playback, but still fairly simple:
- Create a new instance of
android.media.MediaRecorder. - Set the audio source using
MediaRecorder.setAudioSource().
You will probably want to useMediaRecorder.AudioSource.MIC. - Set output file format using
MediaRecorder.setOutputFormat(). - Set output file name using
MediaRecorder.setOutputFile(). - Set the audio encoder using
MediaRecorder.setAudioEncoder(). - Call
MediaRecorder.prepare()on
the MediaRecorder instance. - To start audio capture, call
MediaRecorder.start(). - To stop audio capture, call
MediaRecorder.stop(). - When you are done with the MediaRecorder instance, call
MediaRecorder.release()on
it. CallingMediaRecorder.release()is
always recommended to free the resource immediately.
下面就看看该小例子的代码吧。
文件1.该应用的布局文件,res/layout/main.xml
<!-- 帧布局 -->
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent" android:layout_height="fill_parent"> <!-- 用来展示画面 -->
<SurfaceView android:id="@+id/surfaceView"
android:layout_width="fill_parent" android:layout_height="fill_parent" /> <!-- 相对布局,该界面默认不显示出来,当触摸屏幕时候显示出来 -->
<RelativeLayout android:layout_width="fill_parent"
android:layout_height="fill_parent" android:visibility="gone"
android:id="@+id/buttonlayout">
<!-- 刻录按钮 -->
<Button android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_alignParentRight="true"
android:layout_alignParentBottom="true" android:layout_marginRight="10dp"
android:text="@string/recoderbutton" android:onClick="recoder"
android:id="@+id/recoderbutton" />
<!-- 停止按钮 -->
<Button android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_toLeftOf="@id/recoderbutton"
android:layout_alignTop="@id/recoderbutton" android:layout_marginRight="30dp"
android:text="@string/stopbutton" android:onClick="stop"
android:id="@+id/stopbutton"
android:enabled="false"/>
</RelativeLayout>
</FrameLayout>
文件2:布局文件所用到的资源文件,res/values/string.xml
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="hello">Hello World, RecoderActivity!</string>
<string name="app_name">视频刻录小例子</string>
<string name="recoderbutton">刻录</string>
<string name="stopbutton">停止</string>
<string name="noSDcard">检测到手机没有存储卡!请插入手机存储卡再开启本应用</string>
<string name="maxDuration">已经达到最长录制时间</string>
</resources>
文件3:该应用的主程序,RecoderActivity.java
package cn.oyp.recoder; import java.io.File; import android.app.Activity;
import android.content.pm.ActivityInfo;
import android.media.MediaRecorder;
import android.media.MediaRecorder.OnInfoListener;
import android.os.Bundle;
import android.os.Environment;
import android.view.MotionEvent;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.RelativeLayout;
import android.widget.Toast; public class RecoderActivity extends Activity {
// 用来显示图片
private SurfaceView surfaceView;
// 刻录和停止按钮布局
private RelativeLayout buttonlayout;
// 刻录按钮
private Button recoderbutton;
// 停止按钮
private Button stopbutton;
// 媒体刻录对象
private MediaRecorder mediaRecorder; /** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 窗口特效为无标题
requestWindowFeature(Window.FEATURE_NO_TITLE);
// 设置窗口全屏
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
// 设定屏幕显示为横向
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
setContentView(R.layout.main); buttonlayout = (RelativeLayout) this.findViewById(R.id.buttonlayout);
recoderbutton = (Button) this.findViewById(R.id.recoderbutton);
stopbutton = (Button) this.findViewById(R.id.stopbutton); surfaceView = (SurfaceView) this.findViewById(R.id.surfaceView);
// 获取的画面直接输出到屏幕上
surfaceView.getHolder()
.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
// 画面分辨率
surfaceView.getHolder().setFixedSize(176, 144);
// 保持屏幕高亮
surfaceView.getHolder().setKeepScreenOn(true);
} // 点击刻录按钮处理方法
public void recoder(View v) {
try {
// 判断是否存在SD卡
if (Environment.getExternalStorageState().equals(
Environment.MEDIA_MOUNTED)) {
// 将刻录的视频保存到SD卡中
File videoFile = new File(
Environment.getExternalStorageDirectory(),
System.currentTimeMillis() + ".3gp");
mediaRecorder = new MediaRecorder();
// 设置声音采集来源于麦克风
mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
// 设置视频采集来源于摄像头
mediaRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
// 设置输出格式为3gp
mediaRecorder
.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
// 设置视频尺寸
mediaRecorder.setVideoSize(surfaceView.getWidth(),
surfaceView.getHeight());
// 设置每秒钟捕捉画面个数为5帧
mediaRecorder.setVideoFrameRate(5);
// 设置声音编码
mediaRecorder
.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
// 设置视频编码
mediaRecorder.setAudioEncoder(MediaRecorder.VideoEncoder.H264);
// 设置视频的最大持续时间
mediaRecorder.setMaxDuration(10000);
mediaRecorder.setOnInfoListener(new OnInfoListener() {
@Override
public void onInfo(MediaRecorder mr, int what, int extra) {
if (what == MediaRecorder.MEDIA_RECORDER_INFO_MAX_DURATION_REACHED) {
Toast.makeText(getApplicationContext(),
R.string.maxDuration, Toast.LENGTH_LONG)
.show();
if (mediaRecorder != null) {
mediaRecorder.stop();
mediaRecorder.release();
mediaRecorder = null;
}
}
}
});
// 设置刻录的视频保存路径
mediaRecorder.setOutputFile(videoFile.getAbsolutePath());
// 设置预览显示
mediaRecorder.setPreviewDisplay(surfaceView.getHolder()
.getSurface());
// 预期准备
mediaRecorder.prepare();
// 开始刻录
mediaRecorder.start();
} else {
Toast.makeText(getApplicationContext(), R.string.noSDcard,
Toast.LENGTH_LONG).show();
}
} catch (Exception e) {
e.printStackTrace();
}
// 刻录按钮不可点击
recoderbutton.setEnabled(false);
// 停止按钮可点击
stopbutton.setEnabled(true);
} // 点击停止按钮处理方法
public void stop(View v) {
// 停止刻录,并释放资源
if (mediaRecorder != null) {
mediaRecorder.stop();
mediaRecorder.release();
mediaRecorder = null;
}
// 刻录按钮可点击
recoderbutton.setEnabled(true);
// 停止按钮不可点击
stopbutton.setEnabled(false);
} /** 当触摸屏幕的时候,将对焦和拍照按钮布局显示出来 */
@Override
public boolean onTouchEvent(MotionEvent event) {
if (event.getAction() == MotionEvent.ACTION_DOWN) {
buttonlayout.setVisibility(ViewGroup.VISIBLE);
return true;
}
return super.onTouchEvent(event);
} }
文件4:该应用的描述文件 ,AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="cn.oyp.recoder" android:versionCode="1" android:versionName="1.0">
<uses-sdk android:minSdkVersion="8" /> <!-- 摄像头权限 -->
<uses-permission android:name="android.permission.CAMERA" />
<!-- 录制音频权限 -->
<uses-permission android:name="android.permission.RECORD_AUDIO"/>
<!-- 在SD卡中创建和删除文件权限 -->
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
<!-- 往SD卡中写入数据的权限 -->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <application android:icon="@drawable/icon" android:label="@string/app_name">
<activity android:name=".RecoderActivity" android:label="@string/app_name"
android:screenOrientation="landscape">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity> </application>
</manifest>
=================================================================================================
作者:欧阳鹏 欢迎转载,与人分享是进步的源泉!
转载请保留原文地址:http://blog.csdn.net/ouyang_peng
==================================================================================================
我的Android进阶之旅------>Android视频录制小例子的更多相关文章
- 我的Android进阶之旅------>Android颜色值(#AARRGGBB)透明度百分比和十六进制对应关系以及计算方法
我的Android进阶之旅-->Android颜色值(RGB)所支持的四种常见形式 透明度百分比和十六进制对应关系表格 透明度 十六进制 100% FF 99% FC 98% FA 97% F7 ...
- 我的Android进阶之旅------>Android中查看应用签名信息
一.查看自己的证书签名信息 如上一篇文章<我的Android进阶之旅------>Android中制作和查看自定义的Debug版本Android签名证书>地址:http://blog ...
- 我的Android进阶之旅------>Android利用温度传感器实现带动画效果的电子温度计
要想实现带动画效果的电子温度计,需要以下几个知识点: 1.温度传感器相关知识. 2.ScaleAnimation动画相关知识,来进行水印刻度的缩放效果. 3.android:layout_weight ...
- 我的Android进阶之旅------>Android实现用Android手机控制PC端的关机和重启的功能(三)Android客户端功能实现
我的Android进阶之旅------>Android实现用Android手机控制PC端的关机和重启的功能(一)PC服务器端(地址:http://blog.csdn.net/ouyang_pen ...
- 我的Android进阶之旅------> Android为TextView组件中显示的文本添加背景色
通过上一篇文章 我的Android进阶之旅------> Android在TextView中显示图片方法 (地址:http://blog.csdn.net/ouyang_peng/article ...
- 我的Android进阶之旅------> Android在TextView中显示图片方法
面试题:请说出Android SDK支持哪些方式显示富文本信息(不同颜色.大小.并包含图像的文本信息),并简要说明实现方法. 答案:Android SDK支持如下显示富文本信息的方式. 1.使用Tex ...
- 我的Android进阶之旅------>Android疯狂连连看游戏的实现之实现游戏逻辑(五)
在上一篇<我的Android进阶之旅------>Android疯狂连连看游戏的实现之加载界面图片和实现游戏Activity(四)>中提到的两个类: GameConf:负责管理游戏的 ...
- 我的Android进阶之旅------>Android疯狂连连看游戏的实现之加载界面图片和实现游戏Activity(四)
正如在<我的Android进阶之旅------>Android疯狂连连看游戏的实现之状态数据模型(三)>一文中看到的,在AbstractBoard的代码中,当程序需要创建N个Piec ...
- 我的Android进阶之旅------>Android疯狂连连看游戏的实现之状态数据模型(三)
对于游戏玩家而言,游戏界面上看到的"元素"千变万化:但是对于游戏开发者而言,游戏界面上的元素在底层都是一些数据,不同数据所绘制的图片有所差异而已.因此建立游戏的状态数据模型是实现游 ...
- 我的Android进阶之旅------>Android疯狂连连看游戏的实现之开发游戏界面(二)
连连看的游戏界面十分简单,大致可以分为两个区域: 游戏主界面区 控制按钮和数据显示区 1.开发界面布局 本程序使用一个RelativeLayout作为整体的界面布局元素,界面布局上面是一个自定义组件, ...
随机推荐
- Node.js 网页瘸腿爬虫初体验
延续上一篇,想把自己博客的文档标题利用Node.js的request全提取出来,于是有了下面的初哥爬虫,水平有限,这只爬虫目前还有点瘸腿,请看官你指正了. // 内置http模块,提供了http服务器 ...
- 雷锋沙龙 ppt 演讲内容分享(xss,流量劫持的利用)
http://www.pkav.net/XSS.png?from=timeline&isappinstalled=0
- 【MVC5】使用Autofac实现依赖注入
1.安装Autofac 在Package Manager Console执行如下命令: Install-Package AutofacInstall-Package Autofac.Mvc5 2.追加 ...
- Sql Server 表分区(转)
什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在一个文件里. 但是如果是分区表的话,表数据就会按照你指定的规则分放到不同的文件里,把一个大的数据文件拆分为多个小文件,还可以把这些小文件放在 ...
- Django——静态文件(如bootstrap)的配置
静态文件如CSS, javascript(如bootstrap), 图片等文件在django中的配置官方文档写的比较模糊,自己通过实验验证后并整理如下,以防遗忘,目前只整理了关于本地开发中的设置方式, ...
- IIS7 经典模式和集成模式的区别分析
IIS7.0中的Web应用程序有两种配置模式:经典模式和集成模式.两者区别大家可以参考下,根据实际情况选用. 经典模式是为了与之前的版本兼容,使用ISAPI扩展来调用ASP.NET运行库,原先运行于I ...
- [Hibernate开发之路](2)Hibernate问题
(1)数据库驱动问题 log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment). log4j: ...
- swift 可变參数
func sumof(numbers:Int...)->Int{ var sum = 0; for number in numbers{ sum+=number; } return ...
- iOS中三种方式实现登录界面播放视频或gif效果
现在app都做的越来越炫酷,各种动画效果,各种特效很好的提高了用户的体验.很多app在登录界面都使用了动画效果,比如Uber,Keep,QQ等等.这些动画效果基本都是使用gif或者MP4来实现的. 效 ...
- Linux 查看tomcat占用的端口号
第一步:先查看tomcat占用的进程号 ps -ef|grep tomcat 第二步:根据进程号,查看进程所占用的端口 netstat -apn 由此得知,tomcat的进程号是21845,并得到端口 ...