Cover Flow特效实现(1)

Cover Flow特效实现(1)

Cover Flow特效实现(2)


Cover flow是苹果首创的将多首歌曲的封面以3D界面的形式显示出来的方式。如下图所示:

随处可见的Cover Flow特效

  • iTunes:在iTunes音乐中点击搜索框左边“查看”项第三个,即以cover flow形式显示专辑封面(前提是你得添加插图或音乐自带插图),也可以在全屏模式使用
  • iPhone/iPod Touch:在竖屏模式播放音乐,iPhone只会显示一张专辑的封面;但当用户将机身旋转为横屏模式后,则能看到多首歌曲的封面以3D界面的形式显示出来,用手指左右的滑动能够进行歌曲的选择,点击相应的专辑封面则会显示该张唱片的曲目,点击相应歌曲即可开始播放。
  • 苹果官网:官网上有以Flash展示的cover flow界面
  • iPod NANO3/4/5:基本类似于在iphone中的操作,利用触摸轮滑动使封面转换
  • Safari 4:使用 Cover Flow,您可以像在 iTunes 中翻看专辑插图一样轻松地翻看网站。Cover Flow 可以将您的书签和历史记录显示为大图预览,这样您就能立即找到网站。要查看 Cover Flow 如何工作,请单击 Safari“书签”栏左端的打开书本图标来打开书签列表。在“精选”列表中选择“历史记录”或您要查看其标签的精选。使用水平滚动条来翻看网页预览。您还可以使用鼠标上的滚动按钮来翻看预览。如果您的触控板已配置为支持触控板手势,则您可以左右扫动。

特效制作

方法一:UICoverFlowLayer

正式的SDK并未包含UICoverFlowLayer,但是它仍然是标准的uikit。通过steve nygard的类转储(class-dump), 能从uikit框架中提取 UICoverFlowLayer头文件。

由于UICoverFlowLayer是私有的,无法应用于应用程序(无法通过苹果的审查),所以在此简单介绍使用方法:

  • 将UICoverFlowLayer.h文件拷贝到工程中
  • 创建cover flow视图,并将UICoverFlowLayer图层分配到视图图层中

UICoverFlowLayer *cfLayer = [[UICoverFlowLayer alloc] initWithFrame:frame numberOfCovers:count];
[[self layer] addSublayer:cfLayer];



  
  
  
  
  • 视图发送dragFlow:atPoint消息,以处理与Cover Flow图层的触摸和拖动的交互过程
  • 构建cover flow视图控制器,分配和初始化视图,并提供委托和数据源方法。

方法二:OpenFlow

OpenFlow是一个用于实现Cover Flow特效的开源库,它是基于Quartz实现的,能很好的实现Cover Flow特效,同时又易于使用。

下载地址:https://github.com/thefaj/OpenFlow

使用OpenFlow的基本步骤如下:

  • 创建工程
  • 添加OpenFlow源代码到工程中
  • 添加QuartzCore和CoreGraphics框架到工程中
  • 定义CoverFlowViewController(自定义)类
    • 在CoverFlowViewController.h中导入”AFOpenFlowView.h”
    • 实现AFOpenFlowViewDelegate类和AFOpenFlowDataSource协议

//  CoverFlowViewController.h
//  CoverFlow
//
//  Created by Avinash on 4/7/10.
//  Copyright Apple Inc 2010. All rights reserved.
//
 
#import
#import "AFOpenFlowView.h"
 
@interface CoverFlowViewController : UIViewController  {
 
// Queue to hold the cover flow images
 
NSOperationQueue *loadImagesOperationQueue;
 
}
 
@end
  • 实现CoverFlowViewController类
    • 加载图片
- (void)viewDidLoad {
    [super viewDidLoad];
 
// loading images into the queue
 
loadImagesOperationQueue = [[NSOperationQueue alloc] init];
 
NSString *imageName;
for (int i=0; i < 10; i++) {
imageName = [[NSString alloc] initWithFormat:@"cover_%d.jpg", i];
[(AFOpenFlowView *)self.view setImage:[UIImage imageNamed:imageName] forIndex:i];
[imageName release];
NSLog(@"%d is the index",i);
 
}
[(AFOpenFlowView *)self.view setNumberOfImages:10];
 
}
    • 实现委托方法,以设置Cover Flow默认图片及通知哪幅图片被选中

//delegate protocols
 
// delegate protocol to tell which image is selected
- (void)openFlowView:(AFOpenFlowView *)openFlowView selectionDidChange:(int)index{
 
NSLog(@"%d is selected",index);
 
}
 
// setting the image 1 as the default pic
- (UIImage *)defaultImage{
 
return [UIImage imageNamed:@"cover_1.jpg"];
}
  • 修改xib文件中视图的类UIView为AFOpenFlowView(重要)

完成上述步骤之后,就可以运行一下程序看一下效果了。虽然与苹果的Cover Flow效果还是有点差距,但还是不错哦。

方法三:FlowCover

FlowCover也是一个开源库,它是基于OpenGL ES。FlowCover的源代码非常简单,只有FlowCoverView和DataCache两个类。这两个类的功能如下:

  • FlowCoverView:定义主视图。这是一个OpenGL ES视点,可以被嵌套在其它视图中。
  • DataCache:提供一个简单的数据缓存方案,保存一定量的对象,当对象超过最大值时,旧的对象会被舍弃。

使用FlowCover的基本步骤如下:

  • 创建工程
  • 添加FlowCover源代码到工程中
  • 然后就可以像用其它UIView一样使用FlowCoverView了

FlowCover中需要实现FlowCoverViewDelegate协议,该协议中主要有三个方法:

-(int)flowCoverNumberImages:(FlowCoverView *)view;

返回FlowCoverView视图中显示的图片数量

-(UIImage *)flowCover:(FlowCoverView *)view cover:(int)cover;

返回FlowCoverView视图中用cover指定的图片

-(void)flowCover:(FlowCoverView *)view didSelect:(int)cover;

当用户触击FlowCoverView中的cover时调用。


   

你可能感兴趣的:(quartz,image,音乐,UIView,Safari,protocols)