`
ydbc
  • 浏览: 719016 次
  • 性别: Icon_minigender_1
  • 来自: 大连
文章分类
社区版块
存档分类
最新评论

iphone 动画总结

 
阅读更多

最普通动画:

//开始动画

[UIView beginAnimations:nil context:nil];

//设定动画持续时间

[UIView setAnimationDuration:2];

//动画的内容

frame.origin.x += 150;

[img setFrame:frame];

//动画结束

[UIView commitAnimations];

连续动画:一个接一个地显示一系列的图像

NSArray *myImages = [NSArray arrayWithObjects:

[UIImage imageNamed:@"myImage1.png"],

[UIImage imageNamed:@"myImage2.png"],

[UIImage imageNamed:@"myImage3.png"],

[UIImage imageNamed:@"myImage4.gif"], nil];

UIImageView *myAnimatedView = [UIImageView alloc];

[myAnimatedView initWithFrame:[self bounds]];

myAnimatedView.animationImages = myImages; //animationImages属性返回一个存放动画图片的数组

myAnimatedView.animationDuration = 0.25; //浏览整个图片一次所用的时间

myAnimatedView.animationRepeatCount = 0; // 0 = loops forever动画重复次数

[myAnimatedView startAnimating];

[self addSubview:myAnimatedView];

[myAnimatedView release];

CATransition Public API动画:

CATransition*animation = [CATransitionanimation];

//动画时间

animation.duration=0.5f;

//先慢后快

animation.timingFunction=UIViewAnimationCurveEaseInOut;

animation.fillMode=kCAFillModeForwards;

//animation.removedOnCompletion = NO;

//各种动画效果

/*

kCATransitionFade;

kCATransitionMoveIn;

kCATransitionPush;z

kCATransitionReveal;

*/

/*

kCATransitionFromRight;

kCATransitionFromLeft;

kCATransitionFromTop;

kCATransitionFromBottom;

*/

//各种组合

animation.type=kCATransitionPush;

animation.subtype=kCATransitionFromRight;

[self.view.layeraddAnimation:animationforKey:@"animation"];

CATransition Private API动画:

animation.type可以设定为以下效果

动画效果汇总:

/*

suckEffect(三角)

rippleEffect(水波抖动)

pageCurl(上翻页)

pageUnCurl(下翻页)

oglFlip(上下翻转)

cameraIris/cameraIrisHollowOpen/cameraIrisHollowClose(镜头快门,这一组动画是有效果,只是很难看,不建议使用

而以下为则黑名单:

spewEffect:新版面在屏幕下方中间位置被释放出来覆盖旧版面.

- genieEffect:旧版面在屏幕左下方或右下方被吸走,显示出下面的新版面(阿拉丁灯神?).

- unGenieEffect:新版面在屏幕左下方或右下方被释放出来覆盖旧版面.

- twist:版面以水平方向像龙卷风式转出来.

- tubey:版面垂直附有弹性的转出来.

- swirl:旧版面360度旋转并淡出,显示出新版面.

- charminUltra:旧版面淡出并显示新版面.

- zoomyIn:新版面由小放大走到前面,旧版面放大由前面消失.

- zoomyOut:新版面屏幕外面缩放出现,旧版面缩小消失.

- oglApplicationSuspend:像按"home"按钮的效果.

*/

UIView Animations 动画:

[UIViewbeginAnimations:@"animationID"context:nil];

[UIViewsetAnimationDuration:0.5f];

[UIViewsetAnimationCurve:UIViewAnimationCurveEaseInOut];

[UIViewsetAnimationRepeatAutoreverses:NO];

//以下四种效果

/*

[UIViewsetAnimationTransition:UIViewAnimationTransitionFlipFromLeftforView:self.viewcache:YES];//oglFlip, fromLeft

[UIViewsetAnimationTransition:UIViewAnimationTransitionFlipFromRightforView:self.viewcache:YES];//oglFlip, fromRight

[UIViewsetAnimationTransition:UIViewAnimationTransitionCurlUpforView:self.viewcache:YES];

[UIViewsetAnimationTransition:UIViewAnimationTransitionCurlDownforView:self.viewcache:YES];

*/

[self.viewexchangeSubviewAtIndex:1withSubviewAtIndex:0];

[UIViewcommitAnimations];

IOS4.0新方法:

方法:+(void)animateWithDuration:(NSTimeInterval)durationanimations:(void (^)(void))animations;

+ (void)animateWithDuration:(NSTimeInterval)durationanimations:(void (^)(void))animationscompletion:(void (^)(BOOL finished))completion; //多一个动画结束后可以执行的操作.

//下边是嵌套使用,先变大再消失的动画效果.

[UIViewanimateWithDuration:1.25animations:^{

CGAffineTransformnewTransform =CGAffineTransformMakeScale(1.2,1.2);

[firstImageViewsetTransform:newTransform];

[secondImageViewsetTransform:newTransform];}

completion:^(BOOLfinished){

[UIViewanimateWithDuration:1.2animations:^{

[firstImageViewsetAlpha:0];

[secondImageViewsetAlpha:0];}completion:^(BOOLfinished){

[firstImageViewremoveFromSuperview];

[secondImageViewremoveFromSuperview]; }];

}];

UIView的各种动态效果Demo(10/03/04小更新)

进一步修改,现在应该接近完整了。







引用
受这贴启发http://www.cocoachina.com/bbs/read.php?tid-11856.html
做了一点更新


引用
技术主管的侄子接到一个任务,要求实现UIView切换时的动态效果。居然这个任务签了很多钱,估计有上千欧……
我很无语,我说这个就几句话来着……
我们技术主管是负责Mac代码的,对iPhone编程不太了解。我做了个Demo给她,顺便放上了咱CocoaChina的logo,嘿嘿
[ 此帖被bobgreen在2010-03-04 09:28重新编辑 ]
图片:Screen shot 2010-03-03 at 18.06.01 .png
图片:1.png
图片:2.png
图片:3.png

地图程序那样的Curl效果分享

看了很多例子的CurlUp和CurlDown,都是翻页效果,没有像地图那样翻到一半停下的,偶然在网上看到了方法,自己做了一个例子,不敢独享,拿出来大家看一下。
关键代码如下:
复制代码
  1. - (IBAction)curlUp{
  2. NSLog(@"Curl");
  3. // Curl the image up or down
  4. CATransition *animation = [CATransition animation];
  5. [animation setDelegate:self];
  6. [animation setDuration:0.35];
  7. [animation setTimingFunction:UIViewAnimationCurveEaseInOut];
  8. if (!curled){
  9. animation.type = @"pageCurl";
  10. animation.fillMode = kCAFillModeForwards;
  11. animation.endProgress = 0.58;
  12. } else {
  13. animation.type = @"pageUnCurl";
  14. animation.fillMode = kCAFillModeBackwards;
  15. animation.startProgress = 0.42;
  16. }
  17. [animation setRemovedOnCompletion:NO];
  18. [view exchangeSubviewAtIndex:0 withSubviewAtIndex:1];
  19. [view addAnimation:animation forKey:@"pageCurlAnimation"];
  20. // Disable user interaction where necessary
  21. if (!curled) {
  22. } else {
  23. }
  24. curled = !curled;
  25. }
[ 此帖被gagaga在2009-12-07 17:18重新编辑 ]
图片:屏幕快照 2009-12-07 下午04.24.18.png
实现pushViewController的自定义动画效果
厌烦了千篇一律的push风格了吗 ? 试试这个吧

CATransition *transition = [CATransition animation];
transition.duration = 1.0f;
transition.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
transition.type = @"cube";
transition.subtype = kCATransitionFromRight;
transition.delegate = self;
[self.navigationController.view.layer addAnimation:transition forKey:nil];


DemoViewController*demoViewController=
[[DemoViewControlleralloc]
initWithNibName:@"DemoViewController"
bundle:[NSBundle mainBundle]];
[self.navigationController pushViewController:demoViewControlleranimated:YES];


[demoViewControllerrelease];


简单介绍:.type 设置了主要的页面切换显示形式 cube 等
.subtype 设置了页面的旋转 左右上下 :~)

附件:MapCurlEffect.zip(17 K) 下载次数:1408

分享到:
评论

相关推荐

    优秀的PPT动画学习资料 PPT模板 适合员工转正,个人简历,工作总结,毕业答辩,述职报告

    比如程序启动时由小变大向前推出显示, 比如iphone的程序切换时的动画, 比如圆角矩形的边框, 比如水波纹的动画效果 另外, 还有超炫的目录页面动画, 还有表示当前播放到哪一部分的漂亮的动态圆点行, 还有自动生成页码,...

    iphone开发笔记

    网络编程总结 iphone 19 Iphone 实现画折线图 25 让iPhone屏幕常亮不变暗的方法 27 苹果开发网络编程知识总结 27 如何隐藏状态栏 33 .m 文件与.mm文件的区别 33 NSLog(@"afd")与 NSLog("afd") 33 safari其实没有把...

    《iPhone开发实战》.(Christopher Allen).pdf

    10.2.7 objective-c总结138 10.3 iphone os介绍139 10.3.1 iphone os剖析139 10.3.2 iphone对象的层次结构140 10.3.3 窗口和视图141 10.4 iphone os的方法142 10.4.1 对象创建142 10.4.2 内存管理143...

    PhoneGap Beginner’s Guide

    总结89 第4章:管理一个跨平台的CODEBASE 91 平台之间的内在差异91 使用单一的代码库92 时间F或行动 - 检测和回退93 用户代理嗅探102 特征检测104 媒体查询106 镨eprocessing代码109 Summar Ÿ 110 第5章:HTML5 API...

    非科班出身程序员刷题-iOS_Gather:总结的iOS开发常用库-调调的--持续更新中……

    很赞iPHone适配相关的教程 - 以公司或团体名义在苹果AppStore上架APP - 666的分许了网易的导航实现方式 iOS - 覆盖很广 - 很多开发相关内容都有体现 - 自定义了左边的返回键,导致右滑返回失效 - 顶部TabPage滑动 ...

    android开发资料大全

    最无私的Android资料(书籍+代码)分享[总结] Android中文帮助教程(非常合适新手入门) android程序编写及调试新手入门 大家一起学Android(Windows篇) android入门与提高必看指南 Android入门逆引手册 Android...

    unity虚拟交互工具介绍.pdf

    02 Unity基础知识结构总结 Unity 3D简介 Unity 3D是什么 Unity 3D 也称 Unity,是Unity Techno logies 公司开发的一个让玩家 轻松创建诸如三维视频游戏、建筑可视化、实时三维动画等类型互动内 容的多平台的综合型...

    史上最好传智播客就业班.net培训教程60G 不下会后悔

    未来是移动互联网的时代,未来将是Windows Phone、Android、iphone三足鼎立的时代,掌握了移动开发的技能的人是就业市场的抢手货。微软推出的Windows Phone平台是微软在移动互联网时代的一个重量级产品,微软对于...

    工程硕士学位论文 基于Android+HTML5的移动Web项目高效开发探究

    1.2.6 研究现状总结 7 1.3研究目标与内容 7 1.3.1多窗口浏览器模式的实现机制 7 1.3.2跨域交互即缓存处理方法 7 1.3.3页面自适应机制,即设备自适应与浏览器自适应机制 8 1.3.4 “认我测”质检服务平台的设计和实现 ...

Global site tag (gtag.js) - Google Analytics