IGUIInOutFader.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. // Copyright (C) 2002-2012 Nikolaus Gebhardt
  2. // This file is part of the "Irrlicht Engine".
  3. // For conditions of distribution and use, see copyright notice in irrlicht.h
  4. #ifndef __I_GUI_IN_OUT_FADER_H_INCLUDED__
  5. #define __I_GUI_IN_OUT_FADER_H_INCLUDED__
  6. #include "IGUIElement.h"
  7. #include "SColor.h"
  8. namespace irr
  9. {
  10. namespace gui
  11. {
  12. //! Element for fading out or in
  13. /** Here is a small example on how the class is used. In this example we fade
  14. in from a total red screen in the beginning. As you can see, the fader is not
  15. only useful for dramatic in and out fading, but also to show that the player
  16. is hit in a first person shooter game for example.
  17. \code
  18. gui::IGUIInOutFader* fader = device->getGUIEnvironment()->addInOutFader();
  19. fader->setColor(video::SColor(0,255,0,0));
  20. fader->fadeIn(4000);
  21. \endcode
  22. */
  23. class IGUIInOutFader : public IGUIElement
  24. {
  25. public:
  26. //! constructor
  27. IGUIInOutFader(IGUIEnvironment* environment, IGUIElement* parent, s32 id, core::rect<s32> rectangle)
  28. : IGUIElement(EGUIET_IN_OUT_FADER, environment, parent, id, rectangle) {}
  29. //! Gets the color to fade out to or to fade in from.
  30. virtual video::SColor getColor() const = 0;
  31. //! Sets the color to fade out to or to fade in from.
  32. /** \param color: Color to where it is faded out od from it is faded in. */
  33. virtual void setColor(video::SColor color) = 0;
  34. virtual void setColor(video::SColor source, video::SColor dest) = 0;
  35. //! Starts the fade in process.
  36. /** In the beginning the whole rect is drawn by the set color
  37. (black by default) and at the end of the overgiven time the
  38. color has faded out.
  39. \param time: Time specifying how long it should need to fade in,
  40. in milliseconds. */
  41. virtual void fadeIn(u32 time) = 0;
  42. //! Starts the fade out process.
  43. /** In the beginning everything is visible, and at the end of
  44. the time only the set color (black by the fault) will be drawn.
  45. \param time: Time specifying how long it should need to fade out,
  46. in milliseconds. */
  47. virtual void fadeOut(u32 time) = 0;
  48. //! Returns if the fade in or out process is done.
  49. virtual bool isReady() const = 0;
  50. };
  51. } // end namespace gui
  52. } // end namespace irr
  53. #endif