Editor API
UnigineEditor public API
UnigineEditor::RenderWindow Class Reference

This class is used to represent a window widget to which an image can be rendered by the Engine. For example, to render node or texture previews, frame sequences, etc. More...

Inheritance diagram for UnigineEditor::RenderWindow:
UnigineEditor::EngineGuiWindow

Public Types

enum  RENDERING_POLICY { RENDERING_POLICY_WINDOW_VISIBLE = 0, RENDERING_POLICY_WINDOW_VISIBLE_AND_FOCUSED, RENDERING_POLICY_ALWAYS }
 Rendering policy for the window that defines when it should be rendered depending on its visibility and focus status. More...
 

Signals

void focusChanged ()
 This signal is emitted when the focus has changed because the user pressed the tab-key, clicked into a widget or changed the active window. More...
 

Public Member Functions

Unigine::Event & getEventUpdate ()
 Event triggered for the Render Window on Engine::update(). As an alternative you can inherit your class from the RenderWindow and override the onUpdate() method. More...
 
Unigine::Event & getEventRender ()
 Event triggered for the Render Window on Engine::render(). As an alternative you can inherit your class from the RenderWindow and override the onRender() method. More...
 
Unigine::Event & getEventSwap ()
 Event triggered for the Render Window on Engine::swap(). As an alternative you can inherit your class from the RenderWindow and override the onSwap() method. More...
 
Unigine::Event & getEventFocusChanged ()
 Event triggered when the focus of the Render Window changes. More...
 
Unigine::Event & getEventFocusIn ()
 Event triggered when the Render Window becomes focused. As an alternative you can inherit your class from the RenderWindow and override the focusInEvent() method. More...
 
Unigine::Event & getEventFocusOut ()
 Event triggered when the Render Window loses focus. As an alternative you can inherit your class from the RenderWindow and override the focusOutEvent() method. More...
 
Unigine::Event< QDragEnterEvent * > & getEventDragEnter ()
 Event triggered when something is dragged into the Render Window. The event handler function receives a QDragEnterEvent instance. For more details please refer to Qt documentation. As an alternative you can inherit your class from the RenderWindow and override the dragEnterEvent() method. More...
 
Unigine::Event< QDragMoveEvent * > & getEventDragMove ()
 Event triggered when something is dragged within the Render Window. The event handler function receives a QDragMoveEvent instance. For more details please refer to Qt documentation. As an alternative you can inherit your class from the RenderWindow and override the dragMoveEvent() method. More...
 
Unigine::Event< QDragLeaveEvent * > & getEventDragLeave ()
 Event triggered when something is dragged out of the Render Window. The event handler function receives a QDragLeaveEvent instance. For more details please refer to Qt documentation. As an alternative you can inherit your class from the RenderWindow and override the dragLeaveEvent() method. More...
 
Unigine::Event< QDropEvent * > & getEventDrop ()
 Event triggered when the user drops something within the Render Window. The event handler function receives a QDropEvent instance, that contains a proposed action, available from proposedAction(), for the widget to either accept or ignore. If the action can be handled by the widget, you should call the acceptProposedAction() function. Since the proposed action can be a combination of Qt::DropAction values, it may be useful to either select one of these values as a default action or ask the user to select their preferred action. If the proposed drop action is not suitable, perhaps because your custom widget does not support that action, you can replace it with any of the possible drop actions by calling setDropAction() with your preferred action. If you set a value that is not present in the bitwise OR combination of values returned by possibleActions(), the default copy action will be used. Once a replacement drop action has been set, call accept() instead of acceptProposedAction() to complete the drop operation. For more details please refer to Qt documentation. As an alternative you can inherit your class from the RenderWindow and override the dropEvent() method. More...
 
void setRenderingPolicy (RENDERING_POLICY rendering_policy)
 Sets rendering policy for the Render Window. This policy defines when the window should be rendered depending on its visibility and focus status. More...
 
RENDERING_POLICY getRenderingPolicy () const
 Returns the current rendering policy for the Render Window. This policy defines when the window should be rendered depending on its visibility and focus status (See RENDERING_POLICY). More...
 
void setClearRenderBuffers (bool v)
 Sets a value indicating if render buffers are to be cleared every time the do_render method is called. More...
 
bool isClearRenderBuffers () const
 Returns a value indicating if render buffers are to be cleared every time the do_render method is called. More...
 

Protected Member Functions

virtual void onUpdate ()
 You can inherit your class from RenderWindow and override this method to define your custom actions to be performed on Engine::update(). As an alternative to overriding this method you can use the Update event (getEventUpdate). More...
 
virtual void onRender ()
 You can inherit your class from RenderWindow and override this method to define your custom actions to be performed on Engine::render(). As an alternative to overriding this method you can use the Render event (getEventRender). More...
 
virtual void onSwap ()
 You can inherit your class from RenderWindow and override this method to define your custom actions to be performed on Engine::swap(). As an alternative to overriding this method you can use the Swap event (getEventSwap). More...
 
bool event (QEvent *event) override
 You can inherit your class from RenderWindow and override this method to define your custom actions to be performed on receiving various events (QEvent). As an alternative to overriding this method you can use the Update event (getEventUpdate). More...
 
void paintEvent (QPaintEvent *) final override
 You can inherit your class from RenderWindow and override this method to define actions to be performed on receiving a paint event (QPaintEvent). Paint events are sent to widgets that need to update themselves. For more details please refer to Qt documentation. More...
 
void resizeEvent (QResizeEvent *event) override
 You can inherit your class from RenderWindow and override this method to define actions to be performed on receiving a resize event (QResizeEvent). Resize events are sent to widgets that have been resized. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the Update event (getEventUpdate). More...
 
void closeEvent (QCloseEvent *event) override
 You can inherit your class from RenderWindow and override this method to define actions to be performed on receiving a close event (QCloseEvent). Close events are sent to widgets that have been closed. For more details please refer to Qt documentation. More...
 
void focusInEvent (QFocusEvent *event) override
 You can inherit your class from RenderWindow and override this method to define actions to be performed on getting focus, i.e., receiving the corresponding focus event (QFocusEvent). Focus events are sent to widgets when the keyboard input focus changes. Focus events occur due to mouse actions, key presses (such as Tab or Backtab), the window system, popup menus, keyboard shortcuts, or other application-specific reasons. The reason for a particular focus event is returned by reason() in the appropriate event handler. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the FocusIn event (getEventFocusIn). More...
 
void focusOutEvent (QFocusEvent *event) override
 You can inherit your class from RenderWindow and override this method to define actions to be performed on losing focus, i.e., receiving the corresponding focus event (QFocusEvent). Focus events are sent to widgets when the keyboard input focus changes. Focus events occur due to mouse actions, key presses (such as Tab or Backtab), the window system, popup menus, keyboard shortcuts, or other application-specific reasons. The reason for a particular focus event is returned by reason() in the appropriate event handler. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the FocusOut event (getEventFocusOut). More...
 
void dragEnterEvent (QDragEnterEvent *event) override
 You can inherit your class from RenderWindow and override this method to define actions to be performed when a drag-and-drop action enters the Render Window (QDragEnterEvent). The drag enter event is always immediately followed by a drag move event. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the DragEnter event (getEventDragEnter). More...
 
void dragMoveEvent (QDragMoveEvent *event) override
 You can inherit your class from RenderWindow and override this method to define actions to be performed when a drag-and-drop action is in progress (QDragMoveEvent). The drag move event always immediately follows a drag enter event. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the DragMove event (getEventDragMove). More...
 
void dragLeaveEvent (QDragLeaveEvent *event) override
 You can inherit your class from RenderWindow and override this method to define actions to be performed when a drag-and-drop action leaves the Render Window (QDragLeaveEvent). For more details please refer to Qt documentation. As an alternative to overriding this method you can use the DragLeave event (getEventDragLeave). More...
 
void dropEvent (QDropEvent *event) override
 You can inherit your class from RenderWindow and override this method to define actions to be performed when a drag-and-drop action is completed (QDropEvent). For more details please refer to Qt documentation. As an alternative to overriding this method you can use the Drop event (getEventDrop). More...
 

Detailed Description

This class is used to represent a window widget to which an image can be rendered by the Engine. For example, to render node or texture previews, frame sequences, etc.

Member Enumeration Documentation

◆ RENDERING_POLICY

Rendering policy for the window that defines when it should be rendered depending on its visibility and focus status.

Enumerator
RENDERING_POLICY_WINDOW_VISIBLE 

The window is rendered only when visible.

RENDERING_POLICY_WINDOW_VISIBLE_AND_FOCUSED 

The window is rendered only when it is visible and focused.

RENDERING_POLICY_ALWAYS 

The window is always rendered regardless of its visibility and focus status.

Member Function Documentation

◆ closeEvent()

void UnigineEditor::RenderWindow::closeEvent ( QCloseEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed on receiving a close event (QCloseEvent). Close events are sent to widgets that have been closed. For more details please refer to Qt documentation.

◆ dragEnterEvent()

void UnigineEditor::RenderWindow::dragEnterEvent ( QDragEnterEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed when a drag-and-drop action enters the Render Window (QDragEnterEvent). The drag enter event is always immediately followed by a drag move event. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the DragEnter event (getEventDragEnter).

◆ dragLeaveEvent()

void UnigineEditor::RenderWindow::dragLeaveEvent ( QDragLeaveEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed when a drag-and-drop action leaves the Render Window (QDragLeaveEvent). For more details please refer to Qt documentation. As an alternative to overriding this method you can use the DragLeave event (getEventDragLeave).

◆ dragMoveEvent()

void UnigineEditor::RenderWindow::dragMoveEvent ( QDragMoveEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed when a drag-and-drop action is in progress (QDragMoveEvent). The drag move event always immediately follows a drag enter event. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the DragMove event (getEventDragMove).

◆ dropEvent()

void UnigineEditor::RenderWindow::dropEvent ( QDropEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed when a drag-and-drop action is completed (QDropEvent). For more details please refer to Qt documentation. As an alternative to overriding this method you can use the Drop event (getEventDrop).

◆ event()

bool UnigineEditor::RenderWindow::event ( QEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define your custom actions to be performed on receiving various events (QEvent). As an alternative to overriding this method you can use the Update event (getEventUpdate).

◆ focusChanged

void UnigineEditor::RenderWindow::focusChanged ( )
signal

This signal is emitted when the focus has changed because the user pressed the tab-key, clicked into a widget or changed the active window.

◆ focusInEvent()

void UnigineEditor::RenderWindow::focusInEvent ( QFocusEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed on getting focus, i.e., receiving the corresponding focus event (QFocusEvent). Focus events are sent to widgets when the keyboard input focus changes. Focus events occur due to mouse actions, key presses (such as Tab or Backtab), the window system, popup menus, keyboard shortcuts, or other application-specific reasons. The reason for a particular focus event is returned by reason() in the appropriate event handler. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the FocusIn event (getEventFocusIn).

◆ focusOutEvent()

void UnigineEditor::RenderWindow::focusOutEvent ( QFocusEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed on losing focus, i.e., receiving the corresponding focus event (QFocusEvent). Focus events are sent to widgets when the keyboard input focus changes. Focus events occur due to mouse actions, key presses (such as Tab or Backtab), the window system, popup menus, keyboard shortcuts, or other application-specific reasons. The reason for a particular focus event is returned by reason() in the appropriate event handler. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the FocusOut event (getEventFocusOut).

◆ getEventDragEnter()

Unigine::Event<QDragEnterEvent *>& UnigineEditor::RenderWindow::getEventDragEnter ( )

Event triggered when something is dragged into the Render Window. The event handler function receives a QDragEnterEvent instance. For more details please refer to Qt documentation. As an alternative you can inherit your class from the RenderWindow and override the dragEnterEvent() method.

◆ getEventDragLeave()

Unigine::Event<QDragLeaveEvent *>& UnigineEditor::RenderWindow::getEventDragLeave ( )

Event triggered when something is dragged out of the Render Window. The event handler function receives a QDragLeaveEvent instance. For more details please refer to Qt documentation. As an alternative you can inherit your class from the RenderWindow and override the dragLeaveEvent() method.

◆ getEventDragMove()

Unigine::Event<QDragMoveEvent *>& UnigineEditor::RenderWindow::getEventDragMove ( )

Event triggered when something is dragged within the Render Window. The event handler function receives a QDragMoveEvent instance. For more details please refer to Qt documentation. As an alternative you can inherit your class from the RenderWindow and override the dragMoveEvent() method.

◆ getEventDrop()

Unigine::Event<QDropEvent *>& UnigineEditor::RenderWindow::getEventDrop ( )

Event triggered when the user drops something within the Render Window. The event handler function receives a QDropEvent instance, that contains a proposed action, available from proposedAction(), for the widget to either accept or ignore. If the action can be handled by the widget, you should call the acceptProposedAction() function. Since the proposed action can be a combination of Qt::DropAction values, it may be useful to either select one of these values as a default action or ask the user to select their preferred action. If the proposed drop action is not suitable, perhaps because your custom widget does not support that action, you can replace it with any of the possible drop actions by calling setDropAction() with your preferred action. If you set a value that is not present in the bitwise OR combination of values returned by possibleActions(), the default copy action will be used. Once a replacement drop action has been set, call accept() instead of acceptProposedAction() to complete the drop operation. For more details please refer to Qt documentation. As an alternative you can inherit your class from the RenderWindow and override the dropEvent() method.

◆ getEventFocusChanged()

Unigine::Event& UnigineEditor::RenderWindow::getEventFocusChanged ( )

Event triggered when the focus of the Render Window changes.

◆ getEventFocusIn()

Unigine::Event& UnigineEditor::RenderWindow::getEventFocusIn ( )

Event triggered when the Render Window becomes focused. As an alternative you can inherit your class from the RenderWindow and override the focusInEvent() method.

◆ getEventFocusOut()

Unigine::Event& UnigineEditor::RenderWindow::getEventFocusOut ( )

Event triggered when the Render Window loses focus. As an alternative you can inherit your class from the RenderWindow and override the focusOutEvent() method.

◆ getEventRender()

Unigine::Event& UnigineEditor::RenderWindow::getEventRender ( )

Event triggered for the Render Window on Engine::render(). As an alternative you can inherit your class from the RenderWindow and override the onRender() method.

◆ getEventSwap()

Unigine::Event& UnigineEditor::RenderWindow::getEventSwap ( )

Event triggered for the Render Window on Engine::swap(). As an alternative you can inherit your class from the RenderWindow and override the onSwap() method.

◆ getEventUpdate()

Unigine::Event& UnigineEditor::RenderWindow::getEventUpdate ( )

Event triggered for the Render Window on Engine::update(). As an alternative you can inherit your class from the RenderWindow and override the onUpdate() method.

◆ getRenderingPolicy()

RENDERING_POLICY UnigineEditor::RenderWindow::getRenderingPolicy ( ) const

Returns the current rendering policy for the Render Window. This policy defines when the window should be rendered depending on its visibility and focus status (See RENDERING_POLICY).

◆ isClearRenderBuffers()

bool UnigineEditor::RenderWindow::isClearRenderBuffers ( ) const

Returns a value indicating if render buffers are to be cleared every time the do_render method is called.

◆ onRender()

virtual void UnigineEditor::RenderWindow::onRender ( )
inlineprotectedvirtual

You can inherit your class from RenderWindow and override this method to define your custom actions to be performed on Engine::render(). As an alternative to overriding this method you can use the Render event (getEventRender).

Reimplemented in UnigineEditor::EngineGuiWindow.

◆ onSwap()

virtual void UnigineEditor::RenderWindow::onSwap ( )
inlineprotectedvirtual

You can inherit your class from RenderWindow and override this method to define your custom actions to be performed on Engine::swap(). As an alternative to overriding this method you can use the Swap event (getEventSwap).

◆ onUpdate()

virtual void UnigineEditor::RenderWindow::onUpdate ( )
inlineprotectedvirtual

You can inherit your class from RenderWindow and override this method to define your custom actions to be performed on Engine::update(). As an alternative to overriding this method you can use the Update event (getEventUpdate).

Reimplemented in UnigineEditor::EngineGuiWindow.

◆ paintEvent()

void UnigineEditor::RenderWindow::paintEvent ( QPaintEvent *  )
inlinefinaloverrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed on receiving a paint event (QPaintEvent). Paint events are sent to widgets that need to update themselves. For more details please refer to Qt documentation.

◆ resizeEvent()

void UnigineEditor::RenderWindow::resizeEvent ( QResizeEvent *  event)
overrideprotected

You can inherit your class from RenderWindow and override this method to define actions to be performed on receiving a resize event (QResizeEvent). Resize events are sent to widgets that have been resized. For more details please refer to Qt documentation. As an alternative to overriding this method you can use the Update event (getEventUpdate).

◆ setClearRenderBuffers()

void UnigineEditor::RenderWindow::setClearRenderBuffers ( bool  v)

Sets a value indicating if render buffers are to be cleared every time the do_render method is called.

Parameters
vtrue to clear render buffers every time the do_render method is called; false - not to clear.

◆ setRenderingPolicy()

void UnigineEditor::RenderWindow::setRenderingPolicy ( RENDERING_POLICY  rendering_policy)

Sets rendering policy for the Render Window. This policy defines when the window should be rendered depending on its visibility and focus status.

Parameters
rendering_policyNew rendering policy to be set.