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"
25 * Draw the details for the given vehicle at the given position
27 * @param v current vehicle
28 * @param left The left most coordinate to draw
29 * @param right The right most coordinate to draw
30 * @param y The y coordinate
32 void DrawAircraftDetails(const Aircraft
*v
, int left
, int right
, int y
)
34 int y_offset
= (v
->Next()->cargo_cap
!= 0) ? -(FONT_HEIGHT_NORMAL
+ 1): 0;
35 Money feeder_share
= 0;
37 for (const Aircraft
*u
= v
; u
!= NULL
; u
= u
->Next()) {
38 if (u
->IsNormalAircraft()) {
39 SetDParam(0, u
->engine_type
);
40 SetDParam(1, u
->build_year
);
41 SetDParam(2, u
->value
);
42 DrawString(left
, right
, y
, STR_VEHICLE_INFO_BUILT_VALUE
);
44 SetDParam(0, u
->cargo_type
);
45 SetDParam(1, u
->cargo_cap
);
46 SetDParam(2, u
->Next()->cargo_type
);
47 SetDParam(3, u
->Next()->cargo_cap
);
48 SetDParam(4, GetCargoSubtypeText(u
));
49 DrawString(left
, right
, y
+ FONT_HEIGHT_NORMAL
, (u
->Next()->cargo_cap
!= 0) ? STR_VEHICLE_INFO_CAPACITY_CAPACITY
: STR_VEHICLE_INFO_CAPACITY
);
52 if (u
->cargo_cap
!= 0) {
53 uint cargo_count
= u
->cargo
.StoredCount();
55 y_offset
+= FONT_HEIGHT_NORMAL
+ 1;
56 if (cargo_count
!= 0) {
57 /* Cargo names (fix pluralness) */
58 SetDParam(0, u
->cargo_type
);
59 SetDParam(1, cargo_count
);
60 SetDParam(2, u
->cargo
.Source());
61 DrawString(left
, right
, y
+ 2 * FONT_HEIGHT_NORMAL
+ 1 + y_offset
, STR_VEHICLE_DETAILS_CARGO_FROM
);
62 feeder_share
+= u
->cargo
.FeederShare();
67 SetDParam(0, feeder_share
);
68 DrawString(left
, right
, y
+ 3 * FONT_HEIGHT_NORMAL
+ 3 + y_offset
, STR_VEHICLE_INFO_FEEDER_CARGO_VALUE
);
73 * Draws an image of an aircraft
74 * @param v Front vehicle
75 * @param left The minimum horizontal position
76 * @param right The maximum horizontal position
77 * @param y Vertical position to draw at
78 * @param selection Selected vehicle to draw a frame around
80 void DrawAircraftImage(const Vehicle
*v
, int left
, int right
, int y
, VehicleID selection
, EngineImageType image_type
)
82 bool rtl
= _current_text_dir
== TD_RTL
;
84 SpriteID sprite
= v
->GetImage(rtl
? DIR_E
: DIR_W
, image_type
);
85 const Sprite
*real_sprite
= GetSprite(sprite
, ST_NORMAL
);
87 int width
= UnScaleByZoom(real_sprite
->width
, ZOOM_LVL_GUI
);
88 int x_offs
= UnScaleByZoom(real_sprite
->x_offs
, ZOOM_LVL_GUI
);
89 int x
= rtl
? right
- width
- x_offs
: left
- x_offs
;
90 bool helicopter
= v
->subtype
== AIR_HELICOPTER
;
92 PaletteID pal
= (v
->vehstatus
& VS_CRASHED
) ? PALETTE_CRASH
: GetVehiclePalette(v
);
93 DrawSprite(sprite
, pal
, x
, y
+ 10);
95 const Aircraft
*a
= Aircraft::From(v
);
96 SpriteID rotor_sprite
= GetCustomRotorSprite(a
, true, image_type
);
97 if (rotor_sprite
== 0) rotor_sprite
= SPR_ROTOR_STOPPED
;
98 DrawSprite(rotor_sprite
, PAL_NONE
, x
, y
+ 5);
100 if (v
->index
== selection
) {
102 y
+= UnScaleByZoom(real_sprite
->y_offs
, ZOOM_LVL_GUI
) + 10 - (helicopter
? 5 : 0);
103 DrawFrameRect(x
- 1, y
- 1, x
+ width
+ 1, y
+ UnScaleByZoom(real_sprite
->height
, ZOOM_LVL_GUI
) + (helicopter
? 5 : 0) + 1, COLOUR_WHITE
, FR_BORDERONLY
);