CompositionPage.axaml.cs 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. using System;
  2. using System.Collections.Generic;
  3. using Avalonia;
  4. using Avalonia.Controls;
  5. using Avalonia.Markup.Xaml;
  6. using Avalonia.Media;
  7. using Avalonia.Rendering.Composition;
  8. using Avalonia.Rendering.Composition.Animations;
  9. using Avalonia.VisualTree;
  10. namespace ControlCatalog.Pages;
  11. public partial class CompositionPage : UserControl
  12. {
  13. private ImplicitAnimationCollection? _implicitAnimations;
  14. public CompositionPage()
  15. {
  16. AvaloniaXamlLoader.Load(this);
  17. }
  18. protected override void OnAttachedToVisualTree(VisualTreeAttachmentEventArgs e)
  19. {
  20. base.OnAttachedToVisualTree(e);
  21. this.Get<ItemsControl>("Items").Items = CompositionPage.CreateColorItems();
  22. }
  23. private static List<CompositionPageColorItem> CreateColorItems()
  24. {
  25. var list = new List<CompositionPageColorItem>();
  26. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 255, 185, 0)));
  27. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 231, 72, 86)));
  28. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 0, 120, 215)));
  29. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 0, 153, 188)));
  30. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 122, 117, 116)));
  31. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 118, 118, 118)));
  32. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 255, 141, 0)));
  33. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 232, 17, 35)));
  34. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 0, 99, 177)));
  35. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 45, 125, 154)));
  36. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 93, 90, 88)));
  37. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 76, 74, 72)));
  38. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 247, 99, 12)));
  39. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 234, 0, 94)));
  40. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 142, 140, 216)));
  41. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 0, 183, 195)));
  42. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 104, 118, 138)));
  43. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 105, 121, 126)));
  44. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 202, 80, 16)));
  45. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 195, 0, 82)));
  46. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 107, 105, 214)));
  47. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 3, 131, 135)));
  48. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 81, 92, 107)));
  49. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 74, 84, 89)));
  50. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 218, 59, 1)));
  51. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 227, 0, 140)));
  52. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 135, 100, 184)));
  53. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 0, 178, 148)));
  54. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 86, 124, 115)));
  55. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 100, 124, 100)));
  56. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 239, 105, 80)));
  57. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 191, 0, 119)));
  58. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 116, 77, 169)));
  59. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 1, 133, 116)));
  60. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 72, 104, 96)));
  61. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 82, 94, 84)));
  62. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 209, 52, 56)));
  63. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 194, 57, 179)));
  64. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 177, 70, 194)));
  65. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 0, 204, 106)));
  66. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 73, 130, 5)));
  67. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 132, 117, 69)));
  68. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 255, 67, 67)));
  69. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 154, 0, 137)));
  70. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 136, 23, 152)));
  71. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 16, 137, 62)));
  72. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 16, 124, 16)));
  73. list.Add(new CompositionPageColorItem(Color.FromArgb(255, 126, 115, 95)));
  74. return list;
  75. }
  76. private void EnsureImplicitAnimations()
  77. {
  78. if (_implicitAnimations == null)
  79. {
  80. var compositor = ElementComposition.GetElementVisual(this)!.Compositor;
  81. var offsetAnimation = compositor.CreateVector3KeyFrameAnimation();
  82. offsetAnimation.Target = "Offset";
  83. offsetAnimation.InsertExpressionKeyFrame(1.0f, "this.FinalValue");
  84. offsetAnimation.Duration = TimeSpan.FromMilliseconds(400);
  85. var rotationAnimation = compositor.CreateScalarKeyFrameAnimation();
  86. rotationAnimation.Target = "RotationAngle";
  87. rotationAnimation.InsertKeyFrame(.5f, 0.160f);
  88. rotationAnimation.InsertKeyFrame(1f, 0f);
  89. rotationAnimation.Duration = TimeSpan.FromMilliseconds(400);
  90. var animationGroup = compositor.CreateAnimationGroup();
  91. animationGroup.Add(offsetAnimation);
  92. animationGroup.Add(rotationAnimation);
  93. _implicitAnimations = compositor.CreateImplicitAnimationCollection();
  94. _implicitAnimations["Offset"] = animationGroup;
  95. }
  96. }
  97. public static void SetEnableAnimations(Border border, bool value)
  98. {
  99. var page = border.FindAncestorOfType<CompositionPage>();
  100. if (page == null)
  101. {
  102. border.AttachedToVisualTree += delegate { SetEnableAnimations(border, true); };
  103. return;
  104. }
  105. if (ElementComposition.GetElementVisual(page) == null)
  106. return;
  107. page.EnsureImplicitAnimations();
  108. if (border.GetVisualParent() is Visual visualParent
  109. && ElementComposition.GetElementVisual(visualParent) is CompositionVisual compositionVisual)
  110. {
  111. compositionVisual.ImplicitAnimations = page._implicitAnimations;
  112. }
  113. }
  114. }
  115. public class CompositionPageColorItem
  116. {
  117. public Color Color { get; private set; }
  118. public SolidColorBrush ColorBrush
  119. {
  120. get { return new SolidColorBrush(Color); }
  121. }
  122. public String ColorHexValue
  123. {
  124. get { return Color.ToString().Substring(3).ToUpperInvariant(); }
  125. }
  126. public CompositionPageColorItem(Color color)
  127. {
  128. Color = color;
  129. }
  130. }