swift 动画
//
// ViewController.swift
// Anamation
//
// Created by su on 15/12/9.
// Copyright © 2015年 tian. All rights reserved.
//
//动画
//动画的主要属性
//Position xy坐标属性
//Opacity 透明度属性
//Scale 缩放属性
//其他属性 Color颜色属性 Rotate 旋转属性 3D属性
//动画师如何形成的? 1.动画开始时对象的属性2.动画结束时对象的属性3.动画执行的时间4.执行动画过程中会发生什么,5.动画结束后会发生什么
//动画曲线
//1.Linear 现行匀速变化
//2.Ease In 以慢速开始:加速变化
//3.Ease In, Ease Out 先加速后减速
//4.Ease Out 以慢速开始:减速变化
import UIKit
import CoreGraphics
import QuartzCore
class ViewController: UIViewController {
@IBOutlet weak var redBall1: UIView!
@IBOutlet weak var redBall2: UIView!
@IBOutlet weak var redBall3: UIView!
@IBOutlet weak var redBall4: UIView!
@IBOutlet weak var redBall5: UIView!
@IBOutlet weak var redBall6: UIView!
override func viewDidLoad() {
super.viewDidLoad()
//UIKit和Core Animation动画 原生 优点:简单.代码量少
//球的放大动画 灰色
UIView.animateWithDuration(0.5, delay: 0, options: UIViewAnimationOptions.CurveEaseInOut, animations: { () -> Void in
self.redBall4.transform = CGAffineTransformMakeScale(2, 2)
}, completion: nil)
//组合动画和位移动画
//组合动画-CGAffineTransformConcat
UIView.animateWithDuration(1, delay: 0, options: UIViewAnimationOptions.CurveEaseOut, animations: { () -> Void in
self.redBall1.transform = CGAffineTransformConcat(CGAffineTransformMakeScale(2, 2), CGAffineTransformMakeTranslation(100, 400))
self.redBall1.backgroundColor = UIColor.greenColor()
}, completion: nil)
// Spring Animation 弹性动画 usingSpringWithDamping阻尼值 蓝色
UIView.animateWithDuration(1, delay: 0, usingSpringWithDamping: 0.3, initialSpringVelocity: 0, options: UIViewAnimationOptions.CurveEaseOut, animations: { () -> Void in
self.redBall2.transform = CGAffineTransformConcat(CGAffineTransformMakeScale(2, 2), CGAffineTransformMakeTranslation(100, 200))
self.redBall2.backgroundColor = UIColor.blueColor()
}, completion: nil)
//JNWSpringAnimation 老外写的 优点:这个框架能够很细致的调整弹性动画属性
// JNW所支持的属性: bounds边界,position位置,rotation旋转,sacale缩放,corner圆角,shadow阴影
// 1.导入JNW框架
//获取JNW框架 https://github.com/jwilling/JNWSpringAnimation
//因为JNW框架是使用Object-C编写 所以需要创建桥接头文件, 在头文件中引入#import "JNWSpringAnimation.h" ---swift与object-c混编
//缩放动画 橘色
//创建JNW实例
let scale = JNWSpringAnimation(keyPath: "transform.scale")
//阻尼
scale.damping = 1
//伸展系数,弹簧伸缩的难度
scale.stiffness = 100
//质量 : 决定动画快慢的效果
scale.mass = 2
//设置初始值 和结束值
scale.fromValue = 1
scale.toValue = 2
//将JNW赋予redball
redBall3.layer.addAnimation(scale, forKey: scale.keyPath)
redBall3.transform = CGAffineTransformMakeScale(2, 2)
//旋转动画 红色
//创建JNW实例
let rotation = JNWSpringAnimation(keyPath: "transform.rotation")
//阻尼
rotation.damping = 1
rotation.stiffness = 100
rotation.mass = 2
rotation.fromValue = 0
rotation.toValue = M_PI_2
redBall5.layer.addAnimation(rotation, forKey: rotation.keyPath)
redBall5.transform = CGAffineTransformMakeRotation(CGFloat(M_PI_2))
//位移变化 粉色
let movie = JNWSpringAnimation(keyPath: "tranform.translation.y")
movie.damping = 6
movie.stiffness = 100
movie.mass = 2
movie.fromValue = 0
movie.toValue = 300
redBall6.layer.addAnimation(movie, forKey: movie.keyPath)
//JNWSpringAnimation 默认会还原初始状态,所以要动手设置的到结束状态
redBall6.transform = CGAffineTransformMakeTranslation(0, 300)
//Facebook Pop facebook开源动画引擎pop
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}
swift 动画的更多相关文章
- swift动画小试牛刀
swift刚出没多长时间,看到各种惊呼党,翻译党,黑苹果党,视频教学党如雨后春笋版喷薄而出......我想说有点开发基础的人,其实看看文档也就行了,毕竟语言是拿来用的. 今天花了一下午的时间,没有太看 ...
- swift 动画合集
本例参照objective-c的动画合集进行swift的转换,objective-c地址参照地址https://github.com/yixiangboy/IOSAnimationDemo 1.基础动 ...
- Swift动画编程指南-01 简介
大家好,我是老镇,这段时间家里和工作上发生了很多的事情,所以很长一段时间都没有出来搞什么小动作了.在接下来的一段时间内我会制作一些列关于使用Swift进行动画编程的视频,希望和大家胃口. 在iOS的世 ...
- swift - 动画学习
// // ViewController.swift // MapAnimation // // Created by su on 15/12/10. // Copyright © 2015年 ...
- Swift动画编程指南-02 Swift动画是怎么炼成的
上一节我们看了几个很棒的例子,我们不禁会想.他们是怎么设计的,怎么从一个空白的画布变成一个完整的,美丽的动画.这些动画是如何产生的,是哪些属性被改变了.我们还要认真思考的是,每一个步骤到底发生了什么. ...
- Swift 动画学习笔记
视频地址: http://www.swiftv.cn/course/i275v5lz 1,动画属性 position(位置),opacity(透明度,0 全透明,1 不透明),Scale(尺寸),Co ...
- Swift - 动画效果的实现方法总结(附样例)
在iOS中,实现动画有两种方法.一个是统一的animateWithDuration,另一个是组合出现的beginAnimations和commitAnimations.这三个方法都是类方法. 一,使用 ...
- Swift 动画片段
UIView.transitionWithView( self.WeatherDetailsView, duration: 0.7, options: .TransitionCrossDissolve ...
- iOS开发——动画篇Swift篇&动画效果的实现
Swift - 动画效果的实现 在iOS中,实现动画有两种方法.一个是统一的animateWithDuration,另一个是组合出现的beginAnimations和commitAnimation ...
随机推荐
- oracle之 RAC 11G ASM下控制文件多路复用
如果数据库仅有一组control file文件,需要添加一组或者多组,保证一组文件损坏或者丢失导致数据库宕机. -- 环境说明SQL> select * from v$version;BANNE ...
- MySQL分段统计SQL写法 与 Mybatis 异常 java.math.BigDecimal cannot be cast to java.lang.Integer
mysql> select end) as '<60', end) as '60~69', end) as '70~79', end) as '80~89', end) as '>= ...
- 黄聪:WIN7下回收站不小心删除的文件怎么恢复,免费数据恢复软件下载
上网找了半天,大多数是收费的,总算找到一款免费的,已经帮我恢复了数据了,在此分享给大家. 注意:只能恢复7天内的,而且数据误删了,就尽量不要再修改你那个盘符的数据了,免得覆盖了! 我用的数据恢复软件R ...
- mysql master or master copy
双主复制: 在两台server配置my.cnf [root@localhost mysql]# egrep -v "^$|^#" /etc/my.cnf datadir = /my ...
- MySQL 高性能存储引擎:TokuDB初探
在安装MariaDB的时候了解到代替InnoDB的TokuDB,看简介非常的棒,这里对ToduDB做一个初步的整理,使用后再做更多的分享. 什么是TokuDB? 在MySQL最流行的支持全事务的引擎为 ...
- UDP协议发包的使用(DatagramSocket、DatagramPacket)
1.UDP 是User Datagram Protocol的简称, 中文名是用户数据报协议,是OSI(Open System Interconnection,开放式系统互联) 参考模型中一种无连接的传 ...
- Lucene根据字段进行自定义搜索扩展
最近需要对公司的产品搜索功能做一步改动,搜索到的结果首先按照是否有库存进行排序,然后再按照销量.由于库存量也是一个整数,如果直接按照库存量进行倒序排序的话,是不符合要求的,Lucene也没有支持我们这 ...
- Express详解
express() 创建一个express应用程序 var express = require('express'); var app = express(); app.get('/', functi ...
- phpcms 实现动态价格
什么是动态价格(自命名)?—— 一般来说商品有个固定的价格,随着节假日或者促销活动可能会发生价格变化,结束后又恢复原价,如果每次价格变化都需要修改价格,那么不仅在时间上不好把握,也需要消耗更多的人力 ...
- JSP自定义业务标签
自定义标签: package cn.hv.tag; import javax.servlet.jsp.JspException; import javax.servlet.jsp.JspWriter; ...