来自IOS7 by tutorials   下面是个人的一点翻译总结

1,首先在初始化方法李画一个方块

UIView* square = [[UIView alloc] initWithFrame:
CGRectMake(100, 100, 100, 100)];

square.backgroundColor = [UIColor grayColor]; [self.view addSubview:square];

2,声明两个变量。

UIDynamicAnimator* _animator;

UIGravityBehavior* _gravity;

3,初始化

_animator = [[UIDynamicAnimator alloc] initWithReferenceView:self.view];

_gravity = [[UIGravityBehavior alloc] initWithItems:@[square]]; [_animator addBehavior:_gravity];

4,闲着这个方块直接掉出屏幕了,我们需要加边框。

声明变量

UICollisionBehavior* _collision;

代码

_collision = [[UICollisionBehavior alloc] initWithItems:@[square]];

_collision.translatesReferenceBoundsIntoBoundary = YES; [_animator addBehavior:_collision];

5,多个 方块间的冲突

再声明一个长条。

UIView* barrier = [[UIView alloc]
initWithFrame:CGRectMake(0, 300, 130, 20)];

barrier.backgroundColor = [UIColor redColor]; [self.view addSubview:barrier];

我们看见方块穿过了长条。

修改代码

_collision = [[UICollisionBehavior alloc] initWithItems:@[square, barrier]];

这时长条被砸掉下去了。

6,我们把长条也弄成方框的边框。

_collision = [[UICollisionBehavior alloc] initWithItems:@[square]];

// add a boundary that coincides with the top edge

CGPoint rightEdge = CGPointMake(barrier.frame.origin.x + barrier.frame.size.width,

barrier.frame.origin.y); [_collision addBoundaryWithIdentifier:@"barrier"

fromPoint:barrier.frame.origin toPoint:rightEdge];

可以看见方框被长条弹开并落在了底部。

7,每个动画都由一个方法来执行,如碰撞,反弹等等...添加如下代码

_collision.action = ^{ NSLog(@"%@, %@",

NSStringFromCGAffineTransform(square.transform), NSStringFromCGPoint(square.center));

};

上面代码打印出方框下落时,中心和属性的变化。square.center是方框的中心,square.transform是方框的属性。

第一部分你会看到方框的中心square.center,的Y轴数据在变化,如

2014-07-24 11:41:42.133 DynamicsPlayground[766:60b] [1, 0, 0, 1, 0, 0], {150, 161}

2014-07-24 11:41:42.149 DynamicsPlayground[766:60b] [1, 0, 0, 1, 0, 0], {150, 164}

2014-07-24 11:41:42.167 DynamicsPlayground[766:60b] [1, 0, 0, 1, 0, 0], {150, 167}

当方块撞到长条时,方块开始转动,这时打印的结果是

2014-07-24 11:41:42.649 DynamicsPlayground[766:60b] [0.80305022, 0.59591132, -0.59591132, 0.80305022, 0, 0], {170, 266}

2014-07-24 11:41:42.666 DynamicsPlayground[766:60b] [0.7690773, 0.63915575, -0.63915575, 0.7690773, 0, 0], {172, 269}

2014-07-24 11:41:42.683 DynamicsPlayground[766:60b] [0.72068948, 0.69325799, -0.69325799, 0.72068948, 0, 0], {174, 272}

8,对象的动态行为是采用的 UIDynamicItem 协议  ,下面是协议的定义。

@protocol UIDynamicItem <NSObject>

@property (nonatomic, readwrite) CGPoint center;
@property (nonatomic, readonly) CGRect bounds;
@property (nonatomic, readwrite) CGAffineTransform transform;

@end

9,碰撞通知。添加代码在.m文件里。

@interface ViewController () <UICollisionBehaviorDelegate> @end

碰撞后

_collision.collisionDelegate = self;

碰撞后方法

- (void)collisionBehavior:(UICollisionBehavior *)behavior beganContactForItem:(id<UIDynamicItem>)item

withBoundaryIdentifier:(id<NSCopying>)identifier atPoint:(CGPoint)p {

NSLog(@"Boundary contact occurred - %@", identifier); }

可以看到碰撞后打印的信息,。

2014-07-24 12:15:45.124 DynamicsPlayground[820:60b] Boundary contact occurred - barrier

2014-07-24 12:15:45.692 DynamicsPlayground[820:60b] Boundary contact occurred - (null)

10,在打印后面添加代码

UIView* view = (UIView*)item; view.backgroundColor = [UIColor yellowColor];

[UIView animateWithDuration:0.3

animations:^{

view.backgroundColor = [UIColor grayColor];

}];

会看到方块在每次碰撞后发生的颜色变化。

11,配置属性。

下面代码追加在viewDidLoad方法的底部,

UIDynamicItemBehavior* itemBehaviour =

[[UIDynamicItemBehavior alloc] initWithItems:@[square]];

itemBehaviour.elasticity = 0.6;

[_animator addBehavior:itemBehaviour];

发现方块变得更有弹性了。除了弹性,itemBehaviour有更多其他属性可以更改。

12,添加动态行为

ViewController.m里添加一布尔型变量

BOOL _firstContact;

下面代码添加到协议方法里。

if (!_firstContact) {

_firstContact = YES;

UIView* square = [[UIView alloc] initWithFrame:CGRectMake(30, 0, 100, 100)];

square.backgroundColor = [UIColor grayColor];

[self.view addSubview:square];

[_collision addItem:square];

[_gravity addItem:square];

UIAttachmentBehavior* attach = [[UIAttachmentBehavior alloc]

initWithItem:view

attachedToItem:square];

[_animator addBehavior:attach];

}

两个方块被一根隐藏得线联系起来。

来自-IOS7 by tutorials,第二章第一节,目前网上有英文版下载,无中文版翻译。

--原创可转载 ,如有不恰当的地方可留言--guanliyang

IOS 物理引擎的更多相关文章

  1. 最全的iOS物理引擎demo

    概述 最全的iOS物理引擎demo,实现重力.碰撞.推力.摆动.碰撞+重力.重力弹跳.仿摩拜单车贴纸效果.防iMessage滚动效果.防百度外卖首页重力感应等效果! 详细 代码下载:http://ww ...

  2. UIDynamic仿物理引擎-浮动碰撞效果-b

    最近产品提了个需求(电商的APP-两鲜),需要在APP背景加上几个水果图案在那里无规则缓慢游荡...模仿 天天果园 APP的.好吧,那我就在网上找了很多文章,总结一下写个demo.效果如下: Mou ...

  3. iOS中的物理引擎

    目前知名的2D物理引擎有 Box2d,和Chipmunk,这些是跨平台的.但苹果本身也封装了一个物理引擎, UIDynamic是从iOS 7开始引入的一种新技术,隶属于UIKit框架.这可以让开发人员 ...

  4. iOS开发——高级篇——UIDynamic 物理引擎

    一.UIDynamic 1.简介什么是UIDynamicUIDynamic是从iOS 7开始引入的一种新技术,隶属于UIKit框架可以认为是一种物理引擎,能模拟和仿真现实生活中的物理现象重力.弹性碰撞 ...

  5. 实例介绍Cocos2d-x中Box2D物理引擎:使用关节

    下面我们将使用Box2D物理引擎技术进行重构.使得关节能够掌握如何在Box2D使用关节约束.HelloWorldScene.cpp中与使用关节的相关代码如下: void HelloWorld::add ...

  6. 实例介绍Cocos2d-x中Box2D物理引擎:碰撞检测

    在Box2D中碰撞事件通过实现b2ContactListener类函数实现,b2ContactListener是Box2D提供的抽象类,它的抽象函数:virtual void BeginContact ...

  7. 实例介绍Cocos2d-x中Box2D物理引擎:HelloBox2D

    我们通过一个实例介绍一下,在Cocos2d-x 3.x中使用Box2D物理引擎的开发过程,熟悉这些API的使用.这个实例运行后的场景如图所示,当场景启动后,玩家可以触摸点击屏幕,每次触摸时候,就会在触 ...

  8. 实例介绍Cocos2d-x物理引擎:碰撞检测

    碰撞检测是使用物理引擎的一个重要目的,使用物理引擎可以进行精确的碰撞检测,而且执行的效率也很高.在Cocos2d-x 3.x中使用事件派发机制管理碰撞事件,EventListenerPhysicsCo ...

  9. 实例介绍Cocos2d-x物理引擎:HelloPhysicsWorld

    我们通过一个实例介绍一下,在Cocos2d-x 3.x中使用物理引擎的开发过程,熟悉这些API的使用.这个实例的运行后的场景,当场景启动后,玩家可以触摸点击屏幕,每次触摸时候,就会在触摸点生成一个新的 ...

随机推荐

  1. 《Microsoft SQL Server企业级平台管理实践》笔记

    - 页是 SQL Server 中数据存储的基本单位,大小为 8KB. - 区是空间管理的基本单位,8个物理上连续的页的集合(64KB). - 页的类型包括: 1. Data 2. Index 3. ...

  2. c# 借助cmd命令解析apk文件信息

    借助aapt.exe文件 aapt.exe 解析apk包信息cmd命令: aapt dump badging *.apkaapt d badging *.apk >1.txt(保存成1.txt文 ...

  3. linux下不重启加硬盘

    linux下热加载磁盘 临时给虚拟机加了一块硬盘,增加后懒得重启,于是看了看热加载 [root@centos5 ~]# cat /proc/scsi/scsi Attached devices: Ho ...

  4. C#用网易邮箱发送邮件(同步异步)

    SmtpClient smtpServer = new SmtpClient("smtp.163.com"); smtpServer.Port = ; smtpServer.Cre ...

  5. vue分页组件table-pagebar

    之前一直接触都是原始的前端模型,jquery+bootstrap,冗杂的dom操作,繁琐的更新绑定.接触vue后,对前端MVVM框架有了全新的认识.本文是基于webpack+vue构建,由于之前的工作 ...

  6. SSDT表详解

    SSDT(system service dispatch table) 系统服务分派表 SSPT(system service parameter table) 系统服务参数表 #pragma pac ...

  7. MFC CListCtrl得到ctrl,shift多选的行号

    vector<int> selVect; int count = m_consumeList.GetItemCount(); //你的列表多少行 for (int i = 0; i< ...

  8. Android 动画系列

    Android种最常用的动画: ~1~Tween动画,就是对场景里的对象不断的进行图像变化来产生动画效果(旋转.平移.放缩和渐变) Tweene Animations 主要类: Animation   ...

  9. CSS自学笔记(6):CSS的模型

    CSS 框模型 (Box Model) 规定了元素框处理元素内容.内边距.边框和外边距的方式. 图片来源:w3school.com.cn 元素(element)是一个html文档的实际内容区域,依次由 ...

  10. 利用新版ShareSDK进行手动分享(自定义分享界面)

    之前有用过Share SDK进行快捷分享,可是官方demo中的快捷分享的界面已经设置死了,而公司的产品又设计了自己的分享界面,这就需要我进行手动分享了.当前ShareSDK版本是2.5.4. 看了一堆 ...