这篇文章主要为大家展示了“iOS如何实现一个可以在屏幕中自由移动的按钮”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“iOS如何实现一个可以在屏幕中自由移动的按钮”这篇文章吧。
松岭网站制作公司哪家好,找成都创新互联!从网页设计、网站建设、微信开发、APP开发、响应式网站开发等网站项目制作,到程序开发,运营维护。成都创新互联2013年至今到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选成都创新互联。
效果图如下:
其实实现很简单,只需要写.m就可以了
示例代码
#import "CrossBtnVC.h"
@interface CrossBtnVC () { CGPoint beginPoint; CGFloat rightMargin; CGFloat leftMargin; CGFloat topMargin; CGFloat bottomMargin; CGMutablePathRef pathRef; } @property (nonatomic,strong) UIButton *crossBtn;//聊天移动 @end
@implementation CrossBtnVC
- (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor = [UIColor whiteColor]; _crossBtn = [UIButton buttonWithType:UIButtonTypeCustom]; [_crossBtn setImage:[UIImage imageNamed:@"移动聊天"] forState:UIControlStateNormal]; _crossBtn.frame = CGRectMake(UI_View_Width-54*UI_Width_Scale, UI_View_Height-103, 40, 40); [self.view addSubview:_crossBtn]; [_crossBtn addTarget:self action:@selector(btnAction:) forControlEvents:UIControlEventTouchUpInside]; UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(handlePan:)]; [_crossBtn addGestureRecognizer:pan]; rightMargin = [UIScreen mainScreen].bounds.size.width-30; leftMargin = 30; bottomMargin = [UIScreen mainScreen].bounds.size.height-30-50; topMargin = 30+64; pathRef=CGPathCreateMutable(); CGPathMoveToPoint(pathRef, NULL, leftMargin, topMargin); CGPathAddLineToPoint(pathRef, NULL, rightMargin, topMargin); CGPathAddLineToPoint(pathRef, NULL, rightMargin, bottomMargin); CGPathAddLineToPoint(pathRef, NULL, leftMargin, bottomMargin); CGPathAddLineToPoint(pathRef, NULL, leftMargin, topMargin); CGPathCloseSubpath(pathRef); }
#pragma mark - 事件 - (void)btnAction:(UIButton*)sender{ }
#pragma mark - 手势 - (void)handlePan:(UIPanGestureRecognizer *)pan { if (pan.state == UIGestureRecognizerStateBegan) { beginPoint = [pan locationInView:self.view]; }else if (pan.state == UIGestureRecognizerStateChanged){ CGPoint nowPoint = [pan locationInView:self.view]; float offsetX = nowPoint.x - beginPoint.x; float offsetY = nowPoint.y - beginPoint.y; CGPoint centerPoint = CGPointMake(beginPoint.x + offsetX, beginPoint.y + offsetY); if (CGPathContainsPoint(pathRef, NULL, centerPoint, NO)) { _crossBtn.center = centerPoint; }else{ if (centerPoint.y>bottomMargin) { if (centerPoint.xleftMargin) { _crossBtn.center = CGPointMake(beginPoint.x + offsetX, bottomMargin); } } else if (centerPoint.y leftMargin) { _crossBtn.center = CGPointMake(beginPoint.x + offsetX, topMargin); } } else if (centerPoint.x>rightMargin) { _crossBtn.center = CGPointMake(rightMargin, beginPoint.y + offsetY); } else if (centerPoint.x 以上是“iOS如何实现一个可以在屏幕中自由移动的按钮”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
网站栏目:iOS如何实现一个可以在屏幕中自由移动的按钮
文章链接:http://kswsj.cn/article/jeogog.html