用WPF轻松打造iTunes CoverFlow效果

转载 2012年03月23日 14:34:55

先Show一下:
CoverFlow1.png
CoverFlow2.png

下面这一张是苹果的iTunes软件:
iTunes.png

苹果iTunes播放器的CoverFlow效果羡煞旁人,不过有了WPF,我们也可以轻松实现哈,今天费了半天的时间终于搞定,呵呵...

感兴趣的话可以这里下载源代码
(说明:上传源代码时由于图片较大,所以就没传图片了,程序取的是用户" 我的图片"文件夹下的*.jpg图片,你可以修改代码中的路径或在"我的图片"文件夹下放几张jpg图片就可以看到效果了)

图片是使用3DTools 提供的2D到3D映射的方式贴图上去的,每张图片都帖在一个3D模型上,我们只需要让程序来安排这些模型的摆放位置就可以了

3D模型的摆放是按照如下方法进行的,其中3个传出参数angle指定模型源Y轴的旋转角度,offsetX指定模型的X轴方向上的平移量,offsetZ指定模型在Z轴方向上的平移量

/// <summary>
        /// 依照InteractiveVisual3D在列表中的序号来变换其位置等
        /// </summary>
        /// <param name="index">在列表中的序号</param>
        /// <param name="midIndex">列表中被作为中间项的序号</param>
        private void GetTransformOfInteractiveVisual3D(int index, double midIndex, out double angle, out double offsetX, out double offsetZ)
        {
            double disToMidIndex = index - midIndex;


            //旋转,两翼的图片各旋转一定的度数
            angle = 0;
            if (disToMidIndex < 0)
            {
                angle = this.ModelAngle;//左边的旋转N度
            }
            else if (disToMidIndex > 0)
            {
                angle = (-this.ModelAngle);//右边的旋转-N度
            }
            
         

            //平移,两翼的图片逐渐向X轴负和正两个方向展开
            offsetX = 0;//中间的不平移
            if (Math.Abs(disToMidIndex) <= 1)
            {
                offsetX = disToMidIndex * this.MidModelDistance;
            }
            else if (disToMidIndex != 0)
            {
                offsetX = disToMidIndex * this.XDistanceBetweenModels + (disToMidIndex > 0 ? this.MidModelDistance : -this.MidModelDistance);
            }
            

            //两翼的图片逐渐向Z轴负方向移动一点,造成中间突出(离观众较近的效果)
            offsetZ = Math.Abs(disToMidIndex) * -this.ZDistanceBetweenModels;
          
        }


 


点击图片或指定当前应该被突出显示的图片时的动画效果是这样实现的,先使用上面的方法计算出决定模型位置的几个便量的新值(即上面的几个传出参数),然后在使用动画(DoubleAnimation)让这几个值由旧值过度到新值.

/**//// <summary>
        /// 重新布局3D内容
        /// </summary>
        private void ReLayoutInteractiveVisual3D()
        {
            int j=0;
            for (int i = 0; i < this.viewport3D.Children.Count; i++)
            {
                InteractiveVisual3D iv3d =  this.viewport3D.Children[i] as InteractiveVisual3D;
                if(iv3d != null)
                {
                    double angle = 0;
                    double offsetX = 0;
                    double offsetZ = 0;
                    this.GetTransformOfInteractiveVisual3D(j++, this.CurrentMidIndex,out angle,out offsetX,out offsetZ);


                    NameScope.SetNameScope(this, new NameScope());
                    this.RegisterName("iv3d", iv3d);
                    Duration time = new Duration(TimeSpan.FromSeconds(0.3));

                    DoubleAnimation angleAnimation = new DoubleAnimation(angle, time);
                    DoubleAnimation xAnimation = new DoubleAnimation(offsetX, time);
                    DoubleAnimation zAnimation = new DoubleAnimation(offsetZ, time);

                    Storyboard story = new Storyboard();
                    story.Children.Add(angleAnimation);
                    story.Children.Add(xAnimation);
                    story.Children.Add(zAnimation);

                    Storyboard.SetTargetName(angleAnimation, "iv3d");
                    Storyboard.SetTargetName(xAnimation, "iv3d");
                    Storyboard.SetTargetName(zAnimation, "iv3d");

                    Storyboard.SetTargetProperty(
                        angleAnimation,
                        new PropertyPath("(ModelVisual3D.Transform).(Transform3DGroup.Children)[0].(RotateTransform3D.Rotation).(AxisAngleRotation3D.Angle)"));

                    Storyboard.SetTargetProperty(
                        xAnimation,
                        new PropertyPath("(ModelVisual3D.Transform).(Transform3DGroup.Children)[1].(TranslateTransform3D.OffsetX)"));
                    Storyboard.SetTargetProperty(
                        zAnimation,
                        new PropertyPath("(ModelVisual3D.Transform).(Transform3DGroup.Children)[1].(TranslateTransform3D.OffsetZ)"));

                    story.Begin(this);

                }
            }
        }


原文出处:http://www.cnblogs.com/zhouyinhui/archive/2007/09/27/908213.html

相关文章推荐

WPF下的CoverFlow效果

  • 2008年06月02日 16:12
  • 322KB
  • 下载

iPhone 实现简单的CoverFlow 效果

首先声明一下,这篇文章的作者正是本人(Leo),由于之前代码里面有几个小的问题,一直很忙,今天晚上抽出了点时间来给大家更正一下,要是根据下面一步步的来做的话,一定能建立出绚丽的coverFlow ...

android UI效果一: coverFlow

先看效果图: 自定义Gallery控件实现. 主要有4个文件,1个Layout,1个Activity,1个Adapter,1个Gallery Activity: ? ...

收集的scorllview和coverflow效果

  • 2012年04月19日 13:18
  • 5.23MB
  • 下载

Android版仿iOS的CoverFlow效果

  • 2014年12月22日 02:45
  • 2.48MB
  • 下载

Android 用CoverFlow的效果

我们还是先来看看效果图有多么的好看吧        此类是从Gallery继承过来的,用法自然也就和Gallery一样了,程序的背景是一个xml陪的渐变背景,具体可以参看另外一篇”渐变背...
  • qjbagu
  • qjbagu
  • 2012年04月05日 11:41
  • 504

openFlow实现CoverFlow效果

本文多为转载,我只是把各个大神的资料搜集一下,请各位关注原作者!如果原作者不希望转载,请发邮件留言至我的博客,我会在24小时内删除相关内容! 实现CoverFlow效果有两种方法: 1、C...
  • setipro
  • setipro
  • 2012年03月31日 15:27
  • 459

Android 通过伪3D变换可以基本实现coverflow的效果

Android 通过伪3D变换可以基本实现coverflow的效果 使用过Android自带的gallery组件的人都知道,gallery实现的效果就是拖动浏览一组图片,相比ipho...

Android实现CoverFlow效果

先上一张效果图: 上代码,看了代码什么都明白 CoverFlow从Gallery继承过来 package com.coverflow; import android.content.Co...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:用WPF轻松打造iTunes CoverFlow效果
举报原因:
原因补充:

(最多只允许输入30个字)