bool applying;
object inheritedContext;
- private object bindingContext;
-
/// <summary>
/// Gets or sets object that contains the properties that will be targeted by the bound properties that belong to this BindableObject.
/// </summary>
[EditorBrowsable(EditorBrowsableState.Never)]
public int LinePosition { get; set; } = -1;
- void IDynamicResourceHandler.SetDynamicResource(BindableProperty property, string key)
- {
- SetDynamicResource(property, key, false);
- }
+ void IDynamicResourceHandler.SetDynamicResource(BindableProperty property, string key) => SetDynamicResource(property, key, false);
/// <summary>
/// Raised when a property has changed.
{
nameToBindableProperty2.TryGetValue(keyValuePair.Key, out var bindableProperty);
- if (null != bindableProperty && (ChangedPropertiesSet.Contains(bindableProperty) || other.ChangedPropertiesSet.Contains(bindableProperty)))
+ if (null != bindableProperty && other.IsSet(bindableProperty))
{
object value = other.GetValue(bindableProperty);
-
- if (null != value)
- {
- InternalSetValue(keyValuePair.Value, value);
- }
+ InternalSetValue(keyValuePair.Value, value);
}
}
}
[EditorBrowsable(EditorBrowsableState.Never)]
public event EventHandler BindingContextChanged;
- internal void ClearValue(BindableProperty property, bool fromStyle)
- {
- ClearValue(property, fromStyle: fromStyle, checkAccess: true);
- }
+ internal void ClearValue(BindableProperty property, bool fromStyle) => ClearValue(property, fromStyle: fromStyle, checkAccess: true);
/// <summary>
/// Clears any value set by Tizen.NUI.Xaml.BindableObject.SetValue.
if (property == null)
throw new ArgumentNullException(nameof(property));
- if (!IsBinded && property.ValueGetter != null)
+ if (!IsBound && property.ValueGetter != null)
{
return property.ValueGetter(this);
}
/// Removes a previously set binding.
/// </summary>
/// <param name="property">The BindableProperty from which to remove bindings.</param>
- internal void RemoveBinding(BindableProperty property)
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void RemoveBinding(BindableProperty property)
{
if (property == null)
throw new ArgumentNullException(nameof(property));
/// <param name="binding">The binding to set.</param>
/// This will be public opened in tizen_5.0 after ACR done. Before ACR, need to be hidden as inhouse API.
[EditorBrowsable(EditorBrowsableState.Never)]
- public void SetBinding(BindableProperty targetProperty, BindingBase binding)
+ public void SetBinding(BindableProperty targetProperty, BindingBase binding) => SetBinding(targetProperty, binding, false);
+
+ /// Internal used, will never changed to not hidden.
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public virtual bool IsCreateByXaml
{
- SetBinding(targetProperty, binding, false);
+ get;
+ set;
}
- private bool isCreateByXaml = false;
- /// Only used by the IL of xaml, will never changed to not hidden.
+ /// This will be public opened in next ACR.
[EditorBrowsable(EditorBrowsableState.Never)]
- public virtual bool IsCreateByXaml
+ public void EnforceNotifyBindedInstance(BindableProperty property)
{
- get
- {
- return isCreateByXaml;
- }
- set
+ if (null != property)
{
- isCreateByXaml = value;
+ BindablePropertyContext context = GetOrCreateContext(property);
+ BindingBase binding = context.Binding;
+
+ var currentlyApplying = applying;
+
+ if (binding != null && !currentlyApplying)
+ {
+ applying = true;
+ binding.Apply(true);
+ applying = false;
+ }
+
+ OnPropertyChanged(property.PropertyName);
+
+ PropertyToGroup.TryGetValue(property, out HashSet<BindableProperty> propertyGroup);
+
+ if (null != propertyGroup)
+ {
+ foreach (var relativeProperty in propertyGroup)
+ {
+ if (relativeProperty != property)
+ {
+ var relativeContext = GetOrCreateContext(relativeProperty);
+ var relativeBinding = relativeContext.Binding;
+
+ if (null != relativeBinding)
+ {
+ applying = true;
+ relativeBinding.Apply(true);
+ applying = false;
+ }
+
+ OnPropertyChanged(relativeProperty.PropertyName);
+ }
+ }
+ }
}
}
internal void InternalSetValue(BindableProperty property, object value)
{
- if (true == IsBinded)
+ if (true == IsBound)
{
SetValue(property, value, false, true);
}
}
object oldvalue = null;
- if (null == property.DefaultValueCreator)
+ BindablePropertyContext context = GetOrCreateContext(property);
+ if (null != context)
{
- BindablePropertyContext context = GetOrCreateContext(property);
- if (null != context)
- {
- oldvalue = context.Value;
- context.Value = value;
- }
- }
- else
- {
- oldvalue = property.DefaultValueCreator.Invoke(this);
+ context.Attributes |= BindableContextAttributes.IsManuallySet;
+ oldvalue = context.Value;
+ context.Value = value;
}
+ property.PropertyChanging?.Invoke(this, oldvalue, value);
property.PropertyChanged?.Invoke(this, oldvalue, value);
OnPropertyChanged(property.PropertyName);
OnPropertyChangedWithData(property);
}
-
- ChangedPropertiesSet.Add(property);
- }
-
- private HashSet<BindableProperty> changedPropertiesSet;
- private HashSet<BindableProperty> ChangedPropertiesSet
- {
- get
- {
- if (null == changedPropertiesSet)
- {
- changedPropertiesSet = new HashSet<BindableProperty>();
- }
-
- return changedPropertiesSet;
- }
}
private HashSet<BindableProperty> changedPropertiesSetExcludingStyle;
}
}
- internal void SetValueAndForceSendChangeSignal(BindableProperty property, object value)
- {
- if (property == null)
- throw new ArgumentNullException(nameof(property));
-
- if (true == isCreateByXaml)
- {
- if (property.IsReadOnly)
- throw new InvalidOperationException(string.Format("The BindableProperty \"{0}\" is readonly.", property.PropertyName));
-
- SetValueCore(property, value, SetValueFlags.ClearOneWayBindings | SetValueFlags.ClearDynamicResource,
- SetValuePrivateFlags.ManuallySet | SetValuePrivateFlags.CheckAccess, true);
- }
- else
- {
- property.PropertyChanged?.Invoke(this, null, value);
- }
- }
-
/// <summary>
/// Sets the value of the propertyKey.
/// </summary>
/// </summary>
/// This will be public opened in tizen_5.0 after ACR done. Before ACR, need to be hidden as inhouse API.
[EditorBrowsable(EditorBrowsableState.Never)]
- protected void ApplyBindings()
- {
- ApplyBindings(skipBindingContext: false, fromBindingContextChanged: false);
- }
+ protected void ApplyBindings() => ApplyBindings(skipBindingContext: false, fromBindingContextChanged: false);
/// <summary>
/// Override this method to execute an action when the BindingContext changes.
if (fromStyle && !CanBeSetFromStyle(targetProperty))
return;
- IsBinded = true;
+ IsBound = true;
var context = GetOrCreateContext(targetProperty);
if (fromStyle)
return false;
}
- internal void SetDynamicResource(BindableProperty property, string key)
- {
- SetDynamicResource(property, key, false);
- }
+ internal void SetDynamicResource(BindableProperty property, string key) => SetDynamicResource(property, key, false);
internal void SetDynamicResource(BindableProperty property, string key, bool fromStyle)
{
OnSetDynamicResource(property, key);
}
- internal void SetValue(BindableProperty property, object value, bool fromStyle)
- {
- SetValue(property, value, fromStyle, true);
- }
+ internal void SetValue(BindableProperty property, object value, bool fromStyle) => SetValue(property, value, fromStyle, true);
internal void SetValueCore(BindablePropertyKey propertyKey, object value, SetValueFlags attributes = SetValueFlags.None)
{
- SetValueCore(propertyKey.BindableProperty, value, attributes, SetValuePrivateFlags.None, false);
+ SetValueCore(propertyKey.BindableProperty, value, attributes, SetValuePrivateFlags.None);
}
/// <summary>
/// <param name="value">The value to set</param>
/// <param name="attributes">The set value flag</param>
[EditorBrowsable(EditorBrowsableState.Never)]
- internal void SetValueCore(BindableProperty property, object value, SetValueFlags attributes = SetValueFlags.None)
- {
- SetValueCore(property, value, attributes, SetValuePrivateFlags.Default, false);
- }
+ internal void SetValueCore(BindableProperty property, object value, SetValueFlags attributes = SetValueFlags.None) => SetValueCore(property, value, attributes, SetValuePrivateFlags.Default);
- internal void SetValueCore(BindableProperty property, object value, SetValueFlags attributes, SetValuePrivateFlags privateAttributes, bool forceSendChangeSignal)
+ internal void SetValueCore(BindableProperty property, object value, SetValueFlags attributes, SetValuePrivateFlags privateAttributes)
{
bool checkAccess = (privateAttributes & SetValuePrivateFlags.CheckAccess) != 0;
bool manuallySet = (privateAttributes & SetValuePrivateFlags.ManuallySet) != 0;
else
{
context.Attributes |= BindableContextAttributes.IsBeingSet;
- SetValueActual(property, context, value, currentlyApplying, forceSendChangeSignal, attributes, silent);
+ SetValueActual(property, context, value, currentlyApplying, attributes, silent);
Queue<SetValueArgs> delayQueue = context.DelayedSetters;
if (delayQueue != null)
while (delayQueue.Count > 0)
{
SetValueArgs s = delayQueue.Dequeue();
- SetValueActual(s.Property, s.Context, s.Value, s.CurrentlyApplying, forceSendChangeSignal, s.Attributes);
+ SetValueActual(s.Property, s.Context, s.Value, s.CurrentlyApplying, s.Attributes);
}
context.DelayedSetters = null;
}
}
+ /// <summary>
+ /// Check if object is bound or not.
+ /// This API used for legacy codes.
+ /// Should be removed after all app usage replaced into IsBound.
+ /// </summary>
+ [Obsolete("This has been deprecated in API11. Use IsBound property instead.")]
internal bool IsBinded
{
+ get
+ {
+ return IsBound;
+ }
+ set
+ {
+ IsBound = value;
+ }
+ }
+
+ /// <summary>
+ /// Check if object is bound or not.
+ /// </summary>
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public bool IsBound
+ {
get;
set;
} = false;
if (newvalue is BindableObject targetBindableObject)
{
- targetBindableObject.IsBinded = true;
+ targetBindableObject.IsBound = true;
}
}
return;
SetValueCore(property, value, SetValueFlags.ClearOneWayBindings | SetValueFlags.ClearDynamicResource,
- (fromStyle ? SetValuePrivateFlags.FromStyle : SetValuePrivateFlags.ManuallySet) | (checkAccess ? SetValuePrivateFlags.CheckAccess : 0),
- false);
+ (fromStyle ? SetValuePrivateFlags.FromStyle : SetValuePrivateFlags.ManuallySet) | (checkAccess ? SetValuePrivateFlags.CheckAccess : 0));
}
- void SetValueActual(BindableProperty property, BindablePropertyContext context, object value, bool currentlyApplying, bool forceSendChangeSignal, SetValueFlags attributes, bool silent = false)
+ void SetValueActual(BindableProperty property, BindablePropertyContext context, object value, bool currentlyApplying, SetValueFlags attributes, bool silent = false)
{
object original = context.Value;
bool raiseOnEqual = (attributes & SetValueFlags.RaiseOnEqual) != 0;
PropertyToGroup.TryGetValue(property, out HashSet<BindableProperty> propertyGroup);
- if (!silent)
+ if (!silent && (!same || raiseOnEqual))
{
- if ((!same || raiseOnEqual))
- {
- property.PropertyChanged?.Invoke(this, original, value);
-
- if (binding != null && !currentlyApplying)
- {
- applying = true;
- binding.Apply(true);
- applying = false;
- }
-
- OnPropertyChanged(property.PropertyName);
-
- if (null != propertyGroup)
- {
- foreach (var relativeProperty in propertyGroup)
- {
- if (relativeProperty != property)
- {
- var relativeContext = GetOrCreateContext(relativeProperty);
- var relativeBinding = relativeContext.Binding;
-
- if (null != relativeBinding)
- {
- applying = true;
- relativeBinding.Apply(true);
- applying = false;
- }
+ property.PropertyChanged?.Invoke(this, original, value);
- OnPropertyChanged(relativeProperty.PropertyName);
- }
- }
- }
- }
- else if (true == same && true == forceSendChangeSignal)
+ if (binding != null && !currentlyApplying)
{
- if (binding != null && !currentlyApplying)
- {
- applying = true;
- binding.Apply(true);
- applying = false;
- }
+ applying = true;
+ binding.Apply(true);
+ applying = false;
+ }
- OnPropertyChanged(property.PropertyName);
+ OnPropertyChanged(property.PropertyName);
- if (null != propertyGroup)
+ if (null != propertyGroup)
+ {
+ foreach (var relativeProperty in propertyGroup)
{
- foreach (var relativeProperty in propertyGroup)
+ if (relativeProperty != property)
{
- if (relativeProperty != property)
- {
- var relativeContext = GetOrCreateContext(relativeProperty);
- var relativeBinding = relativeContext.Binding;
+ var relativeContext = GetOrCreateContext(relativeProperty);
+ var relativeBinding = relativeContext.Binding;
- if (null != relativeBinding)
- {
- applying = true;
- relativeBinding.Apply(true);
- applying = false;
- }
-
- OnPropertyChanged(relativeProperty.PropertyName);
+ if (null != relativeBinding)
+ {
+ applying = true;
+ relativeBinding.Apply(true);
+ applying = false;
}
+
+ OnPropertyChanged(relativeProperty.PropertyName);
}
}
}
}
}
- internal void ClearBinding()
+ /// <summary>
+ /// Unapplies all previously set bindings.
+ /// </summary>
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void ClearBinding()
{
foreach (var property in properties)
{