A Quartz/UIKit drawing tool for IOS. Include geometry/Context convenient method, image processing, along path drawing, polygon path, gradient fill, 3D inner outer shadow glow render, gauss blur, animation effect, attributed Text Drawing.
Quartz / UIKit 绘画工具箱,汇集常用几何和Context操作方法、图像效果处理、路径绘图、多变形状、渐变填充、3D内外阴影高光渲染、高斯模糊、动画效果及属性文本绘制。
##安装 ###1、使用Cocoapods
pod 'XFCrystalKit','1.0.1'
###2、手动加入
把 XFCrystalKit
目录拖入到工程下.
##开发文档
###基本Rect方法XFGeometryFunc
/** 从CGPoint和CGSize创建CGRect */
CGRect RectMakeRect(CGPoint origin,CGSize size);
/** 从CGSize创建CGRect */
CGRect SizeMakeRect(CGSize size);
/** 从两点创建CGRect */
CGRect PointsMakeRect(CGPoint p1, CGPoint p2);
/** 从原点创建CGRect */
CGRect OriginMakeRect(CGPoint origin);
/** 从中心点和大小范围创建一个矩形 */
CGRect RectAroundCenter(CGPoint center, CGSize size);
/** 创建一个子矩形在父矩形中居中 */
CGRect RectCenteredInRect(CGRect rect, CGRect containerRect);
/** 按比例缩放大小 */
CGSize SizeScaleByFactor(CGSize aSize, CGFloat factor);
/** 获得源Rect到目标Rect的比例大小*/
CGSize RectGetScale(CGRect sourceRect, CGRect destRect);
/** 计算Fit方式缩放比例 */
CGFloat AspectScaleFit(CGSize sourceSize, CGRect destRect);
/** 计算Fit方式填充后的矩形 */
CGRect RectByFittingInRect(CGRect sourceRect,CGRect destinationRect);
/** 计算Fill方式缩放比例 */
CGFloat AspectScaleFill(CGSize sourceSize, CGRect destRect);
/** 计算Fill方式填充后的矩形 */
CGRect RectByFillingRect(CGRect sourceRect, CGRect destinationRect);
/** 创建一个子矩形在父矩形中居中的百分比大小 */
CGRect RectInsetByPercent(CGRect destinationRect,CGFloat percent);
/** 获得矩形的中心点 */
CGPoint RectGetCenter(CGRect rect);
/** 求两点之间的距离*/
CGFloat PointDistanceFromPoint(CGPoint p1, CGPoint p2);
// 其它...
###绘制类XFCrystal
####1、以image
开头的方法会返回绘制完成的图片,如:
/**
* 给图像添加文字水印
*
* @param image 原图
* @param copyright 水印文字
* @param font 字体样式
* @param textColor 文字颜色
* @param position 放置中心点
* @param rotation 旋转弧度 使用M_PI等
* @param blendMode 混合模式
*
* @return 加水印图像
*/
+ (UIImage *)imageForWatermarkFrom:(UIImage *)image text:(NSString *)copyright font:(UIFont *)font color:(UIColor *)textColor renderPosition:(CGPoint)position rotation:(CGFloat)rotation blendMode:(CGBlendMode)blendMode;
/**
* 通过原图得到一张目标大小的缩略图
*
* @param sourceImage 原图
* @param thumbSize 缩略图大小
* @param fitting 是fit还是fill
*
* @return 缩略图
*/
+ (UIImage *)imageThumbnailBuildFrom:(UIImage *)sourceImage targetSize:(CGSize)thumbSize useFitting:(BOOL)fitting;
/**
* 截取一小块图片
*
* @param sourceImage 原图
* @param rect 截取区域
*
* @return 截取图片
*/
+ (UIImage *)imageExtractRectFrom:(UIImage *)sourceImage subRect:(CGRect)rect;
/**
* 转换彩图到到灰图
*
* @param sourceImage 原图
*
* @return 灰图
*/
+ (UIImage *)imageConvert2GrayFrom:(UIImage *)sourceImage;
/**
* 转换成高斯模糊图像
*
* @param image 原图像
* @param radius 模糊半径
*
* @return 模糊图像
*/
+ (UIImage *)imageGaussianBlurFrom:(UIImage *)image radius:(NSInteger)radius;
####2、以draw
开头的方法是当前的context上绘制,如:
/**
* 根据不同的模式在当前Context绘制图像
*
* @param image 原图
* @param rect 目标大小
* @param pattern 绘制模式
*/
+ (void)drawImage:(UIImage *)image targetRect:(CGRect)rect drawingPattern:(XFImageDrawingPattern)pattern;
/**
* 绘制一页pdf到某个区域
*
* @param pdfPath pdf路径
* @param pageNum 要绘制的页数,下标从1开始
* @param destinationRect 绘制的目标位置
*/
+ (void)drawPDFPageWithFilePath:(NSString *)pdfPath pageNumber:(NSUInteger)pageNum toTargetRect:(CGRect)destinationRect;
/**
* 在某一个Rect中绘制文本
*
* @param text 文本
* @param font 字体
* @param textColor 文字颜色
* @param rect 绘制的目标位置
*/
+ (void)drawString:(NSString *)text font:(UIFont *)font color:(UIColor *)textColor centeredInRect:(CGRect)rect;
/**
* 绘制一个pattern color image
*
* @param targetSize 目标大小
* @param drawBlock 绘制内容
*
*/
+ (UIImage *)drawPatternColorImageWithSize:(CGSize)targetSize drawBlock:(void(^)(CGContextRef context,CGRect rect))drawBlock;
/**
* 绘制路线图案进度
*
* @param patternPath 绘制路径
* @param maxPercent 百分点
* @param drawTilePathBlock 进度小图绘制Block(当前个数,百分点,绘制中心点,颜色变化增量) 如:
UIColor *color = [UIColor colorWithWhite:index * colorDLevel alpha:1];
CGRect r = RectAroundCenter(currentPoint, CGSizeMake(2, 2));
UIBezierPath *marker = [UIBezierPath bezierPathWithOvalInRect:r];
[marker fill:color];
*/
+ (void)drawProgressionOfPath:(UIBezierPath *)patternPath maxPercent:(CGFloat) maxPercent drawTilePathBlock:(void(^)(float index,float percent,CGPoint currentPoint,float colorDLevel))drawTilePathBlock;
####3、一个组合多绘制方法例子
UIImage *sourceImage = [UIImage imageNamed:@"gujian2"];
// 创建截取区域
CGRect clipArea = RectInsetByPercent(rect, 0.75f);
UIBezierPath *path = [UIBezierPath bezierPathWithRect:clipArea];
[XFCrystal drawClipPath:path.CGPath drawBlock:^(CGContextRef context) {
// 在截取区域内绘制居中显示灰图
UIImage *grayImage = [XFCrystal imageConvert2GrayFrom:sourceImage];
[XFCrystal drawImage:grayImage targetRect:rect drawingPattern:XFImageDrawingPatternCenter];
}];
##Author Yizzuide, [email protected]
XFCrystalKit is available under the MIT license. See the LICENSE file for more info.