WKCImageEditorTool
图片编辑工具,如滤镜、亮度调节、旋转、画笔、贴图、马赛克、文本、裁剪.
主体使用:
pod 'WKCImageEditorTool'
#import <WKCImageEditorTool/WKCImageEditorTool.h>
主体 WKCImageEditorTool 有三个代理回调.
- 回调编辑中的图片 - 展示效果用(滤镜、旋转、亮度模式有效).
- (void)imageEditorTool:(WKCImageEditorTool *)tool
editingImage:(UIImage *)editing;
- 回调编辑确认的图片
- (void)imageEditorTool:(WKCImageEditorTool *)tool
editedImage:(UIImage *)edited;
- 彻底取消,回调原始图
- (void)imageEditorTool:(WKCImageEditorTool *)tool
cancelImage:(UIImage *)cancel;
具体的各个工具属性设置,去设置各个tool属性.
/**滤镜工具*/
@property (nonatomic, strong) WKCFilterTool * filterTool;
/**旋转工具*/
@property (nonatomic, strong) WKCRotationTool * rotationTool;
/**画笔工具*/
@property (nonatomic, strong) WKCDrawTool * drawTool;
/**贴图工具*/
@property (nonatomic, strong) WKCStickersTool * stickerTool;
/**马赛克工具*/
@property (nonatomic, strong) WKCMosaicTool * mosaicTool;
/**文本工具*/
@property (nonatomic, strong) WKCTextTool * textTool;
/**亮度工具*/
@property (nonatomic, strong) WKCBrightTool * brightTool;
/**裁剪工具*/
@property (nonatomic, strong) WKCClipTool * clipTool;
滤镜
源图与滤镜后的图都会在子线程强制解析,提升imageView的显示效率,解析后缓存,再在主线程回调.再次加载会加载缓存图片.
- 使用.
- (WKCImageEditorTool *)editorTool {
if (!_editorTool) {
_editorTool = [[WKCImageEditorTool alloc] initWithFrame:self.imageView.bounds sourceImage:self.imageView.image];
_editorTool.editorType = WKCImageEditorToolTypeFilter;
_editorTool.delegate = self;
}
return _editorTool;
}
/**添加到父视图*/
[self.imageView addSubview:self.editorTool];
/**设置类型为滤镜,在触发事件内,设置类型,开启使用*/
self.editorTool.filterTool.filterType = WKCFilterTypeInstant;
[self.editorTool fire];
使用完成后,工具会自动关闭.某些模式下需要手动,调用- (void)confirm;
去回调结果并关闭(例如画笔、图贴等,需要编辑完成再确认操作的).
data:image/s3,"s3://crabby-images/051c4/051c4333c6eec1daaf2b583fad9287590dbf3fdc" alt=""
data:image/s3,"s3://crabby-images/68905/6890529a12fbd1e966cfe949ccc802db193dd079" alt=""
data:image/s3,"s3://crabby-images/c0067/c00679230c5454fa8594fd4ba6448b92d80f72b6" alt=""
data:image/s3,"s3://crabby-images/c3384/c3384d4c0cd3d05b3859608916b1f8964cce2242" alt=""
data:image/s3,"s3://crabby-images/bef3c/bef3c90d0418c8e137af695efe66b1ac5ba3d68a" alt=""
data:image/s3,"s3://crabby-images/aa298/aa2985599841d9f11446dce666da37a2f5bfc701" alt=""
data:image/s3,"s3://crabby-images/91b1e/91b1e921af75337fb22ab89c96a023e07cf5c2d2" alt=""
data:image/s3,"s3://crabby-images/8058d/8058d043dc76526a4ace9c10f0b90452e551ba39" alt=""
还有一些特效类型.
data:image/s3,"s3://crabby-images/5a04f/5a04fbbabb169eebc90cfedebd0b7da49cf650cc" alt=""
data:image/s3,"s3://crabby-images/0591e/0591eefe4bd86b0cb87dc3a00e3737eb78222b98" alt=""
data:image/s3,"s3://crabby-images/c0255/c02551f829ea3de923007110a4fb52ca4e6c3478" alt=""
data:image/s3,"s3://crabby-images/325f0/325f08959f256467b42585122a0bf53824ff3e39" alt=""
data:image/s3,"s3://crabby-images/47123/47123c6dfded7311be4429a874b31698036ac872" alt=""
等等,其他类型详见末尾Demo.
旋转
/**初始化*/
- (WKCImageEditorTool *)editorTool {
if (!_editorTool) {
_editorTool = [[WKCImageEditorTool alloc] initWithFrame:self.imageView.bounds sourceImage:self.imageView.image];
_editorTool.editorType = WKCImageEditorToolTypeRotation;
_editorTool.delegate = self;
}
return _editorTool;
}
/**事件触发内*/
[self.editorTool fire];
self.editorTool.rotationTool.rotationType = WKCImageRotationTypeOrientationLeft;
效果图:
data:image/s3,"s3://crabby-images/6ca2d/6ca2d8374bfdd74beedb21d43c5c2c4955b6d090" alt=""
画笔
/**初始化*/
- (WKCImageEditorTool *)editorTool {
if (!_editorTool) {
_editorTool = [[WKCImageEditorTool alloc] initWithFrame:self.imageView.bounds sourceImage:self.imageView.image];
_editorTool.editorType = WKCImageEditorToolTypeDraw;
_editorTool.delegate = self;
}
return _editorTool;
}
/**开启*/
[self.editorTool fire];
/**确认*/
[self.editorTool confirm];
效果图:
data:image/s3,"s3://crabby-images/7d5c7/7d5c72ac97148b440015cb9897c34da34f7d2cd2" alt=""
贴图
贴图与上边有些区别.贴图初始时需要设置贴图和删除键.其有另外的初始方法.(但仍包含上述方法的初始,各初始化是递进关系,并不是单一关系).
/**初始化*/
- (WKCImageEditorTool *)editorTool {
if (!_editorTool) {
_editorTool = [[WKCImageEditorTool alloc] initWithFrame:self.imageView.bounds sourceImage:self.imageView.image stickerImage:[UIImage imageNamed:@"toolBar_stickes_1"] deleteImage:[UIImage imageNamed:@"toolBar_stickes_delete"]];
_editorTool.editorType = WKCImageEditorToolTypeSticker;
_editorTool.delegate = self;
}
return _editorTool;
}
其他方法相同,之后不重复写了.
/**橡皮擦*/
[self.editorTool.drawTool eraser];
效果图:
data:image/s3,"s3://crabby-images/60b93/60b93892603ed5426e6494a3ba6224ccad7ea364" alt=""
马赛克
/**初始化*/
- (WKCImageEditorTool *)editorTool {
if (!_editorTool) {
_editorTool = [[WKCImageEditorTool alloc] initWithFrame:self.imageView.bounds sourceImage:self.imageView.image];
_editorTool.editorType = WKCImageEditorToolTypeMosaic;
_editorTool.delegate = self;
}
return _editorTool;
}
效果图:
data:image/s3,"s3://crabby-images/88c25/88c259ed8e62e969e9d73bd263696da911622cf2" alt=""
文本
文本也要个别的初始化方法.
- (WKCImageEditorTool *)editorTool {
if (!_editorTool) {
_editorTool = [[WKCImageEditorTool alloc] initWithFrame:self.imageView.bounds sourceImage:self.imageView.image textDelete:[UIImage imageNamed:@"toolBar_stickes_delete"]];
_editorTool.editorType = WKCImageEditorToolTypeText;
_editorTool.delegate = self;
}
return _editorTool;
}
效果图:
data:image/s3,"s3://crabby-images/9cc50/9cc50428bd9c14e843aee60e9595b00382491cf6" alt=""
亮度、对比度、饱和度
/**初始化*/
- (WKCImageEditorTool *)editorTool {
if (!_editorTool) {
_editorTool = [[WKCImageEditorTool alloc] initWithFrame:self.imageView.bounds sourceImage:self.imageView.image];
_editorTool.editorType = WKCImageEditorToolTypeBright;
_editorTool.delegate = self;
}
return _editorTool;
}
/**调用*/
- (IBAction)valueChanged:(UISlider *)sender {
NSLog(@"值是%f",sender.value);
[self.editorTool.brightTool brightWithType:WKCBrightTypeLight value:sender.value];
[self.editorTool fire];
}
效果图:
data:image/s3,"s3://crabby-images/c1aa9/c1aa986d85e16aeb498e17394a944f6dbd16853d" alt=""
裁剪
- (WKCImageEditorTool *)editorTool {
if (!_editorTool) {
_editorTool = [[WKCImageEditorTool alloc] initWithFrame:self.imageView.bounds sourceImage:self.imageView.image];
_editorTool.editorType = WKCImageEditorToolTypeClip;
_editorTool.delegate = self;
}
return _editorTool;
}
效果图:
data:image/s3,"s3://crabby-images/43cbf/43cbff3c4ba2f27f200f9e282f8100f9c47917fd" alt=""
混合使用
当将所有工具在一个界面组合成一个编辑工具时,每次确认时,默认会更新源图,无需再特意处理.
如有bug或问题,请私信.github地址.
网友评论