Step 1. Add the JitPack repository to your build file
Add it in your root settings.gradle at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url 'https://jitpack.io' }
}
}
Add it in your settings.gradle.kts at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url = uri("https://jitpack.io") }
}
}
Add to pom.xml
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add it in your build.sbt at the end of resolvers:
resolvers += "jitpack" at "https://jitpack.io"
Add it in your project.clj at the end of repositories:
:repositories [["jitpack" "https://jitpack.io"]]
Step 2. Add the dependency
dependencies {
implementation 'com.github.bruferrari:CameraKit-Android:0.10.1'
}
dependencies {
implementation("com.github.bruferrari:CameraKit-Android:0.10.1")
}
<dependency>
<groupId>com.github.bruferrari</groupId>
<artifactId>CameraKit-Android</artifactId>
<version>0.10.1</version>
</dependency>
libraryDependencies += "com.github.bruferrari" % "CameraKit-Android" % "0.10.1"
:dependencies [[com.github.bruferrari/CameraKit-Android "0.10.1"]]
CameraKit is an extraordinarily easy to use utility to work with the infamous Android Camera and Camera2 APIs. Built by Dylan McIntyre.
Try out all the unique features using the CameraKit Demo from the Google Play store!
<a href='https://play.google.com/store/apps/details?id=com.wonderkiln.camerakit.demo&pcampaignid=MKT-Other-global-all-co-prtnr-py-PartBadge-Mar2515-1'><img alt='Get it on Google Play' src='https://play.google.com/intl/en_us/badges/images/generic/en_badge_web_generic.png' height='80'/></a>
<img src='.repo/demo1.png' width='120'/> <img src='.repo/demo2.png' width='120'/> <img src='.repo/demo3.png' width='120'/> <img src='.repo/demo4.png' width='120'/>
CameraView of any size (not just presets!).CameraView bounds.METHOD_STANDARD: an image captured normally using the camera APIs.METHOD_STILL: a freeze frame of the CameraView preview (similar to SnapChat and Instagram) for devices with slower cameras.METHOD_SPEED: automatic capture method determination based on measured speed.Add CameraKit to the dependencies block in your app level build.gradle:
compile 'com.wonderkiln:camerakit:0.10.1'
To use CameraKit, simply add a CameraView to your layout:
<com.wonderkiln.camerakit.CameraView
android:id="@+id/camera"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:adjustViewBounds="true" />
Make sure you override onResume and onPause in your activity, and make calls respectively to CameraView.start() and CameraView.stop().
@Override
protected void onResume() {
super.onResume();
cameraView.start();
}
@Override
protected void onPause() {
cameraView.stop();
super.onPause();
}
To capture an image just call CameraView.captureImage(). Make sure you setup a CameraListener to handle the image callback.
camera.setCameraListener(new CameraListener() {
@Override
public void onPictureTaken(byte[] picture) {
super.onPictureTaken(picture);
// Create a bitmap
Bitmap result = BitmapFactory.decodeByteArray(picture, 0, picture.length);
}
});
camera.captureImage();
To capture video just call CameraView.startRecordingVideo() to start, and CameraView.stopRecordingVideo() to finish. Make sure you setup a CameraListener to handle the video callback.
camera.setCameraListener(new CameraListener() {
@Override
public void onVideoTaken(File video) {
super.onVideoTaken(video);
// The File parameter is an MP4 file.
}
});
camera.startRecordingVideo();
camera.postDelayed(new Runnable() {
@Override
public void run() {
camera.stopRecordingVideo();
}
}, 2500);
<com.wonderkiln.camerakit.CameraView xmlns:camerakit="http://schemas.android.com/apk/res-auto"
android:id="@+id/camera"
android:layout_width="match_parent"
android:layout_height="wrap_content"
camerakit:ckFacing="back"
camerakit:ckFlash="off"
camerakit:ckFocus="continuous"
camerakit:ckMethod="standard"
camerakit:ckZoom="pinch"
camerakit:ckPermissions="strict"
camerakit:ckCropOutput="true"
camerakit:ckJpegQuality="100"
camerakit:ckVideoQuality="480p"
android:adjustViewBounds="true" />
|Attribute|Values|Default Value|
|---------|------|-------------|
|ckFacing|back front|back|
|ckFlash|off on auto|off|
|ckFocus|off continuous tap|continuous|
|ckMethod|standard still speed|standard|
|ckZoom|off pinch|off|
|ckPermissions|strict lazy picture|strict|
|ckCropOutput|true false|false|
|ckJpegQuality|0 <= n <= 100|100|
|ckVideoQuality|max480p max720p max1080p max2160p highest lowest|max480p|
ckFacingbackcameraView.setFacing(CameraKit.Constants.FACING_BACK);
frontcameraView.setFacing(CameraKit.Constants.FACING_FRONT);
ckFlashoffcameraView.setFlash(CameraKit.Constants.FLASH_OFF);
oncameraView.setFlash(CameraKit.Constants.FLASH_ON);
autocameraView.setFlash(CameraKit.Constants.FLASH_AUTO);
torchcameraView.setFlash(CameraKit.Constants.FLASH_TORCH);
ckFocusoffcameraView.setFocus(CameraKit.Constants.FOCUS_OFF);
continuouscameraView.setFocus(CameraKit.Constants.FOCUS_CONTINUOUS);
tapcameraView.setFocus(CameraKit.Constants.FOCUS_TAP);
ckMethodstandardcameraView.setMethod(CameraKit.Constants.METHOD_STANDARD);
When you use METHOD_STANDARD (camerakit:ckMethod="standard"), images will be captured using the normal camera API capture method using the shutter.
stillcameraView.setMethod(CameraKit.Constants.METHOD_STILL);
When you use METHOD_STILL (camerakit:ckMethod="still"), images will be captured by grabbing a single frame from the preview. This behavior is the same as SnapChat and Instagram. This method has a higher rate of motion blur but can be a better experience for users with slower cameras.
speedComing soon
cameraView.setMethod(CameraKit.Constants.METHOD_SPEED);
When you use METHOD_SPEED (camerakit:ckMethod="speed"), images will be captured using both METHOD_STANDARD and METHOD_SPEED. After 6 image captures the camera will set itself to METHOD_STANDARD or METHOD_STILL permanently based on whichever is faster.
ckZoomoffcameraView.setZoom(CameraKit.Constants.ZOOM_OFF);
pinchcameraView.setZoom(CameraKit.Constants.ZOOM_PINCH);
ckPermissionsstrictcameraView.setPermissions(CameraKit.Constants.PERMISSIONS_STRICT);
lazycameraView.setPermissions(CameraKit.Constants.PERMISSIONS_LAZY);
picturecameraView.setPermissions(CameraKit.Constants.PERMISSIONS_PICTURE);
ckCropOutputtruecameraView.setCropOutput(true);
falsecameraView.setCropOutput(false);
ckJpegQualitycameraView.setJpegQuality(100);
ckVideoQualitymax480p max720p max1080p max2160p lowest highest qvga
max480pcameraView.setVideoQuality(CameraKit.Constants.VIDEO_QUALITY_480P);
max720pcameraView.setVideoQuality(CameraKit.Constants.VIDEO_QUALITY_720P);
max1080pcameraView.setVideoQuality(CameraKit.Constants.VIDEO_QUALITY_1080P);
max2160pcameraView.setVideoQuality(CameraKit.Constants.VIDEO_QUALITY_2160P);
lowestcameraView.setVideoQuality(CameraKit.Constants.VIDEO_QUALITY_LOWEST);
highestcameraView.setVideoQuality(CameraKit.Constants.VIDEO_QUALITY_HIGHEST);
qvgacameraView.setVideoQuality(CameraKit.Constants.VIDEO_QUALITY_QVGA);
You can handle permissions yourself in whatever way you want, but if you make a call to CameraView.start() without the android.permission.CAMERA permission, an exception would normally be thrown and your app would crash.
With CameraKit, we will automatically prompt for the android.permission.CAMERA permission if it's not available. If you want to handle it yourself, just make sure you don't call CameraView.start() until you acquire the permissions.

You can setup the CameraView dimensions however you want. When your dimensions don't match the aspect ratio of the internal preview surface, the surface will be cropped minimally to fill the view. The behavior is the same as the android:scaleType="centerCrop" on an ImageView.

adjustViewBoundsYou can use a mix of a fixed dimension (a set value or match_parent) as well as wrap_content. When you do this make sure you set android:adjustViewBounds="true" on the CameraView.
When you do this the dimension set to wrap_content will automatically align with the true aspect ratio of the preview surface. In this case the whole preview will be visible with no cropping.
Make sure you can react to different camera events by setting up a CameraListener instance.
camera.setCameraListener(new CameraListener() {
@Override
public void onCameraOpened() {
super.onCameraOpened();
}
@Override
public void onCameraClosed() {
super.onCameraClosed();
}
@Override
public void onPictureTaken(byte[] picture) {
super.onPictureTaken(picture);
}
@Override
public void onVideoTaken(File video) {
super.onVideoTaken(video);
}
});
CameraKit-Android is MIT licensed.