Rearrange storage of reserved tracks for railway tiles
[openttd/fttd.git] / src / aircraft_gui.cpp
blob6db75d3af8143876a37f442ea954149275b6caef
1 /* $Id$ */
3 /*
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/>.
8 */
10 /** @file aircraft_gui.cpp The GUI of aircraft. */
12 #include "stdafx.h"
13 #include "aircraft.h"
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 /**
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);
72 /**
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);
94 if (helicopter) {
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) {
101 x += x_offs;
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);