1.参考:

https://msdn.microsoft.com/zh-cn/library/ms747086(v=vs.110).aspx

http://www.cnblogs.com/cww2010/archive/2012/04/30/2476844.html(系统命名空间中的两个参考)

2.默认命名空间

2.1创建一个WPF应用,默认生成代码:

 <Window x:Class="WpfApplication1.MainWindow"
         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
         Title="MainWindow" Height="350" Width="525">
     <Grid>

     </Grid>
 </Window>

第一个声明将整个 WPF 客户端/框架 XAML 命名空间映射为默认命名空间,包含了所有WPF类,包括用来构建用户界面的控件。该名称空间的声明没有使用名称空间前缀,所以它称为整个文档的默认名称空间,除非另行指明,否则每个元素自动位于这个名称空间:

xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"

第二个声明映射一个单独的 XAML 命名空间,通常将其映射到 x: 前缀。它包含了各种XAML实用特性,这些特性可影响文档的解释方式:

xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"

命名空间的语法格式:xmlns[:可选的映射前缀]="名称空间"

xmlns后可以跟一个可选的映射前缀,之间用冒号分隔,如果没有写可选映射前缀,则意味着所有来自这个命名空间的标签都不用加前缀,该命名空间称作“默认命名空间”,默认命名空间只能有一个。

2.2系统命名空间:

 xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 

xml交互性的命名空间,指明哪些需要处理,哪些可以忽略

 xmlns:d="http://schemas.microsoft.com/expression/blend/2008"

设计时相关的命名空间

2.3引用自定义类

自定义一个Helper类:

 namespace WpfApplication.Helpers
 {
     public static class PasswordHelper
     {
         //代码块
     }
 }

如果引用的类在同一个Project,只需要添加名字空间:

xmlns:local="clr-namespace:WpfApplication.Helpers"

使用方法:

 <PasswordBox x:Name=" 
HorizontalAlignment="Left" local:PasswordHelper.Attach="True" local:PasswordHelper.Password="{Binding Password,Mode=TwoWay}"></PasswordBox>

如果引用的类在另外一个Project,则需要说明Assembly和Namespace

  xmlns:helper="clr-namespace:WpfApplication.Helpers;assembly=WpfApplication"

使用的时候,只需要将local换成helper。

3 程序资源

WPF提供了几个专门使用资源的类,

3.1可以直接使用资源的名称访问资源

方法1:

1    <Button Grid.Row="1" Name="down">
2         <Image Source="Images/Tulips.jpg"></Image>
3    </Button>

方法2:

1 <Button Grid.Row="0" Name="up" Click="up_Click">
2     <Image Name="img"></Image>
3 </Button>

然后在程序中添加资源:

 private void up_Click(object sender, RoutedEventArgs e)
 {
     img.Source = new BitmapImage(new Uri(@"C:\Users\Public\Pictures\Sample Pictures\Koala.jpg"));
 }

或者如下(如此可使用相对路径,但注意反斜杠)

img.Source = new BitmapImage(new Uri("Images/Koala.jpg",UriKind.Relative));

再或者

img.Source = new BitmapImage(new Uri("pack://application:,,,/Images/Koala.jpg"));

注意:当使用绝对URI时,可使用指向程序集资源的文件路径、用于网络共享的UNC路径、Web站点URL以及pack URI。如果应用程序不能从期望的位置检索到资源,就会产生异常。如果URI是使用XAML设置的,那么会在创建页面时产生异常。

3.2位于其他程序集中的资源

使用packURI还可以检索嵌入到另一个库中的资源(换句话说,在应用程序中使用的DLL程序集中的资源)。这种情况下需要使用以下语法:

pack://application:,,,/AssemblyName;component/ResourceName

例如,如果图像被嵌入到引用的名为ImageLibrary的程序集中,将需要使用如下URI:

img.Source = new BitmapImage(new Uri("ImageLibrary;component/images/winter.jpg",UriKind.Relative));

如果使用强命名的程序集,可使用包含版本和/或公钥标记的限定程序集引用代替程序集的名称。使用分号隔离每段信息,并在版本号数字之前添加字母v。下面是一个使用版本号的示例:

img.Source = new BitmapImage(new Uri("ImageLibrary;v1.25;component/images/winter.jpg",UriKind.Relative));

下面的示例同时使用了版本号和公钥标记:

img.Source = new BitmapImage(new Uri("ImageLibrary;v1.25;dc642a7f5bd64912;component/images/winter.jpg",UriKind.Relative));

 4.绑定

4.1元素到元素的绑定

   <!--元素到元素的绑定:ElementName:指示源元素,Path:指示源元素中的属性-->
   <ControlTemplate Background="{Binding ElementName=MainWindow, Path=Background}" />

元素到元素的绑定:

关键字:Binding

Element:指定的源元素

Path:源元素中的属性

Mode:绑定模式(单向,双向)

4.2绑定到非元素的对象

 <ControlTemplate Width="{Binding RelativeSource={RelativeSource Mode=TemplatedParent}, Path=Width}" />

Source:该属性是指向源对象的引用,是提供数据的对象

RelativeSurce:这是引用,使用RelativeSource对象指向源对象。有了这个附加层,可在当前元素(包含绑定表达式的元素)的基础上构建引用。通常用于编写控件模版以及数据模版。

DataContext:如果没有使用Source或RelativeSource属性指定源,WPF就从当前元素开始在元素树中向上查找,检查每个元素的DataContext属性,并使用第一个非空的DataContext属性

4.2.1使用Source属性

绑定到作为资源创建的对象

   <TextBlock Text="{Binding Source={StaticResource CustomFont}, Path=Source}" />

4.2.2使用RelativeSource属性

名称 说明
FindAncesstor 表达式绑定到父元素
Self 表达式绑定到同一元素的另一个属性上
TemplateParent 表达式绑定到应用模版的元素。只有绑定位于控件模版或数据模版内部时,这种模式才能工作

4.2.3使用DataContext属性

WPF之命名空间和资源的更多相关文章

  1. WPF笔记(1.8 资源与映射)——Hello,WPF!

    原文:WPF笔记(1.8 资源与映射)--Hello,WPF! 终于,看明白了,已经是凌晨1:39分.这本书这一节写得实在是不好,一个local搞得我糊里糊涂,于是,准备按照他的思路,按照我的理解,改 ...

  2. WPF之神奇的资源

    原文:WPF之神奇的资源 WPF中的资源有两种,一种称为"程序集资源"(assembly resource),另一种称为"对象资源"(object resour ...

  3. (转)WPF控件开源资源

    (转)WPF控件开源资源 Textbox Drag/Drop in WPFhttp://www.codeproject.com/Articles/42696/Textbox-Drag-Drop-in- ...

  4. WPF中静态引用资源与动态引用资源的区别

    WPF中静态引用资源与动态引用资源的区别   WPF中引用资源分为静态引用与动态引用,两者的区别在哪里呢?我们通过一个小的例子来理解. 点击“Update”按钮,第2个按钮的文字会变成“更上一层楼”, ...

  5. WPF控件开源资源

    (转)WPF控件开源资源 Textbox Drag/Drop in WPFhttp://www.codeproject.com/Articles/42696/Textbox-Drag-Drop-in- ...

  6. WPF中引入外部资源

    有时候需要在WPF中引入外部资源,比如图片.音频.视频等,所以这个常见的技能还是需要GET到. 第一步:在VS中创建一个WPF窗口程序 第二步:从外部引入资源,这里以引入图片资源为例 1)新建Reso ...

  7. WPF 精修篇 管理资源字典

    原文:WPF 精修篇 管理资源字典 样式太多  每个界面可能需要全局的样式 有没有肯能 WPF 中的样式 像Asp.net中 的CSS一样管理那 有的 有资源字典 BurshDictionary &l ...

  8. WPF 精修篇 动态资源

    原文:WPF 精修篇 动态资源 动态资源 使用 DynamicResource 关键字 静态 就是 StaticResource 原则上是 能用静态就用静态 动态会让前台界面压力很大~ 动态资源引用 ...

  9. WPF 精修篇 静态资源

    原文:WPF 精修篇 静态资源 在WPF中 如果设置好了一个控件样式或者矩形样式 如果Copy出一个新的 那么样式也会双份 比如 下面的矩形 我定义好了一个 Copy 以后 就出现一个新的 但是改变样 ...

随机推荐

  1. weui dialog

    切记:weui dialog 的样式是在weui.css,而不是在weui.min.css HTML: <!DOCTYPE html> <html> <head> ...

  2. vector迭代器用法

    #include<iostream> #include<vector> using namespace std; int main() { vector<int> ...

  3. NPOI导出数据,设置格式,锁定单元格

    代码包括: 1:导出多个sheet    2:设置单元格格式   3:合并单元格   4:下拉框选项   5:输入数字限制   6:锁定单元格 static void Main(string[] ar ...

  4. Android studio

      情况一: 描述:写Android app时,出现activity对应的layout预览图所显示的activity是有标题栏的,但是运行该app,无论是模拟器还是真机,却出现没有了标题栏的情况,而自 ...

  5. Android系统全貌 (转)

    转自Gityuan的Android开篇,对自我学习作进一步整理. Android系统以Linux内核作为基底,上层采用Native层和Java层.系统分为内核空间和用户空间,并通过系统调用(Sysca ...

  6. 阿里云免费申请免费SSL证书

    随着互联网的不断进步与发展,对于网站与数据的安全性要求也越来越高,原本的HTTP明文传输已经不被信任,https逐渐被关注,从谷歌.火狐浏览器将对HTTP明文页面标记"不安全",到 ...

  7. [转] C++的引用传递、指针传递参数在java中的相应处理方法

    原文出处:[http://blog.csdn.net/conowen/article/details/7420533] 首先要明白一点,java是没有指针这个概念的. 但是要实现C++的引用传递.指针 ...

  8. TypeScript 素描-变量声明

    博文读自 TypeScript 官方文档而来,不具有学习性,仅是本人学习时记录以供日后翻阅 ,有学习TypeScript的朋友还请去看更为详细的官方文档 /* 变量声明在之前的js中一直是使用var关 ...

  9. 常用的Jquery插件

    0.模块化前端框架(http://www.layui.com) 1.拖拽滑动验证码(http://www.geetest.com/,https://github.com/dyh1995/jquery. ...

  10. 字符串 中的split 与数组中的join

    关于基础,总是隔一段时间,就得看一次,要不不用总是忘,今天又重新看了,一下字符串对象的split,然后就想到了数组对象的join. var str='wo shi yi ge js'; var str ...