hedgewars/uLandObjects.pas
author unc0rr
Sun, 14 Jan 2007 15:58:18 +0000
changeset 330 09cfe028a629
parent 279 5df0ab96b60a
child 351 29bc9c36ad5f
permissions -rw-r--r--
Fix infinite loop
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
184
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     1
(*
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     2
 * Hedgewars, a worms-like game
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     3
 * Copyright (c) 2005, 2006 Andrey Korotaev <unC0Rr@gmail.com>
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     4
 *
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     6
 * it under the terms of the GNU General Public License as published by
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     7
 * the Free Software Foundation; version 2 of the License
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     8
 *
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    12
 * GNU General Public License for more details.
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    13
 *
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    14
 * You should have received a copy of the GNU General Public License
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    15
 * along with this program; if not, write to the Free Software
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    16
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    17
 *)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    18
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    19
unit uLandObjects;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    20
interface
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    21
uses SDLh;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    22
{$include options.inc}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    23
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    24
procedure AddObjects(InSurface, Surface: PSDL_Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    25
procedure BlitImageAndGenerateCollisionInfo(cpX, cpY: Longword; Image, Surface: PSDL_Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    26
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    27
implementation
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    28
uses uLand, uStore, uConsts, uMisc, uConsole, uRandom;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    29
const MaxRects = 256;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    30
      MAXOBJECTRECTS = 16;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    31
      MAXTHEMEOBJECTS = 32;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    32
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    33
type PRectArray = ^TRectsArray;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    34
     TRectsArray = array[0..MaxRects] of TSDL_Rect;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    35
     TThemeObject = record
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    36
                    Surf: PSDL_Surface;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    37
                    inland: TSDL_Rect;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    38
                    outland: array[0..Pred(MAXOBJECTRECTS)] of TSDL_Rect;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    39
                    rectcnt: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    40
                    Width, Height: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    41
                    Maxcnt: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    42
                    end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    43
     TThemeObjects = record
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    44
                     Count: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    45
                     objs: array[0..Pred(MAXTHEMEOBJECTS)] of TThemeObject;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    46
                     end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    47
     TSprayObject = record
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    48
                    Surf: PSDL_Surface;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    49
                    Width, Height: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    50
                    Maxcnt: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    51
                    end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    52
     TSprayObjects = record
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    53
                     Count: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    54
                     objs: array[0..Pred(MAXTHEMEOBJECTS)] of TSprayObject
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    55
                     end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    56
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    57
var Rects: PRectArray;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    58
    RectCount: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    59
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    60
procedure BlitImageAndGenerateCollisionInfo(cpX, cpY: Longword; Image, Surface: PSDL_Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    61
var p: PByteArray;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    62
    x, y: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    63
    bpp: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    64
    r: TSDL_Rect;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    65
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    66
r.x:= cpX;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    67
r.y:= cpY;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    68
SDL_UpperBlit(Image, nil, Surface, @r);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    69
WriteToConsole('Generating collision info... ');
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    70
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    71
if SDL_MustLock(Image) then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    72
   SDLTry(SDL_LockSurface(Image) >= 0, true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    73
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    74
bpp:= Image.format.BytesPerPixel;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    75
WriteToConsole('('+inttostr(bpp)+') ');
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    76
p:= Image.pixels;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    77
case bpp of
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    78
     1: OutError('We don''t work with 8 bit surfaces', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    79
     2: for y:= 0 to Pred(Image.h) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    80
            begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    81
            for x:= 0 to Pred(Image.w) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    82
                if PWord(@p[x * 2])^ <> 0 then Land[cpY + y, cpX + x]:= COLOR_LAND;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    83
            p:= @p[Image.pitch];
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    84
            end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    85
     3: for y:= 0 to Pred(Image.h) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    86
            begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    87
            for x:= 0 to Pred(Image.w) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    88
                if  (p[x * 3 + 0] <> 0)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    89
                 or (p[x * 3 + 1] <> 0)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    90
                 or (p[x * 3 + 2] <> 0) then Land[cpY + y, cpX + x]:= COLOR_LAND;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    91
            p:= @p[Image.pitch];
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    92
            end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    93
     4: for y:= 0 to Pred(Image.h) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    94
            begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    95
            for x:= 0 to Pred(Image.w) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    96
                if PLongword(@p[x * 4])^ <> 0 then Land[cpY + y, cpX + x]:= COLOR_LAND;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    97
            p:= @p[Image.pitch];
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    98
            end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    99
     end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   100
if SDL_MustLock(Image) then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   101
   SDL_UnlockSurface(Image);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   102
WriteLnToConsole(msgOK)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   103
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   104
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   105
procedure AddRect(x1, y1, w1, h1: integer);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   106
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   107
with Rects[RectCount] do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   108
     begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   109
     x:= x1;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   110
     y:= y1;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   111
     w:= w1;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   112
     h:= h1
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   113
     end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   114
inc(RectCount);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   115
TryDo(RectCount < MaxRects, 'AddRect: overflow', true)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   116
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   117
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   118
procedure InitRects;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   119
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   120
RectCount:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   121
New(Rects)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   122
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   123
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   124
procedure FreeRects;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   125
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   126
Dispose(rects)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   127
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   128
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   129
function CheckIntersect(x1, y1, w1, h1: integer): boolean;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   130
var i: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   131
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   132
Result:= false;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   133
i:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   134
if RectCount > 0 then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   135
   repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   136
   with Rects[i] do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   137
        Result:= (x < x1 + w1) and (x1 < x + w) and
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   138
                 (y < y1 + h1) and (y1 < y + h);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   139
   inc(i)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   140
   until (i = RectCount) or (Result)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   141
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   142
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   143
function AddGirder(gX: integer; Surface: PSDL_Surface): boolean;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   144
var tmpsurf: PSDL_Surface;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   145
    x1, x2, y, k, i: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   146
    r, rr: TSDL_Rect;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   147
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   148
    function CountNonZeroz(x, y: integer): Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   149
    var i: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   150
    begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   151
    Result:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   152
    for i:= y to y + 15 do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   153
        if Land[i, x] <> 0 then inc(Result)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   154
    end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   155
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   156
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   157
y:= 150;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   158
repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   159
  inc(y, 24);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   160
  x1:= gX;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   161
  x2:= gX;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   162
  while (x1 > 100) and (CountNonZeroz(x1, y) = 0) do dec(x1, 2);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   163
  i:= x1 - 12;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   164
  repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   165
    k:= CountNonZeroz(x1, y);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   166
    dec(x1, 2)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   167
  until (x1 < 100) or (k = 0) or (k = 16) or (x1 < i);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   168
  inc(x1, 2);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   169
  if k = 16 then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   170
     begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   171
     while (x2 < 1900) and (CountNonZeroz(x2, y) = 0) do inc(x2, 2);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   172
     i:= x2 + 12;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   173
     repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   174
       k:= CountNonZeroz(x2, y);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   175
       inc(x2, 2)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   176
     until (x2 > 1900) or (k = 0) or (k = 16) or (x2 > i);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   177
     if (x2 < 1900) and (k = 16) and (x2 - x1 > 250)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   178
        and not CheckIntersect(x1 - 32, y - 64, x2 - x1 + 64, 144) then break;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   179
     end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   180
x1:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   181
until y > 900;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   182
if x1 > 0 then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   183
   begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   184
   Result:= true;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   185
   tmpsurf:= LoadImage(Pathz[ptGraphics] + '/Girder', false);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   186
   rr.x:= x1;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   187
   rr.y:= y;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   188
   while rr.x + 100 < x2 do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   189
         begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   190
         SDL_UpperBlit(tmpsurf, nil, Surface, @rr);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   191
         inc(rr.x, 100);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   192
         end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   193
   r.x:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   194
   r.y:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   195
   r.w:= x2 - rr.x;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   196
   r.h:= 16;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   197
   SDL_UpperBlit(tmpsurf, @r, Surface, @rr);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   198
   SDL_FreeSurface(tmpsurf);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   199
   AddRect(x1 - 8, y - 32, x2 - x1 + 16, 80);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   200
   for k:= y to y + 15 do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   201
       for i:= x1 to x2 do Land[k, i]:= $FFFFFF
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   202
   end else Result:= false
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   203
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   204
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   205
function CheckLand(rect: TSDL_Rect; dX, dY, Color: Longword): boolean;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   206
var i: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   207
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   208
Result:= true;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   209
inc(rect.x, dX);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   210
inc(rect.y, dY);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   211
i:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   212
{$WARNINGS OFF}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   213
while (i <= rect.w) and Result do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   214
      begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   215
      Result:= (Land[rect.y, rect.x + i] = Color) and (Land[rect.y + rect.h, rect.x + i] = Color);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   216
      inc(i)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   217
      end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   218
i:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   219
while (i <= rect.h) and Result do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   220
      begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   221
      Result:= (Land[rect.y + i, rect.x] = Color) and (Land[rect.y + i, rect.x + rect.w] = Color);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   222
      inc(i)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   223
      end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   224
{$WARNINGS ON}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   225
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   226
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   227
function CheckCanPlace(x, y: Longword; var Obj: TThemeObject): boolean;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   228
var i: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   229
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   230
with Obj do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   231
     if CheckLand(inland, x, y, $FFFFFF) then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   232
        begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   233
        Result:= true;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   234
        i:= 1;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   235
        while Result and (i <= rectcnt) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   236
              begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   237
              Result:= CheckLand(outland[i], x, y, 0);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   238
              inc(i)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   239
              end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   240
        if Result then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   241
           Result:= not CheckIntersect(x, y, Width, Height)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   242
        end else
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   243
        Result:= false
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   244
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   245
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   246
function TryPut(var Obj: TThemeObject; Surface: PSDL_Surface): boolean; overload;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   247
const MaxPointsIndex = 2047;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   248
var x, y: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   249
    ar: array[0..MaxPointsIndex] of TPoint;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   250
    cnt, i: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   251
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   252
cnt:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   253
with Obj do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   254
     begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   255
     if Maxcnt = 0 then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   256
        begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   257
        Result:= false;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   258
        exit
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   259
        end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   260
     x:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   261
     repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   262
         y:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   263
         repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   264
             if CheckCanPlace(x, y, Obj) then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   265
                begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   266
                ar[cnt].x:= x;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   267
                ar[cnt].y:= y;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   268
                inc(cnt);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   269
                if cnt > MaxPointsIndex then // buffer is full, do not check the rest land
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   270
                   begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   271
                   y:= 5000;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   272
                   x:= 5000;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   273
                   end
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   274
                end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   275
             inc(y, 3);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   276
         until y > 1023 - Height;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   277
         inc(x, getrandom(6) + 3)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   278
     until x > 2047 - Width;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   279
     Result:= cnt <> 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   280
     if Result then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   281
        begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   282
        i:= getrandom(cnt);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   283
        BlitImageAndGenerateCollisionInfo(ar[i].x, ar[i].y, Obj.Surf, Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   284
        AddRect(ar[i].x, ar[i].y, Width, Height);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   285
        dec(Maxcnt)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   286
        end else Maxcnt:= 0
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   287
     end
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   288
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   289
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   290
function TryPut(var Obj: TSprayObject; Surface: PSDL_Surface): boolean; overload;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   291
const MaxPointsIndex = 8095;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   292
var x, y: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   293
    ar: array[0..MaxPointsIndex] of TPoint;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   294
    cnt, i: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   295
    r: TSDL_Rect;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   296
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   297
cnt:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   298
with Obj do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   299
     begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   300
     if Maxcnt = 0 then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   301
        begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   302
        Result:= false;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   303
        exit
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   304
        end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   305
     x:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   306
     r.x:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   307
     r.y:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   308
     r.w:= Width;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   309
     r.h:= Height + 16;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   310
     repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   311
         y:= 8;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   312
         repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   313
             if CheckLand(r, x, y - 8, $FFFFFF)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   314
                and not CheckIntersect(x, y, Width, Height) then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   315
                begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   316
                ar[cnt].x:= x;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   317
                ar[cnt].y:= y;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   318
                inc(cnt);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   319
                if cnt > MaxPointsIndex then // buffer is full, do not check the rest land
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   320
                   begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   321
                   y:= 5000;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   322
                   x:= 5000;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   323
                   end
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   324
                end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   325
             inc(y, 12);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   326
         until y > 1023 - Height - 8;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   327
         inc(x, getrandom(12) + 12)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   328
     until x > 2047 - Width;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   329
     Result:= cnt <> 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   330
     if Result then
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   331
        begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   332
        i:= getrandom(cnt);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   333
        r.x:= ar[i].X;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   334
        r.y:= ar[i].Y;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   335
        r.w:= Width;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   336
        r.h:= Height;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   337
        SDL_UpperBlit(Obj.Surf, nil, Surface, @r);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   338
        AddRect(ar[i].x - 32, ar[i].y - 32, Width + 64, Height + 64);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   339
        dec(Maxcnt)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   340
        end else Maxcnt:= 0
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   341
     end
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   342
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   343
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   344
procedure ReadThemeInfo(var ThemeObjects: TThemeObjects; var SprayObjects: TSprayObjects);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   345
var s: string;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   346
    f: textfile;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   347
    i, ii: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   348
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   349
s:= Pathz[ptCurrTheme] + '/' + cThemeCFGFilename;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   350
WriteLnToConsole('Reading objects info...');
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   351
AssignFile(f, s);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   352
{$I-}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   353
Reset(f);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   354
Readln(f, s); // skip color
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   355
Readln(f, ThemeObjects.Count);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   356
for i:= 0 to Pred(ThemeObjects.Count) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   357
    begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   358
    Readln(f, s); // filename
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   359
    with ThemeObjects.objs[i] do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   360
         begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   361
         Surf:= LoadImage(Pathz[ptCurrTheme] + '/' + s, false);
279
5df0ab96b60a Less complex theme.cfg format ;) Information about image dimensions is obtained from image
unc0rr
parents: 184
diff changeset
   362
         Width:= Surf.w;
5df0ab96b60a Less complex theme.cfg format ;) Information about image dimensions is obtained from image
unc0rr
parents: 184
diff changeset
   363
         Height:= Surf.h;
184
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   364
         with inland do Read(f, x, y, w, h);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   365
         Read(f, rectcnt);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   366
         for ii:= 1 to rectcnt do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   367
             with outland[ii] do Read(f, x, y, w, h);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   368
         Maxcnt:= 3;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   369
         ReadLn(f)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   370
         end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   371
    end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   372
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   373
Readln(f, SprayObjects.Count);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   374
for i:= 0 to Pred(SprayObjects.Count) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   375
    begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   376
    Readln(f, s); // filename
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   377
    with SprayObjects.objs[i] do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   378
         begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   379
         Surf:= LoadImage(Pathz[ptCurrTheme] + '/' + s, false);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   380
         Width:= Surf.w;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   381
         Height:= Surf.h;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   382
         ReadLn(f, Maxcnt)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   383
         end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   384
    end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   385
Closefile(f);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   386
{$I+}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   387
TryDo(IOResult = 0, 'Bad data or cannot access file ' + cThemeCFGFilename, true)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   388
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   389
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   390
procedure AddThemeObjects(Surface: PSDL_Surface; var ThemeObjects: TThemeObjects; MaxCount: integer);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   391
var i, ii, t: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   392
    b: boolean;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   393
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   394
if ThemeObjects.Count = 0 then exit;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   395
WriteLnToConsole('Adding theme objects...');
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   396
i:= 1;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   397
repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   398
    t:= getrandom(ThemeObjects.Count);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   399
    ii:= t;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   400
    repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   401
      inc(ii);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   402
      if ii = ThemeObjects.Count then ii:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   403
      b:= TryPut(ThemeObjects.objs[ii], Surface)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   404
    until b or (ii = t);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   405
    inc(i)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   406
until (i > MaxCount) or not b;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   407
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   408
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   409
procedure AddSprayObjects(Surface: PSDL_Surface; var SprayObjects: TSprayObjects; MaxCount: Longword);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   410
var i: Longword;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   411
    ii, t: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   412
    b: boolean;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   413
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   414
if SprayObjects.Count = 0 then exit;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   415
WriteLnToConsole('Adding spray objects...');
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   416
i:= 1;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   417
repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   418
    t:= getrandom(SprayObjects.Count);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   419
    ii:= t;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   420
    repeat
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   421
      inc(ii);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   422
      if ii = SprayObjects.Count then ii:= 0;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   423
      b:= TryPut(SprayObjects.objs[ii], Surface)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   424
    until b or (ii = t);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   425
    inc(i)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   426
until (i > MaxCount) or not b;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   427
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   428
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   429
procedure AddObjects(InSurface, Surface: PSDL_Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   430
var ThemeObjects: TThemeObjects;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   431
    SprayObjects: TSprayObjects;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   432
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   433
InitRects;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   434
AddGirder(256, Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   435
AddGirder(512, Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   436
AddGirder(768, Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   437
AddGirder(1024, Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   438
AddGirder(1280, Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   439
AddGirder(1536, Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   440
AddGirder(1792, Surface);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   441
ReadThemeInfo(ThemeObjects, SprayObjects);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   442
AddThemeObjects(Surface, ThemeObjects, 8);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   443
AddProgress;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   444
SDL_UpperBlit(InSurface, nil, Surface, nil);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   445
AddSprayObjects(Surface, SprayObjects, 10);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   446
FreeRects
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   447
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   448
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
   449
end.