mirror of
https://github.com/OpenTTD/OpenTTD.git
synced 2025-01-22 23:26:34 +00:00
84 lines
2.8 KiB
C
84 lines
2.8 KiB
C
/* $Id$ */
|
|
|
|
#ifndef NEWS_H
|
|
#define NEWS_H
|
|
|
|
struct NewsItem {
|
|
StringID string_id;
|
|
uint16 duration;
|
|
Date date;
|
|
byte flags;
|
|
byte display_mode;
|
|
byte type;
|
|
byte callback;
|
|
|
|
TileIndex data_a;
|
|
TileIndex data_b;
|
|
|
|
uint32 params[10];
|
|
};
|
|
|
|
typedef bool ValidationProc ( uint data_a, uint data_b );
|
|
typedef void DrawNewsCallbackProc(Window *w);
|
|
typedef StringID GetNewsStringCallbackProc(const NewsItem *ni);
|
|
|
|
#define NEWS_FLAGS(mode,flag,type,cb) ((cb)<<24 | (type)<<16 | (flag)<<8 | (mode))
|
|
void AddNewsItem(StringID string, uint32 flags, uint data_a, uint data_b);
|
|
void NewsLoop(void);
|
|
void DrawNewsBorder(const Window *w);
|
|
void InitNewsItemStructs(void);
|
|
|
|
VARDEF NewsItem _statusbar_news_item;
|
|
|
|
enum NewsType {
|
|
NT_ARRIVAL_PLAYER = 0,
|
|
NT_ARRIVAL_OTHER = 1,
|
|
NT_ACCIDENT = 2,
|
|
NT_COMPANY_INFO = 3,
|
|
NT_ECONOMY = 4,
|
|
NT_ADVICE = 5,
|
|
NT_NEW_VEHICLES = 6,
|
|
NT_ACCEPTANCE = 7,
|
|
NT_SUBSIDIES = 8,
|
|
NT_GENERAL = 9,
|
|
};
|
|
|
|
enum NewsMode {
|
|
NM_SMALL = 0, ///< Show only a small popup informing us about vehicle age for example
|
|
NM_NORMAL = 1, ///< Show a simple news message (height 170 pixels)
|
|
NM_THIN = 2, ///< Show a simple news message (height 130 pixels)
|
|
NM_CALLBACK = 3, ///< Do some special processing before displaying news message. Which callback to call is in NewsCallback
|
|
};
|
|
|
|
enum NewsFlags {
|
|
NF_VIEWPORT = (1 << 1), ///< Does the news message have a viewport? (ingame picture of happening)
|
|
NF_TILE = (1 << 2), ///< When clicked on the news message scroll to a given tile? Tile is in data_a/data_b
|
|
NF_VEHICLE = (1 << 3), ///< When clicked on the message scroll to the vehicle? VehicleID is in data_a
|
|
NF_FORCE_BIG = (1 << 4), ///< Force the appearance of a news message if it has already been shown (internal)
|
|
NF_INCOLOR = (1 << 5), ///< Show the newsmessage in colour, otherwise it defaults to black & white
|
|
};
|
|
|
|
enum NewsCallback {
|
|
DNC_TRAINAVAIL = 0, ///< Show new train available message. StringID is EngineID
|
|
DNC_ROADAVAIL = 1, ///< Show new road vehicle available message. StringID is EngineID
|
|
DNC_SHIPAVAIL = 2, ///< Show new ship available message. StringID is EngineID
|
|
DNC_AIRCRAFTAVAIL = 3, ///< Show new aircraft available message. StringID is EngineID
|
|
DNC_BANKRUPCY = 4, ///< Show bankrupcy message. StringID is PlayerID (0-3) and NewsBankrupcy (4-7)
|
|
};
|
|
|
|
enum NewsBankrupcy {
|
|
NB_BTROUBLE = (1 << 4), ///< Company is in trouble (warning)
|
|
NB_BMERGER = (2 << 4), ///< Company has been bought by another company
|
|
NB_BBANKRUPT = (3 << 4), ///< Company has gone bankrupt
|
|
NB_BNEWCOMPANY = (4 << 4), ///< A new company has been started
|
|
};
|
|
|
|
/**
|
|
* Delete a news item type about a vehicle
|
|
* if the news item type is INVALID_STRING_ID all news about the vehicle get
|
|
* deleted
|
|
*/
|
|
void DeleteVehicleNews(VehicleID, StringID news);
|
|
|
|
#endif /* NEWS_H */
|