天极传媒:
天极网
比特网
IT专家网
52PK游戏网
极客修
全国分站

北京上海广州深港南京福建沈阳成都杭州西安长春重庆大庆合肥惠州青岛郑州泰州厦门淄博天津无锡哈尔滨

产品
  • 网页
  • 产品
  • 图片
  • 报价
  • 下载
全高清投影机 净化器 4K电视曲面电视小家电滚筒洗衣机
您现在的位置: 天极网 > 开发>技术文档>Silverlight图形绘制及图像处理

Silverlight图形绘制及图像处理的实例演示

天极网开发频道 2012. 03. 25 作者:Prince Wang 责编:王健楠
我要吐槽

责任编辑

  Silverlight为开发者提供了两大绘图功能:形状及几何图形,他们提供了丰富的、简便的随时可用的绘图对象,用于在屏幕上绘制各种形状元素。

  对于手机软件来说,好的用户体验能吸引更多的用户,而体验离不开丰富的图形及动画,熟悉图形动画技术是开发一款好的应用的前提条件。下面以制作的圆形时钟为例:

  1.打开Microsoft Visual Studio 2010 Express for Windows Phone,新建一个Silverlight for Phone 工程,命名为ImageClock。

  2.修改应用程序的标题,把小标题改为My ImageApp,大标题改为My Clock。代码如下:

                <Grid x:Name="TitleGrid"Grid.Row="0">
                      <TextBlock Text="My ImageApp" x:Name="textBlockPageTitle" Style="{StaticResource PhoneTextPageTitleStyle}"?>
                      <TextBlock Text="My Clock" x:Name="textBlockListTitle" Style="{StaticResource PhoneTextPageTitle2Style}"?>
                </Grid>

  3.首先绘制时钟的外框,设置边线颜色为黑色,厚度为5,同事加入渐变色,分别为灰色与白色,看起来有立体感。代码如下:

                <Ellipse Width="450"Height="450"Stroke="BtrokeThickness="5">
                     <Ellipse.Fill>
                        <RadialGradientBrush   GradientOrigin="0.5,0.5"   RadiusX="0.5 rADIUSy="0.5"">
                            <GradientStop Color="White"Offset="0.75"/>
                            <GradientStop Color="Gray"Offset="1"/>
                        </RadialGradientBrush>
                     </Ellipse.Fill>
                </Ellipse>

  4.绘制内框,同样把边线颜色设置为黑色,厚度为5,为了生产内陷效果,渐变色与外框相反。代码如下:

                <Ellipse Width="350"Height="350"Stroke="BtrokeThickness="2">
                     <Ellipse.Fill>
                        <RadialGradientBrush   GradientOrigin="0.5,0.5"   RadiusX="0.5 rADIUSy="0.5"">
                            <GradientStop Color="White"Offset="0.75"/>
                            <GradientStop Color="Gray"Offset="1"/>
                        </RadialGradientBrush>
                     </Ellipse.Fill>
                </Ellipse>

  5.绘制内盘,代码如下:

                <Ellipse Width="320"Height="320"Stroke="BtrokeThickness="5">
                     <Ellipse.Fill>
                        <SolidColorBrush Color="White"/>
                     </Ellipse.Fill>
                </Ellipse>

  6.准备一幅图片作为内盘的北京,本次示例使用的是Rose.jpg文件,用右击解决方案窗口的工程名,选择添加,然后选择新建目录,命名为Image。用右击Image 目录,选择添加现有文件,把路径指向Rose.jpg。在代码中加入图片,并添加透明效果,代码如下:

                <Image Source="Image\Rose.jpg">
                   <Image.OpacityMask>
                       <RadialGradientBrush>
                          <GradientStop Offset="0.2"Color="White"/>
                          <GradientStop Offset="1"Color="Transparent"/>
                       </RadialGradientBrush>
                   </Image.OpacityMask>
                </Image>

  7.添加时钟的中心和指针,代码如下:

                <Ellipse Width="20"Height="20">
                    <Ellipse.Fill>
                        <SolidColorBrushColor="Red"/>
                    </Ellipse.Fill>
                </Ellipse>
                <Line X1="240" Y1="320" X2="240" Y2="420" Stroke="Red"StrokeThickness="5"/>
                <Line X1="240" Y1="325" X2="320" Y2="330" Stroke="Red"StrokeThickness="5"/>
                <Line X1="240" Y1="325" X2="150" Y2="220" Stroke="Red"StrokeThickness="5"/>

  8.单机运行,就可以在模拟器上看到这次制作的效果图了。

作者:Prince Wang责任编辑:王健楠)
请关注天极网天极新媒体 最酷科技资讯
扫码赢大奖
评论
* 网友发言均非本站立场,本站不在评论栏推荐任何网店、经销商,谨防上当受骗!
办公软件IT新闻整机