/*
* 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);
}
}
}