/* * 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 modes of ColorSelector. /// /// preview public enum ColorSelectorMode { /// /// Only the color palette is displayed, by default. /// Palette, /// /// Only the color selector is displayed. /// [Obsolete("Components is obsolete as of version 1.2.3 and is no longer supported.")] Components, /// /// Both the palette and the selector is displayed. /// [Obsolete("Both is obsolete as of version 1.2.3 and is no longer supported.")] Both, /// /// Only the color picker is displayed. /// [Obsolete("Picker is obsolete as of version 1.2.3 and is no longer supported.")] Picker, /// /// This mode is not supported. If you use this, nothing will be shown. /// [Obsolete("Plane is obsolete as of version 1.2.3 and is no longer supported.")] Plane, /// /// This mode is not supported. If you use this, it will be shown same with the Palette mode. /// [Obsolete("PallettePlane is obsolete as of version 1.2.3 and is no longer supported.")] PallettePlane, /// /// This mode is not supported. If you use this, it will be shown same with the Palette mode. /// [Obsolete("All is obsolete as of version 1.2.3 and is no longer supported.")] All } /// /// The ColorSelector is a widget to set a series of colors. /// It also allows to load/save colors from/to the configuration with a unique identifier. /// /// /// By default, the colors are loaded/saved from/to configuration using the "default" identifier. /// The colors can be picked by the user from the color set by clicking on individual /// color items on the palette, or by selecting it from the selector. /// /// preview public class ColorSelector : Layout { private readonly SmartEvent _changed; private Color _currentColor; /// /// Creates and initializes a new instance of the ColorSelector class. /// /// /// preview public ColorSelector(EvasObject parent) : base(parent) { _changed = new SmartEvent(this, "changed", (data, obj, info) => { return new ColorChangedEventArgs(_currentColor, SelectedColor); }); } /// /// ColorChanged will be triggered when the SelectedColor is changed. /// /// preview public event EventHandler ColorChanged { add { _changed.On += value; } remove { _changed.On -= value; } } /// /// Gets or sets the color of colorselector. /// /// preview public Color SelectedColor { get { int r, g, b, a; Interop.Elementary.elm_colorselector_color_get(Handle, out r, out g, out b, out a); _currentColor = new Color(r, g, b, a); return _currentColor; } set { Interop.Elementary.elm_colorselector_color_set(Handle, value.R, value.G, value.B, value.A); _currentColor = new Color(value.R, value.G, value.B, value.A); } } /// /// Gets the Alpha of a default Color class (value is -1). /// /// preview public override int Opacity { get { return Color.Default.A; } set { Console.WriteLine("ColorSelector instance doesn't support to set Opacity."); } } /// /// Gets or sets the Colorselector's mode. /// /// preview public ColorSelectorMode Mode { get { return (ColorSelectorMode)Interop.Elementary.elm_colorselector_mode_get(Handle); } set { if (ColorSelectorMode.Palette == value) { Interop.Elementary.elm_colorselector_mode_set(Handle, (Interop.Elementary.Elm_Colorselector_Mode)value); } } } /// /// Gets or sets the current palette's name. /// /// preview public string PaletteName { get { return Interop.Elementary.elm_colorselector_palette_name_get(Handle); } set { Interop.Elementary.elm_colorselector_palette_name_set(Handle, value); } } /// /// Adds a new color item to the palette. /// /// The color item to add. /// A new color palette Item. /// preview public ColorSelectorItem AddPaletteColor(Color color) { ColorSelectorItem item = new ColorSelectorItem(this); item.Handle = Interop.Elementary.elm_colorselector_palette_color_add(Handle, color.R, color.G, color.B, color.A); return item; } /// /// Clears the palette items. /// /// preview public void ClearPalette() { Interop.Elementary.elm_colorselector_palette_clear(Handle); } /// /// Creates a widget handle. /// /// Parent EvasObject. /// Handle IntPtr. /// preview protected override IntPtr CreateHandle(EvasObject parent) { return Interop.Elementary.elm_colorselector_add(parent.Handle); } } }