上一篇,我介绍了Silverlight控件被分为三种类型,
第一类: Layout Controls(布局控件)
第二类: Item Controls (项目控件)
第三类: User Interaction Controls(用户交互控件)
 
在以上三种控件类型中,布局控件是最基础的,所以,我从布局控件开始一个快速入门介绍,根据前文所述,我们知道Silverlight标准控件中,包括以下四种布局控件:
Grid控件
Canvas控件 
StackPanel控件
Border控件
经过上一篇文章的学习,我们已经对Grid有了了解, 本文将继续介绍另外一个布局控件Canvas。
Canvas布局控件,相对于其他布局控件的优势在于可以自由的设定其包含区域内控件的位置。该控件在Silverlight游戏设计中最为常见,可以实现游戏中独立部件控制。
使用Blend设置Canvas很简单,我在上一篇项目基础上,在0行0列和0行1列中分别创建两个Canvas,然后在两个Canvas中创建两个控件。
选中Canvas后,可以在右边“Properties”属性栏中修改其属性,从属性栏中可以看出,Canvas是嵌套在Grid中,所以,其位置可以由Grid属性控制。
选中Canvas中的控件,可以在右边“Properties”属性栏中看到该控件在容器Canvas中的位置,包括左距离,顶距离,以及Z坐标值。
其中Left可以理解为X坐标值,Top为Y坐标值,ZIndex(Z坐标值),如果从3D的角度来理解,是相对于平面的立体值。对于ZIndex的使用,可以看看下例,如果有两个Canvas控件,位置坐标相同,会形成覆盖,这里定义ZIndex,值越大的将会在上方覆盖ZIndex值小的控件。通过这个参数设置,我们可以实现很多不同的布局效果。
从上图可以看到,Canvas中的子控件,属性栏中,没有Grid控件中的Margin属性,而是使用Left和Top进行定位。根据微软官方的解释,Canvas中的控件,使用Canvas.left和Canvas.top定位,传递该数值到父容器控件Canvas,重载父容器Canvas的AttachedProperty(附加属性),这样意味着父容器Canvas不能更改子控件的位置。这里引入了AttachedProperty(附加属性),该属性是属于父控件的属性,但是可以被子控件进行设置。
上一篇,我们提到过布局控件Group的功能,这里使用Canvas group的功能,将多个Canvas嵌入到一个Canvas控件中,通过父Canvas控件统一控制子容器控件的属性。
这里我创建四个Canvas,每个Canvas中包含一个圆形控件。当前,处于相互覆盖状态。
按着Shift,分别选中四个Canvas控件,点击鼠标右键,“Group into” - > “Canvas“,
选中后,Blend将生成新的Canvas父控件,将选中的四个Canvas控件,作为子控件。
 1 <Canvas Margin="14,58,130,104" Grid.Row="1">
 2     <Canvas Height="88" Width="100">
 3         <Ellipse Fill="Red" Stroke="Black" Height="84" Width="83" Canvas.Left="11" Canvas.Top="2"/>
 4     </Canvas>
 5     <Canvas Width="100" Height="88" Canvas.Left="64">
 6         <Ellipse Fill="#FF0081FF" Stroke="Black" Height="84" Width="83" Canvas.Left="11" Canvas.Top="2"/>
 7     </Canvas>
 8     <Canvas Height="88" Width="100" Canvas.Left="127">
 9         <Ellipse Fill="#FF71FF00" Stroke="Black" Height="84" Width="83" Canvas.Left="11" Canvas.Top="2"/>
10     </Canvas>
11     <Canvas Height="88" Width="100" Canvas.Left="192">
12         <Ellipse Fill="#FFF4FF1C" Stroke="Black" Height="84" Width="83" Canvas.Left="11" Canvas.Top="2"/>
13     </Canvas>
14 </Canvas>
现在选中父控件的Canvas,将Opacity修改为40,可以看到,所有子控件的Opacity统一修改为40.效果如下:
如果,我们分别设置父控件下的四个Canvas控件Opacity属性,即可看到各自Canvas将按照自己属性为主,效果如下:
Canvas通过Group的功能,可以实现多个控件实现相同方式下动画效果,在Silverlight开发中也是常用的功能。
Canvas布局控件快速入门就介绍到这儿了。

Expression Blend实例中文教程(4) - 布局控件快速入门Canvas相关推荐

  1. Expression Blend实例中文教程(3) - 布局控件快速入门Grid

    上一篇对Blend 3开发界面进行了快速入门介绍,本篇将基于Blend 3介绍Silverlight控件.对于微软开发工具熟悉的朋友,相信您很快就熟悉Blend的开发界面和控件. XAML概述 Sil ...

  2. Expression Blend实例中文教程(6) - 项目控件和用户交互控件快速入门

    前文我们曾经描述过,微软把Silverlight控件大致分为三类: 第一类: Layout Controls(布局控件) 第二类: Item Controls (项目控件) 第三类: User Int ...

  3. Expression Blend实例中文教程(11) - 视觉管理器快速入门Visual State Manager(VSM)

    Visual State Manager,中文又称视觉状态管理器(简称为VSM),是Silverlight 2中引进的一个概念.通过使用VSM,开发人员和设计人员可以轻松的改变项目控件的视觉效果,在项 ...

  4. Expression Blend实例中文教程(12) - 样式和模板快速入门Style,Template

    在上一篇,介绍了Visual State Manager视觉状态管理器,其中涉及到控件的样式(Style)和模板(Template),本篇将详细介绍样式(Style)和模板(Template)在Sil ...

  5. Expression Blend实例中文教程(13) - 控件模板快速入门ControlTemplates

    上篇,介绍了控件样式(Style)和模板(Template)的基础概念,并且演示了使用Blend设计控件样式.本篇将继续介绍使用Blend设计自定义控件模板 - ControlTemplate.Con ...

  6. Expression Blend实例中文教程(2) - 界面快速入门

    上一篇主要介绍Expression系列产品,另外概述了Blend的强大功能,本篇将用Blend 3创建一个新Silverlight项目,通过创建的过程,对Blend进行快速入门学习. 在开始使用Ble ...

  7. Expression Blend实例中文教程(9) - 行为快速入门Behaviors

    在Blend强大的设计功能支持下,设计人员和开发人员可以无代码实现Silverlight/WPF动画效果,例如上文介绍的StoryBoard,就是一个典型例子,设计人员和开发人员仅需提供必要元素,即可 ...

  8. C# winform使用scottplot图表控件快速入门设置XY轴缩放

    Hello大家好我是开箱测评小汪,在C#项目开发中使用图表控件,有时候我们希望放大或缩小图表控件来看数据细节和整体数据情况.所有本期课程将带介绍Scottplot图表控件如何来实现这个功能. 本期课程 ...

  9. 地图控件快速入门——控制地图

    当你的网页中包含一个地图,你可以以编程的方式更改地图.您可以更改地图的风格,调整缩放级别,平移地图到新的位置,显示和隐藏默认导航控件,并添加自己的地图控件. 修改地图视图 有几种方法可以以编程方式更改 ...

最新文章

  1. Codeforces Round #469 (Div. 2) A/B
  2. Stuts2的struts.devMode设置成true后,不起作用,仍需要重启tomcat
  3. POJ 2709 Painter
  4. Java对存储过程的调用方法
  5. 如何绘制逻辑图 — 7.逻辑的表达:业务逻辑
  6. 360安全浏览器兼容模式怎么设置_360浏览器及安全卫士怎么减少广告弹出?
  7. android studio 项目源码_这个标星 2.3k+ 的项目带你 Android 源码分析从入门到放弃...
  8. gitlab 邮件发送
  9. Linux环境下gcc静态编译/usr/bin/ld: cannot find -lc错误原因及解决方法。
  10. vi+ctags+cscope联合使用
  11. 如何开发 Web 应用程序
  12. 使用串口打印系统时间
  13. 天天生鲜项目——登录页面
  14. 单片机原理与接口技术期末总复习
  15. Excel 散点图和折线图的区别
  16. 第二版 手把手教你如何建立自己的Linux系统
  17. 黑马程序员--IO总结(含2个设计模式)
  18. 使用Jimi处理图像
  19. vuecli打包后html文件没有压缩的问题
  20. OpenCV (c++)使用KDTree时,得到正确结果后报Segmentation fault (core dumped)

热门文章

  1. Django模板语言
  2. POJ1284:Primitive Roots——题解
  3. windows 系统nginx做反向代理实例
  4. 找DB2存储过程的package
  5. Sql server 数据库备份、恢复等
  6. flink-jdbc-driver和flink-sql-gateway的作用
  7. win7+ubuntu20.04双系统+easybcd安装以及Reached target Reboot卡住问题
  8. Unable to instantiate org.apache.hadoop.hive.ql.metadata.SessionHiveMetaStoreClient
  9. WARN RestSubmissionClient: Unable to connect to server spark://master:
  10. redis+celery+django设置外网可访问