Megjegyzés
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhat bejelentkezni vagy módosítani a címtárat.
Az oldalhoz való hozzáféréshez engedély szükséges. Megpróbálhatja módosítani a címtárat.
Ez a témakör a ContextMenu vezérlőelem stílusát és sablonjait ismerteti. Módosíthatja az alapértelmezett ControlTemplate, hogy egyedi megjelenést adjon a vezérlőnek. További információkért lásd: Sablon létrehozása egy vezérlő számára.
Kontextusmenü részei
A ContextMenu vezérlő nem rendelkezik névvel ellátott részekkel.
Ha létrehoz egy ControlTemplate-t egy ContextMenuszámára, a sablon tartalmazhat egy ItemsPresenter-t egy ScrollViewer-ban. (A ItemsPresenter megjeleníti az egyes elemeket a ContextMenu; a ScrollViewer lehetővé teszi a görgetést a vezérlőn belül). Ha a ItemsPresenter nem a ScrollViewerközvetlen gyermeke, akkor a ItemsPresenter-nek meg kell adni a nevet ItemsPresenter.
Kontextusmenü állapotok
Az alábbi táblázat a ContextMenu vezérlőelem vizualizációs állapotát sorolja fel.
| Vizualizációs állapot név | VisualStateGroup név | Leírás |
|---|---|---|
| Érvényes | Érvényesítési állapotok | A vezérlő a Validation osztályt használja, a Validation.HasError csatolt tulajdonság pedig false. |
| Érvénytelen fókusz | Érvényesítési állapotok | A Validation.HasError csatolt tulajdonság azt jelzi, ha a true vezérlő fókuszban van. |
| ÉrvénytelenFókuszálatlan | Érvényesítési állapotok | A Validation.HasError hozzárendelt tulajdonság true azt jelzi, hogy a vezérlő nincs fókuszban. |
Példa a ContextMenu ControlTemplate-hez
Az alábbi példa bemutatja, hogyan definiálhat ControlTemplate a ContextMenu vezérlőelemhez.
<Style TargetType="{x:Type ContextMenu}">
<Setter Property="SnapsToDevicePixels"
Value="True" />
<Setter Property="OverridesDefaultStyle"
Value="True" />
<Setter Property="Grid.IsSharedSizeScope"
Value="true" />
<Setter Property="HasDropShadow"
Value="True" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ContextMenu}">
<Border x:Name="Border"
Background="{StaticResource MenuPopupBrush}"
BorderThickness="1">
<Border.BorderBrush>
<SolidColorBrush Color="{StaticResource BorderMediumColor}" />
</Border.BorderBrush>
<StackPanel IsItemsHost="True"
KeyboardNavigation.DirectionalNavigation="Cycle" />
</Border>
<ControlTemplate.Triggers>
<Trigger Property="HasDropShadow"
Value="true">
<Setter TargetName="Border"
Property="Padding"
Value="0,3,0,3" />
<Setter TargetName="Border"
Property="CornerRadius"
Value="4" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
A ControlTemplate a következő erőforrásokat használja.
<!--Control colors.-->
<Color x:Key="WindowColor">#FFE8EDF9</Color>
<Color x:Key="ContentAreaColorLight">#FFC5CBF9</Color>
<Color x:Key="ContentAreaColorDark">#FF7381F9</Color>
<Color x:Key="DisabledControlLightColor">#FFE8EDF9</Color>
<Color x:Key="DisabledControlDarkColor">#FFC5CBF9</Color>
<Color x:Key="DisabledForegroundColor">#FF888888</Color>
<Color x:Key="SelectedBackgroundColor">#FFC5CBF9</Color>
<Color x:Key="SelectedUnfocusedColor">#FFDDDDDD</Color>
<Color x:Key="ControlLightColor">White</Color>
<Color x:Key="ControlMediumColor">#FF7381F9</Color>
<Color x:Key="ControlDarkColor">#FF211AA9</Color>
<Color x:Key="ControlMouseOverColor">#FF3843C4</Color>
<Color x:Key="ControlPressedColor">#FF211AA9</Color>
<Color x:Key="GlyphColor">#FF444444</Color>
<Color x:Key="GlyphMouseOver">sc#1, 0.004391443, 0.002428215, 0.242281124</Color>
<!--Border colors-->
<Color x:Key="BorderLightColor">#FFCCCCCC</Color>
<Color x:Key="BorderMediumColor">#FF888888</Color>
<Color x:Key="BorderDarkColor">#FF444444</Color>
<Color x:Key="PressedBorderLightColor">#FF888888</Color>
<Color x:Key="PressedBorderDarkColor">#FF444444</Color>
<Color x:Key="DisabledBorderLightColor">#FFAAAAAA</Color>
<Color x:Key="DisabledBorderDarkColor">#FF888888</Color>
<Color x:Key="DefaultBorderBrushDarkColor">Black</Color>
<!--Control-specific resources.-->
<Color x:Key="HeaderTopColor">#FFC5CBF9</Color>
<Color x:Key="DatagridCurrentCellBorderColor">Black</Color>
<Color x:Key="SliderTrackDarkColor">#FFC5CBF9</Color>
<Color x:Key="NavButtonFrameColor">#FF3843C4</Color>
<LinearGradientBrush x:Key="MenuPopupBrush"
EndPoint="0.5,1"
StartPoint="0.5,0">
<GradientStop Color="{DynamicResource ControlLightColor}"
Offset="0" />
<GradientStop Color="{DynamicResource ControlMediumColor}"
Offset="0.5" />
<GradientStop Color="{DynamicResource ControlLightColor}"
Offset="1" />
</LinearGradientBrush>
<LinearGradientBrush x:Key="ProgressBarIndicatorAnimatedFill"
StartPoint="0,0"
EndPoint="1,0">
<LinearGradientBrush.GradientStops>
<GradientStopCollection>
<GradientStop Color="#000000FF"
Offset="0" />
<GradientStop Color="#600000FF"
Offset="0.4" />
<GradientStop Color="#600000FF"
Offset="0.6" />
<GradientStop Color="#000000FF"
Offset="1" />
</GradientStopCollection>
</LinearGradientBrush.GradientStops>
</LinearGradientBrush>
A teljes mintát a ControlTemplates Stílus minta-ban tekintheti meg.
Lásd még
- Style
- ControlTemplate
- Vezérlési stílusok és sablonok
- Irányítás testreszabása
- Stílus és sablonkészítés
- Vezérlőelem- sablonjának létrehozása
.NET Desktop feedback