> propertyLambda, IDataBindingConverter converter)
{
-
var propertyInfo = ReflectionUtilities.GetPropertyInfo(CurrentValue, propertyLambda);
-
+ if (converter.SupportedType != propertyInfo.PropertyType)
+ throw new ArtemisCoreException($"Cannot register data binding property for property {propertyInfo.Name} " +
+ "because the provided converter does not support the property's type");
+
+ _dataBindingRegistrations.Add(new DataBindingRegistration(this, propertyInfo, converter));
}
- ///
- /// Registers the provided property to be available for data binding using a data binding property of type
- ///
- ///
- /// The type of data binding property to use
- /// The name of the property
- ///
- public TD RegisterDataBindingProperty| (string propertyName, IDataBindingConverter converter) where TD : BaseDataBindingProperty
- {
- var property = typeof(T).GetProperty(propertyName);
- if (property == null)
- {
- throw new ArtemisCoreException($"Cannot register data binding property for property {propertyName} " +
- $"because it does not exist on type {typeof(T).Name}");
- }
-
- // Create an instance of the converter
- var dataBindingOperator = (TD) Activator.CreateInstance(typeof(TD), property);
- if (dataBindingOperator == null)
- throw new ArtemisCoreException($"Cannot register data binding, failed to create an instance of {typeof(TD).Name}");
- if (dataBindingOperator.PropertyType != property.PropertyType)
- {
- throw new ArtemisCoreException($"Cannot register data binding property for property {propertyName} using a {typeof(TD).Name} " +
- $"because it does not support type {typeof(T).Name}");
- }
-
- AddDataBindingConverter(dataBindingOperator);
-
- return dataBindingOperator;
- }
-
private void UpdateDataBindings(double deltaTime)
{
foreach (var dataBinding in DataBindings)
diff --git a/src/Artemis.Core/Models/Profile/LayerProperties/Types/ColorGradientLayerProperty.cs b/src/Artemis.Core/Models/Profile/LayerProperties/Types/ColorGradientLayerProperty.cs
index 073f17462..ab5d5a91c 100644
--- a/src/Artemis.Core/Models/Profile/LayerProperties/Types/ColorGradientLayerProperty.cs
+++ b/src/Artemis.Core/Models/Profile/LayerProperties/Types/ColorGradientLayerProperty.cs
@@ -11,11 +11,15 @@ namespace Artemis.Core
DataBindingsSupported = false;
}
+ ///
+ /// Implicitly converts an to a
+ ///
public static implicit operator ColorGradient(ColorGradientLayerProperty p)
{
return p.CurrentValue;
}
+ ///
protected override void UpdateCurrentValue(float keyframeProgress, float keyframeProgressEased)
{
throw new ArtemisCoreException("Color Gradients do not support keyframes.");
diff --git a/src/Artemis.Core/Models/Profile/LayerProperties/Types/EnumLayerProperty.cs b/src/Artemis.Core/Models/Profile/LayerProperties/Types/EnumLayerProperty.cs
index 97b8ff3d5..eb99a3b3e 100644
--- a/src/Artemis.Core/Models/Profile/LayerProperties/Types/EnumLayerProperty.cs
+++ b/src/Artemis.Core/Models/Profile/LayerProperties/Types/EnumLayerProperty.cs
@@ -5,22 +5,29 @@ namespace Artemis.Core
///
public class EnumLayerProperty : LayerProperty where T : Enum
{
- public EnumLayerProperty()
+ internal EnumLayerProperty()
{
KeyframesSupported = false;
DataBindingsSupported = false;
}
+ ///
+ /// Implicitly converts an to a
+ ///
public static implicit operator T(EnumLayerProperty p)
{
return p.CurrentValue;
}
+ ///
+ /// Implicitly converts an to an
+ ///
public static implicit operator int(EnumLayerProperty p)
{
return Convert.ToInt32(p.CurrentValue);
}
+ ///
protected override void UpdateCurrentValue(float keyframeProgress, float keyframeProgressEased)
{
throw new ArtemisCoreException("Enum properties do not support keyframes.");
diff --git a/src/Artemis.Core/Models/Profile/LayerProperties/Types/FloatLayerProperty.cs b/src/Artemis.Core/Models/Profile/LayerProperties/Types/FloatLayerProperty.cs
index 3ec2efd90..e425154cd 100644
--- a/src/Artemis.Core/Models/Profile/LayerProperties/Types/FloatLayerProperty.cs
+++ b/src/Artemis.Core/Models/Profile/LayerProperties/Types/FloatLayerProperty.cs
@@ -5,18 +5,26 @@
{
internal FloatLayerProperty()
{
+ RegisterDataBindingProperty(value => value, new FloatDataBindingConverter());
}
+ ///
+ /// Implicitly converts an to a
+ ///
public static implicit operator float(FloatLayerProperty p)
{
return p.CurrentValue;
}
+ ///
+ /// Implicitly converts an to a
+ ///
public static implicit operator double(FloatLayerProperty p)
{
return p.CurrentValue;
}
+ ///
protected override void UpdateCurrentValue(float keyframeProgress, float keyframeProgressEased)
{
var diff = NextKeyframe.Value - CurrentKeyframe.Value;
diff --git a/src/Artemis.Core/Models/Profile/LayerProperties/Types/IntLayerProperty.cs b/src/Artemis.Core/Models/Profile/LayerProperties/Types/IntLayerProperty.cs
index 16600970b..db567e619 100644
--- a/src/Artemis.Core/Models/Profile/LayerProperties/Types/IntLayerProperty.cs
+++ b/src/Artemis.Core/Models/Profile/LayerProperties/Types/IntLayerProperty.cs
@@ -7,23 +7,34 @@ namespace Artemis.Core
{
internal IntLayerProperty()
{
+ RegisterDataBindingProperty(value => value, new IntDataBindingConverter());
}
+ ///
+ /// Implicitly converts an to an
+ ///
public static implicit operator int(IntLayerProperty p)
{
return p.CurrentValue;
}
+ ///
+ /// Implicitly converts an to a
+ ///
public static implicit operator float(IntLayerProperty p)
{
return p.CurrentValue;
}
+ ///
+ /// Implicitly converts an to a
+ ///
public static implicit operator double(IntLayerProperty p)
{
return p.CurrentValue;
}
+ ///
protected override void UpdateCurrentValue(float keyframeProgress, float keyframeProgressEased)
{
var diff = NextKeyframe.Value - CurrentKeyframe.Value;
diff --git a/src/Artemis.Core/Models/Profile/LayerProperties/Types/LayerBrushReferenceLayerProperty.cs b/src/Artemis.Core/Models/Profile/LayerProperties/Types/LayerBrushReferenceLayerProperty.cs
index cebc0b1d7..04eb19730 100644
--- a/src/Artemis.Core/Models/Profile/LayerProperties/Types/LayerBrushReferenceLayerProperty.cs
+++ b/src/Artemis.Core/Models/Profile/LayerProperties/Types/LayerBrushReferenceLayerProperty.cs
@@ -11,11 +11,15 @@
DataBindingsSupported = false;
}
+ ///
+ /// Implicitly converts an to an
+ ///
public static implicit operator LayerBrushReference(LayerBrushReferenceLayerProperty p)
{
return p.CurrentValue;
}
+ ///
protected override void UpdateCurrentValue(float keyframeProgress, float keyframeProgressEased)
{
throw new ArtemisCoreException("Layer brush references do not support keyframes.");
diff --git a/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKColorLayerProperty.cs b/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKColorLayerProperty.cs
index e9c289e75..dc9032d9a 100644
--- a/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKColorLayerProperty.cs
+++ b/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKColorLayerProperty.cs
@@ -1,5 +1,4 @@
-using System;
-using SkiaSharp;
+using SkiaSharp;
namespace Artemis.Core
{
@@ -8,11 +7,11 @@ namespace Artemis.Core
{
internal SKColorLayerProperty()
{
- RegisterDataBindingProperty(color => color.Alpha, new SKColorDataBindingConverter(SKColorDataBindingConverter.Channel.Alpha));
- RegisterDataBindingProperty(color => color.Red, new SKColorDataBindingConverter(SKColorDataBindingConverter.Channel.Red));
- RegisterDataBindingProperty(color => color.Green, new SKColorDataBindingConverter(SKColorDataBindingConverter.Channel.Green));
- RegisterDataBindingProperty(color => color.Blue, new SKColorDataBindingConverter(SKColorDataBindingConverter.Channel.Blue));
- RegisterDataBindingProperty(color => color.Hue, new SKColorDataBindingConverter(SKColorDataBindingConverter.Channel.Hue));
+ RegisterDataBindingProperty(color => color.Alpha, new SKColorPartDataBindingConverter(SKColorPartDataBindingConverter.Channel.Alpha));
+ RegisterDataBindingProperty(color => color.Red, new SKColorPartDataBindingConverter(SKColorPartDataBindingConverter.Channel.Red));
+ RegisterDataBindingProperty(color => color.Green, new SKColorPartDataBindingConverter(SKColorPartDataBindingConverter.Channel.Green));
+ RegisterDataBindingProperty(color => color.Blue, new SKColorPartDataBindingConverter(SKColorPartDataBindingConverter.Channel.Blue));
+ RegisterDataBindingProperty(color => color.Hue, new SKColorPartDataBindingConverter(SKColorPartDataBindingConverter.Channel.Hue));
}
///
@@ -31,83 +30,4 @@ namespace Artemis.Core
CurrentValue = CurrentKeyframe.Value.Interpolate(NextKeyframe.Value, keyframeProgressEased);
}
}
-
- internal class SKColorDataBindingConverter : IDataBindingConverter
- {
- private readonly Channel _channel;
-
- public SKColorDataBindingConverter(Channel channel)
- {
- _channel = channel;
- }
-
- public BaseLayerProperty BaseLayerProperty { get; set; }
-
- public object Sum(object a, object b)
- {
- return (float) a + (float) b;
- }
-
- public object Interpolate(object a, object b, float progress)
- {
- var diff = (float) b - (float) a;
- return diff * progress;
- }
-
- public void ApplyValue(object value)
- {
- var property = (SKColorLayerProperty) BaseLayerProperty;
- switch (_channel)
- {
- case Channel.Alpha:
- property.CurrentValue = property.CurrentValue.WithAlpha((byte) value);
- break;
- case Channel.Red:
- property.CurrentValue = property.CurrentValue.WithRed((byte) value);
- break;
- case Channel.Green:
- property.CurrentValue = property.CurrentValue.WithGreen((byte) value);
- break;
- case Channel.Blue:
- property.CurrentValue = property.CurrentValue.WithBlue((byte) value);
- break;
- case Channel.Hue:
- property.CurrentValue.ToHsv(out var h, out var s, out var v);
- property.CurrentValue = SKColor.FromHsv((float) value, s, v);
- break;
- default:
- throw new ArgumentOutOfRangeException();
- }
- }
-
- public object GetValue()
- {
- var property = (SKColorLayerProperty) BaseLayerProperty;
- switch (_channel)
- {
- case Channel.Alpha:
- return property.CurrentValue.Alpha;
- case Channel.Red:
- return property.CurrentValue.Red;
- case Channel.Green:
- return property.CurrentValue.Green;
- case Channel.Blue:
- return property.CurrentValue.Blue;
- case Channel.Hue:
- property.CurrentValue.ToHsv(out var h, out _, out _);
- return h;
- default:
- throw new ArgumentOutOfRangeException();
- }
- }
-
- public enum Channel
- {
- Alpha,
- Red,
- Green,
- Blue,
- Hue
- }
- }
}
\ No newline at end of file
diff --git a/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKPointLayerProperty.cs b/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKPointLayerProperty.cs
index 75c0a934c..30194bfac 100644
--- a/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKPointLayerProperty.cs
+++ b/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKPointLayerProperty.cs
@@ -1,7 +1,4 @@
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using SkiaSharp;
+using SkiaSharp;
namespace Artemis.Core
{
@@ -10,8 +7,10 @@ namespace Artemis.Core
{
internal SKPointLayerProperty()
{
+ RegisterDataBindingProperty(point => point.X, new FloatDataBindingConverter());
+ RegisterDataBindingProperty(point => point.Y, new FloatDataBindingConverter());
}
-
+
///
/// Implicitly converts an to an
///
diff --git a/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKSizeLayerProperty.cs b/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKSizeLayerProperty.cs
index 5db8b2a35..59504ca18 100644
--- a/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKSizeLayerProperty.cs
+++ b/src/Artemis.Core/Models/Profile/LayerProperties/Types/SKSizeLayerProperty.cs
@@ -1,7 +1,4 @@
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using SkiaSharp;
+using SkiaSharp;
namespace Artemis.Core
{
@@ -10,6 +7,8 @@ namespace Artemis.Core
{
internal SKSizeLayerProperty()
{
+ RegisterDataBindingProperty(size => size.Width, new FloatDataBindingConverter());
+ RegisterDataBindingProperty(size => size.Height, new FloatDataBindingConverter());
}
///
|