Ich erstelle eine App und versuche, sie so zu gestalten, dass ich ein Sprite (mit einem zweiten Sprite oben) über den Bildschirm ziehen kann. Wenn ich jedoch nur auf das Sprite tippe, sollte eine andere Methode aufgerufen werden.
Das Ziehen funktioniert einwandfrei, wenn ich die Kante meines Sprites berühre, aber wenn ich versuche, aus der Mitte des Sprites (wo sich das zweite Sprite oben befindet) zu ziehen, funktioniert das Ziehen überhaupt nicht, aber das Tippen wird aufgerufen .
Ich weiß, warum das nicht so ist, aber es gibt widersprüchliche Berührungen von beiden Geistern, weil der eine oben die Berührung verschluckt, bevor er den zweiten darunter trifft.
Wie kann ich dies implementieren, wenn das Sprite gezogen werden soll, wenn sich der Finger bewegt, aber das Tippen registriert werden soll, wenn nur ein Tippen erfolgt (dh der Finger hat sich nicht auf dem Bildschirm bewegt)?
Ein Bild der Sprites, mit denen ich arbeite (wenn es hilft):
Die gelbe Rune ist ein vom Stein darunter getrenntes Sprite (da es sich um Animationen handelt).
--------Touch for the top sprite----------
-(BOOL) ccTouchBegan:(UITouch*)touch withEvent:(UIEvent *)event{
lastTouchLocation = [RuneScene locationFromTouch:touch];
BOOL isTouchHandled = CGRectContainsPoint([charSprite boundingBox], lastTouchLocation);
return isTouchHandled;
}
-(void) ccTouchEnded:(UITouch*)touch withEvent:(UIEvent *)event{
NSLog(@"Tap received!");
}
------Touch for the bottom sprite--------
-(BOOL) ccTouchBegan:(UITouch*)touch withEvent:(UIEvent *)event{
lastTouchLocation = [RuneScene locationFromTouch:touch];
BOOL isTouchHandled = NO;
// Check if this touch is on the Spider's sprite.
if (CGRectContainsPoint([current.runeSprite boundingBox], lastTouchLocation)){
mover = current;
isTouchHandled = YES;
}
else if(CGRectContainsPoint([rune1.runeSprite boundingBox], lastTouchLocation)){
mover = rune1;
isTouchHandled = YES;
}
else if(CGRectContainsPoint([rune2.runeSprite boundingBox], lastTouchLocation)){
mover = rune2;
isTouchHandled = YES;
}else if(CGRectContainsPoint([rune3.runeSprite boundingBox], lastTouchLocation)){
mover = rune3;
isTouchHandled = YES;
}else if(CGRectContainsPoint([rune4.runeSprite boundingBox], lastTouchLocation)){
mover = rune4;
isTouchHandled = YES;
}else if(CGRectContainsPoint([rune5.runeSprite boundingBox], lastTouchLocation)){
mover = rune5;
isTouchHandled = YES;
}else if(CGRectContainsPoint([rune6.runeSprite boundingBox], lastTouchLocation)){
mover = rune6;
isTouchHandled = YES;
}else if(CGRectContainsPoint([rune7.runeSprite boundingBox], lastTouchLocation)){
mover = rune7;
isTouchHandled = YES;
}else if(CGRectContainsPoint([rune0.runeSprite boundingBox], lastTouchLocation)){
mover = rune0;
isTouchHandled = YES;
}
// Stop the move action so it doesn't interfere with the user's scrolling.
//[self stopActionByTag:ActionTagCastingLayerMovesBack];
// Always swallow touches, GameLayer is the last layer to receive touches.
return isTouchHandled;
}
-(void) ccTouchMoved:(UITouch*)touch withEvent:(UIEvent *)event{
CGPoint currentTouchLocation = [RuneScene locationFromTouch:touch];
// Take the difference of the current to the last touch location.
CGPoint moveTo = ccpSub(lastTouchLocation, currentTouchLocation);
// Then reverse it since the goal is not to give the impression of moving the camera over the background,
// but to touch and move the background.
moveTo = ccpMult(moveTo, -1);
lastTouchLocation = currentTouchLocation;
[self moveActionWithLocation: moveTo];
}
-(void) ccTouchEnded:(UITouch*)touch withEvent:(UIEvent *)event{
if (!current.isPlaced && mover == current && currentR < Rune6) {
// Move the game layer back to its designated position.
CCMoveTo* move = [CCMoveTo actionWithDuration:1 position:curPt];
CCEaseIn* ease = [CCEaseIn actionWithAction:move rate:0.5f];
//ease.tag = ActionTagCastingLayerMovesBack;
[current.runeSprite runAction:ease];
[current setIsPlaced:YES];
current.charSprite = [characters objectAtIndex:currentR];
current.charSprite.position = curPt;
//charSprite.visible = YES;
[current performSelector:@selector(fade:) withObject:current.charSprite afterDelay:1];
[current reorderChild:current.charSprite z:10];
[self updateCurrentRune:currentR];
[self updateCurrentCastNum:currentP];
[self reorderChild:current z:10];
}
}
Ich habe versucht, in den UITapGestureRecognizer zu schauen, aber alles, was ich tue, um zu implementieren, funktioniert nie. Mit meinen Ebenen / Sprites kann ich sie nicht als Gesten hinzufügen. Ich habe auch etwas über CCGrstureRecognizer oder etwas in den cocos2d-Foren gelesen, aber ich kann keine Dokumentation zu dieser Klasse finden und auch nicht herausfinden, wie man sie tatsächlich verwendet ...
Kennt hier jemand einen Weg, um mir bei meinem Problem zu helfen?