Changeset 312


Ignore:
Timestamp:
Mar 17, 2021, 10:42:18 AM (4 years ago)
Author:
chronos
Message:
  • Modified: TGrExtDescr record changed to class. GrExt changed to dynamic array.
Location:
trunk
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/LocalPlayer/Term.pas

    r310 r312  
    25462546          Jump[0] := 999999;
    25472547        GameMode := Command;
    2548         for i := 0 to nGrExt - 1 do
    2549           FillChar(GrExt[i].pixUsed, GrExt[i].Data.height div 49 * 10, 0);
     2548        for i := 0 to GrExt.Count - 1 do
     2549          GrExt[i].ResetPixUsed;
    25502550        IsoEngine.Reset;
    25512551        Tribes.Init;
  • trunk/LocalPlayer/Tribes.pas

    r301 r312  
    623623      ok := True;
    624624      TestPic.GrName := Copy(Input, 8, 255) + '.png';
    625       HGr := nGrExt - 1;
     625      HGr := GrExt.Count - 1;
    626626      while (HGr >= 0) and (GrExt[HGr].Name <> TestPic.GrName) do
    627627        Dec(HGr);
  • trunk/Packages/CevoComponents/ScreenTools.pas

    r300 r312  
    88  {$ENDIF}
    99  StringTables, LCLIntf, LCLType, SysUtils, Classes, Graphics, Controls, Math,
    10   Forms, Menus, GraphType;
     10  Forms, Menus, GraphType, fgl;
    1111
    1212type
     
    106106
    107107const
    108   nGrExtmax = 64;
    109108  wMainTexture = 640;
    110109  hMainTexture = 480;
     
    170169
    171170type
    172   TGrExtDescr = record { don't use dynamic strings here! }
    173     Name: string[31];
     171
     172  { TGrExtDescr }
     173
     174  TGrExtDescr = class
     175    Name: string;
    174176    Data: TBitmap;
    175177    Mask: TBitmap;
    176     pixUsed: array [Byte] of Byte;
    177   end;
    178 
    179   TGrExtDescrSize = record { for size calculation only - must be the same as
    180       TGrExtDescr, but without pixUsed }
    181     Name: string[31];
    182     Data: TBitmap;
    183     Mask: TBitmap;
     178    pixUsed: array of Byte;
     179    procedure ResetPixUsed;
     180    constructor Create;
     181    destructor Destroy; override;
     182  end;
     183
     184  { TGrExtDescrs }
     185
     186  TGrExtDescrs = class(TFPGObjectList<TGrExtDescr>)
     187    function SearchByName(Name: string): TGrExtDescr;
     188    function AddNew(Name: string): TGrExtDescr;
    184189  end;
    185190
     
    189194  Phrases: TStringTable;
    190195  Phrases2: TStringTable;
    191   nGrExt: Integer;
    192   GrExt: array [0 .. nGrExtmax - 1] of ^TGrExtDescr;
     196  GrExt: TGrExtDescrs;
    193197  HGrSystem: Integer;
    194198  HGrSystem2: Integer;
     
    493497function LoadGraphicSet(const Name: string): Integer;
    494498var
    495   I, x, y, xmax, OriginalColor: Integer;
     499  I: Integer;
     500  x: Integer;
     501  y: Integer;
     502  xmax: Integer;
     503  OriginalColor: Integer;
    496504  FileName: string;
    497   Source: TBitmap;
    498   DataPixel, MaskPixel: TPixelPointer;
    499 begin
    500   I := 0;
    501   while (I < nGrExt) and (GrExt[i].Name <> Name) do
    502     Inc(I);
    503   Result := I;
    504   if I = nGrExt then begin
    505     Source := TBitmap.Create;
    506     Source.PixelFormat := pf24bit;
     505  DataPixel: TPixelPointer;
     506  MaskPixel: TPixelPointer;
     507  NewGrExt: TGrExtDescr;
     508begin
     509  NewGrExt := GrExt.SearchByName(Name);
     510  if not Assigned(NewGrExt) then begin
     511    NewGrExt := GrExt.AddNew(Name);
    507512    FileName := GetGraphicsDir + DirectorySeparator + Name;
    508     if not LoadGraphicFile(Source, FileName) then begin
     513    if not LoadGraphicFile(NewGrExt.Data, FileName) then begin
    509514      Result := -1;
    510515      Exit;
    511516    end;
    512517
    513     GetMem(GrExt[nGrExt], SizeOf(TGrExtDescrSize) + Source.Height div 49 * 10);
    514     GrExt[nGrExt].Name := Name;
    515 
    516     xmax := Source.Width - 1; // allows 4-byte access even for last pixel
     518    NewGrExt.ResetPixUsed;
     519
     520    xmax := NewGrExt.Data.Width - 1; // allows 4-byte access even for last pixel
    517521    // Why there was that limit?
    518522    //if xmax > 970 then
    519523    //  xmax := 970;
    520524
    521     GrExt[nGrExt].Data := Source;
    522     GrExt[nGrExt].Data.PixelFormat := pf24bit;
    523     GrExt[nGrExt].Mask := TBitmap.Create;
    524     GrExt[nGrExt].Mask.PixelFormat := pf24bit;
    525     GrExt[nGrExt].Mask.SetSize(Source.Width, Source.Height);
    526 
    527     GrExt[nGrExt].Data.BeginUpdate;
    528     GrExt[nGrExt].Mask.BeginUpdate;
    529     DataPixel := PixelPointer(GrExt[nGrExt].Data);
    530     MaskPixel := PixelPointer(GrExt[nGrExt].Mask);
    531     for y := 0 to ScaleToNative(Source.Height) - 1 do begin
     525    NewGrExt.Mask.SetSize(NewGrExt.Data.Width, NewGrExt.Data.Height);
     526
     527    NewGrExt.Data.BeginUpdate;
     528    NewGrExt.Mask.BeginUpdate;
     529    DataPixel := PixelPointer(NewGrExt.Data);
     530    MaskPixel := PixelPointer(NewGrExt.Mask);
     531    for y := 0 to ScaleToNative(NewGrExt.Data.Height) - 1 do begin
    532532      for x := 0 to ScaleToNative(xmax) - 1 do begin
    533533        OriginalColor := DataPixel.Pixel^.ARGB and $FFFFFF;
     
    548548      MaskPixel.NextLine;
    549549    end;
    550     GrExt[nGrExt].Data.EndUpdate;
    551     GrExt[nGrExt].Mask.EndUpdate;
    552 
    553     FillChar(GrExt[nGrExt].pixUsed, GrExt[nGrExt].Data.Height div 49 * 10, 0);
    554     Inc(nGrExt);
    555   end;
     550    NewGrExt.Data.EndUpdate;
     551    NewGrExt.Mask.EndUpdate;
     552  end;
     553  Result := GrExt.IndexOf(NewGrExt);
    556554end;
    557555
     
    17011699    UniFont[Section] := TFont.Create;
    17021700
    1703   nGrExt := 0;
     1701  GrExt := TGrExtDescrs.Create;
    17041702  HGrSystem := LoadGraphicSet('System.png');
    17051703  HGrSystem2 := LoadGraphicSet('System2.png');
     
    17231721procedure UnitDone;
    17241722var
    1725   I: integer;
     1723  I: Integer;
    17261724begin
    17271725  RestoreResolution;
    1728   for I := 0 to nGrExt - 1 do begin
    1729     FreeAndNil(GrExt[I].Data);
    1730     FreeAndNil(GrExt[I].Mask);
    1731     FreeMem(GrExt[I]);
    1732   end;
    1733 
     1726  FreeAndNil(GrExt);
    17341727  ReleaseFonts;
    1735 
    17361728  FreeAndNil(Phrases);
    17371729  FreeAndNil(Phrases2);
     
    17441736end;
    17451737
     1738{ TGrExtDescr }
     1739
     1740procedure TGrExtDescr.ResetPixUsed;
     1741begin
     1742  SetLength(pixUsed, Data.Height div 49 * 10);
     1743  if Length(pixUsed) > 0 then
     1744    FillChar(pixUsed[0], Length(pixUsed), 0);
     1745end;
     1746
     1747constructor TGrExtDescr.Create;
     1748begin
     1749  Data := TBitmap.Create;
     1750  Data.PixelFormat := pf24bit;
     1751  Mask := TBitmap.Create;
     1752  Mask.PixelFormat := pf24bit;
     1753end;
     1754
     1755destructor TGrExtDescr.Destroy;
     1756begin
     1757  FreeAndNil(Data);
     1758  FreeAndNil(Mask);
     1759  inherited;
     1760end;
     1761
     1762{ TGrExtDescrs }
     1763
     1764function TGrExtDescrs.SearchByName(Name: string): TGrExtDescr;
     1765var
     1766  I: Integer;
     1767begin
     1768  I := 0;
     1769  while (I < Count) and (Items[I].Name <> Name) do Inc(I);
     1770  if I < Count then Result := Items[I]
     1771    else Result := nil;
     1772end;
     1773
     1774function TGrExtDescrs.AddNew(Name: string): TGrExtDescr;
     1775begin
     1776  Result := TGrExtDescr.Create;
     1777  Result.Name := Name;
     1778  Add(Result);
     1779end;
     1780
    17461781end.
Note: See TracChangeset for help on using the changeset viewer.