/*
* 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;
using System.Collections;
using System.Collections.Generic;
namespace ElmSharp
{
///
/// The EdjeObject is a class that the evas object exists in.
///
/// preview
public class EdjeObject
{
IntPtr _edjeHandle;
Dictionary _signalDatas = new Dictionary();
internal EdjeObject(IntPtr handle)
{
_edjeHandle = handle;
}
///
/// Checks whether an edje part exists in a given edje object's group definition.
/// This function returns if a given part exists in the edje group bound to object obj
///
/// This call is useful, for example, when one could expect a given GUI element, depending on the theme applied to object.
/// The part's name to check for existence in object's group.
/// TRUE, if the edje part exists in the object's group, otherwise FALSE.
/// preview
public EdjeTextPartObject this[string part]
{
get
{
if (Interop.Elementary.edje_object_part_exists(_edjeHandle, part))
{
return new EdjeTextPartObject(_edjeHandle, part);
}
return null;
}
}
///
/// Sends or emits an edje signal to a given edje object.
///
/// The signal's "emission" string
/// The signal's "source" string
/// preview
public void EmitSignal(string emission, string source)
{
Interop.Elementary.edje_object_signal_emit(_edjeHandle, emission, source);
}
///
/// Deletes the object Color class.
/// This function deletes any values at the object level for the specified object and Color class.
///
/// Deleting the Color class defined in the theme file.
/// The Color class to be deleted.
/// preview
public void DeleteColorClass(string part)
{
Interop.Elementary.edje_object_color_class_del(_edjeHandle, part);
}
///
/// Sets the object Color class.
///
/// The Color class name.
/// The object red value.
/// The object green value.
/// The object blue value.
/// The object alpha value.
/// The outline red value.
/// The outline green value.
/// The outline blue value.
/// The outline alpha value.
/// The shadow red value.
/// The shadow green value.
/// The shadow blue value.
/// The shadow alpha value.
/// True if succeeds, otherwise False.
/// preview
public bool SetColorClass(string colorClass, int red, int green, int blue, int alpha, int outlineRed, int outlineGreen, int outlineBlue, int outlineAlpha,
int shadowRed, int shadowGreen, int shadowBlue, int shadowAlpha)
{
return Interop.Elementary.edje_object_color_class_set(_edjeHandle, colorClass, red, green, blue, alpha, outlineRed, outlineGreen, outlineBlue, outlineAlpha,
shadowRed, shadowGreen, shadowBlue, shadowAlpha);
}
///
/// Gets the object Color class.
///
/// The Color class name.
/// The object red value.
/// The object green value.
/// The object blue value.
/// The object alpha value.
/// The outline red value.
/// The outline green value.
/// The outline blue value.
/// The outline alpha value.
/// The shadow red value.
/// The shadow green value.
/// The shadow blue value.
/// The shadow alpha value.
/// True if succeeds, otherwise False.
/// preview
public bool GetColorClass(string colorClass, out int red, out int green, out int blue, out int alpha, out int outlineRed, out int outlineGreen, out int outlineBlue, out int outlineAlpha,
out int shadowRed, out int shadowGreen, out int shadowBlue, out int shadowAlpha)
{
return Interop.Elementary.edje_object_color_class_get(_edjeHandle, colorClass, out red, out green, out blue, out alpha, out outlineRed, out outlineGreen, out outlineBlue, out outlineAlpha,
out shadowRed, out shadowGreen, out shadowBlue, out shadowAlpha);
}
///
/// Sets the Edje text class.
///
/// The text class name.
/// Font name.
/// Font size.
/// True if succeeds, otherwise False.
/// preview
public bool SetTextClass(string textClass, string font, int fontSize)
{
return Interop.Elementary.edje_object_text_class_set(_edjeHandle, textClass, font, fontSize);
}
///
/// Gets the Edje text class.
///
/// The text class name.
/// Font name.
/// Font size.
/// True if succeeds, otherwise False.
/// preview
public bool GetTextClass(string textClass, out string font, out int fontSize)
{
return Interop.Elementary.edje_object_text_class_get(_edjeHandle, textClass, out font, out fontSize);
}
///
/// Adds Action for an arriving edje signal, emitted by a given Ejde object.
///
/// The signal's "emission" string.
/// The signal's "source" string.
/// The action to be executed when the signal is emitted.
/// preview
public void AddSignalAction(string emission, string source, Action action)
{
if (emission != null && source != null && action != null)
{
var signalData = new SignalData(emission, source, action);
if (!_signalDatas.ContainsKey(signalData))
{
var signalCallback = new Interop.Elementary.Edje_Signal_Cb((d, o, e, s) =>
{
action(e, s);
});
Interop.Elementary.edje_object_signal_callback_add(_edjeHandle, emission, source, signalCallback, IntPtr.Zero);
_signalDatas.Add(signalData, signalCallback);
}
}
}
///
/// Deletes a signal-triggered action from an object.
///
/// The signal's "emission" string.
/// The signal's "source" string.
/// The action to be executed when the signal is emitted.
/// preview
public void DeleteSignalAction(string emission, string source, Action action)
{
if (emission != null && source != null && action != null)
{
var signalData = new SignalData(emission, source, action);
Interop.Elementary.Edje_Signal_Cb signalCallback = null;
_signalDatas.TryGetValue(signalData, out signalCallback);
if (signalCallback != null)
{
Interop.Elementary.edje_object_signal_callback_del(_edjeHandle, emission, source, signalCallback);
_signalDatas.Remove(signalData);
}
}
}
class SignalData : IEquatable
{
public string Emission { get; set; }
public string Source { get; set; }
public Action Action { get; set; }
public SignalData(string emission, string source, Action action)
{
Emission = emission;
Source = source;
Action = action;
}
public override bool Equals(object other)
{
return Equals(other as SignalData);
}
public bool Equals(SignalData other) {
if (other == null)
{
return false;
}
return (Emission == other.Emission) && (Source == other.Source) && (Action == other.Action);
}
public override int GetHashCode()
{
int hashCode = Emission.GetHashCode();
hashCode ^= Source.GetHashCode();
hashCode ^= Action.GetHashCode();
return hashCode;
}
}
}
///
/// The EdjeTextPartObject is a class dealing with parts of type text.
///
/// preview
public class EdjeTextPartObject
{
string _part;
IntPtr _edjeHandle;
internal EdjeTextPartObject(IntPtr edjeHandle, string part)
{
_edjeHandle = edjeHandle;
_part = part;
}
///
/// Gets the name of the EdjeTextPartObject.
///
/// preview
public string Name { get { return _part; } }
///
/// Gets or sets the text for an object part.
///
/// preview
public string Text
{
get
{
return Interop.Elementary.edje_object_part_text_get(_edjeHandle, _part);
}
set
{
Interop.Elementary.edje_object_part_text_set(_edjeHandle, _part, value);
}
}
///
/// Sets or gets the style of the object part.
///
/// preview
public string TextStyle
{
get
{
return Interop.Elementary.edje_object_part_text_style_user_peek(_edjeHandle, _part);
}
set
{
if (value == null)
{
Interop.Elementary.edje_object_part_text_style_user_pop(_edjeHandle, _part);
}
else
{
Interop.Elementary.edje_object_part_text_style_user_push(_edjeHandle, _part, value);
}
}
}
///
/// Gets the geometry of a given edje part, in a given edje object's group definition, relative to the object's area.
///
/// preview
public Rect Geometry
{
get
{
int x, y, w, h;
Interop.Elementary.edje_object_part_geometry_get(_edjeHandle, _part, out x, out y, out w, out h);
return new Rect(x, y, w, h);
}
}
///
/// Gets the native width and height.
///
/// preview
public Size TextBlockNativeSize
{
get
{
int w;
int h;
IntPtr part = Interop.Elementary.edje_object_part_object_get(_edjeHandle, _part);
Interop.Evas.evas_object_textblock_size_native_get(part, out w, out h);
return new Size(w, h);
}
}
///
/// Gets the formatted width and height.
///
/// preview
public Size TextBlockFormattedSize
{
get
{
int w;
int h;
IntPtr part = Interop.Elementary.edje_object_part_object_get(_edjeHandle, _part);
Interop.Evas.evas_object_textblock_size_formatted_get(part, out w, out h);
return new Size(w, h);
}
}
}
}