zoukankan      html  css  js  c++  java
  • WPF学习(四) 样式 【小达原创】

    wpf这门编写winform程序的技术相比常规的winform技术有一个很显著的特点——

    怎么才能炫起来呢?

    我们都知道常规的winform技术就是拖控件,总的来说想用常规的winform技术来实现很好看的界面很难。

    但是wpf就可以实现起来很轻松。

    有过web知识的童鞋很好理解,咱们看到的网站大部分都比winfrom好看的多,为啥?

    因为里面所有的控件都是程序人员拿HTML编写的,编程人员可以自由的定义控件的样式。我们的WPF一样可以轻松的定义控件的样式。

    下面我们一起来体验一下:

    我们建立一个WFP项目,打开它的MainWindow.xaml窗体文件:

    加入一个按钮标签:

     <Button>提交</Button>

    运行结果……

    大家看到了这个按钮扩充到了整个窗体大小(如果你的控件没有定义大小,它就会自己填充满它所在的容器)。

    接下来我为按钮写一个Style,在项目中新建一个Style文件夹。在Style文件夹处右键添加新项,选择资源词典:

    打开我们添加的资源词典:

    然后再添加一个资源词典。改一下名字,叫Index.xaml

    wpf这门技术是这样的:把所有的资源词典都配置在Index.xaml资源词典文件中,然后将Index.xaml资源词典文件配置在项目的App.xaml文件中,这样项目中所有的资源都可以在项目中引用了

    PS:就不用单个窗体配置资源词典了。(将资源公开化)

    我们在Dictionary1.xaml文件中键入一个Button的样式:

    <Style x:Key="m_Btn" TargetType="{x:Type Button}">
    <Setter Property="Width" Value="40"></Setter>
    <Setter Property="Height" Value="20"></Setter>
    <Setter Property="HorizontalAlignment" Value="Center"></Setter>
    <Setter Property="VerticalAlignment" Value="Center"></Setter>
    <Setter Property="Template">
    <Setter.Value>
    <ControlTemplate TargetType="Button">
    <Image Source="/Bind;Component/Images/4.png"></Image>
    </ControlTemplate>
    </Setter.Value>
    </Setter>
    </Style>

    下面我们解释下上面的样式:

    1、

    <Style x:Key="m_Btn" TargetType="{x:Type Button}">这一句中的x:Key="m_Btn"的意思是给这个样式起一个名字。以后控件要用这个样式直接将m_Btn这个名字付给控件就好了。

    TargetType="{x:Type Button}"这一句的意思是什么类型的控件可以用这个样式。

    2、

    <Setter Property="" Value=""></Setter>这一句的意思是设置Property属性,属性的值是Value。

    3、

    <Setter Property="Template">
    <Setter.Value>
    <ControlTemplate TargetType="Button">
    <Image Source="/Bind;Component/Images/4.png"></Image>
    </ControlTemplate>
    </Setter.Value>
    </Setter>

    这一段的意思是设置属性Template,为什么他的value没有跟在后面反而又写了一行呢?

    因为它的value值比较复杂,一行装不下。

    <ControlTemplate TargetType="Button">这就是属性Template的value值(一个ControlTemplate ),它的内容是一个Image图片标签,大家注意下Image标签Source属性的值:/Bind;Component/Images/4.png,这是wpf种相对路径的写法——(/项目名称;Component/url)

    好了,我们在Dictionary1.xaml文件中写好了一个button的样式,将它放入Index.axml中:

    在Index.xaml中键入 

    <ResourceDictionary.MergedDictionaries>
    <ResourceDictionary Source="/Bind;Component/Style/Dictionary1.xaml"></ResourceDictionary>
    </ResourceDictionary.MergedDictionaries>

    再将Index.xaml配置在APP.xaml中:

    <ResourceDictionary>
    <ResourceDictionary.MergedDictionaries>
    <ResourceDictionary Source=""/Bind;Component/Style/Index.xaml">
    </ResourceDictionary.MergedDictionaries>
    </ResourceDictionary>

    至此我们完成了一个常规的资源词典的引用方式。如果有更多的资源字典,直接配置在Index.axml文件中,这样整个项目都可以应用你所定义的样式了。

    下面,我们将写好的样式应用于BUtton.打开MainWindow.xaml文件,修改Button标签为:

    <Button Style="{StaticResource m_Btn}" Click="Button_Click">提交</Button>

    后台添加Button的单击事件的处理方法:

    private void Button_Click(object sender, RoutedEventArgs e)
    {
    MessageBox.Show("豪车");
    }

    运行程序,单击豪车的图片(其实就是按钮):

    好了,一个简单的带有样式的按钮程序我们就写好了,是不是比传统的按钮要好看很多……

  • 相关阅读:
    POJ2481(树状数组:统计数字 出现个数)
    jenkins(2)-linux环境下jenkins启动/重启/停止命令
    jenkins(1)-部分插件由于缺少依赖无法加载。要恢复这些插件提供的功能,需要修复这些问题并重启Jenkins的解决办法
    linux(4)-rpm包安装
    charles(2)-charles如何打断点,修改Request数据
    charles(1)-charles如何打断点,修改Response数据
    linux(3)-普通用户如何切换到root
    jmeter(51) Groovy脚本高级实战
    jmeter(49)-jenkins+ant+jmeter持续集成接口自动化测试-(linux环境)
    Codeforces Round #545 (Div. 2)D(KMP,最长公共前后缀,贪心)
  • 原文地址:https://www.cnblogs.com/JK1989/p/6958078.html
Copyright © 2011-2022 走看看