自造小轮子:图片展示器(可增减,类似发朋友圈)

趁着没什么事情,打算继续写点小轮子,便于以后项目中直接能用。这次写的是一个图片的展示器,相当于发微博时选完图片后出现的图片集视图。

代码与效果图:

a 默认情况

    __weak typeof(self) ws = self;
    YQEditPhotoContainerView *cv = [[YQEditPhotoContainerView alloc] initWithFrame:CGRectMake(0, 64, self.view.bounds.size.width, self.view.bounds.size.height - 64)];
    cv.addImageBlock = ^(NSInteger photoCount){
        [ws addImage];
    };
    [self.view addSubview:cv];
NORMAL.gif

b 隐藏大按钮

    __weak typeof(self) ws = self;
    YQEditPhotoContainerView *cv = [[YQEditPhotoContainerView alloc] initWithFrame:CGRectMake(0, 64, self.view.bounds.size.width, self.view.bounds.size.height - 64)];
    cv.hiddenBigAddButton = YES;
    cv.addImageBlock = ^(NSInteger photoCount){
        [ws addImage];
    };
    [self.view addSubview:cv];
YES_3_9.gif

c 五列 十张

    __weak typeof(self) ws = self;
    YQEditPhotoContainerView *cv = [[YQEditPhotoContainerView alloc] initWithFrame:CGRectMake(0, 64, self.view.bounds.size.width, 150)];
    cv.totalCount = 10; // 如果要设置totalCount和colCount的话,务必要totalCount先设置,因为frame在colCount的set方法中计算,否则会数组越界而奔溃!
    cv.colCount = 5;
    cv.addImageBlock = ^(NSInteger photoCount){
        [ws addImage];
    };
    [self.view addSubview:cv];
NO_5_10.gif

使用简介

使用起来很简单,只需要通过- (instancetype)initWithFrame:(CGRect)frame方法初始化后添加到控制器的view中就搞定了。通过设置addImageBlock来设置点击添加图片按钮后的操作。

公开属性和方法

@property (nonatomic, strong) NSMutableArray *imageArray;              ///<  照片数组
@property (nonatomic, assign) NSInteger colCount;                      ///<  有多少列 默认3
@property (nonatomic, assign) NSInteger totalCount;                    ///<  总个数 默认9
@property (nonatomic, assign) BOOL hiddenBigAddButton;                 ///<  隐藏大的添加图片按钮 默认NO
@property (nonatomic, copy) AddImageBlock addImageBlock;               ///<  添加照片block

/**
 添加一张照片
 
 @param image 添加的照片

 */
- (void)addImage:(UIImage *)image;


/**
 添加几张照片
 
 @param imageArray 添加的照片
 
 */
- (void)addImageArray:(NSArray *)imageArray;


/**
 获得当前的照片数组
 
 */
- (NSArray *)getImageArray;

主要思路

在重写初始化的方法中设置好属性的默认值以及添加初始化按钮。并在- (void)setColCount:(NSInteger)colCount方法中通过列数和总数计算出各个imageView的frame并加入到imageViewFrameArr数组中。
每添加一张照片,就初始化一个imageView,每删除一张图片,就把imageView移除父视图。
最后重写- (void)layoutSubviews,在该方法�中拿到imageViewFrameArr数组,设置各个imageView和按钮的frame。同时也判断大小按钮是否需要隐藏。

注意

其中需要注意的是,如果totalCount和colCount都要设置的话,务必要totalCount先设置,因为imageview的frame是在colCount的set方法中计算的,否则会数组越界而奔溃!

最后

本文的代码中有用到自造小轮子:一行代码搞定相机相册的权限以及照片获取这篇文章的小工具,就一个类,代码也很简单。

代码地址

Github : YQEditPhotoContainerView

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,678评论 25 708
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,259评论 4 61
  • 从小到大,其实我挺讨厌“邻居家的孩子”这种榜样的,邻居家的孩子可能是邻居家孩子也可能是亲戚家孩子,爸妈总是能发掘出...
    简约Dr阅读 378评论 0 1
  • 现在的孩子可能很多都不知道邮票是什么啦。 也是,如今大家互相联系,不是手机就是网络,谁还会寄信呢? 不过,这个几平...
    搬书回巢阅读 946评论 0 1