一个高效的多媒体支持操作库,可多方面的简单配置操作拍照、相册、录制、录音等功能。
也支持配套使用的展示图片、视频、音频的九宫格功能。
- 本开源库的部分相册代码来自Matisse.
- 本开源库的相机代码来自CameraView.
非X库版本,已经停止维护(https://github.com/zhongjhATC/AlbumCameraRecorder/tree/master)
- 录制拍照完全支持自己自定义!详情请看Demo如何使用,如果需要深入扩展需要了解更多代码CameraFragment架构简介
- 支持相册、录制、录音等三合一功能(类似抖音等),并且也可以通过配置只独立出其中一个功能.
- 支持可自定义权限请求也可以直接交由该库完成权限请求
- 虽然功能很多,但是可以按照所需功能来引入某些库
- 丰富的回调接口和调试信息,可利用现有API实现丰富的效果.
- 兼容性强,不管是低版本的4.1还是目前最新版本的Android 13,都进行了相关兼容处理
- 支持所有图片读取处理自定义,例如可自定义glide、Fresco等等都可以
- 支持从相册选择图片
- 支持相册按照手机文件区分不同的文件夹选择
- 自定义性强,支持各种自定义最多选多少张图片、视频等等,也支持只显示自定义文件大小
- 支持自定义相册的样式,颜色,大小等等
- 兼容横竖版调整
- 录制拍照时支持闪光灯、前后摄像头切换
- 录制拍照时支持双指触摸放大缩小,支持单指上下滑动控制亮度
- 录制拍照长按按钮等所有UI可自定义,全是svg图片可以很好的处理动画细节
- 录制支持分段录制,以后还会加入视频编辑
- 图片编辑支持颜色涂鸦、输入文字、马赛克处理、旋转、裁剪等处理
- 支持拍摄、录制时的水印功能
- 自带权限功能,无需修改任意代码,权限功能包括权限检测、发送权限时告知为何请求、多次拒绝后会提示是否跳转到设置界面设置权限。也可以自定义权限
- 所有录制拍照都可以选择深度压缩处理,图片可选择自定义压缩处理,也可以使用Demo中的LuBan压缩,视频压缩则是使用ffmpeg处理
- 完善的缓存管理系统
- 完善的动画效果,后续还会继续增加
- 性能优化,内存泄漏这些都一一仔细处理过
allprojects {
repositories {
...
maven { url 'https://www.jitpack.io' }
}
}
dependencies {
// 如果想简化代码并且同时用到multilibrary和progresslibrary、albumCameraRecorderCommon,可以直接使用combined库
implementation 'com.github.zhongjhATC.AlbumCameraRecorder:combined:1.1.93X'
// 公共库,如果不使用上面的combined库
implementation 'com.github.zhongjhATC.AlbumCameraRecorder:common:1.1.93X'
// 核心lib,调用显示相册、录屏、录音等
implementation 'com.github.zhongjhATC.AlbumCameraRecorder:multilibrary:1.1.93X'
// 配套使用,主要用于获取数据后进行相关显示,相应的上传进度显示,如果你只需要获取照片录像录音等数据,可以不需要使用这个
implementation 'com.github.zhongjhATC.AlbumCameraRecorder:progresslibrary:1.1.93X'
// 配套编辑图片使用
implementation 'com.github.zhongjhATC.AlbumCameraRecorder:imageedit:1.1.93X'
// 配套编辑视频使用,目前只有压缩功能,后续持续添加相关功能,因为该库使用了ffmpeg,占用了文件大小25M,根据实际情况选择是否使用
implementation 'com.github.zhongjhATC.AlbumCameraRecorder:videoedit:1.1.93X'
// 配套合并视频使用,因为该库使用了mp4parser,占用了文件大小约300kb,根据实际情况选择是否使用
implementation 'com.github.zhongjhATC.AlbumCameraRecorder:videomerge:1.1.93X'
}
android.enableJetifier=true
android.useAndroidX=true
100%通过兼容测试报告.
// 拍摄有关设置
CameraSetting cameraSetting = new CameraSetting();
// 支持的类型:图片,视频
cameraSetting.mimeTypeSet(MimeType.ofAll());
// 相册
AlbumSetting albumSetting = new AlbumSetting(false)
// 支持的类型:图片,视频
.mimeTypeSet(MimeType.ofAll())
// 是否显示多选图片的数字
.countable(true)
// 自定义过滤器
.addFilter(new GifSizeFilter(320, 320, 5 * BaseFilter.K * BaseFilter.K))
// 开启原图
.originalEnable(true)
// 最大原图size,仅当originalEnable为true的时候才有效
.maxOriginalSize(10);
// 录音机
RecorderSetting recorderSetting = new RecorderSetting();
// 全局
GlobalSetting globalSetting = MultiMediaSetting.from(MainActivity.this).choose(MimeType.ofAll());
globalSetting.cameraSetting(cameraSetting);
globalSetting.albumSetting(albumSetting);
globalSetting.recorderSetting(recorderSetting);
globalSetting
// 设置路径和7.0保护路径等等
.allStrategy(new SaveStrategy(true, getPackageName() + ".fileProvider", "aabb"))
// for glide-V4
.imageEngine(new Glide4Engine())
// 最大5张图片、最大3个视频、最大1个音频
.maxSelectablePerMediaType(null,
5,
3,
3,
0,
0,
0)
.forResult(100);
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (resultCode != RESULT_OK)
return;
List<LocalFile> result = MultiMediaSetting.obtainLocalFileResult(data);
}
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.fileProvider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths_public" />
</provider>
如果还有别的常见问题,具体可以看可能会发生的问题搜索报错关键字
简单扩展请参考Demo,如果需要深入扩展了解更多CameraFragment架构简洁 但是请注意,如果有支持配置的情况下,是配置优先.只有在没有配置的情况下,才在这里进行自定义扩展
因为里面的相机来自于CameraView,所以修改分辨率、录制时关闭录音等各种功能可以进入查看更多接口,那么如何通过我们这个库获取CameraView,可以在Demo实例中学习使用
如果你需要用到九宫格展览数据,具体可以看相关代码.
如果你使用展示的九宫库,那么下面这些api对你也有用
从1.0.1版本开始总结的历史更新.
- 1.1.29X版本,跟当前最新代码版本可能会有稍许不同 Gitcode下载地址