Android 相机功能模块相关库

material-camera


#### Material Camera

Android’s video recording APIs are very difficult to figure out, especially since a lot of manufacturers like to mount their camera sensors upside down or sideways. This library is a result of lots of research and experimentation to get video recording to work universally.

#### Notice

Please report any issues you have, and include device information. Camera behavior can be unpredictable across different Android manufacturers and versions, especially on pre-Lollipop devices. I’ve done quite a bit of testing, but it’s possible I missed something.

Some of this documentation may be outdated, exploration of the library is encouraged.


#### Dependency

Add this in your module’s build.gradle file:

  dependencies {
      // ... other dependencies

      compile 'com.afollestad:material-camera:0.2.14'
  }

# Basics

#### Android Manifest

First, you have to register two library Activities from your app’s AndroidManifest.xml file:

  <activity
      android:name="com.afollestad.materialcamera.CaptureActivity"
      android:theme="@style/MaterialCamera.CaptureActivity" />
  <activity
      android:name="com.afollestad.materialcamera.CaptureActivity2"
      android:theme="@style/MaterialCamera.CaptureActivity" />

Feel free to use your own custom theme. The included themes give the activities a good default look. See the sample project for more details.

#### Code

  private final static int CAMERA_RQ = 6969;

  File saveFolder = new File(Environment.getExternalStorageDirectory(), "MaterialCamera Sample");
  if (!saveFolder.mkdirs())
      throw new RuntimeException("Unable to create save directory, make sure WRITE_EXTERNAL_STORAGE permission is granted.");

  new MaterialCamera(this)                               // Constructor takes an Activity
      .allowRetry(true)                                  // Whether or not 'Retry' is visible during playback
      .autoSubmit(false)                                 // Whether or not user is allowed to playback videos after recording. This can affect other things, discussed in the next section.
      .saveDir(saveFolder)                               // The folder recorded videos are saved to
      .primaryColorAttr(R.attr.colorPrimary)             // The theme color used for the camera, defaults to colorPrimary of Activity in the constructor
      .showPortraitWarning(true)                         // Whether or not a warning is displayed if the user presses record in portrait orientation
      .defaultToFrontFacing(false)                       // Whether or not the camera will initially show the front facing camera
      .retryExits(false)                                 // If true, the 'Retry' button in the playback screen will exit the camera instead of going back to the recorder
      .restartTimerOnRetry(false)                        // If true, the countdown timer is reset to 0 when the user taps 'Retry' in playback
      .continueTimerInPlayback(false)                    // If true, the countdown timer will continue to go down during playback, rather than pausing.
      .videoEncodingBitRate(1024000)                     // Sets a custom bit rate for video recording.
      .audioEncodingBitRate(50000)                       // Sets a custom bit rate for audio recording.
      .videoFrameRate(24)                                // Sets a custom frame rate (FPS) for video recording.
      .qualityProfile(MaterialCamera.QUALITY_HIGH)       // Sets a quality profile, manually setting bit rates or frame rates with other settings will overwrite individual quality profile settings
      .videoPreferredHeight(720)                         // Sets a preferred height for the recorded video output.
      .videoPreferredAspect(4f / 3f)                     // Sets a preferred aspect ratio for the recorded video output.
      .maxAllowedFileSize(1024 * 1024 * 5)               // Sets a max file size of 5MB, recording will stop if file reaches this limit. Keep in mind, the FAT file system has a file size limit of 4GB.
      .iconRecord(R.drawable.mcam_action_play)           // Sets a custom icon for the button used to start recording
      .iconStop(R.drawable.mcam_action_stop)             // Sets a custom icon for the button used to stop recording
      .iconFrontCamera(R.drawable.mcam_camera_front)     // Sets a custom icon for the button used to switch to the front camera
      .iconRearCamera(R.drawable.mcam_camera_rear)       // Sets a custom icon for the button used to switch to the rear camera
      .iconPlay(R.drawable.evp_action_play)              // Sets a custom icon used to start playback
      .iconPause(R.drawable.evp_action_pause)            // Sets a custom icon used to pause playback
      .iconRestart(R.drawable.evp_action_restart)        // Sets a custom icon used to restart playback
      .labelRetry(R.string.mcam_retry)                   // Sets a custom button label for the button used to retry recording, when available
      .labelUseVideo(R.string.mcam_use_video)            // Sets a custom button label for the button used to confirm a recording
      .start(CAMERA_RQ);                                 // Starts the camera activity, the result will be sent back to the current Activity

Note: For retryExists(true), onActivityResult() in the Activity that starts the camera will receive MaterialCamera.STATUS_RETRY as the value of the MaterialCamera.STATUS_EXTRA intent extra.


#### Length Limiting

You can specify a time limit for recording. countdownMillis(long), countdownSeconds(float), and countdownMinutes(float) are all methods for length limiting.

  new MaterialCamera(this)
      .countdownMinutes(2.5f)
      .start(CAMERA_RQ);

When the countdown reaches 0, recording stops. There are different behaviors that can occur after this based on autoSubmit and autoRetry:

  1. autoSubmit(false), allowRetry(true)
    • The user will be able to playback the recording, and the ‘Retry’ button will be visible. This is default behavior.
  2. autoSubmit(false), allowRetry(false)
    • The user will be able to playback the recording, but the ‘Retry’ button will be hidden.
  3. autoSubmit(true), allowRetry(false)
    • The user won’t be able to playback the recording, the result will immediately be returned to the starting Activity.
  4. autoSubmit(true), allowRetry(true)
    • If you don’t specify a length limit, the behavior will be the same as number 3. If you do specify a length limit, the user is allowed to retry, but the countdown timer will continue until it reaches 0. When the countdown is complete, the result will be returned to the starting Activity automatically.

If you want the countdown to start immediately when the camera is open, as opposed to when the user presses ‘Record’, you can set countdownImmediately(true):

  new MaterialCamera(this)
      .countdownMinutes(2.5f)
      .countdownImmediately(true)
      .start(CAMERA_RQ);

#### Receiving Results

  public class MainActivity extends AppCompatActivity {

      private final static int CAMERA_RQ = 6969;

      @Override
      protected void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.activity_main);

          new MaterialCamera(this)
              .start(CAMERA_RQ);
      }

      @Override
      protected void onActivityResult(int requestCode, int resultCode, Intent data) {
          super.onActivityResult(requestCode, resultCode, data);

          // Received recording or error from MaterialCamera
          if (requestCode == CAMERA_RQ) {

              if (resultCode == RESULT_OK) {
                  Toast.makeText(this, "Saved to: " + data.getDataString(), Toast.LENGTH_LONG).show();
              } else if(data != null) {
                  Exception e = (Exception) data.getSerializableExtra(MaterialCamera.ERROR_EXTRA);
                  e.printStackTrace();
                  Toast.makeText(this, e.getMessage(), Toast.LENGTH_LONG).show();
              }
          }
      }
  }

Sticker-Camera


#### StickerCamera 这是一款集成了相机,图片裁剪,给图片贴贴图打标签的APP。

#### Feature - 实现相机功能 - 实现对图片进行裁剪的功能 - 图片的滤镜功能 - 能为图片添加贴纸(贴纸可移动,放大,旋转) - 能为图片添加标签(同样可以移动) - 本地保存制作好的图片,并展示 - 较多的自定义控件,不错的项目架构

# Thanks

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏向治洪

开源组件photoView学习

功能特性  支持放缩超出边界,多点触控和双击事件  滚动和滑动  和ViewPager等能完美兼容  矩阵变化等有回调,方便前台其他展示的改变  单...

21650
来自专栏学海无涯

Android开发之Loader与LoaderManager

Loader是什么,有什么作用? 顾名思义就是加载器,简单来说,Loader做了2件事: (1)在单独的线程中读取数据,不会阻塞UI线程 (2)监视数据的更...

35150
来自专栏移动开发

点击空白处隐藏软键盘

在点击Editext的时候安卓会弹出软键盘,在我们输入完后不点击软键盘的”完成”键的时候,软键盘有时候会一直停留在”界面”,甚至跳转到另一个”界面”上.这样体验...

15320
来自专栏Android中高级开发

Android使用百度地图定位并显示手机位置后使用前置摄像头“偷拍”

拿到这个需求后,对于摄像头的使用不太熟悉,于是我先做了定位手机并在百度地图上显示的功能

40720
来自专栏项勇

笔记83 | wifi解析使用

WifiManager是管理android WIFI的连接服务,它可以配置WIFI网络连接,管理当前wifi连接,扫描接入点,监视wifi连接状态;

10420
来自专栏Sorrower的专栏

使用VideoView做个实用的视频播放器

14150
来自专栏腾讯Bugly的专栏

Android ImageView 正确使用姿势

导语 本文主要介绍了ImageView的相关重要方法,从源码角度剖析了一些容易令人混淆或百思不得其解的问题。 一、正确合理使用ImageView 的src 和b...

41480
来自专栏项勇

笔记19 | 利用MediaRecorder实现录像

251100
来自专栏写写代码吃吃瓜

Android简易“吹一吹实现”以及录音和播放示例

27740
来自专栏向治洪

Android+struts2+json方式模拟手机登录功能

涉及到的知识点:  1.Struts2框架的搭建(包括Struts2的jSON插件)   2.Android前台访问Web采用HttpClient方式。 ...

25350

扫码关注云+社区

领取腾讯云代金券