26#ifndef TGUI_PICTURE_HPP
27#define TGUI_PICTURE_HPP
30#include <TGUI/Widgets/ClickableWidget.hpp>
31#include <TGUI/Renderers/PictureRenderer.hpp>
44 using Ptr = std::shared_ptr<Picture>;
45 using ConstPtr = std::shared_ptr<const Picture>;
47 static constexpr const char StaticWidgetType[] =
"Picture";
57 Picture(
const char* typeName = StaticWidgetType,
bool initRenderer =
true);
125 using Widget::setSize;
167 void leftMouseReleased(
Vector2f pos)
override;
216 std::unique_ptr<DataIO::Node>
save(SavingRenderersMap& renderers)
const override;
222 void load(
const std::unique_ptr<DataIO::Node>& node,
const LoadingRenderersMap& renderers)
override;
228 bool updateTime(
Duration elapsedTime)
override;
242 bool m_ignoringMouseEvents =
false;
245 bool m_possibleDoubleClick =
false;
Base class for render targets.
Definition: BackendRenderTarget.hpp:48
Wrapper for durations.
Definition: Duration.hpp:52
Class to store the position or size of a widget.
Definition: Layout.hpp:284
Definition: PictureRenderer.hpp:37
Picture widget.
Definition: Picture.hpp:41
std::shared_ptr< Picture > Ptr
Shared widget pointer.
Definition: Picture.hpp:44
void draw(BackendRenderTarget &target, RenderStates states) const override
Draw the widget to a render target.
bool canGainFocus() const override
Returns whether the widget can gain focus.
bool isMouseOnWidget(Vector2f pos) const override
Returns whether the mouse position (which is relative to the parent widget) lies on top of the widget...
bool isIgnoringMouseEvents() const
Returns whether the widget is ignoring mouse events and letting them pass to the widgets behind it.
std::shared_ptr< const Picture > ConstPtr
Shared constant widget pointer.
Definition: Picture.hpp:45
void rendererChanged(const String &property) override
Function called when one of the properties of the renderer is changed.
static Picture::Ptr copy(const Picture::ConstPtr &picture)
Makes a copy of another picture.
PictureRenderer * getRenderer()
Returns the renderer, which gives access to functions that determine how the widget is displayed.
Signal & getSignal(String signalName) override
Retrieves a signal based on its name.
Widget::Ptr clone() const override
Makes a copy of the widget if you don't know its exact type.
void setSize(const Layout2d &size) override
Changes the size of the picture.
static Picture::Ptr create(const Texture &texture, bool transparentTexture=false)
Creates a new picture widget.
PictureRenderer * getSharedRenderer()
Returns the renderer, which gives access to functions that determine how the widget is displayed.
void ignoreMouseEvents(bool ignore=true)
Sets whether the widget should completely ignore mouse events and let them pass to the widgets behind...
void load(const std::unique_ptr< DataIO::Node > &node, const LoadingRenderersMap &renderers) override
Loads the widget from a tree of nodes.
static Picture::Ptr create()
Creates a new empty picture widget.
std::unique_ptr< DataIO::Node > save(SavingRenderersMap &renderers) const override
Saves the widget as a tree node in order to save it to a file.
Signal to which the user can subscribe to get callbacks from.
Definition: Signal.hpp:58
Definition: Sprite.hpp:45
Wrapper class to store strings.
Definition: String.hpp:79
Definition: Texture.hpp:52
Namespace that contains all TGUI functions and classes.
Definition: AbsoluteOrRelativeValue.hpp:36
States used for drawing.
Definition: RenderStates.hpp:39