/usr/include/SurgSim/Graphics/OsgView.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 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 | // 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_GRAPHICS_OSGVIEW_H
#define SURGSIM_GRAPHICS_OSGVIEW_H
#include <osgViewer/Viewer>
#include "SurgSim/Graphics/View.h"
namespace osgViewer
{
class StatsHandler;
class DisplaySettings;
}
namespace SurgSim
{
namespace Input
{
class CommonDevice;
}
namespace Devices
{
class KeyboardDevice;
class MouseDevice;
}
namespace Graphics
{
class OsgCamera;
class OsgTrackballZoomManipulator;
SURGSIM_STATIC_REGISTRATION(OsgView);
/// OSG-based implementation of graphics view class.
///
/// A Graphics::OsgView wraps a osgViewer::View to provide a visualization of the scene to the user.
///
/// A Graphics::OsgCamera controls the viewpoint of this View.
class OsgView : public View
{
public:
/// Constructor
/// \post The view has no camera.
/// \post The position of the view is (0, 0).
/// \post The dimensions of the view are 800 x 600.
/// \post The window border is enabled.
/// \param name Name of the view
explicit OsgView(const std::string& name);
/// Destructor
~OsgView();
SURGSIM_CLASSNAME(SurgSim::Graphics::OsgView);
void setPosition(const std::array<int, 2>& position) override;
std::array<int, 2> getPosition() const override;
void setDimensions(const std::array<int, 2>& dimensions) override;
std::array<int, 2> getDimensions() const override;
void setDimensionsDouble(const std::array<double, 2>& dimensions) override;
std::array<double, 2> getDimensionsDouble() const override;
void setWindowBorderEnabled(bool enabled) override;
bool isWindowBorderEnabled() const override;
/// Sets the camera which provides the viewpoint in the scene
/// Only allows OsgCamera components, any other will not be set and it will return false.
/// \param camera Camera whose image will be shown in this view
/// \return True if it succeeded, false if it failed
void setCamera(std::shared_ptr<SurgSim::Framework::Component> camera) override;
/// Enables a camera manipulator, implemented via a trackball, this is a temporary solution as it uses
/// the OSG input events rather than reading from the OpenSurgSim input.
/// \param val whether to enable the manipulator or not.
void enableManipulator(bool val);
/// \return whether the manipulator is enabled or not.
bool isManipulatorEnabled();
/// As the camera is not accessible from here and as it cannot be controlled from the outside
/// any more we let the user set the parameters from here.
/// \param position The position of the camera.
/// \param lookat The location the camera looks at.
void setManipulatorParameters(const SurgSim::Math::Vector3d& position, const SurgSim::Math::Vector3d& lookat);
/// Set the camera manipulator position.
/// \param position The position of the camera.
void setManipulatorPosition(const SurgSim::Math::Vector3d& position);
/// \return The position of the camera.
SurgSim::Math::Vector3d getManipulatorPosition();
/// Set the camera manipulator lookAt.
/// \param lookAt The location the camera looks at.
void setManipulatorLookAt(const SurgSim::Math::Vector3d& lookAt);
/// \return The location the camera looks at.
SurgSim::Math::Vector3d getManipulatorLookAt();
/// Enable osg modelview uniforms mapping, in this mode osg replaces the gl builtins with osg_* names, for
/// uniforms and vertex attributes
/// \param val Whether to enable osg uniform mapping, default false
void setOsgMapsUniforms(bool val);
/// \return the state of the osg modelview mapping mode.
bool getOsgMapsUniforms();
/// Return the keyboard to be used with this view.
/// \return A keyboard device
std::shared_ptr<SurgSim::Input::CommonDevice> getKeyboardDevice();
/// Turn on/off the keyboard device to be used.
/// \param val Indicate whether or not to use keyboard device
void enableKeyboardDevice(bool val);
/// \return Whether the keyboard device is enabled.
bool isKeyboardDeviceEnabled();
/// Return the mouse to be used with this view.
/// \return A mouse device
std::shared_ptr<SurgSim::Input::CommonDevice> getMouseDevice();
/// Turn on/off the mouse device to be used.
/// \param val Indicate whether or not to use mouse device
void enableMouseDevice(bool val);
/// \return Whether the mouse device is enabled.
bool isMouseDeviceEnabled();
void update(double dt) override;
/// \return the OSG view which performs the actual work involved in setting up and rendering to a window
osg::ref_ptr<osgViewer::View> getOsgView() const;
protected:
/// Initialize the view
/// \post The view's window is setup.
bool doInitialize() override;
/// Wake up the view
bool doWakeUp() override;
/// Determine Screen Size
int doSetTargetScreen(int val) override;
/// \return The DisplaySettings to be used in this view
virtual osg::ref_ptr<osg::DisplaySettings> createDisplaySettings() const;
private:
/// Patch the StatsHandler rendering
/// \param statsHandler The statshandler that will be patched.
void fixupStatsHandler(osgViewer::StatsHandler* statsHandler);
/// Position of the view on the screen (in pixels)
std::array<int, 2> m_position;
/// Dimensions of the view on the screen (in pixels)
std::array<int, 2> m_dimensions;
std::array<int, 2> m_screenDimensions;
/// Whether the view window has a border
bool m_isWindowBorderEnabled;
/// Whether the next update will be the first time the view has been updated
/// On the first update, the view window is setup.
bool m_isFirstUpdate;
/// Whether the settings have been changed and the window needs to be updated
bool m_areWindowSettingsDirty;
/// OSG view which performs the actual work involved in setting up and rendering to a window
osg::ref_ptr<osgViewer::View> m_view;
/// Wether to enable osg uniform mapping
bool m_osgMapUniforms;
osg::ref_ptr<OsgTrackballZoomManipulator> m_manipulator;
SurgSim::Math::Vector3d m_manipulatorPosition;
SurgSim::Math::Vector3d m_manipulatorLookat;
/// Indicate if a keyboard device is enabled
bool m_keyboardEnabled;
std::shared_ptr<SurgSim::Devices::KeyboardDevice> m_keyboardDevice;
/// Indicate if a mouse device is enabled
bool m_mouseEnabled;
std::shared_ptr<SurgSim::Devices::MouseDevice> m_mouseDevice;
};
}; // namespace Graphics
}; // namespace SurgSim
#endif // SURGSIM_GRAPHICS_OSGVIEW_H
|