2016-01-06 13:19:15 +01:00
|
|
|
#ifndef OPENMW_COMPONENTS_LIGHTUTIL_H
|
|
|
|
#define OPENMW_COMPONENTS_LIGHTUTIL_H
|
|
|
|
|
2016-10-08 03:49:50 +02:00
|
|
|
#include <osg/Vec4f>
|
2022-09-22 21:26:05 +03:00
|
|
|
#include <osg/ref_ptr>
|
2016-10-08 03:49:50 +02:00
|
|
|
|
2016-01-06 13:19:15 +01:00
|
|
|
namespace osg
|
2016-01-06 13:37:55 +01:00
|
|
|
{
|
|
|
|
class Group;
|
2019-04-09 23:32:34 +03:00
|
|
|
class Light;
|
2016-01-06 13:37:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace ESM
|
2016-01-06 13:19:15 +01:00
|
|
|
{
|
2016-02-16 19:17:04 +01:00
|
|
|
struct Light;
|
2016-01-06 13:19:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace SceneUtil
|
|
|
|
{
|
2016-10-08 03:49:50 +02:00
|
|
|
class LightSource;
|
2023-02-07 11:30:57 +01:00
|
|
|
struct LightCommon;
|
2016-01-06 13:19:15 +01:00
|
|
|
|
2019-04-09 23:32:34 +03:00
|
|
|
/// @brief Set up global attenuation settings for an osg::Light.
|
|
|
|
/// @param radius The radius of the light source.
|
|
|
|
/// @param isExterior Is the light outside? May be used for deciding which attenuation settings to use.
|
2022-09-22 21:26:05 +03:00
|
|
|
void configureLight(osg::Light* light, float radius, bool isExterior);
|
2019-04-09 23:32:34 +03:00
|
|
|
|
2016-01-06 13:37:55 +01:00
|
|
|
/// @brief Convert an ESM::Light to a SceneUtil::LightSource, and add it to a sub graph.
|
|
|
|
/// @note If the sub graph contains a node named "AttachLight" (case insensitive), then the light is added to that.
|
2022-06-04 13:35:27 +00:00
|
|
|
/// Otherwise, the light is attached directly to the root node of the subgraph.
|
2016-01-06 13:37:55 +01:00
|
|
|
/// @param node The sub graph to add a light to
|
|
|
|
/// @param esmLight The light definition coming from the game files containing radius, color, flicker, etc.
|
|
|
|
/// @param lightMask Mask to assign to the newly created LightSource.
|
|
|
|
/// @param isExterior Is the light outside? May be used for deciding which attenuation settings to use.
|
2022-09-22 21:26:05 +03:00
|
|
|
osg::ref_ptr<LightSource> addLight(
|
2023-02-07 11:30:57 +01:00
|
|
|
osg::Group* node, const SceneUtil::LightCommon& esmLight, unsigned int lightMask, bool isExterior);
|
2016-01-06 13:19:15 +01:00
|
|
|
|
2016-10-08 03:49:50 +02:00
|
|
|
/// @brief Convert an ESM::Light to a SceneUtil::LightSource, and return it.
|
|
|
|
/// @param esmLight The light definition coming from the game files containing radius, color, flicker, etc.
|
|
|
|
/// @param lightMask Mask to assign to the newly created LightSource.
|
|
|
|
/// @param isExterior Is the light outside? May be used for deciding which attenuation settings to use.
|
|
|
|
/// @param ambient Ambient component of the light.
|
2023-02-07 11:30:57 +01:00
|
|
|
osg::ref_ptr<LightSource> createLightSource(const SceneUtil::LightCommon& esmLight, unsigned int lightMask,
|
2023-02-06 23:38:35 +01:00
|
|
|
bool isExterior, const osg::Vec4f& ambient = osg::Vec4f(0, 0, 0, 1));
|
2016-10-08 03:49:50 +02:00
|
|
|
|
2016-01-06 13:19:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|