Release 8.0.0.15408
[platform/core/csapi/tizenfx.git] / src / Tizen.NUI.Components / Controls / ScrollbarBase.cs
1 /*
2  * Copyright(c) 2020 Samsung Electronics Co., Ltd.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16  */
17 using System.ComponentModel;
18
19 namespace Tizen.NUI.Components
20 {
21     /// <summary>
22     /// The ScrollbarBase is an abstract class that can be linked to the scrollable objects
23     /// indicating the current scrolled position of the scrollable object.
24     /// This only contains non-graphical functionalities of basic scrollbar.
25     /// </summary>
26     [EditorBrowsable(EditorBrowsableState.Never)]
27     public abstract class ScrollbarBase : Control
28     {
29         #region Constructors
30
31         /// <summary>
32         /// Create an empty ScrollbarBase.
33         /// </summary>
34         public ScrollbarBase() : base()
35         {
36         }
37
38         /// <summary>
39         /// Create an empty Scrollbar with a ControlStyle instance to set style properties.
40         /// </summary>
41         [EditorBrowsable(EditorBrowsableState.Never)]
42         public ScrollbarBase(ControlStyle style) : base(style)
43         {
44         }
45
46         /// <summary>
47         /// Static constructor to initialize bindable properties when loading.
48         /// </summary>
49         static ScrollbarBase()
50         {
51         }
52
53         #endregion Constructors
54
55
56         #region Methods
57
58         /// <summary>
59         /// Update content length and position at once.
60         /// </summary>
61         /// <param name="contentLength">The total length of the content.</param>
62         /// <param name="position">The destination position of the View in content length. This is the View's top position if the scroller is vertical, otherwise, View's left position.</param>
63         /// <param name="durationMs">The time it takes to scroll in milliseconds.</param>
64         /// <param name="alphaFunction">The timing function used in animation. It describes the rate of change of the animation parameter over time. (e.g. EaseOut)</param>
65         [EditorBrowsable(EditorBrowsableState.Never)]
66         public abstract void Update(float contentLength, float position, uint durationMs = 0, AlphaFunction alphaFunction = null);
67
68         /// <summary>
69         /// Scroll content to a specific position.
70         /// </summary>
71         /// <param name="position">The destination to scroll.</param>
72         /// <param name="durationMs">The time it takes to scroll in milliseconds.</param>
73         /// <param name="alphaFunction">The timing function used in animation. It describes the rate of change of the animation parameter over time. (e.g. EaseOut)</param>
74         [EditorBrowsable(EditorBrowsableState.Never)]
75         public abstract void ScrollTo(float position, uint durationMs = 0, AlphaFunction alphaFunction = null);
76
77         /// <summary>
78         /// Initialize the scroll bar.
79         /// </summary>
80         /// <param name="contentLength">The length of the scrollable content area.</param>
81         /// <param name="viewportLength">The length of the viewport representing the amount of visible content.</param>
82         /// <param name="currentPosition">The current position of the viewport in scrollable content area. This is the viewport's top position if the scroller is vertical, otherwise, left.</param>
83         /// <param name="isHorizontal">Whether the direction of scrolling is horizontal or not. It is vertical by default.</param>
84         [EditorBrowsable(EditorBrowsableState.Never)]
85         public abstract void Initialize(float contentLength, float viewportLength, float currentPosition, bool isHorizontal = false);
86
87         #endregion Methods
88     }
89 }