iOS 개발 의 터치 이벤트 및 제스처
터치 이벤트:touches Began,touches Moved,touches Ended,touches Cancelled
가속기 사건:motion Began,motion Ended,motion Canceled
원 격 제어 이벤트:remoteControl Received WithEvent
UIVeiw 의 터치 이벤트 처리 과정:
/**
 *        view   
 *
 * @param touches <#touches description#>
 * @param event  <#event description#>
 */
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
   
  NSLog(@"%s",__func__);
}
 
/**
 *     view      
 *
 * @param touches <#touches description#>
 * @param event  <#event description#>
 */
- (void)touchesMoved:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
  NSLog(@"%s",__func__);
}
 
/**
 *      view   
 *
 * @param touches <#touches description#>
 * @param event  <#event description#>
 */
- (void)touchesEnded:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
   
  NSLog(@"%s",__func__);
}
 
/**
 *                
 *
 * @param touches <#touches description#>
 * @param event  <#event description#>
 */
- (void)touchesCancelled:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
   
  NSLog(@"%s",__func__);
}
이 몇 가지 터치 방법 에 대해 서 는 먼저 UITouch 라 는 대상 을 알 아야 한다.한 손가락 이 화면 을 만 지면 연 결 된 UITouch 대상 이 생기 고 한 손가락 은 UITouch 대상 에 대응 합 니 다.이 대상 에는 터치 의 위치,시간,단계 등 이번 터치 의 정보 가 저장 되 어 있 으 며 손가락 이 이동 할 때 시스템 은 같은 UITouch 대상 을 업데이트 합 니 다.손가락 이 있 는 터치 위치 정 보 를 계속 저장 할 수 있 도록 한다.손가락 이 화면 을 떠 날 때 시스템 은 대응 하 는 UITouch 대상 을 소각 합 니 다.
@interface UITouch : NSObject
 
@property(nonatomic,readonly) NSTimeInterval   timestamp;
@property(nonatomic,readonly) UITouchPhase    phase;
@property(nonatomic,readonly) NSUInteger     tapCount;  // touch down within a certain point within a certain amount of time
 
// majorRadius and majorRadiusTolerance are in points
// The majorRadius will be accurate +/- the majorRadiusTolerance
@property(nonatomic,readonly) CGFloat majorRadius NS_AVAILABLE_IOS(8_0);
@property(nonatomic,readonly) CGFloat majorRadiusTolerance NS_AVAILABLE_IOS(8_0);
 
@property(nullable,nonatomic,readonly,strong) UIWindow            *window;
@property(nullable,nonatomic,readonly,strong) UIView             *view;
@property(nullable,nonatomic,readonly,copy)  NSArray <UIGestureRecognizer *> *gestureRecognizers NS_AVAILABLE_IOS(3_2);
 
//      
- (CGPoint)locationInView:(nullable UIView *)view;
//           
- (CGPoint)previousLocationInView:(nullable UIView *)view;
 
// Force of the touch, where 1.0 represents the force of an average touch
@property(nonatomic,readonly) CGFloat force NS_AVAILABLE_IOS(9_0);
// Maximum possible force with this input mechanism
@property(nonatomic,readonly) CGFloat maximumPossibleForce NS_AVAILABLE_IOS(9_0);
 
@end
/**
 *     view      
 *
 * @param touches <#touches description#>
 * @param event  <#event description#>
 */
- (void)touchesMoved:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
  NSLog(@"%s",__func__);
   
  //  UITouch  
  UITouch *touch = [touches anyObject];
   
  //        
  CGPoint curP = [touch locationInView:self];
   
  //         
  CGPoint preP = [touch previousLocationInView:self];
   
  //  x    
  CGFloat offsetX = curP.x - preP.x;
   
  //  y    
  CGFloat offsetY = curP.y = preP.y;
   
  //  view   
  self.transform = CGAffineTransformTranslate(self.transform, offsetX, offsetY);
}이벤트 생 성과 전달:
터치 이벤트 가 발생 하면 시스템 은 이 이 벤트 를 UIApplication 에서 관리 하 는 이벤트 대기 열 에 추가 합 니 다.UIApplication 은 대기 열 에서 맨 앞 에 있 는 이 벤트 를 꺼 내 프로그램의 주 창 에 보 냅 니 다.주 창 은 보기 계층 구조 에서 가장 적합 한 보 기 를 찾 아 터치 이 벤트 를 처리 합 니 다.터치 이벤트 의 전달 은 부모 컨트롤 에서 하위 컨트롤 로 전 달 됩 니 다.부모 컨트롤 이 터치 이 벤트 를 받 아들 일 수 없다 면 하위 컨트롤 은 터치 이 벤트 를 받 아들 일 수 없습니다.
어떻게 가장 적합 한 컨트롤 을 찾 아서 사건 을 처리 합 니까?먼저 터치 사건 을 받 아들 일 수 있 는 지 판단 합 니까?터치 점 은 자신 에 게 있 습 니까?하위 컨트롤 을 뒤로 옮 겨 다 니 며 이전 두 단 계 를 반복 합 니 다.조건 에 맞 는 하위 컨트롤 이 없 으 면 스스로 처리 하 는 것 이 가장 적합 합 니 다.
컨트롤 은 hitTest:withEvent:방법 으로 가장 적합 한 view 를 찾 습 니 다.pointInside 라 는 방법 으로 이 점 이 방법 호출 자 즉 컨트롤 에 있 는 지 판단 합 니 다.
hitTest 방법의 밑바닥 실현:
- (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event {
   
  //               
  if (self.userInteractionEnabled == NO || self.hidden == YES || self.alpha <= 0.01) {
    return nil;
  }
   
  //             
  if ([self pointInside:point withEvent:event] == NO) {
    return nil;
  }
   
  //            
  NSInteger count = self.subviews.count;
  for (NSInteger i = count - 1; i >= 0; i--) {
    UIView *childView = self.subviews[i];
     
    //                     
    CGPoint childPoint = [self convertPoint:point toView:childView];
     
    //    hitTest        view
    UIView *fitView = [childView hitTest:childPoint withEvent:event];
     
    if (fitView) {
      return fitView;
    }
  }
   
  //    ,         view,    
  return self;
   
}구체 적 으로 다음 과 같은 몇 가지 손짓 이 있다.
//    
//  UITapGestureRecognizer *tap = [UITapGestureRecognizer alloc]initWithTarget:<#(nullable id)#> action:<#(nullable SEL)#>
   
  //            
//  UILongPressGestureRecognizer *longP = [UILongPressGestureRecognizer alloc]initWithTarget:<#(nullable id)#> action:<#(nullable SEL)#>
   
  //            
//  UISwipeGestureRecognizer *swipe = [UISwipeGestureRecognizer alloc]initWithTarget:<#(nullable id)#> action:<#(nullable SEL)#>
   
  //    
//  UIRotationGestureRecognizer *rotation = [UIRotationGestureRecognizer alloc]initWithTarget:<#(nullable id)#> action:<#(nullable SEL)#>
 
  //    
//  UIPinchGestureRecognizer *pinch = [UIPinchGestureRecognizer alloc]initWithTarget:<#(nullable id)#> action:<#(nullable SEL)#>
   
  //    
//  UIPanGestureRecognizer *pan = [UIPanGestureRecognizer alloc]initWithTarget:<#(nullable id)#> action:<#(nullable SEL)#>
@interface ViewController ()<UIGestureRecognizerDelegate>
@property (weak, nonatomic) IBOutlet UIImageView *imageView;
 
@end
 
@implementation ViewController
 
- (void)viewDidLoad {
  [super viewDidLoad];
 
  [self setUpPinch];
   
  [self setUpRotation];
 
  [self setUpPan];
   
}
#pragma mark -       
//           
//- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer
//{
//  return NO;
//}
 
//             ,          
//   yes        
- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer
{
  return YES;
}
 
//             
//- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldReceiveTouch:(UITouch *)touch{
//  //         
//  CGPoint curP = [touch locationInView:self.imageView];
//  
//  if (curP.x < self.imageView.bounds.size.width * 0.5) {
//    return NO;
//  }else{
//    return YES;
//  }
//}
 
 
#pragma mark -     
 
- (void)setUpTap
{
  //       
  UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tap:)];
   
  tap.delegate = self;
   
  [_imageView addGestureRecognizer:tap];
}
 
- (void)tap:(UITapGestureRecognizer *)tap
{
  NSLog(@"%s",__func__);
}
 
#pragma mark -     
//        
- (void)setUpLongPress
{
  UILongPressGestureRecognizer *longPress = [[UILongPressGestureRecognizer alloc] initWithTarget:self action:@selector(longPress:)];
   
  [self.imageView addGestureRecognizer:longPress];
}
 
 
- (void)longPress:(UILongPressGestureRecognizer *)longPress
{
   
  if (longPress.state == UIGestureRecognizerStateBegan) {
     
    NSLog(@"%s",__func__);
  }
}
 
#pragma mark -   
- (void)setUpSwipe
{
  //           
  UISwipeGestureRecognizer *swipe = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipe)];
   
  swipe.direction = UISwipeGestureRecognizerDirectionUp;
   
  [self.imageView addGestureRecognizer:swipe];
   
  //                    ,          ,             
  //           
  UISwipeGestureRecognizer *swipeDown = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipe)];
   
  swipeDown.direction = UISwipeGestureRecognizerDirectionDown;
   
  [self.imageView addGestureRecognizer:swipeDown];
 
   
}
 
- (void)swipe
{
  NSLog(@"%s",__func__);
}
 
#pragma mark -     
- (void)setUpRotation
{
  UIRotationGestureRecognizer *rotation = [[UIRotationGestureRecognizer alloc] initWithTarget:self action:@selector(rotation:)];
  rotation.delegate = self;
  [self.imageView addGestureRecognizer:rotation];
}
 
//                      
- (void)rotation:(UIRotationGestureRecognizer *)rotation
{
   
  self.imageView.transform = CGAffineTransformRotate(self.imageView.transform, rotation.rotation);
   
  //   
  rotation.rotation = 0;
   
  //          
  NSLog(@"%f",rotation.rotation);
}
 
#pragma mark -   
- (void)setUpPinch
{
  UIPinchGestureRecognizer *pinch = [[UIPinchGestureRecognizer alloc] initWithTarget:self action:@selector(pinch:)];
  pinch.delegate = self;
  [self.imageView addGestureRecognizer:pinch];
}
 
- (void)pinch:(UIPinchGestureRecognizer *)pinch
{
  self.imageView.transform = CGAffineTransformScale(self.imageView.transform, pinch.scale, pinch.scale);
   
  //   
   
  pinch.scale = 1;
}
 
#pragma mark -   
- (void)setUpPan
{
  UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(pan:)];
   
   
  [self.imageView addGestureRecognizer:pan];
}
 
- (void)pan:(UIPanGestureRecognizer *)pan
{
  //         
  // CGPoint curP = [pan locationInView:self.imageView];
   
  //     
  //        ,           
  CGPoint transP = [pan translationInView:self.imageView];
   
  self.imageView.transform = CGAffineTransformTranslate(self.imageView.transform, transP.x, transP.y);
   
  //   
  [pan setTranslation:CGPointZero inView:self.imageView];
   
 // NSLog(@"%@",NSStringFromCGPoint(curP));
}
 
@end이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
View의 레이아웃 방법을 AutoLayout에서 따뜻한 손 계산으로 하면 성능이 9.26배로 된 이야기이 기사는 의 15 일째 기사입니다. 어제는 에서 이었습니다. 손 계산을 권하는 의도는 없고, 특수한 상황하에서 계측한 내용입니다 화면 높이의 10 배 정도의 contentView가있는 UIScrollView 레이아...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.