hedgewars/uAIMisc.pas
author unc0rr
Mon, 02 Jul 2007 16:21:07 +0000
changeset 545 f527450337c1
parent 542 ec26095f1bed
child 547 b81a055f2d06
permissions -rw-r--r--
Fix some warnings
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
     1
(*
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
     2
 * Hedgewars, a worms-like game
393
db01cc79f278 Update copyright information
unc0rr
parents: 375
diff changeset
     3
 * Copyright (c) 2005-2007 Andrey Korotaev <unC0Rr@gmail.com>
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
     4
 *
183
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
     6
 * it under the terms of the GNU General Public License as published by
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
     7
 * the Free Software Foundation; version 2 of the License
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
     8
 *
183
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
    12
 * GNU General Public License for more details.
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
    13
 *
183
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
    14
 * You should have received a copy of the GNU General Public License
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
    15
 * along with this program; if not, write to the Free Software
57c2ef19f719 Relicense to GPL
unc0rr
parents: 136
diff changeset
    16
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
    17
 *)
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
    18
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    19
unit uAIMisc;
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    20
interface
351
29bc9c36ad5f Fixed-point arithmetics in engine.
unc0rr
parents: 191
diff changeset
    21
uses SDLh, uConsts, uGears, uFloat;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
    22
{$INCLUDE options.inc}
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    23
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    24
type TTarget = record
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    25
               Point: TPoint;
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    26
               Score: LongInt;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    27
               end;
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    28
     TTargets = record
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    29
                Count: Longword;
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    30
                ar: array[0..cMaxHHIndex*5] of TTarget;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    31
                end;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
    32
     TJumpType = (jmpNone, jmpHJump, jmpLJump);
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
    33
     TGoInfo = record
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
    34
               Ticks: Longword;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
    35
               FallPix: Longword;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
    36
               JumpType: TJumpType;
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
    37
               end;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    38
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    39
procedure FillTargets;
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
    40
procedure FillBonuses(isAfterAttack: boolean);
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    41
procedure AwareOfExplosion(x, y, r: LongInt);
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    42
function RatePlace(Gear: PGear): LongInt;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    43
function TestColl(x, y, r: LongInt): boolean;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    44
function RateExplosion(Me: PGear; x, y, r: LongInt): LongInt;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    45
function RateShove(Me: PGear; x, y, r, power: LongInt): LongInt;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
    46
function RateShotgun(Me: PGear; x, y: LongInt): LongInt;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    47
function HHGo(Gear, AltGear: PGear; var GoInfo: TGoInfo): boolean;
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    48
function AIrndSign(num: LongInt): LongInt;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    49
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    50
var ThinkingHH: PGear;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    51
    Targets: TTargets;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    52
                       
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    53
implementation
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    54
uses uTeams, uMisc, uLand, uCollisions;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    55
const KillScore = 200;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    56
      MAXBONUS = 1024;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    57
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    58
type TBonus = record
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    59
              X, Y: LongInt;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    60
              Radius: LongInt;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    61
              Score: LongInt;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    62
              end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    63
var bonuses: record
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    64
             Count: Longword;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    65
             ar: array[0..Pred(MAXBONUS)] of TBonus;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    66
             end;
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
    67
    KnownExplosion: record
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
    68
                    X, Y, Radius: LongInt
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
    69
                    end = (X: 0; Y: 0; Radius: 0);
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    70
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    71
procedure FillTargets;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    72
var t: PTeam;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    73
    i: Longword;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    74
begin
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    75
Targets.Count:= 0;
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    76
t:= TeamsList;
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    77
while t <> nil do
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    78
      begin
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    79
      for i:= 0 to cMaxHHIndex do
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    80
          if (t^.Hedgehogs[i].Gear <> nil)
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    81
             and (t^.Hedgehogs[i].Gear <> ThinkingHH) then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    82
             begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    83
             with Targets.ar[Targets.Count], t^.Hedgehogs[i] do
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    84
                  begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    85
                  Point.X:= hwRound(Gear^.X);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    86
                  Point.Y:= hwRound(Gear^.Y);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    87
                  if t^.Color <> CurrentTeam^.Color then Score:=  Gear^.Health
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    88
                                                    else Score:= -Gear^.Health
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    89
                  end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    90
             inc(Targets.Count)
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    91
             end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    92
      t:= t^.Next
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    93
      end
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    94
end;
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    95
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
    96
procedure FillBonuses(isAfterAttack: boolean);
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    97
var Gear: PGear;
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
    98
    MyColor: Longword;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    99
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   100
    procedure AddBonus(x, y: LongInt; r: Longword; s: LongInt);
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   101
    begin
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   102
    bonuses.ar[bonuses.Count].x:= x;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   103
    bonuses.ar[bonuses.Count].y:= y;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   104
    bonuses.ar[bonuses.Count].Radius:= r;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   105
    bonuses.ar[bonuses.Count].Score:= s;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   106
    inc(bonuses.Count);
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   107
    TryDo(bonuses.Count <= MAXBONUS, 'Bonuses overflow', true)
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   108
    end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   109
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   110
begin
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   111
bonuses.Count:= 0;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   112
MyColor:= PHedgehog(ThinkingHH^.Hedgehog)^.Team^.Color;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   113
Gear:= GearsList;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   114
while Gear <> nil do
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   115
      begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   116
      case Gear^.Kind of
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   117
           gtCase: AddBonus(hwRound(Gear^.X), hwRound(Gear^.Y), 33, 25);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   118
           gtMine: if (Gear^.State and gstAttacking) = 0 then AddBonus(hwRound(Gear^.X), hwRound(Gear^.Y), 50, -50)
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   119
                                                        else AddBonus(hwRound(Gear^.X), hwRound(Gear^.Y), 100, -50); // mine is on
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   120
           gtDynamite: AddBonus(hwRound(Gear^.X), hwRound(Gear^.Y), 150, -75);
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   121
           gtHedgehog: begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   122
                       if Gear^.Damage >= Gear^.Health then AddBonus(hwRound(Gear^.X), hwRound(Gear^.Y), 60, -25) else
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   123
                          if isAfterAttack and (ThinkingHH^.Hedgehog <> Gear^.Hedgehog) then
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   124
                             if (MyColor = PHedgehog(Gear^.Hedgehog)^.Team^.Color) then AddBonus(hwRound(Gear^.X), hwRound(Gear^.Y), 150, -3) // hedgehog-friend
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   125
                                                                                   else AddBonus(hwRound(Gear^.X), hwRound(Gear^.Y), 100, 3)
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   126
                       end;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   127
           end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   128
      Gear:= Gear^.NextGear
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   129
      end;
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   130
if isAfterAttack and (KnownExplosion.Radius > 0) then
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   131
   with KnownExplosion do
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   132
        AddBonus(X, Y, Radius + 10, -Radius);
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   133
end;
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   134
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   135
procedure AwareOfExplosion(x, y, r: LongInt);
71
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   136
begin
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   137
KnownExplosion.X:= x;
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   138
KnownExplosion.Y:= y;
5f56c6979496 - Changed falling damage scoring
unc0rr
parents: 70
diff changeset
   139
KnownExplosion.Radius:= r
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   140
end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   141
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   142
function RatePlace(Gear: PGear): LongInt;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   143
var i, r: LongInt;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   144
    Result: LongInt;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   145
begin
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   146
Result:= 0;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   147
for i:= 0 to Pred(bonuses.Count) do
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   148
    with bonuses.ar[i] do
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   149
         begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   150
         r:= hwRound(Distance(Gear^.X - int2hwFloat(X), Gear^.Y - int2hwFloat(Y)));
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   151
         if r < Radius then
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   152
            inc(Result, Score * (Radius - r))
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   153
         end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   154
    RatePlace:= Result
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   155
end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   156
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   157
function TestColl(x, y, r: LongInt): boolean;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   158
var b: boolean;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   159
begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   160
b:= (((x-r) and $FFFFF800) = 0)and(((y-r) and $FFFFFC00) = 0) and (Land[y-r, x-r] <> 0);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   161
if b then exit(true);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   162
b:=(((x-r) and $FFFFF800) = 0)and(((y+r) and $FFFFFC00) = 0) and (Land[y+r, x-r] <> 0);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   163
if b then exit(true);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   164
b:=(((x+r) and $FFFFF800) = 0)and(((y-r) and $FFFFFC00) = 0) and (Land[y-r, x+r] <> 0);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   165
if b then exit(true);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   166
TestColl:=(((x+r) and $FFFFF800) = 0)and(((y+r) and $FFFFFC00) = 0) and (Land[y+r, x+r] <> 0)
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   167
end;
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   168
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   169
function RateExplosion(Me: PGear; x, y, r: LongInt): LongInt;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   170
var i, dmg, Result: LongInt;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   171
begin
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   172
Result:= 0;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   173
// add our virtual position
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   174
with Targets.ar[Targets.Count] do
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   175
     begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   176
     Point.x:= hwRound(Me^.X);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   177
     Point.y:= hwRound(Me^.Y);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   178
     Score:= - ThinkingHH^.Health
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   179
     end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   180
// rate explosion
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   181
for i:= 0 to Targets.Count do
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   182
    with Targets.ar[i] do
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   183
         begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   184
         dmg:= r - hwRound(DistanceI(Point.x - x, Point.y - y));
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   185
         if dmg > 0 then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   186
            begin
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   187
            dmg:= dmg shr 1;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   188
            if dmg >= abs(Score) then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   189
               if Score > 0 then inc(Result, KillScore)
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   190
                            else dec(Result, KillScore * 3)
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   191
            else
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   192
               if Score > 0 then inc(Result, dmg)
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   193
                            else dec(Result, dmg * 3)
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   194
            end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   195
         end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   196
RateExplosion:= Result * 1024
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   197
end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   198
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   199
function RateShove(Me: PGear; x, y, r, power: LongInt): LongInt;
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   200
var i, dmg, Result: LongInt;
79
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   201
begin
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   202
Result:= 0;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 393
diff changeset
   203
for i:= 0 to Pred(Targets.Count) do
79
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   204
    with Targets.ar[i] do
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   205
         begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   206
         dmg:= r - hwRound(DistanceI(Point.x - x, Point.y - y));
79
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   207
         if dmg > 0 then
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   208
            begin
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   209
            if power >= abs(Score) then
79
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   210
               if Score > 0 then inc(Result, KillScore)
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   211
                            else dec(Result, KillScore * 3)
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   212
            else
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   213
               if Score > 0 then inc(Result, power)
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   214
                            else dec(Result, power * 3)
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   215
            end;
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   216
         end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   217
RateShove:= Result * 1024
79
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   218
end;
29b477319854 - New test map
unc0rr
parents: 75
diff changeset
   219
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   220
function RateShotgun(Me: PGear; x, y: LongInt): LongInt;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   221
var i, dmg, Result: LongInt;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   222
begin
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   223
Result:= 0;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   224
// add our virtual position
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   225
with Targets.ar[Targets.Count] do
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   226
     begin
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   227
     Point.x:= hwRound(Me^.X);
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   228
     Point.y:= hwRound(Me^.Y);
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   229
     Score:= - ThinkingHH^.Health
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   230
     end;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   231
// rate shot
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   232
for i:= 0 to Targets.Count do
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   233
    with Targets.ar[i] do
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   234
         begin
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   235
         dmg:= min(cHHRadius + cShotgunRadius - hwRound(DistanceI(Point.x - x, Point.y - y)), 25);
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   236
         if dmg > 0 then
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   237
            begin
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   238
            if dmg >= abs(Score) then
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   239
               if Score > 0 then inc(Result, KillScore)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   240
                            else dec(Result, KillScore * 3)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   241
            else
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   242
               if Score > 0 then inc(Result, dmg)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   243
                            else dec(Result, dmg * 3)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   244
            end;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   245
         end;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   246
RateShotgun:= Result * 1024
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   247
end;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 498
diff changeset
   248
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   249
function HHJump(Gear: PGear; JumpType: TJumpType; var GoInfo: TGoInfo): boolean;
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   250
var bX, bY: LongInt;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   251
    Result: boolean;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   252
begin
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   253
Result:= false;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   254
GoInfo.Ticks:= 0;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   255
GoInfo.FallPix:= 0;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   256
GoInfo.JumpType:= jmpNone;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   257
bX:= hwRound(Gear^.X);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   258
bY:= hwRound(Gear^.Y);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   259
case JumpType of
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   260
     jmpNone: exit(Result);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   261
    jmpHJump: if not TestCollisionYwithGear(Gear, -1) then
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   262
                 begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   263
                 Gear^.dY:= -_0_2;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   264
                 SetLittle(Gear^.dX);
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   265
                 Gear^.State:= Gear^.State or gstMoving or gstHHJumping;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   266
                 end else exit(Result);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   267
    jmpLJump: begin
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   268
              if not TestCollisionYwithGear(Gear, -1) then
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   269
                 if not TestCollisionXwithXYShift(Gear, _0, -2, hwSign(Gear^.dX)) then Gear^.Y:= Gear^.Y - int2hwFloat(2) else
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   270
                 if not TestCollisionXwithXYShift(Gear, _0, -1, hwSign(Gear^.dX)) then Gear^.Y:= Gear^.Y - _1;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   271
              if not (TestCollisionXwithGear(Gear, hwSign(Gear^.dX))
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   272
                 or   TestCollisionYwithGear(Gear, -1)) then
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   273
                 begin
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 393
diff changeset
   274
                 Gear^.dY:= -_0_15;
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   275
                 Gear^.dX:= SignAs(_0_15, Gear^.dX);
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   276
                 Gear^.State:= Gear^.State or gstMoving or gstHHJumping
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   277
                 end else exit(Result)
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   278
              end
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   279
    end;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   280
    
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   281
repeat
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   282
if not (hwRound(Gear^.Y) + cHHRadius < cWaterLine) then exit(Result);
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   283
if (Gear^.State and gstMoving) <> 0 then
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   284
   begin
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   285
   if (GoInfo.Ticks = 350) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 393
diff changeset
   286
      if (not (hwAbs(Gear^.dX) > cLittle)) and (Gear^.dY < -_0_02) then
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   287
         begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   288
         Gear^.dY:= -_0_25;
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   289
         Gear^.dX:= SignAs(_0_02, Gear^.dX)
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   290
         end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   291
   if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) then SetLittle(Gear^.dX);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   292
   Gear^.X:= Gear^.X + Gear^.dX;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   293
   inc(GoInfo.Ticks);
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   294
   Gear^.dY:= Gear^.dY + cGravity;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   295
   if Gear^.dY > _0_4 then exit(Result);
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   296
   if (Gear^.dY.isNegative)and TestCollisionYwithGear(Gear, -1) then Gear^.dY:= _0;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   297
   Gear^.Y:= Gear^.Y + Gear^.dY;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   298
   if (not Gear^.dY.isNegative)and TestCollisionYwithGear(Gear, 1) then
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   299
      begin
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   300
      Gear^.State:= Gear^.State and not (gstMoving or gstHHJumping);
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   301
      Gear^.dY:= _0;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   302
      case JumpType of
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   303
           jmpHJump: if bY - hwRound(Gear^.Y) > 5 then
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   304
                        begin
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   305
                        Result:= true;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   306
                        GoInfo.JumpType:= jmpHJump;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   307
                        inc(GoInfo.Ticks, 300 + 300) // 300 before jump, 300 after
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   308
                        end;
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   309
           jmpLJump: if abs(bX - hwRound(Gear^.X)) > 30 then
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   310
                        begin
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   311
                        Result:= true;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   312
                        GoInfo.JumpType:= jmpLJump;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   313
                        inc(GoInfo.Ticks, 300 + 300) // 300 before jump, 300 after
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   314
                        end;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   315
           end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   316
      exit(Result)
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   317
      end;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   318
   end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   319
until false
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   320
end;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   321
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   322
function HHGo(Gear, AltGear: PGear; var GoInfo: TGoInfo): boolean;
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   323
var pX, pY: LongInt;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   324
    Result: boolean;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   325
begin
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   326
Result:= false;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   327
AltGear^:= Gear^;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   328
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   329
GoInfo.Ticks:= 0;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   330
GoInfo.FallPix:= 0;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   331
GoInfo.JumpType:= jmpNone;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   332
repeat
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   333
pX:= hwRound(Gear^.X);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   334
pY:= hwRound(Gear^.Y);
375
18012da67681 AI works properly
unc0rr
parents: 371
diff changeset
   335
if pY + cHHRadius >= cWaterLine then exit(false);
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   336
if (Gear^.State and gstMoving) <> 0 then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   337
   begin
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   338
   inc(GoInfo.Ticks);
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   339
   Gear^.dY:= Gear^.dY + cGravity;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   340
   if Gear^.dY > _0_4 then
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   341
      begin
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 79
diff changeset
   342
      Goinfo.FallPix:= 0;
82
2f4f3236cccc - New fort
unc0rr
parents: 80
diff changeset
   343
      HHJump(AltGear, jmpLJump, GoInfo); // try ljump enstead of fall with damage
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   344
      exit(Result)
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   345
      end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   346
   Gear^.Y:= Gear^.Y + Gear^.dY;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   347
   if hwRound(Gear^.Y) > pY then inc(GoInfo.FallPix);
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   348
   if TestCollisionYwithGear(Gear, 1) then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   349
      begin
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   350
      inc(GoInfo.Ticks, 300);
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   351
      Gear^.State:= Gear^.State and not (gstMoving or gstHHJumping);
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   352
      Gear^.dY:= _0;
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   353
      Result:= true;
82
2f4f3236cccc - New fort
unc0rr
parents: 80
diff changeset
   354
      HHJump(AltGear, jmpLJump, GoInfo); // try ljump instead of fall
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   355
      exit(Result)
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   356
      end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   357
   continue
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   358
   end;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   359
   if (Gear^.Message and gm_Left  )<>0 then Gear^.dX:= -cLittle else
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   360
   if (Gear^.Message and gm_Right )<>0 then Gear^.dX:=  cLittle else exit(Result);
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   361
   if TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   362
      begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   363
      if not (TestCollisionXwithXYShift(Gear, _0, -6, hwSign(Gear^.dX))
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   364
         or TestCollisionYwithGear(Gear, -1)) then Gear^.Y:= Gear^.Y - _1;
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   365
      if not (TestCollisionXwithXYShift(Gear, _0, -5, hwSign(Gear^.dX))
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   366
         or TestCollisionYwithGear(Gear, -1)) then Gear^.Y:= Gear^.Y - _1;
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   367
      if not (TestCollisionXwithXYShift(Gear, _0, -4, hwSign(Gear^.dX))
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   368
         or TestCollisionYwithGear(Gear, -1)) then Gear^.Y:= Gear^.Y - _1;
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   369
      if not (TestCollisionXwithXYShift(Gear, _0, -3, hwSign(Gear^.dX))
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   370
         or TestCollisionYwithGear(Gear, -1)) then Gear^.Y:= Gear^.Y - _1;
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   371
      if not (TestCollisionXwithXYShift(Gear, _0, -2, hwSign(Gear^.dX))
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   372
         or TestCollisionYwithGear(Gear, -1)) then Gear^.Y:= Gear^.Y - _1;
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   373
      if not (TestCollisionXwithXYShift(Gear, _0, -1, hwSign(Gear^.dX))
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   374
         or TestCollisionYwithGear(Gear, -1)) then Gear^.Y:= Gear^.Y - _1;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   375
      end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   376
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   377
   if not TestCollisionXwithGear(Gear, hwSign(Gear^.dX)) then
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   378
      begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   379
      Gear^.X:= Gear^.X + int2hwFloat(hwSign(Gear^.dX));
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   380
      inc(GoInfo.Ticks, cHHStepTicks)
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   381
      end;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   382
   if not TestCollisionYwithGear(Gear, 1) then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   383
   begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   384
   Gear^.Y:= Gear^.Y + _1;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   385
   if not TestCollisionYwithGear(Gear, 1) then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   386
   begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   387
   Gear^.Y:= Gear^.Y + _1;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   388
   if not TestCollisionYwithGear(Gear, 1) then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   389
   begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   390
   Gear^.Y:= Gear^.Y + _1;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   391
   if not TestCollisionYwithGear(Gear, 1) then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   392
   begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   393
   Gear^.Y:= Gear^.Y + _1;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   394
   if not TestCollisionYwithGear(Gear, 1) then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   395
   begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   396
   Gear^.Y:= Gear^.Y + _1;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   397
   if not TestCollisionYwithGear(Gear, 1) then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   398
   begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   399
   Gear^.Y:= Gear^.Y + _1;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   400
   if not TestCollisionYwithGear(Gear, 1) then
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   401
      begin
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   402
      Gear^.Y:= Gear^.Y - _6;
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 433
diff changeset
   403
      Gear^.dY:= _0;
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   404
      Gear^.State:= Gear^.State or gstMoving
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   405
      end
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   406
   end
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   407
   end
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   408
   end
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   409
   end
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   410
   end
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   411
   end;
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   412
if (pX <> hwRound(Gear^.X)) and ((Gear^.State and gstMoving) = 0) then
375
18012da67681 AI works properly
unc0rr
parents: 371
diff changeset
   413
   exit(true);
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 509
diff changeset
   414
until (pX = hwRound(Gear^.X)) and (pY = hwRound(Gear^.Y)) and ((Gear^.State and gstMoving) = 0);
375
18012da67681 AI works properly
unc0rr
parents: 371
diff changeset
   415
HHJump(AltGear, jmpHJump, GoInfo);
18012da67681 AI works properly
unc0rr
parents: 371
diff changeset
   416
HHGo:= Result
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   417
end;
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   418
371
731ad6d27bd1 integer -> LongInt
unc0rr
parents: 370
diff changeset
   419
function AIrndSign(num: LongInt): LongInt;
136
89970b70b076 Implement bot levels
unc0rr
parents: 108
diff changeset
   420
begin
370
c75410fe3133 - Repair bots: they can walk and use bazooka, possible cannot jump (why?)
unc0rr
parents: 369
diff changeset
   421
if random(2) = 0 then AIrndSign:=   num
c75410fe3133 - Repair bots: they can walk and use bazooka, possible cannot jump (why?)
unc0rr
parents: 369
diff changeset
   422
                 else AIrndSign:= - num
c75410fe3133 - Repair bots: they can walk and use bazooka, possible cannot jump (why?)
unc0rr
parents: 369
diff changeset
   423
end;  
136
89970b70b076 Implement bot levels
unc0rr
parents: 108
diff changeset
   424
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   425
end.