tron@2186: /* $Id$ */ tron@2186: belugas@6420: /** @file smallmap_gui.cpp */ belugas@6420: truelight@0: #include "stdafx.h" Darkvater@1891: #include "openttd.h" truelight@4356: #include "functions.h" tron@3234: #include "bridge_map.h" tron@3144: #include "clear_map.h" peter1138@3391: #include "industry_map.h" tron@3338: #include "station_map.h" tron@507: #include "table/strings.h" Darkvater@1918: #include "table/sprites.h" maedhros@6453: #include "landscape.h" tron@679: #include "map.h" tron@1209: #include "tile.h" darkvater@152: #include "gui.h" tron@3144: #include "tree_map.h" tron@3180: #include "tunnel_map.h" truelight@0: #include "window.h" truelight@0: #include "gfx.h" truelight@0: #include "viewport.h" truelight@0: #include "player.h" truelight@0: #include "vehicle.h" truelight@0: #include "town.h" tron@337: #include "sound.h" tron@2159: #include "variables.h" truelight@0: truelight@867: static const Widget _smallmap_widgets[] = { peter1138@2725: { WWT_CLOSEBOX, RESIZE_NONE, 13, 0, 10, 0, 13, STR_00C5, STR_018B_CLOSE_WINDOW}, Darkvater@1918: { WWT_CAPTION, RESIZE_RIGHT, 13, 11, 433, 0, 13, STR_00B0_MAP, STR_018C_WINDOW_TITLE_DRAG_THIS}, Darkvater@1918: { WWT_STICKYBOX, RESIZE_LR, 13, 434, 445, 0, 13, 0x0, STR_STICKY_BUTTON}, Darkvater@2907: { WWT_PANEL, RESIZE_RB, 13, 0, 445, 14, 257, 0x0, STR_NULL}, Darkvater@4939: { WWT_INSET, RESIZE_RB, 13, 2, 443, 16, 255, 0x0, STR_NULL}, Darkvater@1918: { WWT_IMGBTN, RESIZE_LRTB, 13, 380, 401, 258, 279, SPR_IMG_SHOW_COUNTOURS, STR_0191_SHOW_LAND_CONTOURS_ON_MAP}, Darkvater@1918: { WWT_IMGBTN, RESIZE_LRTB, 13, 402, 423, 258, 279, SPR_IMG_SHOW_VEHICLES, STR_0192_SHOW_VEHICLES_ON_MAP}, Darkvater@1918: { WWT_IMGBTN, RESIZE_LRTB, 13, 424, 445, 258, 279, SPR_IMG_INDUSTRY, STR_0193_SHOW_INDUSTRIES_ON_MAP}, Darkvater@1918: { WWT_IMGBTN, RESIZE_LRTB, 13, 380, 401, 280, 301, SPR_IMG_SHOW_ROUTES, STR_0194_SHOW_TRANSPORT_ROUTES_ON}, Darkvater@1918: { WWT_IMGBTN, RESIZE_LRTB, 13, 402, 423, 280, 301, SPR_IMG_PLANTTREES, STR_0195_SHOW_VEGETATION_ON_MAP}, Darkvater@1918: { WWT_IMGBTN, RESIZE_LRTB, 13, 424, 445, 280, 301, SPR_IMG_COMPANY_GENERAL, STR_0196_SHOW_LAND_OWNERS_ON_MAP}, truelight@4339: { WWT_IMGBTN, RESIZE_LRTB, 13, 358, 379, 258, 279, SPR_IMG_SMALLMAP, STR_SMALLMAP_CENTER}, Darkvater@1918: { WWT_IMGBTN, RESIZE_LRTB, 13, 358, 379, 280, 301, SPR_IMG_TOWN, STR_0197_TOGGLE_TOWN_NAMES_ON_OFF}, Darkvater@4938: { WWT_PANEL, RESIZE_RTB, 13, 0, 357, 258, 301, 0x0, STR_NULL}, Darkvater@1918: { WWT_PANEL, RESIZE_RTB, 13, 0, 433, 302, 313, 0x0, STR_NULL}, Darkvater@1918: { WWT_RESIZEBOX, RESIZE_LRTB, 13, 434, 445, 302, 313, 0x0, STR_RESIZE_BUTTON}, Darkvater@1918: { WIDGETS_END}, truelight@0: }; truelight@0: truelight@0: static int _smallmap_type; truelight@0: static bool _smallmap_show_towns = true; truelight@0: belugas@6475: /** Macro for ordinary entry of LegendAndColor */ belugas@6475: #define MK(a,b) {a, b, false, false} belugas@6475: /** Macro for end of list marker in arrays of LegendAndColor */ peter1138@6485: #define MKEND() {0, STR_NULL, true, false} belugas@6475: /** Macro for break marker in arrays of LegendAndColor. belugas@6475: * It will have valid data, though */ peter1138@6485: #define MS(a,b) {a, b, false, true} truelight@0: belugas@6475: /** Structure for holding relevant data for legends in small map */ belugas@6475: struct LegendAndColour { belugas@6475: uint16 colour; ///< color of the item on the map belugas@6475: StringID legend; ///< string corresponding to the colored item belugas@6475: bool end; ///< this is the end of the list belugas@6475: bool col_break; ///< perform a break and go one collumn further belugas@6475: }; belugas@6475: belugas@6475: /** Legend text giving the colours to look for on the minimap */ belugas@6475: static const LegendAndColour _legend_land_contours[] = { rubidium@4344: MK(0x5A, STR_00F0_100M), rubidium@4344: MK(0x5C, STR_00F1_200M), rubidium@4344: MK(0x5E, STR_00F2_300M), rubidium@4344: MK(0x1F, STR_00F3_400M), rubidium@4344: MK(0x27, STR_00F4_500M), truelight@193: rubidium@4344: MS(0xD7, STR_00EB_ROADS), rubidium@4344: MK(0x0A, STR_00EC_RAILROADS), rubidium@4344: MK(0x98, STR_00ED_STATIONS_AIRPORTS_DOCKS), rubidium@4344: MK(0xB5, STR_00EE_BUILDINGS_INDUSTRIES), rubidium@4344: MK(0x0F, STR_00EF_VEHICLES), truelight@0: MKEND() truelight@0: }; truelight@0: belugas@6475: static const LegendAndColour _legend_vehicles[] = { rubidium@4344: MK(0xB8, STR_00F5_TRAINS), rubidium@4344: MK(0xBF, STR_00F6_ROAD_VEHICLES), rubidium@4344: MK(0x98, STR_00F7_SHIPS), rubidium@4344: MK(0x0F, STR_00F8_AIRCRAFT), rubidium@4344: MS(0xD7, STR_00F9_TRANSPORT_ROUTES), rubidium@4344: MK(0xB5, STR_00EE_BUILDINGS_INDUSTRIES), truelight@0: MKEND() truelight@0: }; truelight@0: belugas@6475: static const LegendAndColour _legend_routes[] = { rubidium@4344: MK(0xD7, STR_00EB_ROADS), rubidium@4344: MK(0x0A, STR_00EC_RAILROADS), rubidium@4344: MK(0xB5, STR_00EE_BUILDINGS_INDUSTRIES), rubidium@4344: MS(0x56, STR_011B_RAILROAD_STATION), truelight@0: rubidium@4344: MK(0xC2, STR_011C_TRUCK_LOADING_BAY), rubidium@4344: MK(0xBF, STR_011D_BUS_STATION), rubidium@4344: MK(0xB8, STR_011E_AIRPORT_HELIPORT), rubidium@4344: MK(0x98, STR_011F_DOCK), truelight@0: MKEND() truelight@0: }; truelight@0: belugas@6475: static const LegendAndColour _legend_vegetation[] = { rubidium@4344: MK(0x52, STR_0120_ROUGH_LAND), rubidium@4344: MK(0x54, STR_0121_GRASS_LAND), rubidium@4344: MK(0x37, STR_0122_BARE_LAND), rubidium@4344: MK(0x25, STR_0123_FIELDS), rubidium@4344: MK(0x57, STR_0124_TREES), rubidium@4344: MK(0xD0, STR_00FC_FOREST), rubidium@4344: MS(0x0A, STR_0125_ROCKS), truelight@0: rubidium@4344: MK(0xC2, STR_012A_DESERT), rubidium@4344: MK(0x98, STR_012B_SNOW), rubidium@4344: MK(0xD7, STR_00F9_TRANSPORT_ROUTES), rubidium@4344: MK(0xB5, STR_00EE_BUILDINGS_INDUSTRIES), truelight@0: MKEND() truelight@0: }; truelight@0: belugas@6475: static const LegendAndColour _legend_land_owners[] = { rubidium@4344: MK(0xCA, STR_0126_WATER), rubidium@4344: MK(0x54, STR_0127_NO_OWNER), rubidium@4344: MK(0xB4, STR_0128_TOWNS), rubidium@4344: MK(0x20, STR_0129_INDUSTRIES), truelight@0: MKEND() truelight@0: }; truelight@0: #undef MK truelight@0: #undef MS truelight@0: #undef MKEND truelight@0: belugas@6533: /** Allow room for all industries, plus a terminator entry belugas@6533: * This is required in order to have the indutry slots all filled up */ belugas@6533: static LegendAndColour _legend_from_industries[NUM_INDUSTRYTYPES+1]; truelight@0: belugas@6533: /** belugas@6533: * Fills an array for the industries legends. belugas@6533: */ belugas@6533: void BuildIndustriesLegend() belugas@6533: { belugas@6533: const IndustrySpec *indsp; belugas@6533: uint j = 0; belugas@6533: belugas@6533: /* Add each name */ belugas@6533: for (IndustryType i = 0; i < NUM_INDUSTRYTYPES; i++) { belugas@6533: indsp = GetIndustrySpec(i); belugas@6748: if (indsp->enabled) { belugas@6533: _legend_from_industries[j].legend = indsp->name; belugas@6533: _legend_from_industries[j].colour = indsp->map_colour; belugas@6533: _legend_from_industries[j].col_break = (j % 6) == 0; // break is performed on the 7th item belugas@6533: _legend_from_industries[j].end = false; belugas@6533: j++; belugas@6533: } belugas@6533: } belugas@6533: /* Terminate the list */ belugas@6533: _legend_from_industries[j].end = true; belugas@6533: } belugas@6475: belugas@6475: static const LegendAndColour * const _legend_table[] = { truelight@0: _legend_land_contours, truelight@0: _legend_vehicles, belugas@6533: _legend_from_industries, truelight@0: _legend_routes, truelight@0: _legend_vegetation, truelight@0: _legend_land_owners, truelight@0: }; truelight@0: Darkvater@2966: #if defined(OTTD_ALIGNMENT) tron@2062: static inline void WRITE_PIXELS(Pixel* d, uint32 val) truelight@0: { truelight@0: # if defined(TTD_BIG_ENDIAN) tron@2635: d[0] = GB(val, 24, 8); tron@2635: d[1] = GB(val, 16, 8); tron@2635: d[2] = GB(val, 8, 8); tron@2635: d[3] = GB(val, 0, 8); truelight@0: # elif defined(TTD_LITTLE_ENDIAN) tron@2635: d[0] = GB(val, 0, 8); tron@2635: d[1] = GB(val, 8, 8); tron@2635: d[2] = GB(val, 16, 8); tron@2635: d[3] = GB(val, 24, 8); truelight@0: # endif truelight@0: } truelight@0: truelight@0: /* need to use OR, otherwise we will overwrite the wrong pixels at the edges :( */ belugas@4171: static inline void WRITE_PIXELS_OR(Pixel *d, uint32 val) truelight@0: { truelight@0: # if defined(TTD_BIG_ENDIAN) tron@2635: d[0] |= GB(val, 24, 8); tron@2635: d[1] |= GB(val, 16, 8); tron@2635: d[2] |= GB(val, 8, 8); tron@2635: d[3] |= GB(val, 0, 8); truelight@0: # elif defined(TTD_LITTLE_ENDIAN) tron@2635: d[0] |= GB(val, 0, 8); tron@2635: d[1] |= GB(val, 8, 8); tron@2635: d[2] |= GB(val, 16, 8); tron@2635: d[3] |= GB(val, 24, 8); truelight@0: # endif truelight@0: } truelight@0: #else rubidium@4549: # define WRITE_PIXELS(dst, val) *(uint32*)(dst) = (val); rubidium@4549: # define WRITE_PIXELS_OR(dst,val) *(uint32*)(dst) |= (val); truelight@0: #endif truelight@0: Darkvater@2984: #define MKCOLOR(x) TO_LE32X(x) truelight@0: Darkvater@1918: /* Height encodings; 16 levels XXX - needs updating for more/finer heights! */ truelight@0: static const uint32 _map_height_bits[16] = { truelight@0: MKCOLOR(0x5A5A5A5A), truelight@0: MKCOLOR(0x5A5B5A5B), truelight@0: MKCOLOR(0x5B5B5B5B), truelight@0: MKCOLOR(0x5B5C5B5C), truelight@0: MKCOLOR(0x5C5C5C5C), truelight@0: MKCOLOR(0x5C5D5C5D), truelight@0: MKCOLOR(0x5D5D5D5D), truelight@0: MKCOLOR(0x5D5E5D5E), truelight@0: MKCOLOR(0x5E5E5E5E), truelight@0: MKCOLOR(0x5E5F5E5F), truelight@0: MKCOLOR(0x5F5F5F5F), truelight@0: MKCOLOR(0x5F1F5F1F), truelight@0: MKCOLOR(0x1F1F1F1F), truelight@0: MKCOLOR(0x1F271F27), truelight@0: MKCOLOR(0x27272727), truelight@0: MKCOLOR(0x27272727), truelight@0: }; truelight@0: rubidium@6248: struct AndOr { tron@1511: uint32 mor; tron@1511: uint32 mand; rubidium@6248: }; tron@1511: belugas@4171: static inline uint32 ApplyMask(uint32 colour, const AndOr *mask) tron@1511: { tron@1511: return (colour & mask->mand) | mask->mor; tron@1511: } tron@1511: Darkvater@1918: tron@1511: static const AndOr _smallmap_contours_andor[] = { rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0x000A0A00), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00B5B500), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0x98989898), MKCOLOR(0x00000000)}, rubidium@4344: {MKCOLOR(0xCACACACA), MKCOLOR(0x00000000)}, rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0xB5B5B5B5), MKCOLOR(0x00000000)}, rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0x00B5B500), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x000A0A00), MKCOLOR(0xFF0000FF)}, truelight@0: }; truelight@0: tron@1511: static const AndOr _smallmap_vehicles_andor[] = { rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00B5B500), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0xCACACACA), MKCOLOR(0x00000000)}, rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0xB5B5B5B5), MKCOLOR(0x00000000)}, rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0x00B5B500), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, truelight@0: }; truelight@0: tron@1511: static const AndOr _smallmap_vegetation_andor[] = { rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00B5B500), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00575700), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0xCACACACA), MKCOLOR(0x00000000)}, rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0xB5B5B5B5), MKCOLOR(0x00000000)}, rubidium@4344: {MKCOLOR(0x00000000), MKCOLOR(0xFFFFFFFF)}, rubidium@4344: {MKCOLOR(0x00B5B500), MKCOLOR(0xFF0000FF)}, rubidium@4344: {MKCOLOR(0x00D7D700), MKCOLOR(0xFF0000FF)}, truelight@0: }; truelight@0: Darkvater@1918: typedef uint32 GetSmallMapPixels(TileIndex tile); // typedef callthrough function Darkvater@1918: Darkvater@1918: /** Darkvater@1918: * Draws one column of the small map in a certain mode onto the screen buffer. This Darkvater@1918: * function looks exactly the same for all types Darkvater@1918: * Darkvater@1918: * @param dst Pointer to a part of the screen buffer to write to. Darkvater@1918: * @param xc The X coordinate of the first tile in the column. Darkvater@1918: * @param yc The Y coordinate of the first tile in the column Darkvater@1918: * @param pitch Number of pixels to advance in the screen buffer each time a pixel is written. Darkvater@1918: * @param reps Number of lines to draw Darkvater@1918: * @param mask ? Darkvater@1918: * @param proc Pointer to the colour function Darkvater@1918: * @see GetSmallMapPixels(TileIndex) Darkvater@1918: */ tron@2062: static void DrawSmallMapStuff(Pixel *dst, uint xc, uint yc, int pitch, int reps, uint32 mask, GetSmallMapPixels *proc) Darkvater@1918: { tron@2062: Pixel *dst_ptr_end = _screen.dst_ptr + _screen.width * _screen.height - _screen.width; Darkvater@1918: Darkvater@1918: do { belugas@6420: /* check if the tile (xc,yc) is within the map range */ Darkvater@1919: if (xc < MapMaxX() && yc < MapMaxY()) { belugas@6420: /* check if the dst pointer points to a pixel inside the screen buffer */ Darkvater@1918: if (dst > _screen.dst_ptr && dst < dst_ptr_end) tron@1981: WRITE_PIXELS_OR(dst, proc(TileXY(xc, yc)) & mask); Darkvater@1918: } belugas@6420: /* switch to next tile in the column */ Darkvater@1918: } while (xc++, yc++, dst += pitch, --reps != 0); Darkvater@1918: } Darkvater@1918: tron@1516: tron@1516: static inline TileType GetEffectiveTileType(TileIndex tile) truelight@0: { tron@1516: TileType t = GetTileType(tile); truelight@0: truelight@0: if (t == MP_TUNNELBRIDGE) { tron@3180: TransportType tt; tron@3180: tron@3184: if (IsTunnel(tile)) { tron@3184: tt = GetTunnelTransportType(tile); tron@3184: } else { tron@3234: tt = GetBridgeTransportType(tile); tron@3180: } tron@3180: switch (tt) { tron@3180: case TRANSPORT_RAIL: t = MP_RAILWAY; break; tron@3180: case TRANSPORT_ROAD: t = MP_STREET; break; tron@3180: default: t = MP_WATER; break; truelight@0: } truelight@0: } tron@1516: return t; tron@1516: } tron@1516: Darkvater@1918: /** Darkvater@1918: * Return the color a tile would be displayed with in the small map in mode "Contour". Darkvater@1918: * @param tile The tile of which we would like to get the color. Darkvater@1918: * @return The color of tile in the small map in mode "Contour" Darkvater@1918: */ tron@1516: static inline uint32 GetSmallMapContoursPixels(TileIndex tile) tron@1516: { tron@1516: TileType t = GetEffectiveTileType(tile); truelight@0: tron@1511: return tron@1511: ApplyMask(_map_height_bits[TileHeight(tile)], &_smallmap_contours_andor[t]); truelight@0: } truelight@0: Darkvater@1918: /** Darkvater@1918: * Return the color a tile would be displayed with in the small map in mode "Vehicles". Darkvater@1918: * belugas@6483: * @param tile The tile of which we would like to get the color. Darkvater@1918: * @return The color of tile in the small map in mode "Vehicles" Darkvater@1918: */ tron@1515: static inline uint32 GetSmallMapVehiclesPixels(TileIndex tile) truelight@0: { tron@1516: TileType t = GetEffectiveTileType(tile); truelight@0: tron@1511: return ApplyMask(MKCOLOR(0x54545454), &_smallmap_vehicles_andor[t]); truelight@0: } truelight@0: Darkvater@1918: /** Darkvater@1918: * Return the color a tile would be displayed with in the small map in mode "Industries". Darkvater@1918: * Darkvater@1918: * @param tile The tile of which we would like to get the color. Darkvater@1918: * @return The color of tile in the small map in mode "Industries" Darkvater@1918: */ tron@1515: static inline uint32 GetSmallMapIndustriesPixels(TileIndex tile) truelight@0: { tron@1516: TileType t = GetEffectiveTileType(tile); truelight@0: truelight@0: if (t == MP_INDUSTRY) { belugas@6441: return GetIndustrySpec(GetIndustryByTile(tile)->type)->map_colour * 0x01010101; truelight@0: } Darkvater@1918: Darkvater@1918: return ApplyMask(MKCOLOR(0x54545454), &_smallmap_vehicles_andor[t]); truelight@0: } truelight@0: Darkvater@1918: /** Darkvater@1918: * Return the color a tile would be displayed with in the small map in mode "Routes". Darkvater@1918: * belugas@6483: * @param tile The tile of which we would like to get the color. Darkvater@1918: * @return The color of tile in the small map in mode "Routes" Darkvater@1918: */ tron@1515: static inline uint32 GetSmallMapRoutesPixels(TileIndex tile) truelight@0: { tron@1516: TileType t = GetEffectiveTileType(tile); truelight@0: uint32 bits; truelight@0: truelight@0: if (t == MP_STATION) { tron@3338: switch (GetStationType(tile)) { tron@3338: case STATION_RAIL: bits = MKCOLOR(0x56565656); break; tron@3338: case STATION_AIRPORT: bits = MKCOLOR(0xB8B8B8B8); break; tron@3338: case STATION_TRUCK: bits = MKCOLOR(0xC2C2C2C2); break; tron@3338: case STATION_BUS: bits = MKCOLOR(0xBFBFBFBF); break; tron@3338: case STATION_DOCK: bits = MKCOLOR(0x98989898); break; tron@3338: default: bits = MKCOLOR(0xFFFFFFFF); break; tron@3338: } truelight@0: } else { belugas@6420: /* ground color */ tron@1511: bits = ApplyMask(MKCOLOR(0x54545454), &_smallmap_contours_andor[t]); truelight@0: } truelight@0: return bits; truelight@0: } truelight@0: truelight@0: tron@2955: static const uint32 _vegetation_clear_bits[] = { Darkvater@1918: MKCOLOR(0x54545454), ///< full grass Darkvater@1918: MKCOLOR(0x52525252), ///< rough land Darkvater@1918: MKCOLOR(0x0A0A0A0A), ///< rocks Darkvater@1918: MKCOLOR(0x25252525), ///< fields Darkvater@1918: MKCOLOR(0x98989898), ///< snow Darkvater@1918: MKCOLOR(0xC2C2C2C2), ///< desert Darkvater@1918: MKCOLOR(0x54545454), ///< unused Darkvater@1918: MKCOLOR(0x54545454), ///< unused truelight@0: }; truelight@0: tron@1515: static inline uint32 GetSmallMapVegetationPixels(TileIndex tile) truelight@0: { tron@1516: TileType t = GetEffectiveTileType(tile); truelight@0: uint32 bits; truelight@0: tron@1515: switch (t) { tron@1515: case MP_CLEAR: tron@3447: if (IsClearGround(tile, CLEAR_GRASS) && GetClearDensity(tile) < 3) { tron@2955: bits = MKCOLOR(0x37373737); tron@2955: } else { tron@2955: bits = _vegetation_clear_bits[GetClearGround(tile)]; tron@2955: } tron@1515: break; tron@1515: tron@1515: case MP_INDUSTRY: belugas@6757: bits = GetIndustrySpec(GetIndustryByTile(tile)->type)->check_proc == CHECK_FOREST ? MKCOLOR(0xD0D0D0D0) : MKCOLOR(0xB5B5B5B5); tron@1515: break; tron@1515: tron@1515: case MP_TREES: tron@3441: if (GetTreeGround(tile) == TREE_GROUND_SNOW_DESERT) { belugas@6357: bits = (_opt.landscape == LT_ARCTIC) ? MKCOLOR(0x98575798) : MKCOLOR(0xC25757C2); tron@2951: } else { tron@1515: bits = MKCOLOR(0x54575754); tron@2951: } tron@1515: break; tron@1515: tron@1515: default: tron@1515: bits = ApplyMask(MKCOLOR(0x54545454), &_smallmap_vehicles_andor[t]); tron@1515: break; truelight@0: } truelight@0: truelight@0: return bits; truelight@0: } truelight@0: truelight@0: Darkvater@4846: static uint32 _owner_colors[OWNER_END + 1]; truelight@0: Darkvater@1918: /** Darkvater@1918: * Return the color a tile would be displayed with in the small map in mode "Owner". Darkvater@1918: * belugas@6483: * @param tile The tile of which we would like to get the color. Darkvater@1918: * @return The color of tile in the small map in mode "Owner" Darkvater@1918: */ tron@1515: static inline uint32 GetSmallMapOwnerPixels(TileIndex tile) truelight@0: { tron@2368: Owner o; truelight@0: tron@2368: switch (GetTileType(tile)) { Darkvater@4846: case MP_INDUSTRY: o = OWNER_END; break; tron@2368: case MP_HOUSE: o = OWNER_TOWN; break; tron@2368: default: o = GetTileOwner(tile); break; truelight@0: } truelight@0: tron@2368: return _owner_colors[o]; truelight@0: } truelight@0: truelight@0: truelight@0: static const uint32 _smallmap_mask_left[3] = { truelight@0: MKCOLOR(0xFF000000), truelight@0: MKCOLOR(0xFFFF0000), truelight@0: MKCOLOR(0xFFFFFF00), truelight@0: }; truelight@0: tron@1515: static const uint32 _smallmap_mask_right[] = { truelight@0: MKCOLOR(0x000000FF), truelight@0: MKCOLOR(0x0000FFFF), truelight@0: MKCOLOR(0x00FFFFFF), truelight@0: }; truelight@0: truelight@0: /* each tile has 4 x pixels and 1 y pixel */ truelight@0: Darkvater@1918: static GetSmallMapPixels *_smallmap_draw_procs[] = { Darkvater@1918: GetSmallMapContoursPixels, Darkvater@1918: GetSmallMapVehiclesPixels, Darkvater@1918: GetSmallMapIndustriesPixels, Darkvater@1918: GetSmallMapRoutesPixels, Darkvater@1918: GetSmallMapVegetationPixels, Darkvater@1918: GetSmallMapOwnerPixels, truelight@0: }; truelight@0: truelight@0: static const byte _vehicle_type_colors[6] = { truelight@0: 184, 191, 152, 15, 215, 184 truelight@0: }; truelight@0: truelight@0: truelight@0: static void DrawVertMapIndicator(int x, int y, int x2, int y2) truelight@0: { tron@2951: GfxFillRect(x, y, x2, y + 3, 69); tron@2951: GfxFillRect(x, y2 - 3, x2, y2, 69); truelight@0: } truelight@0: truelight@0: static void DrawHorizMapIndicator(int x, int y, int x2, int y2) truelight@0: { tron@2951: GfxFillRect(x, y, x + 3, y2, 69); tron@2951: GfxFillRect(x2 - 3, y, x2, y2, 69); truelight@0: } truelight@0: Darkvater@1918: /** Darkvater@1918: * Draws the small map. Darkvater@1918: * Darkvater@1918: * Basically, the small map is draw column of pixels by column of pixels. The pixels Darkvater@1918: * are drawn directly into the screen buffer. The final map is drawn in multiple passes. Darkvater@1918: * The passes are: Darkvater@1918: *