# HG changeset patch # User Wuzzy <Wuzzy2@mail.ru> # Date 1521257833 -3600 # Node ID 9f5023a5f9e1d6ba53bc79f716df7565c29e6084 # Parent 6fa6626eb2733e3c731c8feb72e9d4eb2a3af252 Fix speech bubble briefly rendering at (0,0) after spawning diff -r 6fa6626eb273 -r 9f5023a5f9e1 hedgewars/uVisualGears.pas --- a/hedgewars/uVisualGears.pas Sat Mar 17 04:12:10 2018 +0100 +++ b/hedgewars/uVisualGears.pas Sat Mar 17 04:37:13 2018 +0100 @@ -264,16 +264,16 @@ else DrawSpriteRotatedF(sprite, round(Gear^.X) + WorldDx, round(Gear^.Y) + WorldDy + SkyOffset, Gear^.Frame, 1, Gear^.Angle) end;*) - vgtSpeechBubble: begin - if (Gear^.Tex <> nil) and (((Gear^.State = 0) and (Gear^.Hedgehog <> nil) and (Gear^.Hedgehog^.Team <> CurrentTeam)) or (Gear^.State = 1)) then - begin - tinted:= true; - Tint($FF, $FF, $FF, $66); - DrawTextureCentered(round(Gear^.X) + WorldDx, round(Gear^.Y) + WorldDy, Gear^.Tex) - end - else if (Gear^.Tex <> nil) and (((Gear^.State = 0) and ((Gear^.Hedgehog = nil) or (Gear^.Hedgehog^.Team = CurrentTeam))) or (Gear^.State = 2)) then - DrawTextureCentered(round(Gear^.X) + WorldDx, round(Gear^.Y) + WorldDy, Gear^.Tex); - end; + vgtSpeechBubble: if (Gear^.Angle <> 0) then + // ^ Before this gear renders, Angle must be set to mark it ready (e.g. coordinates properly initialized) + if (Gear^.Tex <> nil) and (((Gear^.State = 0) and (Gear^.Hedgehog <> nil) and (Gear^.Hedgehog^.Team <> CurrentTeam)) or (Gear^.State = 1)) then + begin + tinted:= true; + Tint($FF, $FF, $FF, $66); + DrawTextureCentered(round(Gear^.X) + WorldDx, round(Gear^.Y) + WorldDy, Gear^.Tex) + end + else if (Gear^.Tex <> nil) and (((Gear^.State = 0) and ((Gear^.Hedgehog = nil) or (Gear^.Hedgehog^.Team = CurrentTeam))) or (Gear^.State = 2)) then + DrawTextureCentered(round(Gear^.X) + WorldDx, round(Gear^.Y) + WorldDy, Gear^.Tex); vgtSmallDamageTag: DrawTextureCentered(round(Gear^.X) + WorldDx, round(Gear^.Y) + WorldDy, Gear^.Tex); vgtHealthTag: if Gear^.Tex <> nil then begin diff -r 6fa6626eb273 -r 9f5023a5f9e1 hedgewars/uVisualGearsHandlers.pas --- a/hedgewars/uVisualGearsHandlers.pas Sat Mar 17 04:12:10 2018 +0100 +++ b/hedgewars/uVisualGearsHandlers.pas Sat Mar 17 04:37:13 2018 +0100 @@ -640,12 +640,14 @@ begin Gear^.X:= hwFloat2Float(realgear^.X) + (Gear^.Tex^.w div 2 - Gear^.Tag); Gear^.Y:= hwFloat2Float(realgear^.Y) - (realgear^.Radius + Gear^.Tex^.h); + Gear^.Angle:= 1; // Mark speech bubble as ready for rendering end end else if Gear^.Hedgehog^.Gear <> nil then begin Gear^.X:= hwFloat2Float(Gear^.Hedgehog^.Gear^.X) + (Gear^.Tex^.w div 2 - Gear^.Tag); Gear^.Y:= hwFloat2Float(Gear^.Hedgehog^.Gear^.Y) - (cHHRadius + Gear^.Tex^.h); + Gear^.Angle:= 1; // Mark speech bubble as ready for rendering end; if (Gear^.Timer = 0) or ((realgear = nil) and (Gear^.Frame <> 0)) then