- 查看/选择GIF图片
- 照片、视频可同时多选/原图
- 3DTouch预览照片
- 长按拖动改变顺序
- 自定义相机拍照/录制视频
- 自定义转场动画
- 查看/选择LivePhoto IOS9.1以上才有用
- 支持浏览网络图片
- 支持裁剪图片
- 观察系统相册变化实时增删
- Cocoapods:
pod 'HXWeiboPhotoPicker' '~> 2.0.4'
搜索不到库或最新版请执行pod repo update
- 手动导入:将项目中的“HXWeiboPhotoPicker”文件夹拖入项目中
- 网络图片加载使用的是
SDWebImage v4.0.0
- 只使用照片选择功能 导入头文件 "HXPhotoViewController.h"
- 选完照片/视频后自动布局功能 导入头文件 "HXPhotoView.h"
- iOS8及以上系统可使用. ARC环境. - iOS 8 or later. Requires ARC
- 在Xcode8环境下将项目运行在iOS10的设备/模拟器中,访问相册和相机需要配置三个info.plist文件
- Privacy - Photo Library Usage Description 和 Privacy - Camera Usage Description 以及 Privacy - Microphone Usage Description
- 相机拍照功能请使用真机调试
- HXPhotoManager 照片管理类相关属性介绍
HXPhotoManagerSelectedTypePhoto // 只选择图片
HXPhotoManagerSelectedTypeVideo // 只选择视频
HXPhotoManagerSelectedTypePhotoAndVideo // 图片和视频一起
HXPhotoManagerCameraTypeHalfScreen // 半屏相机
HXPhotoManagerCameraTypeFullScreen // 全屏相机
HXPhotoManagerCameraTypeSystem // 系统相机
/**
* 管理UI的类
*/
HXPhotoUIManager *UIManager;
/**
* 拍摄的 照片/视频 是否保存到系统相册 默认NO 此功能需要配合 监听系统相册 和 缓存相册 功能 (请不要关闭)
*/
BOOL saveSystemAblum;
/**
* 视频能选择的最大秒数 - 默认 5分钟/300秒
*/
NSTimeInterval videoMaxDuration;
/**
* 是否缓存相册, manager会监听系统相册变化(需要此功能时请不要关闭监听系统相册功能) 默认YES
*/
BOOL cacheAlbum;
/**
* 是否监听系统相册 默认 YES
*/
BOOL monitorSystemAlbum;
/**
是否为单选模式 默认 NO
*/
BOOL singleSelected;
/**
单选模式下是否需要裁剪 默认YES
*/
BOOL singleSelecteClip;
/**
是否开启3DTouch预览功能 默认NO
*/
BOOL open3DTouchPreview;
/**
相机界面类型 // 默认 半屏
*/
HXPhotoManagerCameraType cameraType;
/**
删除网络图片时是否显示Alert // 默认不显示
*/
BOOL showDeleteNetworkPhotoAlert;
/**
网络图片地址数组
*/
NSMutableArray *networkPhotoUrls;
/**
是否把相机功能放在外面 默认 NO 使用 HXPhotoView 时有用
*/
BOOL outerCamera;
/**
是否打开相机功能
*/
BOOL openCamera;
/**
是否开启查看GIF图片功能 - 默认开启
*/
BOOL lookGifPhoto;
/**
是否开启查看LivePhoto功能呢 - 默认NO
*/
BOOL lookLivePhoto;
/**
是否一开始就进入相机界面
*/
BOOL goCamera;
/**
最大选择数 等于 图片最大数 + 视频最大数 默认10 - 必填
*/
NSInteger maxNum;
/**
图片最大选择数 默认9 - 必填
*/
NSInteger photoMaxNum;
/**
视频最大选择数 // 默认1 - 必填
*/
NSInteger videoMaxNum;
/**
图片和视频是否能够同时选择 默认支持
*/
BOOL selectTogether;
/**
相册列表每行多少个照片 默认4个 iphone 4s / 5 默认3个
*/
NSInteger rowCount;
- HXPhotoUIManager类相关属性
/** HXPhotoView添加按钮图片 */
NSString *photoViewAddImageName;
/** 网络图片占位图 */
NSString *placeholderImageName;
/*-------------------导航栏相关属性------------------*/
/** 导航栏背景颜色 */
UIColor *navBackgroundColor;
/** 导航栏背景图片 */
NSString *navBackgroundImageName;
/** 导航栏左边按钮文字颜色 */
UIColor *navLeftBtnTitleColor;
/** 导航栏 标题/相册名 文字颜色 */
UIColor *navTitleColor;
/** 导航栏标题箭头图标 */
NSString *navTitleImageName;
/** 导航栏右边按钮普通状态背景颜色 */
UIColor *navRightBtnNormalBgColor;
/** 导航栏右边按钮普通状态文字颜色 */
UIColor *navRightBtnNormalTitleColor;
/** 导航栏右边按钮禁用状态背景颜色 */
UIColor *navRightBtnDisabledBgColor;
/** 导航栏右边按钮禁用状态文字颜色 */
UIColor *navRightBtnDisabledTitleColor;
/** 导航栏右边按钮禁用状态下的 layer.borderColor 边框线颜色 */
UIColor *navRightBtnBorderColor;
/*-------------------相册列表视图------------------*/
/** 相册列表有选择内容的提醒图标 */
NSString *albumViewSelectImageName;
/** 相册名称文字颜色 */
UIColor *albumNameTitleColor;
/** 照片数量文字颜色 */
UIColor *photosNumberTitleColor;
/** 相册列表视图背景颜色 */
UIColor *albumViewBgColor;
/** 相册列表cell选中颜色 */
UIColor *albumViewCellSelectedColor;
/*-------------------Cell------------------*/
/** cell相机照片图片 */
NSString *cellCameraPhotoImageName;
/** cell相机视频图片 */
NSString *cellCameraVideoImageName;
/** 选择按钮普通状态图片 */
NSString *cellSelectBtnNormalImageName;
/** 选择按钮选中状态图片 */
NSString *cellSelectBtnSelectedImageName;
/** gif标示图标 */
NSString *cellGitIconImageName;
/*-------------------底部预览、原图按钮视图------------------*/
/** 是否开启毛玻璃效果开启了自动屏蔽背景颜色 */
BOOL blurEffect;
/** 底部视图背景颜色 */
UIColor *bottomViewBgColor;
/** 预览按钮普通状态文字颜色 */
UIColor *previewBtnNormalTitleColor;
/** 预览按钮禁用状态文字颜色 */
UIColor *previewBtnDisabledTitleColor;
/** 预览按钮普通状态背景图片 */
NSString *previewBtnNormalBgImageName;
/** 预览按钮禁用状态背景图片 */
NSString *previewBtnDisabledBgImageName;
/** 原图按钮普通状态文字颜色 */
UIColor *originalBtnNormalTitleColor;
/** 原图按钮禁用状态文字颜色 */
UIColor *originalBtnDisabledTitleColor;
/** 原图按钮边框线颜色 */
UIColor *originalBtnBorderColor;
/** 原图按钮背景颜色 */
UIColor *originalBtnBgColor;
/** 原图按钮普通状态图片 */
NSString *originalBtnNormalImageName;
/** 原图按钮选中状态图片 */
NSString *originalBtnSelectedImageName;
/*-------------------半屏相机界面------------------*/
/** 返回按钮X普通状态图片 */
NSString *cameraCloseNormalImageName;
/** 返回按钮X高亮状态图片 */
NSString *cameraCloseHighlightedImageName;
/** 闪光灯自动模式图片 */
NSString *flashAutoImageName;
/** 闪光灯打开模型图片 */
NSString *flashOnImageName;
/** 闪光灯关闭模式图片 */
NSString *flashOffImageName;
/** 反转相机普通状态图片 */
NSString *cameraReverseNormalImageName;
/** 反转相机高亮状态图片 */
NSString *cameraReverseHighlightedImageName;
/** 中心圆点下照片and视频普通状态文字颜色 */
UIColor *cameraPhotoVideoNormalTitleColor;
/** 中心圆点下照片and视频选中状态文字颜色 */
UIColor *cameraPhotoVideoSelectedTitleColor;
/** 拍照按钮普通状态图片 */
NSString *takePicturesBtnNormalImageName;
/** 拍照按钮高亮状态图片 */
NSString *takePicturesBtnHighlightedImageName;
/** 录制按钮普通状态图片 */
NSString *recordedBtnNormalImageName;
/** 录制按钮高亮状态图片 */
NSString *recordedBtnHighlightedImageName;
/** 删除拍摄的照片/视频图片 */
NSString *cameraDeleteBtnImageName;
/** 确定拍摄的照片/视频普通状态图片 */
NSString *cameraNextBtnNormalImageName;
/** 确定拍摄的照片/视频高亮状态图片 */
NSString *cameraNextBtnHighlightedImageName;
/** 中心圆点图片 */
NSString *cameraCenterDotImageName;
/** 相机聚焦图片 */
NSString *cameraFocusImageName;
/** 全屏相机界面下一步按钮文字颜色 */
UIColor *fullScreenCameraNextBtnTitleColor;
/** 全屏相机界面下一步按钮背景颜色 */
UIColor *fullScreenCameraNextBtnBgColor;
- HXPhotoResultModel相关属性介绍
HXPhotoResultModelMediaTypePhoto // 照片
HXPhotoResultModelMediaTypeVideo // 视频
/** 资源类型 */
HXPhotoResultModelMediaType type;
/** 原图URL */
NSURL *fullSizeImageURL;
/** 原尺寸image 如果资源为视频时此字段为视频封面图片 */
UIImage *displaySizeImage;
/** 原图方向 */
int fullSizeImageOrientation;
/** 视频Asset */
AVAsset *avAsset;
/** 视频URL */
NSURL *videoURL;
/** 创建日期 */
NSDate *creationDate;
/** 位置信息 */
CLLocation *location;
- Demo1
// 懒加载 照片管理类
- (HXPhotoManager *)manager {
if (!_manager) {
_manager = [[HXPhotoManager alloc] initWithType:HXPhotoManagerSelectedTypePhotoAndVideo];
}
return _manager;
}
// 照片选择控制器
HXPhotoViewController *vc = [[HXPhotoViewController alloc] init];
vc.delegate = self;
vc.manager = self.manager;
[self presentViewController:[[UINavigationController alloc] initWithRootViewController:vc] animated:YES completion:nil];
// 通过 HXPhotoViewControllerDelegate 代理返回选择的图片以及视频
- (void)photoViewControllerDidNext:(NSArray *)allList Photos:(NSArray *)photos Videos:(NSArray *)videos Original:(BOOL)original
// 点击取消
- (void)photoViewControllerDidCancel
- Demo2
// 懒加载 照片管理类
- (HXPhotoManager *)manager {
if (!_manager) {
_manager = [[HXPhotoManager alloc] initWithType:HXPhotoManagerSelectedTypePhotoAndVideo];
}
return _manager;
}
self.navigationController.navigationBar.translucent = NO;
self.automaticallyAdjustsScrollViewInsets = YES;
HXPhotoView *photoView = [[HXPhotoView alloc] initWithFrame:CGRectMake((414 - 375) / 2, 100, 375, 400) WithManager:self.manager];
photoView.delegate = self;
photoView.backgroundColor = [UIColor whiteColor];
[self.view addSubview:photoView];
// 代理返回 选择、移动顺序、删除之后的图片以及视频
- (void)photoView:(HXPhotoView *)photoView changeComplete:(NSArray<HXPhotoModel *> *)allList photos:(NSArray<HXPhotoModel *> *)photos videos:(NSArray<HXPhotoModel *> *)videos original:(BOOL)isOriginal;
// 当view更新高度时调用
- (void)photoView:(HXPhotoView *)photoView updateFrame:(CGRect)frame;
// 删除网络图片的地址
- (void)photoView:(HXPhotoView *)photoView deleteNetworkPhoto:(NSString *)networkPhotoUrl;
// 网络图片全部下载完成时调用
- (void)photoViewAllNetworkingPhotoDownloadComplete:(HXPhotoView *)photoView;
- 关于HXPhotoTools获取资源信息 具体代码还是请下载Demo
// 将HXPhotoModel模型数组转化成HXPhotoResultModel模型数组 - 已按选择顺序排序
// !!!! 必须是全部类型的那个数组 就是 allList 这个数组 !!!!
[HXPhotoTools getSelectedListResultModel:allList complete:^(NSArray<HXPhotoResultModel *> *alls, NSArray<HXPhotoResultModel *> *photos, NSArray<HXPhotoResultModel *> *videos) {
NSSLog(@"\n全部类型:%@\n照片:%@\n视频:%@",alls,photos,videos);
}];
HXPhotoTools提供一个方法可以根据传入的模型数组转换成图片(UIImage)数组
type是个枚举
HXPhotoToolsFetchHDImageType = 0, // 高清
HXPhotoToolsFetchOriginalImageTpe, // 原图
[HXPhotoTools getImageForSelectedPhoto:photos type:HXPhotoToolsFetchHDImageType completion:^(NSArray<UIImage *> *images) {
NSSLog(@"%@",images);
for (UIImage *image in images) {
if (image.images.count > 0) {
// 到这里了说明这个image 是个gif图
}
}
}];
- 2017-03-07 修复通过相机拍照时照片旋转90°的问题
- ...
- 2017-06-26 合并一些方法、删除无用方法
- 2017-07-01 添加单选样式、支持裁剪图片
- 2017-07-05 解决同一界面多个选择器界面跳转问题,拍摄视频完成时遗留问题
- 2017-07-26 优化cell性能、3DTouch预览内存消耗。添加是否需要裁剪框属性、刷新界面方法以及拍照/选择照片完之后跳界面Demo
- 2017-08-08 添加国际化支持英文、保存拍摄的照片/视频到系统相册、实时监听系统相册变化并改变、缓存相册、选择视频时限制超过指定秒数不能选。以及一些小问题
- 2017-08-10 添加自定义属性、修复导航栏可能偏移64的问题
- 2017-08-12 添加系统相机、HXPhotoTools添加转换方法
-
支持横屏功能正在准备当中...
-
如果您发现了bug请尽可能详细地描述系统版本、手机型号和复现步骤等信息 提一个issue.
-
如果您有什么好的建议也可以提issue,大家一起讨论一起学习进步...
-
具体代码请下载项目 如果觉得喜欢的能给一颗小星星么! ✨✨✨
-
如果觉得的不行,麻烦请多包涵。