--- oup/current/FileClasses/TXMP.pas 2007/05/27 23:31:26 206 +++ oup/current/FileClasses/TXMP.pas 2007/06/12 16:42:53 212 @@ -3,7 +3,7 @@ unit TXMP; interface uses - TypeDefs, _DataTypes, _FileTypes; + _FileTypes; type TFile_TXMP = class(TFile) @@ -16,51 +16,105 @@ type implementation uses - ConnectionManager, Math; - -{ TFile_SNDD } - -procedure TFile_TXMP.InitDatLinks; -begin - SetLength(FDatLinks, 2); - FDatLinks[0].SrcOffset := $94; - FDatLinks[0].DestID := -1; - FDatLinks[0].PosDestExts := '*'; - FDatLinks[1].SrcOffset := $98; - FDatLinks[1].DestID := -1; - FDatLinks[1].PosDestExts := 'TXMP'; -end; + ConnectionManager, Math, Classes, TypeDefs, _DataTypes; +{ TFile_TXMP } procedure TFile_TXMP.InitDataFields; var tempi: Integer; temps: String; + templist: TStringList; begin - FDataFields := TBlock.Create(Self, 0, 'Base', '', nil); + FDataFields := TBlock.Create(Self, nil, 0, 'Base', '', nil); + templist := TStringList.Create; with FDataFields do begin AddField(TFileID, $00, 'FileID', '', nil); + AddField(TLevelID, $04, 'LevelID', '', nil); + tempi := 128; AddField(TString, $08, 'FileName', '', @tempi); - tempi := 4; - AddField(TInt, $88, 'Flags', '', @tempi); + + templist.Add('MipMapping enabled'); + templist.Add('unknown'); + templist.Add('U wrapping disabled'); + templist.Add('V wrapping disabled'); + templist.Add('EnvMapped/EnvMap'); + templist.Add('unused'); + templist.Add('Play anim back to back'); + templist.Add('Random anim order + frame time'); + AddField(TBitSet, $88, 'Flags1', '', @templist); + + templist.Clear; + templist.Add('Random anim time offset'); + templist.Add('High byte as EnvMap'); + templist.Add('High byte as alpha'); + templist.Add('Different alpha formula'); + templist.Add('Data swapping (always set)'); + templist.Add('used at runtime'); + templist.Add('TXAN looping on/off'); + templist.Add('16 bit blue'); + AddField(TBitSet, $89, 'Flags2', '', @templist); + + templist.Clear; + templist.Add('16 bit alpha'); + templist.Add('16 bit red'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + AddField(TBitSet, $8A, 'Flags3', '', @templist); + + templist.Clear; + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + templist.Add('unknown'); + AddField(TBitSet, $8B, 'Flags4', '', @templist); + tempi := 2; AddField(TInt, $8C, 'Width', '', @tempi); + tempi := 2; AddField(TInt, $8E, 'Height', '', @tempi); + tempi := 4; AddField(TInt, $90, 'StoreType', '', @tempi); - temps := 'TXAN'; + + temps := '*'; AddField(TLinkByID, $94, 'TXAN', '', @temps); + temps := 'TXMP'; AddField(TLinkByID, $98, 'TXMP', '', @temps); + AddField(TRawLink, $9C, 'RawLink', '', nil); + AddField(TRawLink, $A0, 'SepLink', '', nil); + tempi := $1C; AddField(TUnused, $A4, 'Unused', '', @tempi); end; + templist.Free; +end; + + +procedure TFile_TXMP.InitDatLinks; +begin + SetLength(FDatLinks, 2); + FDatLinks[0].SrcOffset := $94; + FDatLinks[0].DestID := GetDatLinkValue(FFileStream, $94); + FDatLinks[0].PosDestExts := '*'; + FDatLinks[1].SrcOffset := $98; + FDatLinks[1].DestID := GetDatLinkValue(FFileStream, $98); + FDatLinks[1].PosDestExts := 'TXMP'; end;