[Silverlight动画]转向行为 - 转向机车

简介: 转向机车类继承机车类并增加转向行为。每个行为都被定义成公开函数,在每帧或者一段时间间隔内调用以实现对应的转向力。通常所有转向力在调用之后再调用机车的update函数。 转向函数都是这样工作的:不管什么时候调用了一个转向函数,都会计算转向力,这个力用来确定机车是顺时针旋转还是逆时针旋转。

转向机车类继承机车类并增加转向行为。每个行为都被定义成公开函数,在每帧或者一段时间间隔内调用以实现对应的转向力。通常所有转向力在调用之后再调用机车的update函数。

转向函数都是这样工作的:不管什么时候调用了一个转向函数,都会计算转向力,这个力用来确定机车是顺时针旋转还是逆时针旋转。比如,seek(寻找)函数会 计算出一个力,确保机车能从当前方向直接面向目标点。这或许会受到不止一个拥有转向行为的机车的影响,起初的寻找点,会在考虑避开或躲避后而改变。当这些 力叠加后,update函数才被调用,最终把一切都反应在机车上,并导致其速度的改变(方向和大小)。

    public class SteeredVehicle:Vehicle
    {
        private double _maxForce = 1;
        private Vector2D _steeringForce;

        public SteeredVehicle()
        {
            _steeringForce = new Vector2D(0, 0);            
        }

        public double maxForce
        {
            get
            {
                return _maxForce;
            }
            set
            {
                _maxForce = value;
            }
        }

        public override void update()
        {
            _steeringForce.truncate(_maxForce);
            _steeringForce = _steeringForce.divide(_mass);
            _velocity = _velocity.add(_steeringForce);
            _steeringForce = new Vector2D(0, 0);
            base.update();
        }
    }

立刻进入眼帘的是_steeringForce属性,它是一个2D向量。该属性作为每个行为叠加后的转向合力。同时留意此处还有一个_maxForce属 性,因为现实中不会有什么旋转是一瞬间完成的,所以要对旋转力加以限制,使其在一帧里的大小不会太离谱。可以通过公maxForce赋值对maxForce的修正,会使机车旋转更急剧,移动更快速,走位更准确,或是出现一个很牛x的大甩尾。
现在,让我们解剖update函数。先假设有一堆转向行为已经被调用,那么此时的_steeringForce属性即是一个有意义的向量。第一个 truncate(截断)函数是不让_steeringForce超过最大作用力。然后除以(divide)机车的质量(mass)。在现实中,越重的物 体有着越大的动力,旋转的角度也越大,而较轻的物体则旋转更快速。接着把转向力叠加于机车的当前速度上,再把_steeringForce设回零向量,以 便于下一轮作用力的叠加。最终调用父类已经实现的update函数。

该是了解行为实现的时候了,从寻找(seek)行为开始。每个行为都是转向机车类的一个公开函数,某些行为会需要新的属性和额外的函数。

相关文章
|
容器
Silverlight & Blend动画设计系列二:旋转动画(RotateTransform)
原文:Silverlight & Blend动画设计系列二:旋转动画(RotateTransform)   Silverlight的基础动画包括偏移、旋转、缩放、倾斜和翻转动画,这些基础动画毫无疑问是在Silverlight中使用得最多的动画效果,其使用也是非常简单的。
1039 0
|
容器 数据可视化 内存技术
Silverlight & Blend动画设计系列一:偏移动画(TranslateTransform)
原文:Silverlight & Blend动画设计系列一:偏移动画(TranslateTransform)   用户界面组件、图像元素和多媒体功能可以让我们的界面生动活泼,除此之外,Silverlight还具备动画功能,它可以让应用程序“动起来”。
832 0
Silverlight & Blend动画设计系列四:倾斜动画(SkewTransform)
原文:Silverlight & Blend动画设计系列四:倾斜动画(SkewTransform)   Silverlight中的倾斜变化动画(SkewTransform)能够实现对象元素的水平、垂直方向的倾斜变化动画效果。
858 0
|
容器
Silverlight & Blend动画设计系列五:故事板(StoryBoards)和动画(Animations)
原文:Silverlight & Blend动画设计系列五:故事板(StoryBoards)和动画(Animations)   正如你所看到的,Blend是一个非常强大的节约时间的设计工具,在Blend下能够设计出很多满意的动画作品,或许他具体是怎么实现的,通过什么方式实现的我们还是一无所知。
958 0
Silverlight & Blend动画设计系列七:模糊效果(BlurEffect)与阴影效果(DropShadowEffect)
原文:Silverlight & Blend动画设计系列七:模糊效果(BlurEffect)与阴影效果(DropShadowEffect)   模糊效果(BlurEffect)与阴影效果(DropShadowEffect)是两个非常实用和常用的两个特效,比如在开发相册中,可以对照片的缩略图添加模糊效果,在放大照片的过程中动态改变照片的大小和模糊的透明度来达到一个放大透明的效果。
1104 0

热门文章

最新文章