-#ifndef __DALI_TOOLKIT_INTERNAL_PUSH_BUTTON_H__
-#define __DALI_TOOLKIT_INTERNAL_PUSH_BUTTON_H__
+#ifndef DALI_TOOLKIT_INTERNAL_PUSH_BUTTON_H
+#define DALI_TOOLKIT_INTERNAL_PUSH_BUTTON_H
-//
-// Copyright (c) 2014 Samsung Electronics Co., Ltd.
-//
-// Licensed under the Flora License, Version 1.0 (the License);
-// you may not use this file except in compliance with the License.
-// You may obtain a copy of the License at
-//
-// http://floralicense.org/license/
-//
-// Unless required by applicable law or agreed to in writing, software
-// distributed under the License is distributed on an AS IS BASIS,
-// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-// See the License for the specific language governing permissions and
-// limitations under the License.
-//
+/*
+ * Copyright (c) 2021 Samsung Electronics Co., Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
-// INTERNAL INCLUDES
-#include <dali/public-api/common/dali-vector.h>
+// EXTERNAL INCLUDES
+#include <dali/public-api/common/vector-wrapper.h>
+// INTERNAL INCLUDES
#include <dali-toolkit/public-api/controls/buttons/push-button.h>
-
#include "button-impl.h"
namespace Dali
{
-
namespace Toolkit
{
-
namespace Internal
{
-
/**
* PushButton implementation class.
*
class PushButton : public Button
{
public:
-
/**
* Create a new PushButton.
* @return A smart-pointer to the newly allocated PushButton.
*/
static Dali::Toolkit::PushButton New();
+protected:
/**
- * @copydoc Dali::Toolkit::PushButton::SetAutoRepeating( bool autoRepeating )
- */
- void SetAutoRepeating( bool autoRepeating );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::IsAutoRepeating() const
- */
- bool IsAutoRepeating() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetInitialAutoRepeatingDelay( float initialAutoRepeatingDelay )
- */
- void SetInitialAutoRepeatingDelay( float initialAutoRepeatingDelay );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::GetInitialAutoRepeatingDelay() const
- */
- float GetInitialAutoRepeatingDelay() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetNextAutoRepeatingDelay( float nextAutoRepeatingDelay )
- */
- void SetNextAutoRepeatingDelay( float nextAutoRepeatingDelay );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::GetNextAutoRepeatingDelay() const
- */
- float GetNextAutoRepeatingDelay() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetToggleButton( bool toggle )
- */
- void SetToggleButton( bool toggle );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::IsToggleButton() const
- */
- bool IsToggleButton() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetToggled( bool toggle )
- */
- void SetToggled( bool toggle );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::IsToggled() const
- */
- bool IsToggled() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetButtonImage( const Image image )
- */
- void SetButtonImage( Image image );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetButtonImage( Actor image )
- */
- void SetButtonImage( Actor image );
-
- /**
- * Used by the painter only.
- * @return A reference to the button image.
- */
- Actor& GetButtonImage();
-
- /**
- * @copydoc Dali::Toolkit::PushButton::
- */
- Actor GetButtonImage() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetBackgroundImage( const Image image )
- */
- void SetBackgroundImage( Image image );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetBackgroundImage( Actor image )
- */
- void SetBackgroundImage( Actor image );
-
- /**
- * Used by the painter only.
- * @return A reference to the background image.
- */
- Actor& GetBackgroundImage();
-
- /**
- * @copydoc Dali::Toolkit::PushButton::GetBackgroundImage()
- */
- Actor GetBackgroundImage() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetPressedImage( const Image image )
- */
- void SetPressedImage( Image image );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetPressedImage( Actor image )
- */
- void SetPressedImage( Actor image );
-
- /**
- * Used by the painter only.
- * @return A reference to the pressed image.
- */
- Actor& GetPressedImage();
-
- /**
- * @copydoc Dali::Toolkit::PushButton::GetPressedImage()
- */
- Actor GetPressedImage() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetDimmedBackgroundImage( Image image )
- */
- void SetDimmedBackgroundImage( Image image );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetDimmedBackgroundImage( Actor image )
- */
- void SetDimmedBackgroundImage( Actor image );
-
- /**
- * Used by the painter only.
- * @return A reference to the dimmed background image.
- */
- Actor& GetDimmedBackgroundImage();
-
- /**
- * @copydoc Dali::Toolkit::PushButton::GetDimmedBackgroundImage()
- */
- Actor GetDimmedBackgroundImage() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetDimmedImage( Image image )
- */
- void SetDimmedImage( Image image );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetDimmedImage( Actor image )
- */
- void SetDimmedImage( Actor image );
-
- /**
- * Used by the painter only.
- * @return A reference to the dimmed button image.
- */
- Actor& GetDimmedImage();
-
- /**
- * @copydoc Dali::Toolkit::PushButton::GetDimmedImage()
- */
- Actor GetDimmedImage() const;
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetLabelText( const std::string& text )
- */
- void SetLabelText( const std::string& text );
-
- /**
- * @copydoc Dali::Toolkit::PushButton::SetLabelText( Actor text )
- */
- void SetLabelText( Actor text );
-
- /**
- * Used by the painter only.
- * @return A reference to the label actor.
- */
- Actor& GetLabel();
-
- /**
- * @copydoc Dali::Toolkit::PushButton::GetLabelText()
- */
- Actor GetLabelText() const;
-
- /**
- * Used by the painter only.
- * @return A reference to the background image that is fading out.
+ * Construct a new PushButton.
*/
- Actor& GetFadeOutBackgroundImage();
+ PushButton();
/**
- * Used by the painter only.
- * @return A reference to the button image that is fading out.
+ * A reference counted object may only be deleted by calling Unreference()
*/
- Actor& GetFadeOutButtonImage();
+ virtual ~PushButton();
public:
-
- // Signals
-
- /**
- * @copydoc Dali::Toolkit::PushButton::ToggledSignal()
- */
- Toolkit::PushButton::ToggledSignalV2& ToggledSignal();
-
- /**
- * @copydoc Dali::Toolkit::PushButton::PressedSignal()
- */
- Toolkit::PushButton::PressedSignalV2& PressedSignal();
-
- /**
- * @copydoc Dali::Toolkit::PushButton::ReleasedSignal()
- */
- Toolkit::PushButton::ReleasedSignalV2& ReleasedSignal();
-
- /**
- * Connects a callback function with the object's signals.
- * @param[in] object The object providing the signal.
- * @param[in] tracker Used to disconnect the signal.
- * @param[in] signalName The signal to connect to.
- * @param[in] functor A newly allocated FunctorDelegate.
- * @return True if the signal was connected.
- * @post If a signal was connected, ownership of functor was passed to CallbackBase. Otherwise the caller is responsible for deleting the unused functor.
- */
- static bool DoConnectSignal( BaseObject* object, ConnectionTrackerInterface* tracker, const std::string& signalName, FunctorDelegate* functor );
-
// Properties
/**
- * @copydoc Button::SetProperty
- */
- static void SetProperty( BaseObject* object, Property::Index propertyIndex, const Property::Value& value );
-
- /**
- * @copydoc Button::GetProperty
- */
- static Property::Value GetProperty( BaseObject* object, Property::Index propertyIndex );
-
-protected: // From Button
-
- /**
- * Sets the Leave signal.
- */
- virtual void OnButtonInitialize();
-
- /**
- * Emits signals and notifies the painter accordingly with the set button
- * properties when the button is pressed.
- */
- virtual void OnButtonDown();
-
- /**
- * Emits signals and notifies the painter accordingly with the set button
- * properties when the button is released.
+ * Enum for the alignment modes of the icon.
*/
- virtual void OnButtonUp();
+ enum IconAlignment
+ {
+ LEFT,
+ RIGHT,
+ TOP,
+ BOTTOM,
+ DEFAULT = RIGHT
+ };
/**
- * Emits signals and notifies the painter accordingly with the set button
- * properties when the touch point leaves the boundary of the button.
+ * Called when a property of an object of this type is set.
+ * @param[in] object The object whose property is set.
+ * @param[in] index The property index.
+ * @param[in] value The new property value.
*/
- virtual void OnTouchPointLeave();
+ static void SetProperty(BaseObject* object, Property::Index index, const Property::Value& value);
/**
- * Currently it doesn't need different behaviour than @see OnTouchPointLeave()
+ * Called to retrieve a property of an object of this type.
+ * @param[in] object The object whose property is to be retrieved.
+ * @param[in] index The property index.
+ * @return The current value of the property.
*/
- virtual void OnTouchPointInterrupted();
+ static Property::Value GetProperty(BaseObject* object, Property::Index propertyIndex);
+private: // From Button
/**
- * Sets the push button animation time.
- * @param animationTime The animation time in seconds.
+ * @copydoc Toolkit::Internal::Button::OnInitialize
*/
- virtual void OnAnimationTimeSet( float animationTime );
+ void OnInitialize() override;
/**
- * Retrieves the animation time.
- * @return The animation time in seconds.
+ * @copydoc Toolkit::Internal::Control::CreateAccessibleObject()
*/
- virtual float OnAnimationTimeRequested() const;
-
-protected: // From ControlImpl
-
- /**
- * Respond the activate notification.
- */
- virtual void OnActivated();
+ DevelControl::ControlAccessible* CreateAccessibleObject() override;
private:
-
/**
- * Perform the click action to click the button.
- * @param[in] attributes The attributes to perfrom this action.
+ * @brief Sets the alignment mode to use to align the icon to the label.
+ *
+ * @param[in] iconAlignment The alignment mode to use
*/
- void DoClickAction(const PropertyValueContainer& attributes);
-
-public:
+ void SetIconAlignment(const PushButton::IconAlignment iconAlignment);
/**
- * Performs actions as requested using the action name.
- * @param[in] object The object on which to perform the action.
- * @param[in] actionName The action to perform.
- * @param[in] attributes The attributes with which to perfrom this action.
- * @return true if action has been accepted by this control
+ * @brief Gets the alignment mode used to align the icon to the label.
+ *
+ * @return The alignment mode in use
*/
- static bool DoAction(BaseObject* object, const std::string& actionName, const std::vector<Property::Value>& attributes);
-
- /**
- * Construct a new PushButton.
- */
- PushButton();
-
- /**
- * A reference counted object may only be deleted by calling Unreference()
- */
- virtual ~PushButton();
+ const PushButton::IconAlignment GetIconAlignment() const;
private:
-
// Undefined
- PushButton( const PushButton& );
+ PushButton(const PushButton&);
// Undefined
- PushButton& operator=( const PushButton& );
-
- /**
- * Sets up the autorepeating timer.
- * @param[in] delay The delay time in seconds.
- */
- void SetUpTimer( float delay );
-
- /**
- * Slot called when Dali::Timer::SignalTick signal. Resets the autorepeating timer.
- */
- bool AutoRepeatingSlot();
+ PushButton& operator=(const PushButton&);
private:
- bool mAutoRepeating; ///< Stores the autorepeating property.
- float mInitialAutoRepeatingDelay; ///< Stores the initial autorepeating delay in seconds.
- float mNextAutoRepeatingDelay; ///< Stores the next autorepeating delay in seconds.
- bool mToggleButton; ///< Stores the toggle property.
-
- // AutoRepeating
- Timer mAutoRepeatingTimer; ///< Timer used to implement the autorepeating property.
-
- // Toggle
- bool mToggled; ///< Stores the toggle state.
-
- // Signals
- Toolkit::PushButton::ToggledSignalV2 mToggledSignalV2; ///< Signal emitted when the button is toggled.
- Toolkit::PushButton::PressedSignalV2 mPressedSignalV2; ///< Signal emitted when the button is pressed.
- Toolkit::PushButton::ReleasedSignalV2 mReleasedSignalV2; ///< Signal emitted when the button is released.
-
- Actor mButtonImage; ///< Stores the released image.
- Actor mBackgroundImage; ///< Stores the background image.
- Actor mPressedImage; ///< Stores the pressed image.
- Actor mDimmedImage; ///< Stores the dimmed image.
- Actor mDimmedBackgroundImage; ///< Stores the dimmed background image.
+ IconAlignment mIconAlignment; ///< The alignment of the icon against the label.
- Actor mLabel; ///< Stores the text label.
+protected:
+ class PushButtonAccessible : public Button::ButtonAccessible
+ {
+ public:
+ using Button::ButtonAccessible::ButtonAccessible;
- Actor mFadeOutBackgroundImage; ///< Stores a background image, which is in a fade out animation, to be removed when the animation finishes.
- Actor mFadeOutButtonImage; ///< Stores a foreground image, which is in a fade out animation, to be removed when the animation finishes.
+ /**
+ * @copydoc Dali::Toolkit::DevelControl::ControlAccessible::CalculateStates()
+ */
+ Dali::Accessibility::States CalculateStates() override;
+ };
- // Actions
- bool mClickActionPerforming;
+ void OnStateChange(State newState) override;
};
} // namespace Internal
// Helpers for public-api forwarding methods
-inline Toolkit::Internal::PushButton& GetImplementation( Toolkit::PushButton& button )
+inline Toolkit::Internal::PushButton& GetImplementation(Toolkit::PushButton& button)
{
- DALI_ASSERT_ALWAYS( button );
+ DALI_ASSERT_ALWAYS(button);
Dali::RefObject& handle = button.GetImplementation();
- return static_cast<Toolkit::Internal::PushButton&>( handle );
+ return static_cast<Toolkit::Internal::PushButton&>(handle);
}
-inline const Toolkit::Internal::PushButton& GetImplementation( const Toolkit::PushButton& button )
+inline const Toolkit::Internal::PushButton& GetImplementation(const Toolkit::PushButton& button)
{
- DALI_ASSERT_ALWAYS( button );
+ DALI_ASSERT_ALWAYS(button);
const Dali::RefObject& handle = button.GetImplementation();
- return static_cast<const Toolkit::Internal::PushButton&>( handle );
+ return static_cast<const Toolkit::Internal::PushButton&>(handle);
}
} // namespace Toolkit
} // namespace Dali
-#endif // __DALI_TOOLKIT_INTERNAL_PUSH_BUTTON_H__
+#endif // DALI_TOOLKIT_INTERNAL_PUSH_BUTTON_H