/* * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved * * 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. */ using System; namespace ElmSharp { /// /// Enumeration for the PanelDirection types. /// /// preview public enum PanelDirection { /// /// Top to bottom. /// Top = 0, /// /// Bottom to top. /// Bottom, /// /// Left to right. /// Left, /// /// Right to left. /// Right, } /// /// The Panel is a container that can contain subobjects. /// /// preview public class Panel : Layout { SmartEvent _toggled; SmartEvent _scrolled; /// /// Creates and initializes a new instance of the Panel class. /// /// The EvasObject to which the new panel will be attached as a child. /// preview public Panel(EvasObject parent) : base(parent) { _toggled = new SmartEvent(this, this.RealHandle, "toggled"); _scrolled = new SmartEvent(this, this.RealHandle, "scroll"); _toggled.On += (s, e) => Toggled?.Invoke(this, EventArgs.Empty); _scrolled.On += (s, e) => Scrolled?.Invoke(this, EventArgs.Empty); } /// /// Sets or gets the hidden status of a given Panel widget. /// /// preview public bool IsOpen { get { return !Interop.Elementary.elm_panel_hidden_get(RealHandle); } set { Interop.Elementary.elm_panel_hidden_set(RealHandle, !value); } } /// /// Sets or gets the direction of a given Panel widget. /// /// preview public PanelDirection Direction { get { return (PanelDirection)Interop.Elementary.elm_panel_orient_get(RealHandle); } set { Interop.Elementary.elm_panel_orient_set(RealHandle, (int)value); } } /// /// Toggled will be triggered when the panel is toggled. /// /// preview public event EventHandler Toggled; /// /// Scrolled will be triggered when the panel has been scrolled. This event is emitted only when the panel is scrollable /// /// preview public event EventHandler Scrolled; /// /// Enable or disable scrolling in the panel. /// /// /// Bool value can be false or true. /// /// preview public void SetScrollable(bool enable) { Interop.Elementary.elm_panel_scrollable_set(RealHandle, enable); } /// /// Sets the scroll size of the panel. /// /// /// The size of the scroll area. /// /// preview public void SetScrollableArea(double ratio) { Interop.Elementary.elm_panel_scrollable_content_size_set(RealHandle, ratio); } /// /// Toggles the hidden state of the panel. /// /// preview public void Toggle() { Interop.Elementary.elm_panel_toggle(RealHandle); } /// /// Creates a widget handle. /// /// Parent EvasObject. /// Handle IntPtr. /// preview protected override IntPtr CreateHandle(EvasObject parent) { IntPtr handle = Interop.Elementary.elm_layout_add(parent.Handle); Interop.Elementary.elm_layout_theme_set(handle, "layout", "elm_widget", "default"); RealHandle = Interop.Elementary.elm_panel_add(handle); Interop.Elementary.elm_object_part_content_set(handle, "elm.swallow.content", RealHandle); return handle; } } }