Wt  4.11.0
Loading...
Searching...
No Matches
Public Member Functions | List of all members
Wt::WAbstractArea Class Referenceabstract

Abstract base class for interactive areas in a widget. More...

#include <Wt/WAbstractArea.h>

Inheritance diagram for Wt::WAbstractArea:
[legend]

Public Member Functions

virtual ~WAbstractArea ()
 Destructor.
 
void setHole (bool hole)
 Specifies that this area specifies a hole for another area.
 
bool isHole () const
 Returns whether this area specifies a hole.
 
void setLink (const WLink &link)
 Sets a link.
 
WLink link () const
 Returns the link.
 
void setAlternateText (const WString &text)
 Sets an alternate text.
 
const WString alternateText () const
 Returns the alternate text.
 
void setToolTip (const WString &text)
 Sets the tooltip.
 
WString toolTip () const
 Returns the tooltip text.
 
void setStyleClass (const WString &styleClass)
 Defines a style class.
 
WString styleClass () const
 Returns the style class.
 
void addStyleClass (const WString &styleClass, bool force=false)
 Adds a style class.
 
void removeStyleClass (const WString &styleClass, bool force=false)
 Removes a style class.
 
void setCursor (Cursor cursor)
 Sets the cursor.
 
void setCursor (std::string cursorImage, Cursor fallback=Cursor::Arrow)
 Sets a custom cursor image URL.
 
Cursor cursor () const
 Returns the cursor.
 
EventSignal< WKeyEvent > & keyWentDown ()
 Event signal emitted when a keyboard key is pushed down.
 
EventSignal< WKeyEvent > & keyPressed ()
 Event signal emitted when a "character" was entered.
 
EventSignal< WKeyEvent > & keyWentUp ()
 Event signal emitted when a keyboard key is released.
 
EventSignalenterPressed ()
 Event signal emitted when enter was pressed.
 
EventSignalescapePressed ()
 Event signal emitted when escape was pressed.
 
EventSignal< WMouseEvent > & clicked ()
 Event signal emitted when a mouse key was clicked on this widget.
 
EventSignal< WMouseEvent > & doubleClicked ()
 Event signal emitted when a mouse key was double clicked on this widget.
 
EventSignal< WMouseEvent > & mouseWentDown ()
 Event signal emitted when a mouse key was pushed down on this widget.
 
EventSignal< WMouseEvent > & mouseWentUp ()
 Event signal emitted when a mouse key was released on this widget.
 
EventSignal< WMouseEvent > & mouseWentOut ()
 Event signal emitted when the mouse went out of this widget.
 
EventSignal< WMouseEvent > & mouseWentOver ()
 Event signal emitted when the mouse entered this widget.
 
EventSignal< WMouseEvent > & mouseMoved ()
 Event signal emitted when the mouse moved over this widget.
 
EventSignal< WMouseEvent > & mouseDragged ()
 Event signal emitted when the mouse is dragged over this widget.
 
EventSignal< WMouseEvent > & mouseWheel ()
 Event signal emitted when the mouse scroll wheel was used.
 
- Public Member Functions inherited from Wt::WObject
void addChild (std::unique_ptr< WObject > child)
 Add a child WObject whose lifetime is determined by this WObject.
 
template<typename Child >
ChildaddChild (std::unique_ptr< Child > child)
 Add a child WObject, returning a raw pointer.
 
std::unique_ptr< WObjectremoveChild (WObject *child)
 Remove a child WObject, so its lifetime is no longer determined by this WObject.
 
template<typename Child >
std::unique_ptr< ChildremoveChild (Child *child)
 Remove a child WObject, so its lifetime is no longer determined by this WObject.
 
virtual const std::string id () const
 Returns the (unique) identifier for this object.
 
virtual void setObjectName (const std::string &name)
 Sets an object name.
 
virtual std::string objectName () const
 Returns the object name.
 
void resetLearnedSlots ()
 Resets learned stateless slot implementations.
 
template<class T >
void resetLearnedSlot (void(T::*method)())
 Resets a learned stateless slot implementation.
 
template<class T >
WStatelessSlot * implementStateless (void(T::*method)())
 Declares a slot to be stateless and learn client-side behaviour on first invocation.
 
template<class T >
WStatelessSlot * implementStateless (void(T::*method)(), void(T::*undoMethod)())
 Declares a slot to be stateless and learn client-side behaviour in advance.
 
void isNotStateless ()
 Marks the current function as not stateless.
 
template<class T >
WStatelessSlot * implementJavaScript (void(T::*method)(), const std::string &jsCode)
 Provides a JavaScript implementation for a method.
 
- Public Member Functions inherited from Wt::Core::observable
 observable () noexcept
 Default constructor.
 
virtual ~observable ()
 Destructor.
 
template<typename... Args, typename C >
auto bindSafe (void(C::*method)(Args...)) noexcept
 Protects a method call against object destruction.
 
template<typename... Args, typename C >
auto bindSafe (void(C::*method)(Args...) const) const noexcept
 Protects a const method call against object destruction.
 
template<typename Function >
auto bindSafe (const Function &function) noexcept
 Protects a function against object destruction.
 

Additional Inherited Members

- Public Types inherited from Wt::WObject
typedef void(WObject::* Method) ()
 Typedef for a WObject method without arguments.
 
- Protected Member Functions inherited from Wt::WObject
virtual WStatelessSlot * getStateless (Method method)
 On-demand stateless slot implementation.
 

Detailed Description

Abstract base class for interactive areas in a widget.

Use an WAbstractArea (or rather, one of its concrete implementations), to define interactivity that applies on a part of a WImage or WPaintedWidget. The area may be defined using different shapes through WRectArea, WCircleArea or WPolygonArea.

See also
WImage::addArea(), WPaintedWidget::addArea()

Constructor & Destructor Documentation

◆ ~WAbstractArea()

Wt::WAbstractArea::~WAbstractArea ( )
virtual

Destructor.

The area is automatically removed from the WImage or WPaintedWidget to which it was added.

See also
WImage::removeArea(), WPaintedWidget::removeArea()

Member Function Documentation

◆ addStyleClass()

void Wt::WAbstractArea::addStyleClass ( const WString styleClass,
bool  force = false 
)

Adds a style class.

Note
Only few CSS declarations are known to affect the look of a image area, the most notable one being the 'cursor'. Other things will simply be ignored.

◆ alternateText()

const WString Wt::WAbstractArea::alternateText ( ) const

Returns the alternate text.

See also
setAlternateText()

◆ clicked()

EventSignal< WMouseEvent > & Wt::WAbstractArea::clicked ( )

Event signal emitted when a mouse key was clicked on this widget.

The event details contains information such as the button, optional keyboard modifiers, and mouse coordinates relative to the widget, the window window, or the document.

Note
When JavaScript is disabled, the event details contain invalid information.

◆ cursor()

Cursor Wt::WAbstractArea::cursor ( ) const

Returns the cursor.

See also
setCursor()

◆ doubleClicked()

EventSignal< WMouseEvent > & Wt::WAbstractArea::doubleClicked ( )

Event signal emitted when a mouse key was double clicked on this widget.

The event details contains information such as the button, optional keyboard modifiers, and mouse coordinates relative to the widget, the window window, or the document.

Note
When JavaScript is disabled, the signal will never fire.

◆ enterPressed()

EventSignal & Wt::WAbstractArea::enterPressed ( )

Event signal emitted when enter was pressed.

This signal is emitted when the Enter or Return key was pressed.

See also
keyPressed(), Key::Enter

◆ escapePressed()

EventSignal & Wt::WAbstractArea::escapePressed ( )

Event signal emitted when escape was pressed.

This signal is emitted when the Escape key was pressed.

See also
keyPressed(), Key::Escape

◆ isHole()

bool Wt::WAbstractArea::isHole ( ) const

Returns whether this area specifies a hole.

See also
setHole()

◆ keyPressed()

EventSignal< WKeyEvent > & Wt::WAbstractArea::keyPressed ( )

Event signal emitted when a "character" was entered.

The keyPressed signal is emitted when a key is pressed, and a character is entered. Unlike keyWentDown(), it is emitted only for key presses that result in a character being entered, and thus not for modifier keys or keyboard navigation keys.

See also
keyWentDown()

◆ keyWentDown()

EventSignal< WKeyEvent > & Wt::WAbstractArea::keyWentDown ( )

Event signal emitted when a keyboard key is pushed down.

The keyWentDown signal is the first signal emitted when a key is pressed (before the keyPressed() signal). Unlike keyPressed() however it is also emitted for modifier keys (such as "shift", "control", ...) or keyboard navigation keys that do not have a corresponding character.

See also
keyPressed(), keyWentUp()

◆ keyWentUp()

EventSignal< WKeyEvent > & Wt::WAbstractArea::keyWentUp ( )

Event signal emitted when a keyboard key is released.

This is the counter-part of the keyWentDown() event. Every key-down has its corresponding key-up.

See also
keyWentDown()

◆ link()

WLink Wt::WAbstractArea::link ( ) const

Returns the link.

See also
setLink()

◆ mouseDragged()

EventSignal< WMouseEvent > & Wt::WAbstractArea::mouseDragged ( )

Event signal emitted when the mouse is dragged over this widget.

The mouse event contains information on the button(s) currently pressed. If multiple buttons are currently pressed, only the button with smallest enum value is returned.

Note
When JavaScript is disabled, the signal will never fire.

◆ mouseMoved()

EventSignal< WMouseEvent > & Wt::WAbstractArea::mouseMoved ( )

Event signal emitted when the mouse moved over this widget.

Note
When JavaScript is disabled, the signal will never fire.

◆ mouseWentDown()

EventSignal< WMouseEvent > & Wt::WAbstractArea::mouseWentDown ( )

Event signal emitted when a mouse key was pushed down on this widget.

The event details contains information such as the button, optional keyboard modifiers, and mouse coordinates relative to the widget, the window window, or the document.

Note
When JavaScript is disabled, the signal will never fire.

◆ mouseWentOut()

EventSignal< WMouseEvent > & Wt::WAbstractArea::mouseWentOut ( )

Event signal emitted when the mouse went out of this widget.

Note
When JavaScript is disabled, the signal will never fire.

◆ mouseWentOver()

EventSignal< WMouseEvent > & Wt::WAbstractArea::mouseWentOver ( )

Event signal emitted when the mouse entered this widget.

Note
When JavaScript is disabled, the signal will never fire.

◆ mouseWentUp()

EventSignal< WMouseEvent > & Wt::WAbstractArea::mouseWentUp ( )

Event signal emitted when a mouse key was released on this widget.

The event details contains information such as the button, optional keyboard modifiers, and mouse coordinates relative to the widget, the window window, or the document.

Note
When JavaScript is disabled, the signal will never fire.

◆ mouseWheel()

EventSignal< WMouseEvent > & Wt::WAbstractArea::mouseWheel ( )

Event signal emitted when the mouse scroll wheel was used.

The event details contains information such as the wheel delta, optional keyboard modifiers, and mouse coordinates relative to the widget, the window window, or the document.

Note
When JavaScript is disabled, the signal will never fire.

◆ setAlternateText()

void Wt::WAbstractArea::setAlternateText ( const WString text)

Sets an alternate text.

The alternate text should provide a fallback for browsers that do not display an image. If no sensible fallback text can be provided, an empty text is preferred over nonsense.

This should not be confused with toolTip() text, which provides additional information that is displayed when the mouse hovers over the area.

The default alternate text is an empty text ("").

See also
alternateText()

◆ setCursor() [1/2]

void Wt::WAbstractArea::setCursor ( Cursor  cursor)

Sets the cursor.

This sets the mouse cursor that is shown when the mouse pointer is over the area. Most browsers only support Cursor::PointingHand, which is activated by a non-empty ref.

See also
setRef()

◆ setCursor() [2/2]

void Wt::WAbstractArea::setCursor ( std::string  cursorImage,
Cursor  fallback = Cursor::Arrow 
)

Sets a custom cursor image URL.

The URL should point to a .cur file. For optimal portability, make sure that the .cur file is proparly constructed. A renamed .ico file will not work on Internet Explorer.

◆ setHole()

void Wt::WAbstractArea::setHole ( bool  hole)

Specifies that this area specifies a hole for another area.

When set to true, this area will define an area that does not provide interactivity. When it preceeds other, overlapping, areas, it acts as if it cuts a hole in those areas.

The default value is false.

See also
isHole()

◆ setLink()

void Wt::WAbstractArea::setLink ( const WLink link)

Sets a link.

By setting a link, the area behaves like a WAnchor.

By default, no destination link is set.

Note
Even when no destination link is set, in some circumstances, an identity URL ('#') will be linked to on the underlying HTML <area> element (see also setCursor()).

◆ setStyleClass()

void Wt::WAbstractArea::setStyleClass ( const WString styleClass)

Defines a style class.

Note
Only few CSS declarations are known to affect the look of a image area, the most notable one being the 'cursor'. Other things will simply be ignored.

◆ setToolTip()

void Wt::WAbstractArea::setToolTip ( const WString text)

Sets the tooltip.

The tooltip is displayed when the cursor hovers over the area.

◆ styleClass()

WString Wt::WAbstractArea::styleClass ( ) const

Returns the style class.

See also
setStyleClass()

◆ toolTip()

WString Wt::WAbstractArea::toolTip ( ) const

Returns the tooltip text.

See also
setToolTip()