This file is indexed.

/usr/include/SurgSim/Blocks/ShadowMapping.h is in libopensurgsim-dev 0.7.0-5.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
// This file is a part of the OpenSurgSim project.
// Copyright 2013, SimQuest Solutions Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef SURGSIM_BLOCKS_SHADOWMAPPING_H
#define SURGSIM_BLOCKS_SHADOWMAPPING_H

#include <string>
#include <memory>
#include <array>
#include <vector>

namespace SurgSim
{

namespace Graphics
{
class OsgMaterial;
}
namespace Framework
{
class SceneElement;
class Component;
}



namespace Blocks
{

///@{
/// Names to use as RenderGroupReferences
static const std::string GROUP_SHADOW_CASTER = "Shadowing";
static const std::string GROUP_SHADOW_RECEIVER = "Shadowed";
///@}

/// Builds a series of SceneElements enabling the rendering of shadows, all graphics object that should cast shadows
/// need to be in the render group GROUP_SHADOW_CASTER, all objects that should receive shadows should be in the
/// render group GROUP_SHADOW_RECEIVER. The rest is done by the graphics system.
/// All of the elements added are \sa RenderPass elements
/// \param camera the view camera that is used for this pass
/// \param light the light that should be used for the shadows
/// \param depthTextureSize the size of the texture for the depth map, main determinant for the quality of the shadows
/// \param shadowTextureSize the size of shadowTexture pass and the blur textures
/// \param lightCameraProjection parameters for an orthogonal projection that will be used to render the scene from
///        the lights point of view, needs to be set so it encompasses all the shadow casters and receivers
/// \param bias the bias to be used when determining something is in shadow or not, increasing this can help remove
///        sharp edges at glancing angles
/// \param intensity the general intensity of the shadow, 1 means everything in shadow will be black, 0 means there
///        won't be any shadows at all
/// \param useBlur whether to blur the output of the light map pass, this will remove some of the blockiness of the
///        shadows
/// \param blurRadius sampling radius for the blur pass
/// \param showDebug whether to show debug information
std::vector<std::shared_ptr<Framework::SceneElement>> createShadowMapping(
			std::shared_ptr<Framework::Component> camera,
			std::shared_ptr<Framework::Component> light,
			int depthTextureSize,
			int shadowTextureSize,
			std::array<double, 6> lightCameraProjection,
			double bias,
			double intensity,
			bool useBlur,
			double blurRadius,
			bool showDebug);

}
}

#endif