我正在尝试在xaml工具包中实现Material Design并收到此错误
The name "XamlDisplay" does not exist in the namespace "clr-namespace:ShowMeTheXAML;assembly=ShowMeTheXAML"
我只是复制并粘贴了官方文档中的这段代码
Xaml code
我尝试了此处Other Question on StackOverflow提供的解决方案,例如将Debug更改为Release模式,清理shadowCache和DLL文件权限。
但是这些都是技巧,不是可靠的答案,对我没用。
怎么了?
我的Xaml代码
<Window x:Class="MaterialTestApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:MaterialTestApp"
mc:Ignorable="d"
xmlns:smtx="clr-namespace:ShowMeTheXAML;assembly=ShowMeTheXAML"
xmlns:materialDesign="http://materialdesigninxaml.net/winfx/xaml/themes"
TextElement.Foreground="{DynamicResource MaterialDesignBody}"
TextElement.FontWeight="Regular"
TextElement.FontSize="13"
TextOptions.TextFormattingMode="Ideal"
TextOptions.TextRenderingMode="Auto"
Background="{DynamicResource MaterialDesignPaper}"
FontFamily="{DynamicResource MaterialDesignFont}">
<Grid>
<StackPanel Margin="8 8 0 0">
<TextBlock>Raised controls have default shadows set, but the shadows can be overriden.</TextBlock>
<StackPanel Orientation="Horizontal" Margin="0 32 0 0">
<smtx:XamlDisplay Key="shadow_1">
<Button Style="{DynamicResource MaterialDesignRaisedButton}"
>DEPTH 1</Button>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_2" Margin="16 0 0 0">
<Button Style="{DynamicResource MaterialDesignRaisedButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth2"
>DEPTH 2</Button>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_3" Margin="16 0 0 0">
<Button Style="{DynamicResource MaterialDesignRaisedButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth3"
>DEPTH 3</Button>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_4" Margin="16 0 0 0">
<Button Style="{DynamicResource MaterialDesignRaisedButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth4"
>DEPTH 4</Button>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_5" Margin="16 0 0 0">
<Button Style="{DynamicResource MaterialDesignRaisedButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth5"
>DEPTH 5</Button>
</smtx:XamlDisplay>
</StackPanel>
<StackPanel Orientation="Horizontal" Margin="0 32 0 0">
<smtx:XamlDisplay Key="shadow_6">
<Button Style="{DynamicResource MaterialDesignFloatingActionMiniButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth1"
>1</Button>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_7" Margin="16 0 0 0">
<Button Style="{DynamicResource MaterialDesignFloatingActionMiniButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth2"
>2</Button>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_8" Margin="16 0 0 0">
<Button Style="{DynamicResource MaterialDesignFloatingActionMiniButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth3"
>3</Button>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_9" Margin="16 0 0 0">
<Button Style="{DynamicResource MaterialDesignFloatingActionMiniButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth4"
>4</Button>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_10" Margin="16 0 0 0">
<Button Style="{DynamicResource MaterialDesignFloatingActionMiniButton}"
materialDesign:ShadowAssist.ShadowDepth="Depth5"
>5</Button>
</smtx:XamlDisplay>
</StackPanel>
<StackPanel Orientation="Horizontal" Margin="0 32 0 0">
<smtx:XamlDisplay Key="shadow_11">
<materialDesign:Card materialDesign:ShadowAssist.ShadowDepth="Depth1" Padding="32">DEPTH 1</materialDesign:Card>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_12" Margin="16 0 0 0">
<materialDesign:Card materialDesign:ShadowAssist.ShadowDepth="Depth2" Padding="32">DEPTH 2</materialDesign:Card>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_13" Margin="16 0 0 0">
<materialDesign:Card materialDesign:ShadowAssist.ShadowDepth="Depth3" Padding="32">DEPTH 3</materialDesign:Card>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_14" Margin="16 0 0 0">
<materialDesign:Card materialDesign:ShadowAssist.ShadowDepth="Depth4" Padding="32">DEPTH 4</materialDesign:Card>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_15" Margin="16 0 0 0">
<materialDesign:Card materialDesign:ShadowAssist.ShadowDepth="Depth5" Padding="32">DEPTH 5</materialDesign:Card>
</smtx:XamlDisplay>
</StackPanel>
<StackPanel Orientation="Horizontal" Margin="0 32 0 0">
<smtx:XamlDisplay Key="shadow_16">
<materialDesign:Card materialDesign:ShadowAssist.ShadowDepth="Depth3" materialDesign:ShadowAssist.ShadowEdges="Bottom,Right" Padding="32">CUSTOM CLIP</materialDesign:Card>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_17" Margin="16 0 0 0">
<materialDesign:Card materialDesign:ShadowAssist.ShadowDepth="Depth3" materialDesign:ShadowAssist.ShadowEdges="Top" Padding="32">CUSTOM CLIP</materialDesign:Card>
</smtx:XamlDisplay>
<smtx:XamlDisplay Key="shadow_18" Margin="16 0 0 0">
<materialDesign:Card materialDesign:ShadowAssist.ShadowDepth="Depth3" materialDesign:ShadowAssist.ShadowEdges="Bottom,Left" Padding="32">CUSTOM CLIP</materialDesign:Card>
</smtx:XamlDisplay>
</StackPanel>
</StackPanel>
</Grid>
应用程式
<Application x:Class="Test_App.App"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:Test_App"
StartupUri="MainWindow.xaml">
<Application.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Light.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Defaults.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignColors;component/Themes/Recommended/Primary/MaterialDesignColor.DeepPurple.xaml" />
<ResourceDictionary Source="pack://application:,,,/MaterialDesignColors;component/Themes/Recommended/Accent/MaterialDesignColor.Lime.xaml" />
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</Application.Resources>
最佳答案
我是ShowMeTheXaml的作者。该项目的目的是使MaterialDesignInXAML(MDIX)中的演示应用程序具有显示MDIX控件和样式的相应XAML的功能。除非您希望在应用程序中具有相同的功能(非常不可能),否则可以从项目中删除ShowMeTheXaml。至于您的xaml,您只需删除<smtx:XamlDisplay>
标记并保留内容即可。