5 * Copyright (c) 2018 Samsung Electronics Co., Ltd.
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
22 #include <dali/public-api/object/base-handle.h>
25 #include <dali/public-api/dali-adaptor-common.h>
31 * @addtogroup dali_adaptor_framework
48 * @brief Widget class is the base class for custom widget.
50 * To make own Widget, user should inherit this class and its impl class.
54 class DALI_ADAPTOR_API Widget : public BaseHandle
59 * @brief Enumeration class for termination type of widget instance.
62 enum class Termination
64 PERMANENT, //< User deleted this widget from the viewer @SINCE_1_3_5
65 TEMPORARY, //< Widget is deleted because of other reasons (e.g. widget process is terminated temporarily by the system) @SINCE_1_3_5
71 * @brief This is the constructor for Widget.
73 * @return A handle to the Widget
78 * @brief The default constructor.
84 * @brief Copy Constructor.
86 * @param[in] widget Handle to an object
88 Widget( const Widget& widget );
91 * @brief Assignment operator.
93 * @param[in] widget Handle to an object
94 * @return A reference to this
96 Widget& operator=( const Widget& widget );
104 public: // Not intended for application developers
105 explicit Widget(Internal::Adaptor::Widget* widget);
113 #endif // DALI_WIDGET_H