Я рисую строку, используя следующий код, она работает просто потрясающе,
http://www.merowing.info/2012/04/drawing-smooth-lines-with-cocos2d-ios-inspired-by-paper/
Теперь я хочу.....
1 > Определите, пересекает ли линия с собой. 2) Обнаружение, если CCSprite находится внутри этой закрытой линии или нет.
Во время поиска я наткнулся на многие логики для LineIntersection, но ни один из них не является точным. Я даю один из них, который обнаруживает пересечение, но он также обнаруживает его, когда нет пересечения линии.
-
Первый метод
- (BOOL) lineIntersectOccured:(CGPoint)t1 pointEnd:(CGPoint)t2 { BOOL result = NO; int pointsCount = [arrlinePoints count]; CGPoint cp1; CGPoint cp2; for(int i = 0, j = 1; j < pointsCount; i++,j++) { [[arrlinePoints objectAtIndex:i] getValue:&cp1]; [[arrlinePoints objectAtIndex:j] getValue:&cp2]; // lines connected do not need to be included. if((cp2.x == t1.x && cp2.y == t1.y) || (cp1.x == t2.x && cp1.y == t2.y)) { continue; } CGPoint diffLA = CGPointMake(cp2.x - cp1.x,cp2.y - cp1.y); CGPoint diffLB = CGPointMake(t2.x - t1.x, t2.y - t1.y); float compA = diffLA.x*cp1.y - diffLA.y * cp1.x; float compB = diffLB.x*t1.y - diffLB.y*t1.x; BOOL compA1 = (diffLA.x*t1.y - diffLA.y*t1.x) < compA; BOOL compA2 = (diffLA.x*t2.y - diffLA.y*t2.x) < compA; BOOL compB1 = (diffLB.x*cp1.y - diffLB.y*cp1.x) < compB; BOOL compB2 = (diffLB.x*cp2.y - diffLB.y*cp2.x) < compB; if(((!compA1 && compA2) || (compA1 && !compA2)) && ((!compB1 && compB2) || (compB1 && !compB2))) { result = YES; } } return result; }
И вот как я называю этот метод, Я сохранил свои точки в arrLinePoints из метода распознавания pangesture
if ([self lineIntersectOccured:[[arrlinePoints objectAtIndex:0] CGPointValue] pointEnd:[[arrlinePoints objectAtIndex:[arrlinePoints count] - 1] CGPointValue]] )
{
NSLog(@"Line Intersected");
}
Это дает мне правду даже со следующей ситуацией
Я также попробовал ту же функциональность с другим подходом, добавив представление в представление CCDirector
Но это дает проблемы с производительностью, мои fps уменьшены почти до 3-6. А также проблема пересечения остается прежней.
Идеальная ситуация для пересечения -
Пожалуйста, помогите как можно скорее! Спасибо за поддержку.