ventanas tareas restablecer quitar poner inicio iconos configurar como cambiar barra ancladas abajo windows xaml windows-runtime winrt-xaml

tareas - quitar ventanas ancladas windows 10



Estilo de botón en la barra de configuración de la aplicación de tienda de Windows 8 (1)

El problema es que el estilo de botón predeterminado utiliza un primer plano blanco y un pincel de borde, y un pincel de fondo transparente cuando la aplicación utiliza el tema oscuro. En una página, el estilo de botón predeterminado se ve bien:

Sin embargo, en el panel de contenido de Callisto SettingsFlyout, el botón es invisible porque el fondo del panel de contenido es blanco. Debe haberlo notado ya que está configurando las propiedades de primer plano y fondo del botón manualmente en su UserControl.

Una solución es definir un nuevo estilo para botones en SettingsFlyout, trabajando fuera de la plantilla de botón predeterminada para hacerlo. Los estilos predeterminados se encuentran aquí en una máquina de 64 bits:

C:/Program Files (x86)/Windows Kits/8.0/Include/WinRT/Xaml/Design

Encontré el estilo predeterminado para el control Button en default.xaml en esta carpeta.

Primero, copié este estilo predeterminado en un nuevo diccionario de recursos. Configuré App.xaml para hacer referencia a este nuevo diccionario de recursos de esta manera:

<!-- Add this line to your MergedDictionaries in App.xaml --> <ResourceDictionary Source="FlyoutResources.xaml"/>

Con un poco de trabajo, modifiqué el estilo de botón predeterminado copiado y le di una clave única. Aquí está el ejemplo:

<!-- contents of FlyoutResources.xaml --> <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:local="using:App1"> <ResourceDictionary.ThemeDictionaries> <ResourceDictionary x:Key="Default"> <SolidColorBrush x:Key="FlyoutButtonForeground">#FF000000</SolidColorBrush> <SolidColorBrush x:Key="FlyoutButtonBackground">#FFD3D3D3</SolidColorBrush> <SolidColorBrush x:Key="FlyoutButtonBorder">#FF000000</SolidColorBrush> <SolidColorBrush x:Key="FlyoutButtonPointerOverBackgroundThemeBrush" Color="#21D3D3D3" /> <SolidColorBrush x:Key="FlyoutButtonPointerOverForegroundThemeBrush" Color="#FF000000" /> <SolidColorBrush x:Key="FlyoutButtonPressedBackgroundThemeBrush" Color="#FFFFFFFF" /> <SolidColorBrush x:Key="FlyoutButtonPressedForegroundThemeBrush" Color="#FF000000" /> <SolidColorBrush x:Key="FlyoutButtonDisabledBackgroundThemeBrush" Color="#FFD3D3D3" /> <SolidColorBrush x:Key="FlyoutButtonDisabledBorderThemeBrush" Color="#66000000" /> <SolidColorBrush x:Key="FlyoutButtonDisabledForegroundThemeBrush" Color="#66000000" /> </ResourceDictionary> </ResourceDictionary.ThemeDictionaries> <Style TargetType="Button" x:Key="flyoutButton"> <Setter Property="Background" Value="{StaticResource FlyoutButtonBackground}" /> <Setter Property="Foreground" Value="{StaticResource FlyoutButtonForeground}"/> <Setter Property="BorderBrush" Value="{StaticResource FlyoutButtonBorder}" /> <Setter Property="BorderThickness" Value="{StaticResource ButtonBorderThemeThickness}" /> <Setter Property="Padding" Value="12,4,12,4" /> <Setter Property="HorizontalAlignment" Value="Left" /> <Setter Property="VerticalAlignment" Value="Center" /> <Setter Property="FontFamily" Value="{StaticResource ContentControlThemeFontFamily}" /> <Setter Property="FontWeight" Value="SemiBold" /> <Setter Property="FontSize" Value="{StaticResource ControlContentThemeFontSize}" /> <Setter Property="Template"> <Setter.Value> <ControlTemplate TargetType="Button"> <Grid> <VisualStateManager.VisualStateGroups> <VisualStateGroup x:Name="CommonStates"> <VisualState x:Name="Normal" /> <VisualState x:Name="PointerOver"> <Storyboard> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="Border" Storyboard.TargetProperty="Background"> <DiscreteObjectKeyFrame KeyTime="0" Value="{StaticResource FlyoutButtonPointerOverBackgroundThemeBrush}" /> </ObjectAnimationUsingKeyFrames> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="ContentPresenter" Storyboard.TargetProperty="Foreground"> <DiscreteObjectKeyFrame KeyTime="0" Value="{StaticResource FlyoutButtonPointerOverForegroundThemeBrush}" /> </ObjectAnimationUsingKeyFrames> </Storyboard> </VisualState> <VisualState x:Name="Pressed"> <Storyboard> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="Border" Storyboard.TargetProperty="Background"> <DiscreteObjectKeyFrame KeyTime="0" Value="{StaticResource FlyoutButtonPressedBackgroundThemeBrush}" /> </ObjectAnimationUsingKeyFrames> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="ContentPresenter" Storyboard.TargetProperty="Foreground"> <DiscreteObjectKeyFrame KeyTime="0" Value="{StaticResource FlyoutButtonPressedForegroundThemeBrush}" /> </ObjectAnimationUsingKeyFrames> </Storyboard> </VisualState> <VisualState x:Name="Disabled"> <Storyboard> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="Border" Storyboard.TargetProperty="Background"> <DiscreteObjectKeyFrame KeyTime="0" Value="{StaticResource FlyoutButtonDisabledBackgroundThemeBrush}" /> </ObjectAnimationUsingKeyFrames> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="Border" Storyboard.TargetProperty="BorderBrush"> <DiscreteObjectKeyFrame KeyTime="0" Value="{StaticResource FlyoutButtonDisabledBorderThemeBrush}" /> </ObjectAnimationUsingKeyFrames> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="ContentPresenter" Storyboard.TargetProperty="Foreground"> <DiscreteObjectKeyFrame KeyTime="0" Value="{StaticResource FlyoutButtonDisabledForegroundThemeBrush}" /> </ObjectAnimationUsingKeyFrames> </Storyboard> </VisualState> </VisualStateGroup> <VisualStateGroup x:Name="FocusStates"> <VisualState x:Name="Focused"> <Storyboard> <DoubleAnimation Storyboard.TargetName="FocusVisualWhite" Storyboard.TargetProperty="Opacity" To="1" Duration="0" /> <DoubleAnimation Storyboard.TargetName="FocusVisualBlack" Storyboard.TargetProperty="Opacity" To="1" Duration="0" /> </Storyboard> </VisualState> <VisualState x:Name="Unfocused" /> <VisualState x:Name="PointerFocused" /> </VisualStateGroup> </VisualStateManager.VisualStateGroups> <Border x:Name="Border" Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Margin="3"> <ContentPresenter x:Name="ContentPresenter" Content="{TemplateBinding Content}" ContentTransitions="{TemplateBinding ContentTransitions}" ContentTemplate="{TemplateBinding ContentTemplate}" Margin="{TemplateBinding Padding}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" /> </Border> <Rectangle x:Name="FocusVisualWhite" IsHitTestVisible="False" Stroke="{StaticResource FocusVisualWhiteStrokeThemeBrush}" StrokeEndLineCap="Square" StrokeDashArray="1,1" Opacity="0" StrokeDashOffset="1.5" /> <Rectangle x:Name="FocusVisualBlack" IsHitTestVisible="False" Stroke="{StaticResource FocusVisualBlackStrokeThemeBrush}" StrokeEndLineCap="Square" StrokeDashArray="1,1" Opacity="0" StrokeDashOffset="0.5" /> </Grid> </ControlTemplate> </Setter.Value> </Setter> </Style> </ResourceDictionary>

El último paso es establecer ese estilo en las definiciones de los botones XAML:

<Button Name="ChoosePomidoroButton" Content="Choose pomidoro image..." Style="{StaticResource flyoutButton}" /> <!-- etc. -->

Y así es como se ve (el botón del medio está en el estado hover):

Estoy creando la aplicación Windows Store. Yo uso la biblioteca de callisto para crear el menú desplegable en la configuración. Tengo un problema con los botones de diseño. Cuando paso el mouse sobre el fondo y la fuente se vuelve blanca ...

Ver la imagen (el mouse está sobre el segundo botón):

Este es mi archivo XAML:

<UserControl x:Class="Pomidoro.PomidoroUserControl" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:local="using:Pomidoro" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" mc:Ignorable="d" d:DesignHeight="300" d:DesignWidth="400"> <Grid> <StackPanel x:Name="FlyoutContent"> <Button Name="ChoosePomidoroButton" Click="ChoosePomidoroButton_Click" Content="Choose pomidoro image..." Background="LightGray" Foreground="Black" BorderBrush="Black" /> <Button Name="DefaultPomidoroButton" Click="DefaultPomidoroButton_Click" Content="Set default pomidoro image" Background="LightGray" Foreground="Black" BorderBrush="Black" /> </StackPanel> </Grid>

Y así es como creo flyout en App.xaml.cs:

// Add an Pomidoro settings var pomidoro = new SettingsCommand("pomidoro", "Pomidoro image", (handler) => { var settings = new SettingsFlyout(); settings.Content = new PomidoroUserControl(); settings.HeaderText = "Pomidoro"; settings.IsOpen = true; }); args.Request.ApplicationCommands.Add(pomidoro);

Cuando intenté usar estilos predeterminados ...

<Button Name="DefaultPomidoroButton" Click="DefaultPomidoroButton_Click" Content="Set default pomidoro image" />

... fondo, borde y primer plano era blanco ... y el usuario no podía ver nada.

¿Qué debo hacer para aplicar el estilo predeterminado para tener el botón gris (como lo está en muchas aplicaciones en la Tienda)?