4 * This file is part of OpenTTD.
5 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
6 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
7 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
10 /** @file aircraft_gui.cpp The GUI of aircraft. */
14 #include "vehicle_gui.h"
15 #include "newgrf_engine.h"
16 #include "strings_func.h"
17 #include "vehicle_func.h"
18 #include "window_gui.h"
19 #include "spritecache.h"
20 #include "zoom_func.h"
22 #include "table/strings.h"
24 #include "safeguards.h"
27 * Draw the details for the given vehicle at the given position
29 * @param v current vehicle
30 * @param left The left most coordinate to draw
31 * @param right The right most coordinate to draw
32 * @param y The y coordinate
34 void DrawAircraftDetails(const Aircraft
*v
, int left
, int right
, int y
)
36 int y_offset
= (v
->Next()->cargo_cap
!= 0) ? -(FONT_HEIGHT_NORMAL
+ 1): 0;
37 Money feeder_share
= 0;
39 for (const Aircraft
*u
= v
; u
!= nullptr; u
= u
->Next()) {
40 if (u
->IsNormalAircraft()) {
41 SetDParam(0, u
->engine_type
);
42 SetDParam(1, u
->build_year
);
43 SetDParam(2, u
->value
);
44 DrawString(left
, right
, y
, STR_VEHICLE_INFO_BUILT_VALUE
);
46 SetDParam(0, u
->cargo_type
);
47 SetDParam(1, u
->cargo_cap
);
48 SetDParam(2, u
->Next()->cargo_type
);
49 SetDParam(3, u
->Next()->cargo_cap
);
50 SetDParam(4, GetCargoSubtypeText(u
));
51 DrawString(left
, right
, y
+ FONT_HEIGHT_NORMAL
, (u
->Next()->cargo_cap
!= 0) ? STR_VEHICLE_INFO_CAPACITY_CAPACITY
: STR_VEHICLE_INFO_CAPACITY
);
54 if (u
->cargo_cap
!= 0) {
55 uint cargo_count
= u
->cargo
.StoredCount();
57 y_offset
+= FONT_HEIGHT_NORMAL
+ 1;
58 if (cargo_count
!= 0) {
59 /* Cargo names (fix pluralness) */
60 SetDParam(0, u
->cargo_type
);
61 SetDParam(1, cargo_count
);
62 SetDParam(2, u
->cargo
.Source());
63 DrawString(left
, right
, y
+ 2 * FONT_HEIGHT_NORMAL
+ 1 + y_offset
, STR_VEHICLE_DETAILS_CARGO_FROM
);
64 feeder_share
+= u
->cargo
.FeederShare();
72 * Draws an image of an aircraft
73 * @param v Front vehicle
74 * @param left The minimum horizontal position
75 * @param right The maximum horizontal position
76 * @param y Vertical position to draw at
77 * @param selection Selected vehicle to draw a frame around
79 void DrawAircraftImage(const Vehicle
*v
, int left
, int right
, int y
, VehicleID selection
, EngineImageType image_type
)
81 bool rtl
= _current_text_dir
== TD_RTL
;
84 v
->GetImage(rtl
? DIR_E
: DIR_W
, image_type
, &seq
);
86 Rect16 rect
= seq
.GetBounds();
88 int width
= UnScaleGUI(rect
.right
- rect
.left
+ 1);
89 int x_offs
= UnScaleGUI(rect
.left
);
90 int x
= rtl
? right
- width
- x_offs
: left
- x_offs
;
91 bool helicopter
= v
->subtype
== AIR_HELICOPTER
;
93 int y_offs
= ScaleGUITrad(10);
96 PaletteID pal
= (v
->vehstatus
& VS_CRASHED
) ? PALETTE_CRASH
: GetVehiclePalette(v
);
97 seq
.Draw(x
, y
+ y_offs
, pal
, (v
->vehstatus
& VS_CRASHED
) != 0);
99 const Aircraft
*a
= Aircraft::From(v
);
100 VehicleSpriteSeq rotor_seq
;
101 GetCustomRotorSprite(a
, true, image_type
, &rotor_seq
);
102 if (!rotor_seq
.IsValid()) rotor_seq
.Set(SPR_ROTOR_STOPPED
);
103 heli_offs
= ScaleGUITrad(5);
104 rotor_seq
.Draw(x
, y
+ y_offs
- heli_offs
, PAL_NONE
, false);
106 if (v
->index
== selection
) {
108 y
+= UnScaleGUI(rect
.top
) + y_offs
- heli_offs
;
109 DrawFrameRect(x
- 1, y
- 1, x
+ width
+ 1, y
+ UnScaleGUI(rect
.bottom
- rect
.top
+ 1) + heli_offs
+ 1, COLOUR_WHITE
, FR_BORDERONLY
);