tdf#154285 Check upper bound of arguments in SbRtl_Minute function
[LibreOffice.git] / oox / inc / drawingml / scene3dhelper.hxx
blob0f79825b13cac101f756bef7b16a9bed2c5bc84c
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 */
11 #pragma once
13 #include <drawingml/shape3dproperties.hxx>
14 #include <oox/drawingml/drawingmltypes.hxx>
15 #include <oox/helper/propertymap.hxx>
17 namespace oox
19 class Scene3DHelper
21 public:
22 /** Creates extrusion properties in rPropertyMap from the 3D information in p3DProperties and
23 gives values which have to be set as shape properties.
24 @param [in] p3DProperties a pointer to Shape3DProperties
25 @param [in] rnMSOShapeRotation a MSO shape rotation angle in 1/60000 deg
26 @param [in, out] rPropertyMap a map that is filled with properties directly usable in
27 CustomShapeProperties.pushToPropSet() for property Extrusion.
28 @param [out] rRotZ the angle for shape rotation around z-axis in rad, with orientation
29 same as API shape property RotateAngle. It has the shape rotation from rnMSOShapeRotation
30 integrated.
31 @param [out] rExtrusionColor a complex color from which the color of the extruded faces can
32 be created. The extrusion color is not handled as extrusion property but as secondary
33 color in the style of the shape. If no 3D exist or the camera is invalid, the parameter
34 value is unchanged.
35 @param [in] This optional parameter bBlockExtrusion can be removed when tdf#159912 is
36 fixed. For details see the bugreport.
37 @return Returns true if extrusion properties are generated. Returns false if there is no 3D
38 or if rendering without 3D is currently better. rPropertyMap is unchanged in such case.
40 bool setExtrusionProperties(const oox::drawingml::Shape3DPropertiesPtr p3DProperties,
41 const sal_Int32& rnMSOShapeRotation, oox::PropertyMap& rPropertyMap,
42 double& rRotZ, oox::drawingml::Color& rExtrusionColor,
43 const bool bBlockExtrusion = false);
45 /** Creates lighting properties in rPropertyMap from MSO preset and shape rotation
46 @param [in] p3DProperties a pointer to Shape3DProperties
47 @param [in] rRotZ the shape rotation inclusive camera z-rotation as calculated by
48 setExtrusionProperties()
49 @param [in, out] rPropertyMap the map, that was already filled by setExtrusionProperties()*/
50 void setLightingProperties(const oox::drawingml::Shape3DPropertiesPtr p3DProperties,
51 const double& rRotZ, oox::PropertyMap& rPropertyMap);
53 /** Puts the material properties of the 3D-shape into the property map
54 @details OOXML and MSO describe the material properties using Specular Color (RGBA), Diffuse
55 Color (RGBA), Ambient Color (RGBA), Emissive Color (RGBA), Specular Power (positive int),
56 Diffuse Fresnel (int), Alpha Fresnel (int), Metal (bool) and Blinn Highlight (bool). ODF
57 and API have Diffusion (double), Specularity (double), Shininess (double), Metal (bool),
58 MetalType (enum). Thus a directly use of the MSO values is not possible and some material
59 types cannot be rendered. The method uses workarounds and approximations.
60 @param [in] p3DProperties contains besides other properties the material preset name
61 @param [in, out] rPropertyMap has properties directly usable in
62 CustomShapeProperties.pushToPropSet() for property Extrusion.*/
63 static void setMaterialProperties(const oox::drawingml::Shape3DPropertiesPtr p3DProperties,
64 oox::PropertyMap& rPropertyMap);
66 private:
67 /** Calculates angles suitable for API from OOXML scene3d angles.
68 @param [in] nLat, nLon, nRev in unit 1/60000 deg with same orientation as the attributes lat,
69 lon and rev of the <rot> child element of the <scene3d> element in OOXML markup.
70 @param [out] fX, fY, fZ values in unit radians with correct orientation for API properties
71 EnhancedCustomShapeExtrusion::RotateAngle and RotationDescriptor::RotateAngle*/
72 static void getAPIAnglesFromOOXAngle(const sal_Int32 nLat, const sal_Int32 nLon,
73 const sal_Int32 nRev, double& fX, double& fY, double& fZ);
75 /** Calculates angles suitable for API from Shape3DProperties.
76 @details It considers the preset camera in case the optional, direct rotation angles have no
77 value. It integrates the given rnMSOShapeRotation into fZ.
78 @param [in] p3DProperties a pointer to Shape3DProperties
79 @param [in] rnMSOShapeRotation rotation in 1/60000 deg as given in 'rot' attribute of 'xfrm'
80 element in OOXML.
81 @param [out] fX, fY, fZ values in unit radians with correct orientation for API properties
82 EnhancedCustomShapeExtrusion::RotateAngle and RotationDescriptor::RotateAngle*/
83 void getAPIAnglesFrom3DProperties(const oox::drawingml::Shape3DPropertiesPtr p3DProperties,
84 const sal_Int32& rnMSOShapeRotation, double& fX, double& fY,
85 double& fZ);
87 /** Adds the rotation angles fX and fY as property RotateAngle to the map.
88 @param [in, out] rPropertyMap a map to add the RotateAngle property
89 @param [in] fX, fY rotation angle in unit rad with correct orientation for the property.*/
90 static void addRotateAngleToMap(oox::PropertyMap& rPropertyMap, const double fX,
91 const double fY);
93 /** Adds the Depth property to the map.
94 @details The second component is relative, whereas the z-position in OOXML is absolute. Uses
95 360EMU depth in case of zero Depth as otherwise no relative position is possible.
96 @param [in] p3DProperties a pointer to Shape3DProperties
97 @param [in, out] rPropertyMap a map to add the Depth property*/
98 static void addExtrusionDepthToMap(const oox::drawingml::Shape3DPropertiesPtr p3DProperties,
99 oox::PropertyMap& rPropertyMap);
101 /** Adds the projection mode itself and the associated camera parameters to the map.
102 @details Both modes add ProjectionMode and Origin properties. Adds Skew property in case of
103 mode PARALLEL and ViewPoint property in case of mode PERSPECTIVE. The Skew angles includes the
104 shape rotation because MSOffice rotates after creating the projection and ODF before.
105 @param [in] p3DProperties a pointer to Shape3DProperties
106 @param [in, out] rPropertyMap a map to add ProjectMode, Origin and Skew or ViewPoint
107 properties.
108 @param [in] bIsParallel true for mode PARALLEL, false for PERSPECTIVE
109 @param [in] rnMSOShapeRotation shape rotation in 1/60000 degree*/
110 void addProjectionGeometryToMap(const oox::drawingml::Shape3DPropertiesPtr p3DProperties,
111 oox::PropertyMap& rPropertyMap, const bool bIsParallel,
112 const sal_Int32 rnMSOShapeRotation);
114 // Index into array aPrstCameraValuesArray.
115 sal_Int16 mnPrstCameraIndex = -1; // '-1' means invalid or not yet searched
116 }; // end class Scene3DHelper
118 } // end namespace oox
120 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */