iOS 一款可绕指定点旋转、缩放的多功能贴纸
2017-03-23 本文已影响149人
Genie_GY
iOS 一款可绕指定点旋转、缩放的多功能贴纸
支持双指手势操作,单指移动控制图操作,满足你所有需求
</br>
先上效果图:
data:image/s3,"s3://crabby-images/31c41/31c410a4f206b86b3808f5342cb931c57df79b74" alt=""
</br>
</br>
示例用法:
把Demo中GYStickerView文件夹添加到项目,#import "GYStickerView.h"
CtrlTypeGesture:双指手势模式,支持等比缩放,绕中心旋转,可设置ScaleMode(缩放模式,通过改变bounds或transform达到缩放效果)
示例代码:
GYStickerView *stickerView = [[GYStickerView alloc] initWithContentView:yourCustomView];
stickerView.ctrlType = GYStickerViewCtrlTypeGesture;
stickerView.scaleMode = GYStickerViewScaleModeTransform;
[self.view addSubview:stickerView];
效果:
data:image/s3,"s3://crabby-images/d242a/d242a1211082fa7726d331f60367a0734a2006a2" alt=""
</br>
CtrlTypeOne:一个控制图模式,同时控制旋转和缩放,支持等比缩放,可设置绕指定点旋转,可设置ScaleMode
示例代码:
GYStickerView *stickerView = [[GYStickerView alloc] initWithContentView:yourCustomView];
stickerView.ctrlType = GYStickerViewCtrlTypeOne;
stickerView.scaleMode = GYStickerViewScaleModeTransform;
stickerView.originalPoint = CGPointMake(0.2, 0.2);
[stickerView showOriginalPoint:YES];
[self.view addSubview:stickerView];
效果:
data:image/s3,"s3://crabby-images/959af/959affe424c430b42e31f45710274b6ca705b131" alt=""
</br>
CtrlTypeTwo:两个控制图模式,右下角控制图控制缩放,右上角控制图控制旋转,支持等比缩放和自由缩放,可设置绕指定点旋转,可设置ScaleMode
注意:自由缩放不支持ScaleModeTransform
示例代码:
GYStickerView *stickerView = [[GYStickerView alloc] initWithContentView:yourCustomView];
stickerView.ctrlType = GYStickerViewCtrlTypeTwo;
stickerView.scaleMode = GYStickerViewScaleModeBounds;
stickerView.scaleFit = YES;
stickerView.originalPoint = CGPointMake(-0.2, -0.2);
[stickerView showOriginalPoint:YES];
[self.view addSubview:stickerView];
效果:
data:image/s3,"s3://crabby-images/48b34/48b341f4ad74239109c6cbb5067ba5860ac732bf" alt=""
</br>
</br>
</br>
部分属性分析:
指定点originalPoint
/**
指定参考点(比例),不设置默认为中心点 CGPoint(0.5, 0.5)
范围:x: 0 --- 1
y: 0 --- 1
提示:可以超出范围,设置参考点在self外面
注意:CtrlTypeGesture 仅支持中心点,该属性无效
*/
@property (nonatomic) CGPoint originalPoint;
可通过方法(showOriginalPoint:)显示红色的指定参考点
</br>
效果:</br>
data:image/s3,"s3://crabby-images/6745b/6745b220a89b2c33deee131a1e103d7606facb5d" alt=""
是否为等比缩放scaleFit
/**
等比缩放 : YES
自由缩放 : NO
注意:1、仅适用于CtrlTypeTwo的缩放,默认YES.
2、与ScaleModeTransform不兼容,待完善
*/
@property (nonatomic, getter=isScaleFit) BOOL scaleFit;
等比缩放:</br>
data:image/s3,"s3://crabby-images/70f54/70f548492f51655f05b6df0d170372a39978a7a8" alt=""
自由缩放:</br>
data:image/s3,"s3://crabby-images/4bdf1/4bdf14ba66a153a72f424a3531c5515608082f30" alt=""
</br>
缩放模式scaleMode
typedef NS_ENUM(NSInteger, GYStickerViewScaleMode) {
GYStickerViewScaleModeBounds, //通过改变self.bounds达到缩放效果
GYStickerViewScaleModeTransform //通过改变self.transform达到缩放效果
};
@property (nonatomic) GYStickerViewScaleMode scaleMode;
ScaleModeBounds:</br>
data:image/s3,"s3://crabby-images/2ffc6/2ffc6e058f8ab39b9a9bae2c8f7698a1f5c5ddb5" alt=""
ScaleModeTransform:</br>
data:image/s3,"s3://crabby-images/64281/64281269c21ca367086153765bc44d0d23972f9e" alt=""
</br>