You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
206 lines
4.9 KiB
206 lines
4.9 KiB
// |
|
// XRCarouselView.h |
|
// |
|
// Created by 肖睿 on 16/3/17. |
|
// Copyright © 2016年 肖睿. All rights reserved. |
|
// |
|
|
|
#import <UIKit/UIKit.h> |
|
@class XRCarouselView; |
|
|
|
typedef void(^ClickBlock)(NSInteger index); |
|
|
|
//pageControl的显示位置 |
|
typedef NS_ENUM(NSInteger, PageControlPosition) { |
|
PositionDefault, //默认值 == PositionBottomCenter |
|
PositionHide, //隐藏 |
|
PositionTopCenter, //中上 |
|
PositionBottomLeft, //左下 |
|
PositionBottomCenter, //中下 |
|
PositionBottomRight //右下 |
|
}; |
|
|
|
//gif播放方式 |
|
typedef NS_ENUM(NSInteger, GifPlayMode) { |
|
GifPlayModeAlways, //始终播放 |
|
GifPlayModeNever, //从不播放 |
|
GifPlayModePauseWhenScroll //切换图片时不播放 |
|
}; |
|
|
|
//图片切换的方式 |
|
typedef NS_ENUM(NSInteger, ChangeMode) { |
|
ChangeModeDefault, //轮播滚动 |
|
ChangeModeFade //淡入淡出 |
|
}; |
|
|
|
|
|
|
|
/** |
|
* 代理 |
|
*/ |
|
@protocol XRCarouselViewDelegate <NSObject> |
|
|
|
/** |
|
* 该方法用来处理图片的点击,会返回图片在数组中的索引 |
|
* 代理与block二选一即可,若两者都实现,block的优先级高 |
|
* |
|
* @param carouselView 控件本身 |
|
* @param index 图片索引 |
|
*/ |
|
- (void)carouselView:(XRCarouselView *)carouselView clickImageAtIndex:(NSInteger)index; |
|
|
|
@end |
|
|
|
|
|
/** |
|
* C语言函数,创建本地gif图片 |
|
* 本地gif图片请使用该函数创建,否则gif无动画效果 |
|
* @param imageName 图片名称 |
|
*/ |
|
UIImage *gifImageNamed(NSString *imageName); |
|
|
|
|
|
/** |
|
* 说明:要想正常使用,图片数组imageArray必须设置 |
|
* 控件的frame必须设置,xib\sb创建的可不设置 |
|
* 其他属性都有默认值,可不设置 |
|
*/ |
|
@interface XRCarouselView : UIView |
|
|
|
|
|
#pragma mark 属性 |
|
|
|
|
|
/** |
|
* 设置图片的切换模式,默认为ChangeModeDefault |
|
*/ |
|
@property (nonatomic, assign) ChangeMode changeMode; |
|
|
|
|
|
/** |
|
* 设置图片的内容模式,默认为UIViewContentModeScaleToFill |
|
*/ |
|
@property (nonatomic, assign) UIViewContentMode contentMode; |
|
|
|
|
|
/** |
|
* 设置分页控件位置,默认为PositionBottomCenter |
|
* 只有一张图片时,pageControl隐藏 |
|
*/ |
|
@property (nonatomic, assign) PageControlPosition pagePosition; |
|
|
|
|
|
/** |
|
* 如果pagePosition无法满足需求,可通过该属性设置分页控件的偏移量 |
|
* 在pagePosition的基础上进行偏移 |
|
*/ |
|
@property (nonatomic, assign) CGPoint pageOffset; |
|
|
|
|
|
/** |
|
* 占位图片,在设置图片数组之前设置 |
|
* 不设置则为默认占位图 |
|
*/ |
|
@property (nonatomic, strong) UIImage *placeholderImage; |
|
|
|
|
|
/** |
|
* 轮播的图片数组,可以是本地图片(UIImage,不能是图片名称),也可以是网络路径 |
|
* 支持网络gif图片,本地gif需做处理后传入 |
|
*/ |
|
@property (nonatomic, strong) NSArray *imageArray; |
|
|
|
|
|
/** |
|
* 图片描述的字符串数组,应与图片顺序对应 |
|
* |
|
* 图片描述控件默认是隐藏的 |
|
* 设置该属性,控件会显示 |
|
* 设置为nil或空数组,控件会隐藏 |
|
*/ |
|
@property (nonatomic, strong) NSArray *describeArray; |
|
|
|
|
|
/** |
|
* 每一页停留时间,默认为5s,最少1s |
|
* 当设置的值小于1s时,则为默认值 |
|
*/ |
|
@property (nonatomic, assign) NSTimeInterval time; |
|
|
|
|
|
/** |
|
* 是否开启图片缓存,默认为YES |
|
*/ |
|
@property (nonatomic, assign) BOOL autoCache; |
|
|
|
/** |
|
* gif的播放方式,默认为GifPlayModeAlways |
|
* 淡入淡出模式下修改无效 |
|
*/ |
|
@property (nonatomic, assign) GifPlayMode gifPlayMode; |
|
|
|
/** |
|
* 点击图片后要执行的操作,会返回图片在数组中的索引 |
|
*/ |
|
@property (nonatomic, copy) ClickBlock imageClickBlock; |
|
|
|
|
|
/** |
|
* 代理,用来处理图片的点击 |
|
*/ |
|
@property (nonatomic, weak) id<XRCarouselViewDelegate> delegate; |
|
|
|
|
|
#pragma mark 方法 |
|
|
|
/** |
|
* 开启定时器 |
|
* 默认已开启,调用该方法会重新开启 |
|
*/ |
|
- (void)startTimer; |
|
|
|
|
|
/** |
|
* 停止定时器 |
|
* 停止后,如果手动滚动图片,定时器会重新开启 |
|
*/ |
|
- (void)stopTimer; |
|
|
|
|
|
/** |
|
* 设置分页控件指示器的图片 |
|
* 两个图片必须同时设置,否则设置无效 |
|
* 不设置则为系统默认 |
|
* |
|
* @param image 其他页码的图片 |
|
* @param currentImage 当前页码的图片 |
|
*/ |
|
- (void)setPageImage:(UIImage *)image andCurrentPageImage:(UIImage *)currentImage; |
|
|
|
|
|
/** |
|
* 设置分页控件指示器的颜色 |
|
* 不设置则为系统默认 |
|
* |
|
* @param color 其他页码的颜色 |
|
* @param currentColor 当前页码的颜色 |
|
*/ |
|
- (void)setPageColor:(UIColor *)color andCurrentPageColor:(UIColor *)currentColor; |
|
|
|
|
|
/** |
|
* 修改图片描述控件的部分属性,不需要修改的传nil |
|
* |
|
* @param color 字体颜色,默认为[UIColor whiteColor] |
|
* @param font 字体,默认为[UIFont systemFontOfSize:13] |
|
* @param bgColor 背景颜色,默认为[UIColor colorWithWhite:0 alpha:0.5] |
|
*/ |
|
- (void)setDescribeTextColor:(UIColor *)color font:(UIFont *)font bgColor:(UIColor *)bgColor; |
|
|
|
|
|
/** |
|
* 清除沙盒中的图片缓存 |
|
*/ |
|
+ (void)clearDiskCache; |
|
|
|
@end
|
|
|