一头雾水的"Follow The Pointer"
周银辉
Microsoft Expression Blend中有一个示例程序"Follow The Pointer", 看程序演示会觉得很酷,看代码(点击下载)会觉得一头雾水, 不过现在我便借此介绍一下WPF中的CompositionTarget 以及该示例中设计到了一些物理知识.
一, CompositionTarget
虽然我们拥有Storyboard(故事板)以及Microsoft Expression Blend为WPF动画制作提供强有力的支持,但你会发现这是不够的,也许你希望能通过代码来控制动画中的每一帧,以便显示更加复杂和视觉效果更好的动画, 那么你就得了解CompositionTarget 类.
CompositionTarget 类用于呈现你的应用程序显示表面, 每次绘制时其都会触发其Rendering事件, 其绘制次数取决于你计算机的FPS.
我们可以自定义Rendering事件的处理器来进行一些自定义的绘制或其他工作(注意其会根据计算机的FPS来不停地调用改事件处理器,比如每秒60次,所以不应该在这里进行复杂费时的操作) 比如:
data:image/s3,"s3://crabby-images/3daef/3daef9ec5655197b945f0efa4108dd7f5ca9de37" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/d2bf3/d2bf33ea77c2b120e97e379bae1d582fd4012b65" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/b733a/b733a108a0956d2e7c0176595fd17d7811a87fa4" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/c5878/c587809232521d27b8ae055d41cb6c6a7e7c4d46" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/3f301/3f301319c576b8ad19442eff49142bbc8ec40c09" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
这里有一个简单的例子说明CompositionTarget的用法,你可以点击这里下载
二, "Follow The Pointer"中的物理知识
编写视觉效果稍稍好一点的动画时不使用数学或物理知识几乎是不可能的. "Follow The Pointer"示例中用到了力,速度,加速度以及流动摩擦(其变形形式).
动画的简单的流程: 当用户移动鼠标时,程序会计算可移动控件(以下称"小方块",就是跟随鼠标的那个控件)的位置到鼠标位置所形成的向量, 并将该向量作为施加到小方块上的作用力.该作用力会使小方块朝鼠标所在位置移动.假设小方块处于空气(或水等)环境中,小方块的移动会产生流摩擦力,该摩擦力与速度成正比,其会使小方块减速并最终停止下来.
具体如何表现这些物理知识请参考下面的两段代码
这里是原示例代码:
data:image/s3,"s3://crabby-images/3daef/3daef9ec5655197b945f0efa4108dd7f5ca9de37" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/d2bf3/d2bf33ea77c2b120e97e379bae1d582fd4012b65" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/b733a/b733a108a0956d2e7c0176595fd17d7811a87fa4" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/c5878/c587809232521d27b8ae055d41cb6c6a7e7c4d46" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/3f301/3f301319c576b8ad19442eff49142bbc8ec40c09" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
这里是改写与简化后的示例代码:
data:image/s3,"s3://crabby-images/3daef/3daef9ec5655197b945f0efa4108dd7f5ca9de37" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/d2bf3/d2bf33ea77c2b120e97e379bae1d582fd4012b65" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/b733a/b733a108a0956d2e7c0176595fd17d7811a87fa4" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/c5878/c587809232521d27b8ae055d41cb6c6a7e7c4d46" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/9d192/9d1927e30fe712ff89436618813263b126451d33" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/3f301/3f301319c576b8ad19442eff49142bbc8ec40c09" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""
data:image/s3,"s3://crabby-images/3daef/3daef9ec5655197b945f0efa4108dd7f5ca9de37" alt="一头雾水的"Follow The Pointer" 一头雾水的"Follow The Pointer""