2020-04-20 18:47:14 +02:00
|
|
|
#ifndef OPENMW_MWRENDER_VISMASK_H
|
|
|
|
#define OPENMW_MWRENDER_VISMASK_H
|
2015-04-19 01:57:52 +02:00
|
|
|
|
2020-04-20 18:47:14 +02:00
|
|
|
namespace MWRender
|
2015-04-19 01:57:52 +02:00
|
|
|
{
|
|
|
|
|
|
|
|
/// Node masks used for controlling visibility of game objects.
|
2016-01-15 16:31:24 +01:00
|
|
|
/// @par Any node in the OSG scene graph can have a node mask. When traversing the scene graph,
|
2016-01-15 16:34:57 +01:00
|
|
|
/// the node visitor's traversal mask is bitwise AND'ed with the node mask. If the result of this test is
|
2016-01-15 16:31:24 +01:00
|
|
|
/// 0, then the node <i>and all its child nodes</i> are not processed.
|
|
|
|
/// @par Important traversal masks are the camera's cull mask (determines what is visible),
|
|
|
|
/// the update visitor mask (what is updated) and the intersection visitor mask (what is
|
|
|
|
/// selectable through mouse clicks or other intersection tests).
|
|
|
|
/// @par In practice, it can be useful to make a "hierarchy" out of the node masks - e.g. in OpenMW,
|
|
|
|
/// all 3D rendering nodes are child of a Scene Root node with Mask_Scene. When we do not want 3D rendering,
|
|
|
|
/// we can just omit Mask_Scene from the traversal mask, and do not need to omit all the individual
|
|
|
|
/// element masks (water, sky, terrain, etc.) since the traversal will already have stopped at the Scene root node.
|
|
|
|
/// @par The comments within the VisMask enum should give some hints as to what masks are commonly "child" of
|
|
|
|
/// another mask, or what type of node this mask is usually set on.
|
|
|
|
/// @note The mask values are not serialized within models, nor used in any other way that would break backwards
|
|
|
|
/// compatibility if the enumeration values were to be changed. Feel free to change them when it makes sense.
|
2021-04-20 10:42:06 +04:00
|
|
|
enum VisMask : unsigned int
|
2015-04-19 01:57:52 +02:00
|
|
|
{
|
|
|
|
Mask_UpdateVisitor = 0x1, // reserved for separating UpdateVisitors from CullVisitors
|
|
|
|
|
2015-04-30 23:21:25 +02:00
|
|
|
// child of Scene
|
2015-05-24 03:36:34 +02:00
|
|
|
Mask_Effect = (1<<1),
|
|
|
|
Mask_Debug = (1<<2),
|
|
|
|
Mask_Actor = (1<<3),
|
|
|
|
Mask_Player = (1<<4),
|
2015-05-26 16:40:44 +02:00
|
|
|
Mask_Sky = (1<<5),
|
2015-11-10 17:19:51 +01:00
|
|
|
Mask_Water = (1<<6), // choose Water or SimpleWater depending on detail required
|
|
|
|
Mask_SimpleWater = (1<<7),
|
|
|
|
Mask_Terrain = (1<<8),
|
|
|
|
Mask_FirstPerson = (1<<9),
|
2018-03-01 17:32:45 +00:00
|
|
|
Mask_Object = (1<<10),
|
2019-02-21 20:14:18 +04:00
|
|
|
Mask_Static = (1<<11),
|
2015-11-03 23:20:17 +01:00
|
|
|
|
|
|
|
// child of Sky
|
2019-02-21 20:14:18 +04:00
|
|
|
Mask_Sun = (1<<12),
|
|
|
|
Mask_WeatherParticles = (1<<13),
|
2015-11-03 23:20:17 +01:00
|
|
|
|
2015-04-30 23:21:25 +02:00
|
|
|
// top level masks
|
2019-02-21 20:14:18 +04:00
|
|
|
Mask_Scene = (1<<14),
|
|
|
|
Mask_GUI = (1<<15),
|
2015-05-26 16:40:44 +02:00
|
|
|
|
2016-03-10 13:17:01 +01:00
|
|
|
// Set on a ParticleSystem Drawable
|
2019-02-21 20:14:18 +04:00
|
|
|
Mask_ParticleSystem = (1<<16),
|
2015-06-17 15:13:41 +02:00
|
|
|
|
2015-05-26 16:40:44 +02:00
|
|
|
// Set on cameras within the main scene graph
|
2019-02-21 20:14:18 +04:00
|
|
|
Mask_RenderToTexture = (1<<17),
|
2015-05-26 16:40:44 +02:00
|
|
|
|
2019-02-21 20:14:18 +04:00
|
|
|
Mask_PreCompile = (1<<18),
|
2017-03-07 17:10:46 +01:00
|
|
|
|
2015-11-10 17:19:51 +01:00
|
|
|
// Set on a camera's cull mask to enable the LightManager
|
2020-01-12 11:42:47 +04:00
|
|
|
Mask_Lighting = (1<<19),
|
|
|
|
|
|
|
|
Mask_Groundcover = (1<<20),
|
2015-04-19 01:57:52 +02:00
|
|
|
};
|
|
|
|
|
2021-10-27 09:16:01 -07:00
|
|
|
// Defines masks to remove when using ToggleWorld command
|
|
|
|
constexpr static unsigned int sToggleWorldMask = Mask_Debug | Mask_Actor | Mask_Terrain | Mask_Object | Mask_Static | Mask_Groundcover;
|
|
|
|
|
2015-04-19 01:57:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|