Merge pull request #57605 from naithar/fix/godot-view-touch-4.0
This commit is contained in:
commit
5b866426fd
|
@ -59,4 +59,9 @@ class String;
|
||||||
- (void)stopRendering;
|
- (void)stopRendering;
|
||||||
- (void)startRendering;
|
- (void)startRendering;
|
||||||
|
|
||||||
|
- (void)godotTouchesBegan:(NSSet *)touches withEvent:(UIEvent *)event;
|
||||||
|
- (void)godotTouchesMoved:(NSSet *)touches withEvent:(UIEvent *)event;
|
||||||
|
- (void)godotTouchesEnded:(NSSet *)touches withEvent:(UIEvent *)event;
|
||||||
|
- (void)godotTouchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event;
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
|
@ -336,7 +336,7 @@ static const float earth_gravity = 9.80665;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)touchesBegan:(NSSet *)touchesSet withEvent:(UIEvent *)event {
|
- (void)godotTouchesBegan:(NSSet *)touchesSet withEvent:(UIEvent *)event {
|
||||||
NSArray *tlist = [event.allTouches allObjects];
|
NSArray *tlist = [event.allTouches allObjects];
|
||||||
for (unsigned int i = 0; i < [tlist count]; i++) {
|
for (unsigned int i = 0; i < [tlist count]; i++) {
|
||||||
if ([touchesSet containsObject:[tlist objectAtIndex:i]]) {
|
if ([touchesSet containsObject:[tlist objectAtIndex:i]]) {
|
||||||
|
@ -349,7 +349,7 @@ static const float earth_gravity = 9.80665;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event {
|
- (void)godotTouchesMoved:(NSSet *)touches withEvent:(UIEvent *)event {
|
||||||
NSArray *tlist = [event.allTouches allObjects];
|
NSArray *tlist = [event.allTouches allObjects];
|
||||||
for (unsigned int i = 0; i < [tlist count]; i++) {
|
for (unsigned int i = 0; i < [tlist count]; i++) {
|
||||||
if ([touches containsObject:[tlist objectAtIndex:i]]) {
|
if ([touches containsObject:[tlist objectAtIndex:i]]) {
|
||||||
|
@ -363,7 +363,7 @@ static const float earth_gravity = 9.80665;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
|
- (void)godotTouchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
|
||||||
NSArray *tlist = [event.allTouches allObjects];
|
NSArray *tlist = [event.allTouches allObjects];
|
||||||
for (unsigned int i = 0; i < [tlist count]; i++) {
|
for (unsigned int i = 0; i < [tlist count]; i++) {
|
||||||
if ([touches containsObject:[tlist objectAtIndex:i]]) {
|
if ([touches containsObject:[tlist objectAtIndex:i]]) {
|
||||||
|
@ -377,7 +377,7 @@ static const float earth_gravity = 9.80665;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event {
|
- (void)godotTouchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event {
|
||||||
NSArray *tlist = [event.allTouches allObjects];
|
NSArray *tlist = [event.allTouches allObjects];
|
||||||
for (unsigned int i = 0; i < [tlist count]; i++) {
|
for (unsigned int i = 0; i < [tlist count]; i++) {
|
||||||
if ([touches containsObject:[tlist objectAtIndex:i]]) {
|
if ([touches containsObject:[tlist objectAtIndex:i]]) {
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
/*************************************************************************/
|
/*************************************************************************/
|
||||||
|
|
||||||
#import "godot_view_gesture_recognizer.h"
|
#import "godot_view_gesture_recognizer.h"
|
||||||
|
#import "godot_view.h"
|
||||||
|
|
||||||
#include "core/config/project_settings.h"
|
#include "core/config/project_settings.h"
|
||||||
|
|
||||||
|
@ -58,6 +59,10 @@ const CGFloat kGLGestureMovementDistance = 0.5;
|
||||||
|
|
||||||
@implementation GodotViewGestureRecognizer
|
@implementation GodotViewGestureRecognizer
|
||||||
|
|
||||||
|
- (GodotView *)godotView {
|
||||||
|
return (GodotView *)self.view;
|
||||||
|
}
|
||||||
|
|
||||||
- (instancetype)init {
|
- (instancetype)init {
|
||||||
self = [super init];
|
self = [super init];
|
||||||
|
|
||||||
|
@ -104,7 +109,7 @@ const CGFloat kGLGestureMovementDistance = 0.5;
|
||||||
self.delayTimer = nil;
|
self.delayTimer = nil;
|
||||||
|
|
||||||
if (self.delayedTouches) {
|
if (self.delayedTouches) {
|
||||||
[self.view touchesBegan:self.delayedTouches withEvent:self.delayedEvent];
|
[self.godotView godotTouchesBegan:self.delayedTouches withEvent:self.delayedEvent];
|
||||||
}
|
}
|
||||||
|
|
||||||
self.delayedTouches = nil;
|
self.delayedTouches = nil;
|
||||||
|
@ -114,6 +119,8 @@ const CGFloat kGLGestureMovementDistance = 0.5;
|
||||||
- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event {
|
- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event {
|
||||||
NSSet *cleared = [self copyClearedTouches:touches phase:UITouchPhaseBegan];
|
NSSet *cleared = [self copyClearedTouches:touches phase:UITouchPhaseBegan];
|
||||||
[self delayTouches:cleared andEvent:event];
|
[self delayTouches:cleared andEvent:event];
|
||||||
|
|
||||||
|
[super touchesBegan:touches withEvent:event];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event {
|
- (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event {
|
||||||
|
@ -123,8 +130,8 @@ const CGFloat kGLGestureMovementDistance = 0.5;
|
||||||
// We should check if movement was significant enough to fire an event
|
// We should check if movement was significant enough to fire an event
|
||||||
// for dragging to work correctly.
|
// for dragging to work correctly.
|
||||||
for (UITouch *touch in cleared) {
|
for (UITouch *touch in cleared) {
|
||||||
CGPoint from = [touch locationInView:self.view];
|
CGPoint from = [touch locationInView:self.godotView];
|
||||||
CGPoint to = [touch previousLocationInView:self.view];
|
CGPoint to = [touch previousLocationInView:self.godotView];
|
||||||
CGFloat xDistance = from.x - to.x;
|
CGFloat xDistance = from.x - to.x;
|
||||||
CGFloat yDistance = from.y - to.y;
|
CGFloat yDistance = from.y - to.y;
|
||||||
|
|
||||||
|
@ -133,7 +140,7 @@ const CGFloat kGLGestureMovementDistance = 0.5;
|
||||||
// Early exit, since one of touches has moved enough to fire a drag event.
|
// Early exit, since one of touches has moved enough to fire a drag event.
|
||||||
if (distance > kGLGestureMovementDistance) {
|
if (distance > kGLGestureMovementDistance) {
|
||||||
[self.delayTimer fire];
|
[self.delayTimer fire];
|
||||||
[self.view touchesMoved:cleared withEvent:event];
|
[self.godotView godotTouchesMoved:cleared withEvent:event];
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -141,26 +148,32 @@ const CGFloat kGLGestureMovementDistance = 0.5;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
[self.view touchesMoved:cleared withEvent:event];
|
[self.godotView touchesMoved:cleared withEvent:event];
|
||||||
|
|
||||||
|
[super touchesMoved:touches withEvent:event];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
|
- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
|
||||||
[self.delayTimer fire];
|
[self.delayTimer fire];
|
||||||
|
|
||||||
NSSet *cleared = [self copyClearedTouches:touches phase:UITouchPhaseEnded];
|
NSSet *cleared = [self copyClearedTouches:touches phase:UITouchPhaseEnded];
|
||||||
[self.view touchesEnded:cleared withEvent:event];
|
[self.godotView godotTouchesEnded:cleared withEvent:event];
|
||||||
|
|
||||||
|
[super touchesEnded:touches withEvent:event];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event {
|
- (void)touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event {
|
||||||
[self.delayTimer fire];
|
[self.delayTimer fire];
|
||||||
[self.view touchesCancelled:touches withEvent:event];
|
[self.godotView godotTouchesCancelled:touches withEvent:event];
|
||||||
};
|
|
||||||
|
[super touchesCancelled:touches withEvent:event];
|
||||||
|
}
|
||||||
|
|
||||||
- (NSSet *)copyClearedTouches:(NSSet *)touches phase:(UITouchPhase)phaseToSave {
|
- (NSSet *)copyClearedTouches:(NSSet *)touches phase:(UITouchPhase)phaseToSave {
|
||||||
NSMutableSet *cleared = [touches mutableCopy];
|
NSMutableSet *cleared = [touches mutableCopy];
|
||||||
|
|
||||||
for (UITouch *touch in touches) {
|
for (UITouch *touch in touches) {
|
||||||
if (touch.phase != phaseToSave) {
|
if (touch.view != self.view || touch.phase != phaseToSave) {
|
||||||
[cleared removeObject:touch];
|
[cleared removeObject:touch];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue