【发布时间】:2019-06-19 03:25:39
【问题描述】:
我正在尝试让 Fluent Design 在我的 Xamarin.Forms UWP 应用上运行。我尝试了使用渲染器、覆盖样式的不同方法,但它们都不起作用。
丙烯酸笔刷总是回退到 FallbackColor。
设置:
目标版本:Windows 10 (1803) 最低版本:Windows 10 Fall Creators Update(16299)。
我也在检查
Windows.Foundation.Metadata.ApiInformation.IsTypePresent("Windows.UI.Xaml.Media.AcrylicBrush") 可用。
使用任何预定义的 Acrylic 画笔都会导致“找不到具有名称/键 SystemControlChromeLowAcrylicWindowBrush 的资源”。
AcrylicBrush 和 Splitview 样式:
<media:AcrylicBrush x:Key="HostBackdropBrush"
BackgroundSource="HostBackdrop"
TintColor="White"
TintOpacity="0.4"
FallbackColor="WhiteSmoke" />
<Style TargetType="SplitView">
<Setter Property="HorizontalContentAlignment" Value="Stretch"/>
<Setter Property="VerticalContentAlignment" Value="Stretch"/>
<Setter Property="OpenPaneLength" Value="{ThemeResource SplitViewOpenPaneThemeLength}"/>
<Setter Property="CompactPaneLength" Value="{ThemeResource SplitViewCompactPaneThemeLength}"/>
<Setter Property="PaneBackground" Value="{StaticResource HostBackdropBrush}"/>
</Style>
自定义渲染器:
[assembly: ExportRenderer(typeof(MasterPage), typeof(MasterPageRenderer))]
namespace MasterDetailPageNavigation.UWP
{
class MasterPageRenderer : PageRenderer
{
protected override void OnElementChanged(ElementChangedEventArgs<Page> e)
{
base.OnElementChanged(e);
if (e.OldElement != null || Element == null)
{
return;
}
try
{
if (Windows.Foundation.Metadata.ApiInformation.IsTypePresent("Windows.UI.Xaml.Media.XamlCompositionBrushBase"))
{
Windows.UI.Xaml.Media.AcrylicBrush myBrush = new Windows.UI.Xaml.Media.AcrylicBrush();
myBrush.BackgroundSource = Windows.UI.Xaml.Media.AcrylicBackgroundSource.HostBackdrop;
myBrush.TintColor = Windows.UI.Color.FromArgb(255, 200, 200, 200);
myBrush.TintOpacity = 0.2;
Background = myBrush;
}
else
{
SolidColorBrush myBrush = new SolidColorBrush(Windows.UI.Color.FromArgb(255, 240, 240, 240));
Background = myBrush;
}
}
catch (Exception ex)
{
System.Diagnostics.Debug.WriteLine(ex);
}
}
protected override Windows.Foundation.Size ArrangeOverride(Windows.Foundation.Size finalSize)
{
return base.ArrangeOverride(finalSize);
}
}
}
```
【问题讨论】:
-
请看一下这个项目:stackoverflow.com/a/13563083/4373895
-
谢谢!这解决了我的问题!你能回答一下,我可以奖励你吗?
-
当然 iNCEPTION_ 这是个好消息
标签: c# xamarin.forms uwp xamarin.uwp