2009-08-21 20:21:05 +00:00
|
|
|
/*
|
|
|
|
* This file is part of OpenTTD.
|
|
|
|
* 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.
|
|
|
|
* 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.
|
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
2008-05-06 15:11:33 +00:00
|
|
|
/** @file transparency.h Functions related to transparency. */
|
2007-11-10 01:17:15 +00:00
|
|
|
|
|
|
|
#ifndef TRANSPARENCY_H
|
|
|
|
#define TRANSPARENCY_H
|
|
|
|
|
2007-12-23 10:56:02 +00:00
|
|
|
#include "gfx_func.h"
|
2010-01-08 22:42:00 +00:00
|
|
|
#include "openttd.h"
|
2010-01-14 22:56:54 +00:00
|
|
|
#include "core/bitmath_func.hpp"
|
2007-12-23 10:56:02 +00:00
|
|
|
|
2007-11-10 01:17:15 +00:00
|
|
|
/**
|
|
|
|
* Transparency option bits: which position in _transparency_opt stands for which transparency.
|
|
|
|
* If you change the order, change the order of the ShowTransparencyToolbar() stuff in transparency_gui.cpp too.
|
|
|
|
* If you add or remove an option don't forget to change the transparency 'hot keys' in main_gui.cpp.
|
|
|
|
*/
|
|
|
|
enum TransparencyOption {
|
|
|
|
TO_SIGNS = 0, ///< signs
|
|
|
|
TO_TREES, ///< trees
|
|
|
|
TO_HOUSES, ///< town buildings
|
|
|
|
TO_INDUSTRIES, ///< industries
|
2008-09-30 20:39:50 +00:00
|
|
|
TO_BUILDINGS, ///< company buildings - depots, stations, HQ, ...
|
2007-11-10 01:17:15 +00:00
|
|
|
TO_BRIDGES, ///< bridges
|
2010-08-08 10:59:30 +00:00
|
|
|
TO_STRUCTURES, ///< other objects such as transmitters and lighthouses
|
2008-02-10 15:53:26 +00:00
|
|
|
TO_CATENARY, ///< catenary
|
2007-11-10 01:17:15 +00:00
|
|
|
TO_LOADING, ///< loading indicators
|
|
|
|
TO_END,
|
2011-05-28 09:46:37 +00:00
|
|
|
TO_INVALID, ///< Invalid transparency option
|
2007-11-10 01:17:15 +00:00
|
|
|
};
|
|
|
|
|
2008-02-10 15:53:26 +00:00
|
|
|
typedef uint TransparencyOptionBits; ///< transparency option bits
|
2007-11-10 01:17:15 +00:00
|
|
|
extern TransparencyOptionBits _transparency_opt;
|
2008-02-10 14:49:44 +00:00
|
|
|
extern TransparencyOptionBits _transparency_lock;
|
2008-04-03 19:55:40 +00:00
|
|
|
extern TransparencyOptionBits _invisibility_opt;
|
2011-05-01 19:14:12 +00:00
|
|
|
extern byte _display_opt;
|
2007-11-10 01:17:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the transparency option bit is set
|
|
|
|
* and if we aren't in the game menu (there's never transparency)
|
|
|
|
*
|
|
|
|
* @param to the structure which transparency option is ask for
|
|
|
|
*/
|
|
|
|
static inline bool IsTransparencySet(TransparencyOption to)
|
|
|
|
{
|
2007-11-19 21:02:30 +00:00
|
|
|
return (HasBit(_transparency_opt, to) && _game_mode != GM_MENU);
|
2007-11-10 01:17:15 +00:00
|
|
|
}
|
|
|
|
|
2008-04-03 19:55:40 +00:00
|
|
|
/**
|
|
|
|
* Check if the invisibility option bit is set
|
|
|
|
* and if we aren't in the game menu (there's never transparency)
|
|
|
|
*
|
|
|
|
* @param to the structure which invisibility option is ask for
|
|
|
|
*/
|
|
|
|
static inline bool IsInvisibilitySet(TransparencyOption to)
|
|
|
|
{
|
|
|
|
return (HasBit(_transparency_opt & _invisibility_opt, to) && _game_mode != GM_MENU);
|
|
|
|
}
|
|
|
|
|
2007-11-10 01:17:15 +00:00
|
|
|
/**
|
|
|
|
* Toggle the transparency option bit
|
|
|
|
*
|
2008-02-10 14:49:44 +00:00
|
|
|
* @param to the transparency option to be toggled
|
2007-11-10 01:17:15 +00:00
|
|
|
*/
|
|
|
|
static inline void ToggleTransparency(TransparencyOption to)
|
|
|
|
{
|
2007-11-20 14:11:19 +00:00
|
|
|
ToggleBit(_transparency_opt, to);
|
2007-11-10 01:17:15 +00:00
|
|
|
}
|
|
|
|
|
2008-04-03 19:55:40 +00:00
|
|
|
/**
|
|
|
|
* Toggle the invisibility option bit
|
|
|
|
*
|
|
|
|
* @param to the structure which invisibility option is toggle
|
|
|
|
*/
|
|
|
|
static inline void ToggleInvisibility(TransparencyOption to)
|
|
|
|
{
|
|
|
|
ToggleBit(_invisibility_opt, to);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Toggles between invisible and solid state.
|
|
|
|
* If object is transparent, then it is made invisible.
|
|
|
|
* Used by the keyboard shortcuts.
|
|
|
|
*
|
|
|
|
* @param to the object type which invisibility option to toggle
|
|
|
|
*/
|
|
|
|
static inline void ToggleInvisibilityWithTransparency(TransparencyOption to)
|
|
|
|
{
|
|
|
|
if (IsInvisibilitySet(to)) {
|
|
|
|
ClrBit(_invisibility_opt, to);
|
|
|
|
ClrBit(_transparency_opt, to);
|
|
|
|
} else {
|
|
|
|
SetBit(_invisibility_opt, to);
|
|
|
|
SetBit(_transparency_opt, to);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-02-10 14:49:44 +00:00
|
|
|
/**
|
|
|
|
* Toggle the transparency lock bit
|
|
|
|
*
|
|
|
|
* @param to the transparency option to be locked or unlocked
|
|
|
|
*/
|
|
|
|
static inline void ToggleTransparencyLock(TransparencyOption to)
|
2007-11-10 01:17:15 +00:00
|
|
|
{
|
2008-02-10 14:49:44 +00:00
|
|
|
ToggleBit(_transparency_lock, to);
|
|
|
|
}
|
2007-11-10 01:17:15 +00:00
|
|
|
|
2008-02-10 14:49:44 +00:00
|
|
|
/** Set or clear all non-locked transparency options */
|
|
|
|
static inline void ResetRestoreAllTransparency()
|
|
|
|
{
|
|
|
|
/* if none of the non-locked options are set */
|
|
|
|
if ((_transparency_opt & ~_transparency_lock) == 0) {
|
|
|
|
/* set all non-locked options */
|
2008-02-29 15:20:02 +00:00
|
|
|
_transparency_opt |= GB(~_transparency_lock, 0, TO_END);
|
2007-11-10 01:17:15 +00:00
|
|
|
} else {
|
2008-02-10 14:49:44 +00:00
|
|
|
/* clear all non-locked options */
|
|
|
|
_transparency_opt &= _transparency_lock;
|
2007-11-10 01:17:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
MarkWholeScreenDirty();
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* TRANSPARENCY_H */
|