# HG changeset patch # User sheepluva # Date 1320439497 -3600 # Node ID 7f724835ea579bd9e8f50a17c9b61dc6bd081ad8 # Parent 654eed7c6b97f1986dbb2b5a3297693520e18c67 I hope this helps... diff -r 654eed7c6b97 -r 7f724835ea57 hedgewars/uCollisions.pas --- a/hedgewars/uCollisions.pas Fri Nov 04 12:50:37 2011 +0100 +++ b/hedgewars/uCollisions.pas Fri Nov 04 21:44:57 2011 +0100 @@ -52,7 +52,8 @@ function TestRectancleForObstacle(x1, y1, x2, y2: LongInt; landOnly: boolean): boolean; -function CalcSlopeTangentBelowGear(Gear: PGear; var outDeltaX, outDeltaY: LongInt): boolean; +// returns: negative sign if going downhill to left, value is steepness (noslope/error = _0, 45° = _0_5) +function CalcSlopeBelowGear(Gear: PGear): hwFloat; function CalcSlopeTangent(Gear: PGear; collisionX, collisionY: LongInt; var outDeltaX, outDeltaY: LongInt; TestWord: LongWord): Boolean; implementation @@ -403,7 +404,7 @@ if (dx.QWordValue > _0_995.QWordValue ) or (dy.QWordValue > _0_995.QWordValue ) then begin // scale - s := _1 / Distance(dx,dy); + s := _0_995 / Distance(dx,dy); dx := s * dx; dy := s * dy; end; @@ -519,17 +520,12 @@ exit(true); end; -function CalcSlopeTangentBelowGear(Gear: PGear; var outDeltaX, outDeltaY: LongInt): boolean; +function CalcSlopeBelowGear(Gear: PGear): hwFloat; var dx, dy: hwFloat; - collX, i, y, x, gx: LongInt; + collX, i, y, x, gx, sdx, sdy: LongInt; isColl, succ: Boolean; begin -// save original dx/dy -dx:= Gear^.dX; -dy:= Gear^.dY; -Gear^.dX.QWordValue:= 0; -Gear^.dY:= _1; y:= hwRound(Gear^.Y) + Gear^.Radius; gx:= hwRound(Gear^.X); @@ -553,15 +549,32 @@ end; if isColl then - succ := CalcSlopeTangent(Gear, collX, y, outDeltaX, outDeltaY, 255) -else - succ := false; + begin + // save original dx/dy + dx := Gear^.dX; + dy := Gear^.dY; + + Gear^.dX.QWordValue:= 0; + Gear^.dX.isNegative:= (collX >= gx); + Gear^.dY:= _1; + + sdx:= 0; + sdy:= 0; + succ := CalcSlopeTangent(Gear, collX, y, sdx, sdy, 255); -// restore original dx/dy -Gear^.dX:= dx; -Gear^.dY:= dy; + // restore original dx/dy + Gear^.dX := dx; + Gear^.dY := dy; -CalcSlopeTangentBelowGear := succ; + if succ and (sdx <> 0) and (sdy <> 0) then + begin + dx := int2hwFloat(sdy) / (abs(sdx) + abs(sdy)); + dx.isNegative := (sdx * sdy) < 0; + exit (dx); + end; + end; + +CalcSlopeBelowGear := _0; end; procedure initModule;