RenderSettings.generated.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. using System;
  2. using System.Runtime.CompilerServices;
  3. using System.Runtime.InteropServices;
  4. namespace BansheeEngine
  5. {
  6. /** @addtogroup Rendering
  7. * @{
  8. */
  9. /// <summary>Settings that control rendering for a specific camera (view).</summary>
  10. public partial class RenderSettings : ScriptObject
  11. {
  12. private RenderSettings(bool __dummy0) { }
  13. public RenderSettings()
  14. {
  15. Internal_RenderSettings(this);
  16. }
  17. /// <summary>
  18. /// Determines should automatic exposure be applied to the HDR image. When turned on the average scene brightness will be
  19. /// calculated and used to automatically expose the image to the optimal range. Use the parameters provided by
  20. /// autoExposure to customize the automatic exposure effect. You may also use exposureScale to manually adjust the
  21. /// automatic exposure. When automatic exposure is turned off you can use exposureScale to manually set the exposure.
  22. /// </summary>
  23. public bool EnableAutoExposure
  24. {
  25. get { return Internal_getenableAutoExposure(mCachedPtr); }
  26. set { Internal_setenableAutoExposure(mCachedPtr, value); }
  27. }
  28. /// <summary>Parameters used for customizing automatic scene exposure.</summary>
  29. public AutoExposureSettings AutoExposure
  30. {
  31. get { return Internal_getautoExposure(mCachedPtr); }
  32. set { Internal_setautoExposure(mCachedPtr, value); }
  33. }
  34. /// <summary>
  35. /// Determines should the image be tonemapped. Tonemapping converts an HDR image into LDR image by applying a filmic
  36. /// curve to the image, simulating the effect of film cameras. Filmic curve improves image quality by tapering off lows
  37. /// and highs, preventing under- and over-exposure. This is useful if an image contains both very dark and very bright
  38. /// areas, in which case the global exposure parameter would leave some areas either over- or under-exposed. Use
  39. /// #tonemapping to customize how tonemapping performed.
  40. ///
  41. /// If this is disabled, then color grading and white balancing will not be enabled either. Only relevant for HDR images.
  42. /// </summary>
  43. public bool EnableTonemapping
  44. {
  45. get { return Internal_getenableTonemapping(mCachedPtr); }
  46. set { Internal_setenableTonemapping(mCachedPtr, value); }
  47. }
  48. /// <summary>Parameters used for customizing tonemapping.</summary>
  49. public TonemappingSettings Tonemapping
  50. {
  51. get { return Internal_gettonemapping(mCachedPtr); }
  52. set { Internal_settonemapping(mCachedPtr, value); }
  53. }
  54. /// <summary>
  55. /// Parameters used for customizing white balancing. White balancing converts a scene illuminated by a light of the
  56. /// specified temperature into a scene illuminated by a standard D65 illuminant (average midday light) in order to
  57. /// simulate the effects of chromatic adaptation of the human visual system.
  58. /// </summary>
  59. public WhiteBalanceSettings WhiteBalance
  60. {
  61. get { return Internal_getwhiteBalance(mCachedPtr); }
  62. set { Internal_setwhiteBalance(mCachedPtr, value); }
  63. }
  64. /// <summary>Parameters used for customizing color grading.</summary>
  65. public ColorGradingSettings ColorGrading
  66. {
  67. get { return Internal_getcolorGrading(mCachedPtr); }
  68. set { Internal_setcolorGrading(mCachedPtr, value); }
  69. }
  70. /// <summary>Parameters used for customizing the depth of field effect.</summary>
  71. public DepthOfFieldSettings DepthOfField
  72. {
  73. get { return Internal_getdepthOfField(mCachedPtr); }
  74. set { Internal_setdepthOfField(mCachedPtr, value); }
  75. }
  76. /// <summary>Parameters used for customizing screen space ambient occlusion.</summary>
  77. public AmbientOcclusionSettings AmbientOcclusion
  78. {
  79. get { return Internal_getambientOcclusion(mCachedPtr); }
  80. set { Internal_setambientOcclusion(mCachedPtr, value); }
  81. }
  82. /// <summary>Parameters used for customizing screen space reflections.</summary>
  83. public ScreenSpaceReflectionsSettings ScreenSpaceReflections
  84. {
  85. get { return Internal_getscreenSpaceReflections(mCachedPtr); }
  86. set { Internal_setscreenSpaceReflections(mCachedPtr, value); }
  87. }
  88. /// <summary>Parameters used for customizing the bloom effect.</summary>
  89. public BloomSettings Bloom
  90. {
  91. get { return Internal_getbloom(mCachedPtr); }
  92. set { Internal_setbloom(mCachedPtr, value); }
  93. }
  94. /// <summary>Enables the fast approximate anti-aliasing effect.</summary>
  95. public bool EnableFXAA
  96. {
  97. get { return Internal_getenableFXAA(mCachedPtr); }
  98. set { Internal_setenableFXAA(mCachedPtr, value); }
  99. }
  100. /// <summary>
  101. /// Log2 value to scale the eye adaptation by (for example 2^0 = 1). Smaller values yield darker image, while larger
  102. /// yield brighter image. Allows you to customize exposure manually, applied on top of eye adaptation exposure (if
  103. /// enabled). In range [-8, 8].
  104. /// </summary>
  105. public float ExposureScale
  106. {
  107. get { return Internal_getexposureScale(mCachedPtr); }
  108. set { Internal_setexposureScale(mCachedPtr, value); }
  109. }
  110. /// <summary>
  111. /// Gamma value to adjust the image for. Larger values result in a brighter image. When tonemapping is turned on the best
  112. /// gamma curve for the output device is chosen automatically and this value can by used to merely tweak that curve. If
  113. /// tonemapping is turned off this is the exact value of the gamma curve that will be applied.
  114. /// </summary>
  115. public float Gamma
  116. {
  117. get { return Internal_getgamma(mCachedPtr); }
  118. set { Internal_setgamma(mCachedPtr, value); }
  119. }
  120. /// <summary>
  121. /// High dynamic range allows light intensity to be more correctly recorded when rendering by allowing for a larger range
  122. /// of values. The stored light is then converted into visible color range using exposure and a tone mapping operator.
  123. /// </summary>
  124. public bool EnableHDR
  125. {
  126. get { return Internal_getenableHDR(mCachedPtr); }
  127. set { Internal_setenableHDR(mCachedPtr, value); }
  128. }
  129. /// <summary>
  130. /// Determines if scene objects will be lit by lights. If disabled everything will be rendered using their albedo texture
  131. /// with no lighting applied.
  132. /// </summary>
  133. public bool EnableLighting
  134. {
  135. get { return Internal_getenableLighting(mCachedPtr); }
  136. set { Internal_setenableLighting(mCachedPtr, value); }
  137. }
  138. /// <summary>Determines if shadows cast by lights should be rendered. Only relevant if lighting is turned on.</summary>
  139. public bool EnableShadows
  140. {
  141. get { return Internal_getenableShadows(mCachedPtr); }
  142. set { Internal_setenableShadows(mCachedPtr, value); }
  143. }
  144. /// <summary>Parameters used for customizing shadow rendering.</summary>
  145. public ShadowSettings ShadowSettings
  146. {
  147. get { return Internal_getshadowSettings(mCachedPtr); }
  148. set { Internal_setshadowSettings(mCachedPtr, value); }
  149. }
  150. /// <summary>Determines if indirect lighting (e.g. from light probes or the sky) is rendered.</summary>
  151. public bool EnableIndirectLighting
  152. {
  153. get { return Internal_getenableIndirectLighting(mCachedPtr); }
  154. set { Internal_setenableIndirectLighting(mCachedPtr, value); }
  155. }
  156. /// <summary>
  157. /// Signals the renderer to only render overlays (like GUI), and not scene objects. Such rendering doesn't require depth
  158. /// buffer or multi-sampled render targets and will not render any scene objects. This can improve performance and memory
  159. /// usage for overlay-only views.
  160. /// </summary>
  161. public bool OverlayOnly
  162. {
  163. get { return Internal_getoverlayOnly(mCachedPtr); }
  164. set { Internal_setoverlayOnly(mCachedPtr, value); }
  165. }
  166. /// <summary>
  167. /// If enabled the camera will use the skybox for rendering the background. A skybox has to be present in the scene. When
  168. /// disabled the camera will use the clear color for rendering the background.
  169. /// </summary>
  170. public bool EnableSkybox
  171. {
  172. get { return Internal_getenableSkybox(mCachedPtr); }
  173. set { Internal_setenableSkybox(mCachedPtr, value); }
  174. }
  175. [MethodImpl(MethodImplOptions.InternalCall)]
  176. private static extern void Internal_RenderSettings(RenderSettings managedInstance);
  177. [MethodImpl(MethodImplOptions.InternalCall)]
  178. private static extern bool Internal_getenableAutoExposure(IntPtr thisPtr);
  179. [MethodImpl(MethodImplOptions.InternalCall)]
  180. private static extern void Internal_setenableAutoExposure(IntPtr thisPtr, bool value);
  181. [MethodImpl(MethodImplOptions.InternalCall)]
  182. private static extern AutoExposureSettings Internal_getautoExposure(IntPtr thisPtr);
  183. [MethodImpl(MethodImplOptions.InternalCall)]
  184. private static extern void Internal_setautoExposure(IntPtr thisPtr, AutoExposureSettings value);
  185. [MethodImpl(MethodImplOptions.InternalCall)]
  186. private static extern bool Internal_getenableTonemapping(IntPtr thisPtr);
  187. [MethodImpl(MethodImplOptions.InternalCall)]
  188. private static extern void Internal_setenableTonemapping(IntPtr thisPtr, bool value);
  189. [MethodImpl(MethodImplOptions.InternalCall)]
  190. private static extern TonemappingSettings Internal_gettonemapping(IntPtr thisPtr);
  191. [MethodImpl(MethodImplOptions.InternalCall)]
  192. private static extern void Internal_settonemapping(IntPtr thisPtr, TonemappingSettings value);
  193. [MethodImpl(MethodImplOptions.InternalCall)]
  194. private static extern WhiteBalanceSettings Internal_getwhiteBalance(IntPtr thisPtr);
  195. [MethodImpl(MethodImplOptions.InternalCall)]
  196. private static extern void Internal_setwhiteBalance(IntPtr thisPtr, WhiteBalanceSettings value);
  197. [MethodImpl(MethodImplOptions.InternalCall)]
  198. private static extern ColorGradingSettings Internal_getcolorGrading(IntPtr thisPtr);
  199. [MethodImpl(MethodImplOptions.InternalCall)]
  200. private static extern void Internal_setcolorGrading(IntPtr thisPtr, ColorGradingSettings value);
  201. [MethodImpl(MethodImplOptions.InternalCall)]
  202. private static extern DepthOfFieldSettings Internal_getdepthOfField(IntPtr thisPtr);
  203. [MethodImpl(MethodImplOptions.InternalCall)]
  204. private static extern void Internal_setdepthOfField(IntPtr thisPtr, DepthOfFieldSettings value);
  205. [MethodImpl(MethodImplOptions.InternalCall)]
  206. private static extern AmbientOcclusionSettings Internal_getambientOcclusion(IntPtr thisPtr);
  207. [MethodImpl(MethodImplOptions.InternalCall)]
  208. private static extern void Internal_setambientOcclusion(IntPtr thisPtr, AmbientOcclusionSettings value);
  209. [MethodImpl(MethodImplOptions.InternalCall)]
  210. private static extern ScreenSpaceReflectionsSettings Internal_getscreenSpaceReflections(IntPtr thisPtr);
  211. [MethodImpl(MethodImplOptions.InternalCall)]
  212. private static extern void Internal_setscreenSpaceReflections(IntPtr thisPtr, ScreenSpaceReflectionsSettings value);
  213. [MethodImpl(MethodImplOptions.InternalCall)]
  214. private static extern BloomSettings Internal_getbloom(IntPtr thisPtr);
  215. [MethodImpl(MethodImplOptions.InternalCall)]
  216. private static extern void Internal_setbloom(IntPtr thisPtr, BloomSettings value);
  217. [MethodImpl(MethodImplOptions.InternalCall)]
  218. private static extern bool Internal_getenableFXAA(IntPtr thisPtr);
  219. [MethodImpl(MethodImplOptions.InternalCall)]
  220. private static extern void Internal_setenableFXAA(IntPtr thisPtr, bool value);
  221. [MethodImpl(MethodImplOptions.InternalCall)]
  222. private static extern float Internal_getexposureScale(IntPtr thisPtr);
  223. [MethodImpl(MethodImplOptions.InternalCall)]
  224. private static extern void Internal_setexposureScale(IntPtr thisPtr, float value);
  225. [MethodImpl(MethodImplOptions.InternalCall)]
  226. private static extern float Internal_getgamma(IntPtr thisPtr);
  227. [MethodImpl(MethodImplOptions.InternalCall)]
  228. private static extern void Internal_setgamma(IntPtr thisPtr, float value);
  229. [MethodImpl(MethodImplOptions.InternalCall)]
  230. private static extern bool Internal_getenableHDR(IntPtr thisPtr);
  231. [MethodImpl(MethodImplOptions.InternalCall)]
  232. private static extern void Internal_setenableHDR(IntPtr thisPtr, bool value);
  233. [MethodImpl(MethodImplOptions.InternalCall)]
  234. private static extern bool Internal_getenableLighting(IntPtr thisPtr);
  235. [MethodImpl(MethodImplOptions.InternalCall)]
  236. private static extern void Internal_setenableLighting(IntPtr thisPtr, bool value);
  237. [MethodImpl(MethodImplOptions.InternalCall)]
  238. private static extern bool Internal_getenableShadows(IntPtr thisPtr);
  239. [MethodImpl(MethodImplOptions.InternalCall)]
  240. private static extern void Internal_setenableShadows(IntPtr thisPtr, bool value);
  241. [MethodImpl(MethodImplOptions.InternalCall)]
  242. private static extern ShadowSettings Internal_getshadowSettings(IntPtr thisPtr);
  243. [MethodImpl(MethodImplOptions.InternalCall)]
  244. private static extern void Internal_setshadowSettings(IntPtr thisPtr, ShadowSettings value);
  245. [MethodImpl(MethodImplOptions.InternalCall)]
  246. private static extern bool Internal_getenableIndirectLighting(IntPtr thisPtr);
  247. [MethodImpl(MethodImplOptions.InternalCall)]
  248. private static extern void Internal_setenableIndirectLighting(IntPtr thisPtr, bool value);
  249. [MethodImpl(MethodImplOptions.InternalCall)]
  250. private static extern bool Internal_getoverlayOnly(IntPtr thisPtr);
  251. [MethodImpl(MethodImplOptions.InternalCall)]
  252. private static extern void Internal_setoverlayOnly(IntPtr thisPtr, bool value);
  253. [MethodImpl(MethodImplOptions.InternalCall)]
  254. private static extern bool Internal_getenableSkybox(IntPtr thisPtr);
  255. [MethodImpl(MethodImplOptions.InternalCall)]
  256. private static extern void Internal_setenableSkybox(IntPtr thisPtr, bool value);
  257. }
  258. /** @} */
  259. }