Настройка стиля WinUI ProgressRing недоступна в WASM с Uno 2.4 - PullRequest
0 голосов
/ 26 мая 2020

Я знаю глобальное изменение цвета темы с помощью способа привязки шаблона еще не поддерживается в Uno. (Я пробовал это для ToggleSwitch, теперь собственный стиль ToggleSwitch отлично работает как в UWP, так и в WASM). Таким же образом я подготовил собственный стиль для WinUI 2.4 ProgressRing. Я собрал стиль ProgressRing по умолчанию из репозитория WinUI Github и настроил его:

 <!-- Default style for Microsoft.UI.Xaml.Controls.ProgressRing -->
            <Style x:Key="AcmProgressRing" TargetType="controls:ProgressRing">
                <Setter Property="Foreground" Value="{StaticResource AcmPink}" />
                <Setter Property="Background" Value="{StaticResource AcmPurple}" />
                <Setter Property="IsHitTestVisible" Value="False" />
                <Setter Property="HorizontalAlignment" Value="Center" />
                <Setter Property="VerticalAlignment" Value="Center" />
                <Setter Property="MinHeight" Value="16" />
                <Setter Property="MinWidth" Value="16" />
                <Setter Property="IsTabStop" Value="False" />
                <Setter Property="Width" Value="32" />
                <Setter Property="Template">
                    <Setter.Value>
                        <ControlTemplate TargetType="controls:ProgressRing">
                            <Grid x:Name="LayoutRoot" Background="Transparent">
                                <VisualStateManager.VisualStateGroups>
                                    <VisualStateGroup x:Name="CommonStates">
                                        <VisualState x:Name="Active">
                                            <Storyboard>
                                                <DoubleAnimation
                                            Storyboard.TargetName="LayoutRoot"
                                            Storyboard.TargetProperty="Opacity"
                                            To="1"
                                            Duration="0:0:0.15" />
                                            </Storyboard>
                                        </VisualState>
                                        <VisualState x:Name="Inactive">
                                            <Storyboard>
                                                <DoubleAnimation
                                            Storyboard.TargetName="LayoutRoot"
                                            Storyboard.TargetProperty="Opacity"
                                            To="0"
                                            Duration="0" />
                                            </Storyboard>
                                        </VisualState>
                                    </VisualStateGroup>
                                </VisualStateManager.VisualStateGroups>
                                <!-- AnimatedVisualPlayer for Lottie -->
                                <controls:AnimatedVisualPlayer x:Name="IndeterminateAnimatedVisualPlayer" AutoPlay="false" Stretch="fill"/>

                            </Grid>
                        </ControlTemplate>
                    </Setter.Value>
                </Setter>
            </Style>

My ProgressRing:

<controls:ProgressRing x:Name="Waiter" Width="50" Height="50" Style="{StaticResource AcmProgressRing}" IsActive="True"/>

Как видите, стиль корректно работает в UWP: enter image description here

Однако WASM показывает стиль по умолчанию: (

enter image description here

Пакеты

  - Uno.UI.RemoteControl {2.4.0}

  - Newtonsoft.Json {12.0.3}

  - Uno.UI.Lottie {2.4.0}

  - Uno.Wasm.Bootstrap {1.2.0}

  - Uno.Wasm.Bootstrap.DevServer {1.2.0}

  - ACM_Search_AdminApps.Shared {1.1.0}

  - Microsoft.Extensions.Logging.Filter {1.1.2}

  - Microsoft.Extensions.Logging.Con... {1.1.1}

  - NETStandard.Library {2.0.3}

   - Uno.UI {2.4.0}

   - ACM_Search_AdminApps.Shared {1.1.0}

  - Microsoft.NETCore.UniversalWindo... {6.2.10}

   - Microsoft.Extensions.Logging.Con... {1.1.1}

  - Microsoft.Extensions.Logging.Filter {1.1.2}

  - Microsoft.Toolkit.Uwp.UI.Lottie {6.0.0}

  - Microsoft.UI.Xaml {2.4.2}

   - Newtonsoft.Json {12.0.3}

  - Uno.Core {2.0.0}

Стиль WinUI ProgressRing в WASM должен совпадать со стилем UWP. Как я могу это исправить? Спасибо.

...