概述

Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, Ironpython,对JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlight 2系列》文章将从Silverlight 2基础知识、数据与通信、自定义控件、动画、图形图像等几个方面带您快速进入Silverlight 2开发。

本文将简单介绍Silverlight中的基本图形,主要有Line、Ellipse、Rectangle、Path、Polygon、Polyline六种,它们之间的继承关系如下所示:

在Silverlight中,所有的图形几乎都具有如下几个重要的属性:

Stroke:对边框线填充

StrokeThickness:边框线的宽度

Fill:对图形进行填充

Line

Line顾名思义,在两点之间画出一条直线,需要指定起始点(X1、Y1)和终结点(X2、Y2)的坐标。如下面的例子:

<Canvas Background="#CDFCAE">
<Line Canvas.Top="20" Canvas.Left="20"
X1="20" Y1="20" X2="400" Y2="20"
Stroke="#FF9900" StrokeThickness="4">
</Line> <Line Canvas.Top="40" Canvas.Left="20"
X1="20" Y1="40" X2="200" Y2="180"
Stroke="#0099FF" StrokeThickness="5">
</Line> <Line Canvas.Top="20" Canvas.Left="240"
X1="220" Y1="20" X2="220" Y2="200"
StrokeThickness="6">
<Line.Stroke>
<LinearGradientBrush StartPoint="0,0">
<GradientStop Color="#FFFFFF" Offset="0.0" />
<GradientStop Color="#307801" Offset="1.0" />
</LinearGradientBrush>
</Line.Stroke>
</Line>
</Canvas>

运行后如下所示,分别画出三条直线:

Ellipse

Ellipse即椭圆形,如果设置长和高相等,画出来将是圆形,主要的属性还是前面说的那三个。如下面的示例:

<Canvas Background="#CDFCAE">
<Ellipse Canvas.Top="20" Canvas.Left="40"
Width="160" Height="80" Fill="#FF9900"
Stroke="Black" StrokeThickness="3">
</Ellipse> <Ellipse Canvas.Top="20" Canvas.Left="260"
Width="180" Height="100">
<Ellipse.Fill>
<RadialGradientBrush GradientOrigin="0.5,0.5" Center="0.5,0.5"
RadiusX="0.5" RadiusY="0.5">
<GradientStop Color="#0099FF" Offset="0" />
<GradientStop Color="#FF0000" Offset="0.25" />
<GradientStop Color="#FCF903" Offset="0.75" />
<GradientStop Color="#3E9B01" Offset="1" />
</RadialGradientBrush>
</Ellipse.Fill>
</Ellipse> <Ellipse Canvas.Top="120" Canvas.Left="160"
Width="100" Height="100" Fill="#FF9900"
Stroke="#000000" StrokeThickness="2">
</Ellipse>
</Canvas>

运行后如下所示,显示三个椭圆形:

Rectangle

Rectangle看名称就知道是矩形,设置长度和高度相等则为正方形,其主要的属性还是开始我们提到的那三个,同时还可以通过RadiusX和RadiusY来设置它的圆角效果,看下面的例子:

<Canvas Background="#CDFCAE">
<Rectangle Canvas.Top="20" Canvas.Left="40"
Width="160" Height="80" Fill="#FF9900"
Stroke="Black" StrokeThickness="3">
</Rectangle> <Rectangle Canvas.Top="20" Canvas.Left="260"
Width="180" Height="100">
<Rectangle.Fill>
<RadialGradientBrush GradientOrigin="0.5,0.5" Center="0.5,0.5"
RadiusX="0.5" RadiusY="0.5">
<GradientStop Color="#0099FF" Offset="0" />
<GradientStop Color="#FF0000" Offset="0.25" />
<GradientStop Color="#FCF903" Offset="0.75" />
<GradientStop Color="#3E9B01" Offset="1" />
</RadialGradientBrush>
</Rectangle.Fill>
</Rectangle> <Rectangle Canvas.Top="120" Canvas.Left="120"
Width="100" Height="100"
Stroke="#000000" StrokeThickness="2" RadiusX="15" RadiusY="15">
<Rectangle.Fill>
<LinearGradientBrush StartPoint="0,1">
<GradientStop Color="#FFFFFF" Offset="0.0" />
<GradientStop Color="#FF9900" Offset="1.0" />
</LinearGradientBrush>
</Rectangle.Fill>
</Rectangle>
</Canvas>

运行后如下所示,其中有两个加上了渐变效果:

Path

相比较前面三个简单的图形来说,Path相对来说比较复杂,它用来画出一系列的相连的圆弧或者线条,可以称之为“轨迹”,使用它可以画出任意复杂的形状,主要通过Data属性来展现。一个简单的Path声明示例如下:

<Canvas Background="#CDFCAE">
<Path Stroke="Orange" StrokeThickness="3"
Data="M 10,40 L 300,40 V 100 H 240 S 300,240 400,175">
</Path>
</Canvas>

运行后如下所示:

这里对Data做一下简单的解释,Silverlight提供了一种称之为“迷你语言”的属性句法,来描述如何画出轨迹形状,包括M(移动命令,起始点)、L(直线,结束点)、H(水平线)、V(垂直线)、C(三次贝塞尔曲线)、Q(两次贝塞尔曲线)、A(椭圆弧曲线)、Z(结束命令)等。更为详细的使用大家可以参考SDK。

Polygon

Polygon用来画多边形,需要用Points属性来指定几个特定的点,至于画几边形,要看你定义几个点了(要看救生员啥时救他—宋丹丹语录),它会自动闭合。

<Canvas Background="#CDFCAE">
<Polygon Canvas.Left="50" Canvas.Top="50"
Points="50,20 300,20 300,160 200,160"
Stroke="Green" StrokeThickness="3" Fill="Orange">
</Polygon>
</Canvas>

每一个点之间用空格分开,运行后如下所示:

Polyline

Polyline用来画多边线,与上面的Polygon不同的地方是它不一定要是闭合的,同样用Points属性来指定几个特定的点,我们定义一个跟上面的示例一样的Polyline:

<Canvas Background="#CDFCAE">
<Polyline Canvas.Left="50" Canvas.Top="50"
Points="50,20 300,20 300,160 200,160"
Stroke="Green" StrokeThickness="3" Fill="Orange">
</Polyline>
</Canvas>

运行后可以看到,有一条边未闭合:

结束语

本文内容比较简单,介绍了Silverlight中的一些基本的图形。

作者:TerryLee
出处:http://terrylee.cnblogs.com 
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
 
 
 
===============================================================
 
@lings 
继续顶自己的贴 
哈哈,终于搞定 A 命令,开心啊 
同大家分享下,用 A 命令画圆弧的格式如下 
Data="M 200 200 A 100 100 0 1 1 200 201"

startPoint :200 200 (起始坐标点) 
size :100 100 ( 圆弧 X,Y 轴长度) 
rotationAngle :0 (这个不明,双精度类型[double]) 
isLargeArcFlag :1 (也不明,1/0, 布尔值[0,1]) 
sweepDirectionFlag :1 (逆/顺时针画圆弧,布尔值[0,1]) 
endPoint:200 201 (结束坐标点)

如果起点坐标和结束坐标一致,那么这圆弧是看不见的

 
再次继续顶自己的帖子 
今天自己写了一个绘制圆弧轨迹的类 
是根据圆的标准方程式得来的: 
(x-A)(x-A)+(y-B)(y-B)= R*R 
[A,B] 是圆心的横,纵坐标,[r] 是圆半径 
(全部采用双精度类型 [double],提高画图精度) 
得出圆弧 [x] 坐标 与 [y] 坐标 的关系: 
// 分解 (x - A)(x - A) 
double x_result = (x * x) - (2 * x * A) + (A * A); 
// 分解方程式等式 
double right = (R * R) - x_result; 
// 开平方计算 
y = Math.Sqrt(right) + B; 
(绘制动作) 
得出[x]与[y]的关系后,我把绘制动作放在时间控件的 Tick()事件里 
设置一个控件的相对左边距 =x;相对右边距 = y; 
这样随着时间的推移,该控件就会走出近似于圆弧的轨迹(点到点的画法) 
但这个方法得到还只是半圆弧 
(关系式改为: x = Math.Sqrt(right)+A 就能得到另一半的圆弧) 
而且并不是真正绘制(只是描述动作轨迹而已)。 
我测试的时候是用 Ellipse 画一个同圆心坐标,同半径的背景 
看控件是否在该背景的圆弧上运动 。 
正圆形画出来了,那椭圆形自然不在话下了 
画出椭圆形了,我的天体运行轨道的 Demo 也迎刃而解了 
Thanks for TerryLee's! 
Your course is very inserting! 
===================================

一步一步学Silverlight 2系列(26):基本图形的更多相关文章

  1. 一步一步学Silverlight 2系列文章

    概述 由TerryLee编写的<Silverlight 2完美征程>一书,已经上市,在该系列文章的基础上补充了大量的内容,敬请关注.官方网站:http://www.dotneteye.cn ...

  2. 一步一步学Silverlight 2系列(32):图形图像综合实例—“功夫之王”剧照播放

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  3. 一步一步学Silverlight 2系列(31):图形图像综合实例—实现水中倒影效果

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  4. 一步一步学Silverlight 2系列(30):使用Transform实现更炫的效果(下)

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  5. 一步一步学Silverlight 2系列(29):使用Transform实现更炫的效果(上)

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  6. 一步一步学Silverlight 2系列(28):图片处理

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  7. 一步一步学Silverlight 2系列(27):使用Brush进行填充

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  8. 一步一步学Silverlight 2系列(25):综合实例之Live Search

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  9. 一步一步学Silverlight 2系列(24):与浏览器交互相关辅助方法

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

随机推荐

  1. 关于a标签的onclick和href谁先执行的问题

    今天上午遇到一个问题,我想在a标签跳转的时候增加一些程序上的判断,但又不会影响a标签的正常跳转,于是就有了这篇文章. 我的具体代码是这样的: <a href="http://www.m ...

  2. android图片上传

    package com.example.center; import java.io.ByteArrayOutputStream;import java.io.InputStream; import ...

  3. 用“道”的思想解决费用流问题---取/不取皆是取 (有下界->有上界) / ACdreamoj 1171

    题意: 给一个矩阵,给出约束:i(0<i<n)行至少去ai个数,j行至少取bi个数,要求取的数值之和最小. 开始一见,就直接建了二分图,但是,发现这是有下界无上界最小费用流问题,肿么办.. ...

  4. (12)centos之stmp服务器

    yum remove sendmail #卸载sendmail  

  5. WdatePicker.js的使用方法 帮助文档 使用说明(时间控件)*转载

    4. 日期范围限制 静态限制 注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致 你可以给通过配置minDate(最小日期),maxDate(最大日期)为静态日期值,来限定 ...

  6. 深入GCD(五):资源竞争

    概述我将分四步来带大家研究研究程序的并发计算.第一步是基本的串行程序,然后使用GCD把它并行计算化.如果你想顺着步骤来尝试这些程序的话,可以下载源码.注意,别运行imagegcd2.m,这是个反面教材 ...

  7. python内存诊断

    1.计算内存地址: str1 = 'shn' print id(str1) 2.计算内存大小,返回字节数 str1 = 'td' print sys.getsizeof(str1) 3.

  8. BUPT复试专题—最值问题(2013计院)

    题目描述 给出N个数,求出这N个数中最大值和次大值.注意这里的次大值必须严格小于最大值.输入保证N个数中至少存在两个不同的数. 输入格式 第一行为测试数据的组数T(T≤20).请注意,任意两组测试数据 ...

  9. Android6.0权限管理以及使用权限该注意的地方

    Android 6.0 Marshmallow首次增加了执行时权限管理,这对用户来说,能够更好的了解.控 制 app 涉及到的权限.然而对开发人员来说却是一件比較蛋疼的事情.须要兼容适配,并保证程序功 ...

  10. POJ 3928 Ping pong 树状数组模板题

    開始用瓜神说的方法撸了一发线段树.早上没事闲的看了一下树状数组的方法,于是又写了一发树状数组 树状数组: #include <cstdio> #include <cstring> ...