【转】IOS的处理touch事件处理(依照手指的移动移动一个圆,开发环境用的ios7,storyboard)-- 不错
原文网址:http://blog.csdn.net/baidu_nod/article/details/32934565
先看下页面的效果图:
首先定义这个ball它有两个属性和两个方法:
@property(nonatomic) CGPoint location;
@property(nonatomic) CGFloat length;
-(CGPoint) getCenterPoint;
-(BOOL) isInTheBall:(CGPoint) point;
方法体是:
- //找出ball的中心点
- -(CGPoint) getCenterPoint {
- return CGPointMake((self.location.x+self.length/2), self.location.y+self.length/2);
- };
- //看点point是不是在ball的范围内
- -(BOOL) isInTheBall:(CGPoint) point{
- CGPoint center = self.getCenterPoint;
- float t = (point.x - center.x) * (point.x - center.x);
- float y = (point.y - center.y) * (point.y - center.y);
- float k = sqrtf(t+y);
- if (k < self.length/2) {
- return YES;
- }else {
- return NO;
- }
- };
定义BallView继承UIView
- @property(nonatomic) Ball* ball;
- @property(nonatomic) BOOL isTouch; //表示手指在ball的范围内移动
- @property(nonatomic) CGPoint prePoint; //手指在进入move事件之前的那个点
- - (id)initWithBall:(CGRect)frame aBall:(Ball*) ball; //初始化方法
初始化函数为:
- - (id)initWithBall:(CGRect)frame aBall:(Ball*) ball
- {
- self = [super initWithFrame:frame];
- if (self) {
- // Initialization code
- self.ball = ball;
- }
- return self;
- }
- -(void)awakeFromNib{
- self.backgroundColor = nil;
- self.opaque = NO;
- }
- // Only override drawRect: if you perform custom drawing.
- // An empty implementation adversely affects performance during animation.
- - (void)drawRect:(CGRect)rect
- {
- // Drawing code
- [super drawRect:rect];
- CGContextRef contextRef = UIGraphicsGetCurrentContext();
- [[UIColor whiteColor] set];
- //rect是整个view
- CGContextFillRect(contextRef, rect);
- [[UIColor redColor] set];
- //CGContextAddEllipseInRect不会填充圆圈的内部
- // CGContextAddEllipseInRect(contextRef, CGRectMake(200.0f, 200.0f, 50.0f, 50.0f));
- CGContextFillEllipseInRect(contextRef, CGRectMake(self.ball.location.x,self.ball.location.y,self.ball.length,self.ball.length));
- CGContextStrokePath(contextRef);
- }
我们在viewController里初始化只要:
- -(void) loadView{
- [super loadView];
- Ball* ball = [[Ball alloc] init];
- ball.location = CGPointMake(200.0f, 100.0f);
- ball.length = 80.0f;
- BallView* view = [[BallView alloc] initWithBall:[UIScreen mainScreen].bounds aBall:ball];
- [self.view addSubview:view];
- }
然后在下面在BallView中进行事件处理
- -(void) touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{
- NSLog(@"touchesBegan");
- //下面两句知道手指在屏幕上的点的信息
- UITouch* touch = [touches anyObject];
- CGPoint point = [touch locationInView:self];
- if ([self.ball isInTheBall:point]) {
- self.isTouch = YES;
- self.prePoint = point;
- }else{
- self.isTouch = NO;
- }
- NSLog(@"x=%f,y=%f",point.x,point.y);
- }
- -(void) touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event{
- NSLog(@"touchesMoved");
- if (self.isTouch) {
- CGRect preRect = CGRectMake(self.ball.location.x, self.ball.location.y, self.ball.length, self.ball.length);
- //先用之前的location绘制一遍
- [self setNeedsDisplayInRect:preRect];
- UITouch* touch = [touches anyObject];
- CGPoint point = [touch locationInView:self];
- //cx和cy是手指的偏移量,用他们可以计算出新的location
- float cx = point.x - self.prePoint.x;
- float cy = point.y - self.prePoint.y;
- self.ball.location = CGPointMake(self.ball.location.x + cx, self.ball.location.y+cy);
- CGRect newRect = CGRectMake(self.ball.location.x, self.ball.location.y, self.ball.length, self.ball.length);
- //用新的location绘制一遍
- [self setNeedsDisplayInRect:newRect];
- self.prePoint = point;
- }
- }
- -(void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event{
- NSLog(@"touchesEnded");
- self.isTouch = NO;
- }
代码可以在http://download.csdn.net/detail/baidu_nod/7533317下载
ios-day17-01(UIView的拖拽(跟随手指移动))
原文网址:http://www.ithao123.cn/content-7926067.html
源码下载地址:http://download.csdn.net/detail/liu537192/8544289
【转】IOS的处理touch事件处理(依照手指的移动移动一个圆,开发环境用的ios7,storyboard)-- 不错的更多相关文章
- IOS的处理touch事件处理(按照手指的移动移动一个圆,开发环境用的ios7,storyboard)
先看下页面的效果图: 首先定义这个ball它有两个属性和两个方法: @property(nonatomic) CGPoint location; @property(nonatomic) CGFloa ...
- ios学习笔记(一)Windows7上使用VMWare搭建iPhone开发环境(转)
原文地址:http://blog.csdn.net/shangyuan21/article/details/18153605 我们都知道开发iPhone等ios平台的移动应用时需要使用Mac本,但是M ...
- ios学习笔记(一)Windows7上使用VMWare搭建iPhone开发环境
我们都知道开发iPhone等ios平台的移动应用时需要使用Mac本,但是Mac本都比较昂贵,所以我们可以采用Windows7上利用VMWare安装Mac操作系统的方法来模拟ios开发环境,达到降低成本 ...
- Cocoa Touch事件处理流程--响应者链
Cocoa Touch事件处理流程--响应者链 作者:wangzz 原文地址:http://blog.csdn.net/wzzvictory/article/details/9264335 转载请注明 ...
- Android touch事件处理流程
前面我们看了key事件的处理流程,相信大家对此已经有了新的认识,这篇文章我打算带领大家来看看稍微复杂些的touch 事件的处理流程.说它复杂是因为key事件本身就key down,up,long pr ...
- Android的Touch事件处理机制
Android的Touch事件处理机制比较复杂,特别是在考虑了多点触摸以及事件拦截之后. Android的Touch事件处理分3个层面:Activity层,ViewGroup层,View层. 首先说一 ...
- 移动端的touch事件处理
简要的探讨一下移动端 touch 事件处理几个坑,以及相应的简单处理方法. click 穿透 假设有个弹出层,上面有个关闭的按钮支持 touchend 触发后关闭,若正好下方有个元素支持 click ...
- 自定义View系列教程06--详解View的Touch事件处理
深入探讨Android异步精髓Handler 站在源码的肩膀上全解Scroller工作机制 Android多分辨率适配框架(1)- 核心基础 Android多分辨率适配框架(2)- 原理剖析 Andr ...
- iOS开发教程之:iPhone开发环境搭建
安装条件: 硬件:一台拥有支持虚拟技术的64位双核处理器和2GB以上内存的PC. 注意:运行MAC OS,需要电脑支持虚拟技术(VT),安装时,需要将VT启动,在BIOS中开启. 软件: Window ...
随机推荐
- 《WPF程序设计指南》读书笔记——第8章 依赖属性
1.依赖属性的效果 一旦规定视觉树上一个对象的fontsize属性,那么属于他的节点之下的所有对象都会沿袭这个属性,然而如果某个子节点明确的设定了自己的fontsize,就不会沿袭父节点的fontsi ...
- N皇后摆放问题
Description 在N*N的方格棋盘放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在与棋盘边框成45角的斜线上. 你的任务是,对于给定的N,求出有多少种 ...
- python logging 日志轮转文件不删除问题
前言 最近在维护项目的python项目代码,项目使用了 python 的日志模块 logging, 设定了保存的日志数目, 不过没有生效,还要通过contab定时清理数据. 分析 项目使用了 logg ...
- 【BZOJ 2654】tree
Description 给你一个无向带权连通图,每条边是黑色或白色.让你求一棵最小权的恰好有need条白色边的生成树. 题目保证有解. Input 第一行V,E,need分别表示点数,边数和需要的白色 ...
- 0ffice365 Calendar API
Calendar REST API in Office 365 APIs Preview http://msdn.microsoft.com/EN-US/library/office/dn792114 ...
- MYSQL系列1_MySQL的安装,可视化工具的使用,以及建库建表等
大家都知道MYSQL是开源的数据库,现在MYSQL在企业中的使用也越来越多,本人之前用过SQL SERVER数据库,因业务需要和自己的兴趣想要学习MYSQL,对于MYSQL,本人还是新手,请大家多多指 ...
- poj 1679 The Unique MST(唯一的最小生成树)
http://poj.org/problem?id=1679 The Unique MST Time Limit: 1000MS Memory Limit: 10000K Total Submis ...
- 实时数据处理环境搭建flume+kafka+storm:2.flume 安装
1. 解压 tar -zxvf 2.配置 拷贝配置文件 :cp flume-conf.properties.template flume-conf.properties ...
- ionicPopup确认对话框
$ionicPopup.confirm({ title: $rootScope.app_name, template: 'Do you want to add this to database?', ...
- 响应式菜单(bootstrap)
<nav class="navbar navbar-default" role="navigation"> <div class=" ...