zoukankan      html  css  js  c++  java
  • Silverlight & Blend动画设计系列七:模糊效果(BlurEffect)与阴影效果(DropShadowEffect)

      模糊效果(BlurEffect)与阴影效果(DropShadowEffect)是两个非常实用和常用的两个特效,比如在开发相册中,可以对照片的缩略图添加模糊效果,在放大照片的过程中动态改变照片的大小和模糊的透明度来达到一个放大透明的效果。

    一、模糊效果(BlurEffect)

      Silverlight中的每个对象都是支持添加模糊和阴影效果的, 在Blend工具中通过“外观”面板可以直接可视化的进行设计完成模糊和阴影效果的添加,以及效果参数的调整。如下图为模糊效果的设计界面:

            

      点击”新建“将会弹出模糊和阴影效果选择对话框,下图为模糊和阴影效果选择对话框:

            

      就拿相册开发中的一个典型实例来分析吧,比如相片默认缩小为一定的比例并添加了模糊的效果呈现在相片列表中的,当鼠标指向照片的时候将照片进行放大显示(放大图片可通过缩放动画实现,详细可查阅:《Silverlight & Blend动画设计系列三:缩放动画(ScaleTransform) 》),并动态改变其模糊效果值为0以达到可清晰的查看照片效果。如下XAML对图片的相关定义:

    <Image Height="240" x:Name="Flower" Width="320" Source="yellowFlower.jpg" Opacity="1" 
        Canvas.Left
    ="240" Canvas.Top="180" RenderTransformOrigin="0.5,0.5" 
        MouseEnter
    ="Flower_MouseEnter" MouseLeave="Flower_MouseLeave" OpacityMask="{x:Null}">
        
    <Image.RenderTransform>
            
    <TransformGroup>
                
    <ScaleTransform/>
                
    <SkewTransform/>
                
    <RotateTransform/>
                
    <TranslateTransform/>
            
    </TransformGroup>
        
    </Image.RenderTransform>
        
    <Image.Effect>
            
    <BlurEffect/> <!--为该图片添加了模糊效果-->
        
    </Image.Effect>
    </Image>

      可以通过两个动画来处理,一个完成将图片缩放比例进行放大(ScaleX,ScaleY:1-->2)同时改变其模糊值为0(Radius:5-->0),另一个动画则相反。

    <Storyboard x:Name="Flower_Enter">
        
    <DoubleAnimation BeginTime="00:00:00" Storyboard.TargetName="Flower" Duration="00:00:00.50" To="2" 
        Storyboard.TargetProperty
    ="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleX)">
        
    </DoubleAnimation>
        
    <DoubleAnimation BeginTime="00:00:00" Storyboard.TargetName="Flower" Duration="00:00:00.50" To="2"  
        Storyboard.TargetProperty
    ="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleY)">
        
    </DoubleAnimation>
        
    <DoubleAnimation BeginTime="00:00:00" Storyboard.TargetName="Flower" Duration="00:00:00.50" To="0"  
        Storyboard.TargetProperty
    ="(UIElement.Effect).(BlurEffect.Radius)">
        
    </DoubleAnimation>
    </Storyboard>
    <Storyboard x:Name="Flower_Level">
        
    <DoubleAnimation BeginTime="00:00:00" Storyboard.TargetName="Flower" Duration="00:00:00.50" To="1" 
        Storyboard.TargetProperty
    ="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleX)">
        
    </DoubleAnimation>
        
    <DoubleAnimation BeginTime="00:00:00" Storyboard.TargetName="Flower" Duration="00:00:00.50" To="1"  
        Storyboard.TargetProperty
    ="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleY)">
        
    </DoubleAnimation>
        
    <DoubleAnimation BeginTime="00:00:00" Storyboard.TargetName="Flower" Duration="00:00:00.5000000" To="5"  
        Storyboard.TargetProperty
    ="(UIElement.Effect).(BlurEffect.Radius)">
        
    </DoubleAnimation>
    </Storyboard>

      通过鼠标事件(MouseEnter,MouseLeave)动态的触发上面定义的两个动画的执行就可以达到预期的目的,如下代码:

    private void Flower_MouseEnter(object sender, System.Windows.Input.MouseEventArgs e)
    {
        
    // TODO: Add event handler implementation here.
        this.Flower_Enter.Begin();
    }

    private void Flower_MouseLeave(object sender, System.Windows.Input.MouseEventArgs e)
    {
        
    // TODO: Add event handler implementation here.
        this.Flower_Level.Begin();
    }

          

    二、阴影效果(DropShadowEffect)

      Silverlight中应用阴影效果和模糊效果一样的简单,通添加模糊效果一样的方式实现对元素添加阴影效果处理,需要关注的就是设置阴影效果的相关属性。

        BlurRadius:模糊半径
        Color:填充颜色
        Direction:方向
        Opacity:透明度
        ShadowDepth:阴影深度

      通过以上几个属性选项的设置就可以完成阴影效果的设计,由于其设计过程非常简单,详细如下图所示:

                  

      对应生成的XAML代码如下:

    <Image Height="240" x:Name="Flower" Width="320" Canvas.Left="240" Canvas.Top="180" 
        Source
    ="yellowFlower.jpg" Stretch="Fill" Cursor="Hand">
        
    <Image.Effect>
            
    <DropShadowEffect x:Name="FlowerShadow" 
            BlurRadius
    ="18" 
            ShadowDepth
    ="27" 
            Opacity
    ="0.6" 
            Direction
    ="321"/>
        
    </Image.Effect>
    </Image>

    推荐资源:

      MSDN:http://msdn.microsoft.com/zh-cn/library/cc189090(VS.95).aspx

      http://www.silverlight.net/learn/quickstarts/animations/

      http://blog.csdn.net/ghj1976/archive/2009/12/22/5056916.aspx

          《Function Silverlight 3 Animation》----本篇中使用的示例素材选自此书

    版权说明

      本文属原创文章,欢迎转载且注明文章出处,其版权归作者和博客园共有。  

      作      者:Beniao

     文章出处:http://beniao.cnblogs.com/  或  http://www.cnblogs.com/

  • 相关阅读:
    ios中的几种多线程实现
    在mac下使用终端管理svn
    关于UIScrollViewDelegate协议中每个回调函数的意义及执行顺序的理解
    UIView 及其子类对象 抖动效果的实现
    ios、andriod、cocos2d 视图层次理解
    委托  通知中心   监听/观察
    iphone 中使用苹果禁用的私有Framework
    关于苹果官方网站Reachability检测网络的总结
    iOS设备的分辨率
    ios开发多线程、网络请求的理解 错误码的理解
  • 原文地址:https://www.cnblogs.com/beniao/p/1716203.html
Copyright © 2011-2022 走看看