CurveBounds.cs
2.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/******************************************************************************
* Copyright (C) Leap Motion, Inc. 2011-2017. *
* Leap Motion proprietary and confidential. *
* *
* Use subject to the terms of the Leap Motion SDK Agreement available at *
* https://developer.leapmotion.com/sdk_agreement, or another agreement *
* between Leap Motion and you, your company or other organization. *
******************************************************************************/
using System.Collections.Generic;
#if UNITY_EDITOR
using UnityEditor;
#endif
using UnityEngine;
namespace Leap.Unity.Attributes {
/// <summary>
/// You can use this attribute to mark that an AnimationCurve can only have
/// values that fall within specific bounds. The user will be prevented from
/// entering a curve that lies outside of these bounds.
/// </summary>
public class CurveBoundsAttribute : CombinablePropertyAttribute, IFullPropertyDrawer {
public readonly Rect bounds;
public CurveBoundsAttribute(Rect bounds) {
this.bounds = bounds;
}
public CurveBoundsAttribute(float width, float height) {
bounds = new Rect(0, 0, width, height);
}
#if UNITY_EDITOR
public void DrawProperty(Rect rect, SerializedProperty property, GUIContent label) {
EditorGUI.CurveField(rect, property, Color.green, bounds);
}
public override IEnumerable<SerializedPropertyType> SupportedTypes {
get {
yield return SerializedPropertyType.AnimationCurve;
}
}
#endif
}
/// <summary>
/// You can use this attribute to mark that an AnimationCurve can only have values
/// that range from 0 to 1. The user will be prevented from entering a curve that
/// lies outside of these bounds.
/// </summary>
public class UnitCurveAttribute : CurveBoundsAttribute {
public UnitCurveAttribute() : base(new Rect(0, 0, 1, 1)) { }
}
}