详细解读Silverlight Line对象使用技巧

开发 开发工具
Silverlight Line对象在实际使用中是一个非常重要的操作技巧。我们可以通过这篇文章介绍的内容来详细掌握其中的应用技巧。

Silverlight中关于编码方面的应用是一个应用重点。只有熟练的使用各种方法来进行合理的编写代码,才能真正的实现我们所需要的图形界面的需求。在Silverlight提供的诸多形状对象中,Line对象无疑是最简单的一个,源于此,大家很容易忽略掉Line对象的一些特色功能。例如下面提到的两个应用技巧。#t#

 

定义Silverlight Line对象起点和终点的外观

默认情况下,Line对象绘制的线条的起点和终点都是没有样式的,但可以通过StrokeStartLineCap、StrokeEndLineCap、StrokeDashCap属性为直线对象额外增加线帽样式。其中前两个属性主要用于实线对象,其取值类型为PenLineCap 枚举(PenLineCap 枚举的取值范围见下表)。

所谓线帽是在直线的原有长度外,额外增加的图形

 

Silverlight Line对象成员名称及说明

Flat 一个未超出直线上***一点的线帽。等同于无线帽。

Square 一个高度等于直线粗细、长度等于直线粗细一半的矩形。

Round 一个直径等于直线粗细的半圆形。

Triangle 一个底边长度等于直线粗细的等腰直角三角形。

下面的示例显示的就是设置不同的StrokeStartLineCap、StrokeEndLineCap属性值的Xmal代码跟显示效果:

 

  1. < Line Grid.Row="0" X1="80" Y1="30" 
    X2="330" Y2="30" Stroke="Red" 
    StrokeThickness="10" StrokeEndLineCap=
    "Triangle"> 
  2. < /Line> 
  3. < Line Grid.Row="0" X1="80" Y1="80" 
    X2="330" Y2="80" Stroke="Blue" 
    StrokeThickness="10" StrokeEndLineCap=
    "Triangle" StrokeStartLineCap="Round"> 
  4. < /Line> 

 

 

通过Silverlight Line对象绘制虚线效果,需要用到StrokeDashArray属性,该属性对应一个Double类型的集合。该集合的奇数位表示线段的长度,偶数位表示两个线段之间的间隔长度。如果只是表示普通的虚线,则只需定义一个数值就可以了,默认会将该数值作为线段跟间隔的长度。例如,下面的Xaml代码就表示等一条等间距的虚线。

 

  1. < Line Grid.Row="1" X1="80" 
    Y1="30" X2="330" Y2="30" 
    StrokeDashArray="4" Stroke="Blue" 
    StrokeThickness="2" 
    StrokeStartLineCap="Round"> 
  2. < /Line> 

 

 

 

如果想表示一些特殊类型的虚线,那么就需要为StrokeDashArray属性设置多个数值了。

其Xaml代码如下:

 

 

  1. < Line Grid.Row="1" X1="80" Y1="60" 
    X2="330" Y2="60" StrokeDashArray=
    "4 2 1 2" Stroke="Blue" StrokeThickness=
    "2" StrokeStartLineCap="Round"> 
  2. < /Line> 

 

在Silverlight Line对象应用StrokeDashArray属性时需要注意的是,其设置的数值并不是线段以及间隔的实际像素值,而是相对于StrokeThickness的倍数。

责任编辑:曹凯 来源: CSDN
相关推荐

2009-12-30 15:42:08

Silverlight

2009-12-10 09:48:26

PHP获取远程图片

2009-12-25 16:26:03

ADO.NET控制

2009-12-11 15:35:50

PHP弹出对话框

2009-12-31 10:58:31

silverlight

2009-03-04 10:18:50

生命周期JVMjava

2009-12-30 13:30:16

Silverlight

2009-12-30 18:23:13

Silverlight

2011-02-21 17:15:14

SilverlightNEY

2009-12-29 17:56:47

Silverlight

2011-11-18 16:17:55

OpenStack实例

2009-12-31 13:56:57

ADO访问接口

2010-01-04 14:06:35

Silverlight

2009-12-15 18:30:56

Ruby使用DBI包装

2009-12-31 17:00:40

Silverlight

2009-12-29 17:34:52

Silverlight

2010-01-04 14:35:55

Silverlight

2020-10-16 06:57:46

UnixLinux命令操作系统

2010-01-04 14:49:30

Silverlight

2009-12-29 16:08:41

Silverlight
点赞
收藏

51CTO技术栈公众号