创建一个显示所有预定义WPF颜色的ListBox

原文 Creating a ListBox that Shows All Predefined WPF Colors

在WPF中,您可以使用Colors类访问一系列预定义颜色,这些颜色定义为Colors类的静态属性只需使用颜色名称引用每种颜色。

作为参考,这里是一个小应用程序,显示ListBox中的所有颜色(感谢casperOne,在*文章中展示了如何创建一个封装Colors中属性列表的对象)。

这是最终的结果。(单击图像可查看其全尺寸)。

创建一个显示所有预定义WPF颜色的ListBox

用于生成此列表的XAML非常简单:

<Window
    x:Class="WpfApp5.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:sys="clr-namespace:System;assembly=mscorlib"
    x:Name="Window"
    Title="All Colors"
    Width="800"
    Height="600"
    mc:Ignorable="d">

    <Window.Resources>
        <ObjectDataProvider
            x:Key="colorsTypeOdp"
            MethodName="GetType"
            ObjectType="{x:Type sys:Type}">
            <ObjectDataProvider.MethodParameters>
                <sys:String>
                    System.Windows.Media.Colors, PresentationCore,
                    Version=3.0.0.0, Culture=neutral,
                    PublicKeyToken=31bf3856ad364e35
                </sys:String>
            </ObjectDataProvider.MethodParameters>
        </ObjectDataProvider>

        <ObjectDataProvider
            x:Key="colorPropertiesOdp"
            MethodName="GetProperties"
            ObjectInstance="{StaticResource colorsTypeOdp}" />
    </Window.Resources>

    <ListBox
        ItemsSource="{Binding Source={StaticResource colorPropertiesOdp}}"
        ScrollViewer.HorizontalScrollBarVisibility="Disabled"
        ScrollViewer.VerticalScrollBarVisibility="Auto">
        <ListBox.ItemsPanel>
            <ItemsPanelTemplate>
                <WrapPanel />
            </ItemsPanelTemplate>
        </ListBox.ItemsPanel>
        <ListBox.ItemTemplate>
            <DataTemplate>
                <StackPanel Orientation="Vertical">
                    <Rectangle
                        Width="81"
                        Height="50"
                        Margin="4"
                        Fill="{Binding Path=Name}"
                        Stroke="Black"
                        StrokeThickness="1" />
                    <Label Content="{Binding Path=Name}" />
                </StackPanel>
            </DataTemplate>
        </ListBox.ItemTemplate>
    </ListBox>
</Window>

 

上一篇:【Android开发】经典范例2-仿QQ在状态栏显示登录状态的图标


下一篇:日立数据系统亚太地区年度CIO峰会召开